/* mAIgler.dk — Petroleum & Gold */
:root{
  --petrol-900:#06181b;
  --petrol-800:#0a262b;
  --petrol-700:#0f343a;
  --petrol-600:#13434a;
  --petrol-500:#1a575f;
  --petrol-400:#2a7780;
  --gold-100:#f7eccf;
  --gold-300:#e7cf94;
  --gold-500:#c9a961;
  --gold-600:#b48b3c;
  --gold-700:#8a672a;
  --cream:#f5efe2;
  --ink:#0b1d20;
  --line:rgba(231,207,148,.22);
  --shadow-xl:0 30px 80px -20px rgba(0,0,0,.55);
  --shadow-gold:0 10px 40px -10px rgba(201,169,97,.35);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter','Helvetica Neue',Arial,sans-serif;
  background:var(--petrol-900);
  color:var(--cream);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--gold-300);text-decoration:none;transition:color .3s var(--ease)}
a:hover{color:var(--gold-500)}

/* Typography */
.script{font-family:'Pinyon Script','Tangerine','Great Vibes',cursive;font-weight:400;color:var(--gold-500);letter-spacing:.01em}
.serif{font-family:'Cormorant Garamond','Playfair Display',Georgia,serif;font-weight:300;letter-spacing:.01em}
.eyebrow{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold-500);font-size:.95rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:1rem;display:inline-block}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:400;color:var(--gold-100);line-height:1.1}
h1{font-size:clamp(2.6rem,6vw,5.4rem)}
h2{font-size:clamp(2rem,4vw,3.6rem);margin-bottom:1rem}
h3{font-size:1.6rem}
p{font-size:1.02rem;color:rgba(245,239,226,.78)}

/* Custom cursor */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;mix-blend-mode:difference}
.cursor-dot{width:6px;height:6px;background:var(--gold-300);transform:translate(-50%,-50%);transition:transform .15s var(--ease)}
.cursor-ring{width:36px;height:36px;border:1px solid var(--gold-500);transform:translate(-50%,-50%);transition:transform .25s var(--ease),width .25s,height .25s,border-color .25s}
.cursor-ring.hover{width:64px;height:64px;border-color:var(--gold-300);background:rgba(201,169,97,.06)}
@media(hover:none){.cursor-dot,.cursor-ring{display:none}}

/* Loading overlay */
.preloader{position:fixed;inset:0;z-index:10000;background:var(--petrol-900);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.5rem;transition:opacity .9s var(--ease),visibility .9s}
.preloader.done{opacity:0;visibility:hidden}
.preloader .logo-mark{font-family:'Pinyon Script',cursive;font-size:5rem;color:var(--gold-500);opacity:0;animation:fadeIn 1.2s var(--ease) forwards}
.preloader .bar{width:240px;height:1px;background:var(--line);position:relative;overflow:hidden}
.preloader .bar::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,var(--gold-500),transparent);animation:slide 1.4s var(--ease) infinite}
@keyframes slide{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
@keyframes fadeIn{to{opacity:1}}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.6rem 4vw;display:flex;align-items:center;justify-content:space-between;transition:background .4s var(--ease),padding .4s,backdrop-filter .4s,border-color .4s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(6,24,27,.78);backdrop-filter:blur(18px) saturate(140%);padding:1rem 4vw;border-bottom-color:var(--line)}
.logo{font-family:'Pinyon Script',cursive;font-size:2.4rem;color:var(--gold-500);line-height:1;text-decoration:none}
.logo span{color:var(--cream);font-family:'Cormorant Garamond',serif;font-size:1rem;letter-spacing:.4em;margin-left:.4rem;vertical-align:middle}
.nav-links{display:flex;gap:2.4rem;list-style:none}
.nav-links a{color:var(--cream);font-size:.85rem;letter-spacing:.22em;text-transform:uppercase;position:relative;padding:.4rem 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold-500);transition:width .4s var(--ease)}
.nav-links a:hover{color:var(--gold-300)}
.nav-links a:hover::after{width:100%}
.nav-cta{padding:.7rem 1.6rem;border:1px solid var(--gold-500);color:var(--gold-300);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;transition:all .3s var(--ease)}
.nav-cta:hover{background:var(--gold-500);color:var(--petrol-900)}
.burger{display:none;width:32px;height:24px;position:relative;cursor:pointer;z-index:101}
.burger span{position:absolute;left:0;right:0;height:1px;background:var(--gold-300);transition:all .4s var(--ease)}
.burger span:nth-child(1){top:4px}
.burger span:nth-child(2){top:50%}
.burger span:nth-child(3){bottom:4px}
.burger.open span:nth-child(1){top:50%;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){bottom:auto;top:50%;transform:rotate(-45deg)}

@media(max-width:900px){
  .burger{display:block}
  .nav-links{position:fixed;inset:0;background:var(--petrol-900);flex-direction:column;align-items:center;justify-content:center;gap:2rem;transform:translateX(100%);transition:transform .6s var(--ease)}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.4rem;font-family:'Cormorant Garamond',serif;letter-spacing:.1em;text-transform:none}
  .nav-cta{display:none}
}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:8rem 6vw 4rem;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.45) saturate(1.1);transform:scale(1.1);animation:kenburns 18s var(--ease) infinite alternate}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,24,27,.4) 0%,rgba(6,24,27,.7) 60%,var(--petrol-900) 100%),radial-gradient(ellipse at 30% 30%,rgba(201,169,97,.18),transparent 60%)}
@keyframes kenburns{0%{transform:scale(1.1) translate(0,0)}100%{transform:scale(1.2) translate(-2%,-1%)}}
.hero-grain{position:absolute;inset:0;z-index:1;opacity:.08;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:1100px;margin:0 auto;width:100%}
.hero h1{margin:.5rem 0 1.5rem}
.hero h1 .script{display:block;font-size:1.2em;margin-bottom:-.4em;color:var(--gold-500);text-shadow:0 2px 30px rgba(201,169,97,.25)}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line span{display:inline-block;transform:translateY(110%);animation:rise 1s var(--ease) forwards;animation-delay:var(--d,0s)}
@keyframes rise{to{transform:translateY(0)}}
.hero-sub{max-width:560px;font-size:1.15rem;color:rgba(245,239,226,.85);margin-bottom:2.5rem;opacity:0;animation:fadeUp 1s var(--ease) 1.2s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.hero-actions{display:flex;gap:1.2rem;flex-wrap:wrap;opacity:0;animation:fadeUp 1s var(--ease) 1.4s forwards}

.btn{display:inline-flex;align-items:center;gap:.7rem;padding:1.1rem 2.2rem;font-family:'Cormorant Garamond',serif;font-size:1rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:all .4s var(--ease);border:none;position:relative;overflow:hidden}
.btn-primary{background:var(--gold-500);color:var(--petrol-900)}
.btn-primary:hover{background:var(--gold-300);transform:translateY(-2px);box-shadow:var(--shadow-gold)}
.btn-ghost{background:transparent;color:var(--cream);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--gold-500);color:var(--gold-300)}
.btn .arrow{transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(6px)}

/* Hero search bar */
.hero-search{position:relative;z-index:2;max-width:1100px;margin:3rem auto 0;background:rgba(13,67,74,.55);border:1px solid var(--line);backdrop-filter:blur(20px);padding:1.2rem;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr auto;gap:1rem;opacity:0;animation:fadeUp 1s var(--ease) 1.6s forwards}
.hero-search .field{display:flex;flex-direction:column;padding:.4rem 1rem;border-right:1px solid var(--line)}
.hero-search .field:last-of-type{border-right:none}
.hero-search label{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-500);margin-bottom:.3rem;font-family:'Cormorant Garamond',serif;font-style:italic}
.hero-search input,.hero-search select{background:transparent;border:none;color:var(--cream);font-family:inherit;font-size:.95rem;outline:none;appearance:none}
.hero-search option{background:var(--petrol-800);color:var(--cream)}
.hero-search button{background:var(--gold-500);color:var(--petrol-900);border:none;padding:0 2rem;cursor:pointer;font-family:'Cormorant Garamond',serif;letter-spacing:.15em;text-transform:uppercase;transition:background .3s}
.hero-search button:hover{background:var(--gold-300)}
@media(max-width:900px){.hero-search{grid-template-columns:1fr;gap:0}.hero-search .field{border-right:none;border-bottom:1px solid var(--line);padding:.8rem 1rem}}

.scroll-cue{position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);z-index:3;color:var(--gold-500);font-family:'Cormorant Garamond',serif;font-style:italic;letter-spacing:.3em;font-size:.7rem;text-transform:uppercase;text-align:center;opacity:.7}
.scroll-cue::after{content:"";display:block;width:1px;height:50px;background:var(--gold-500);margin:.8rem auto 0;animation:scroll 2s var(--ease) infinite}
@keyframes scroll{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* Sections */
section{padding:8rem 6vw;position:relative}
.section-head{text-align:center;max-width:760px;margin:0 auto 5rem}
.section-head h2 .script{display:block;font-size:1.1em;color:var(--gold-500);margin-bottom:-.5em}

/* Stats strip */
.stats{background:linear-gradient(135deg,var(--petrol-800),var(--petrol-700));padding:4rem 6vw;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat{position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-1rem;top:20%;bottom:20%;width:1px;background:var(--line)}
.stat .num{font-family:'Cormorant Garamond',serif;font-size:clamp(2.6rem,5vw,4rem);color:var(--gold-500);line-height:1}
.stat .num small{font-size:.5em;vertical-align:super;margin-left:.1em}
.stat .lbl{display:block;margin-top:.6rem;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,239,226,.6)}
@media(max-width:700px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:3rem 1rem}.stat:nth-child(2)::after{display:none}}

/* Listing grid */
.listings{background:var(--petrol-900)}
.listing-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:2.5rem}
.card{background:var(--petrol-800);border:1px solid var(--line);position:relative;overflow:hidden;cursor:pointer;transition:transform .6s var(--ease),box-shadow .6s,border-color .4s}
.card:hover{transform:translateY(-10px);box-shadow:var(--shadow-xl);border-color:var(--gold-500)}
.card .media{position:relative;aspect-ratio:4/3;overflow:hidden}
.card .media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease),filter .6s}
.card:hover .media img{transform:scale(1.1);filter:brightness(.7)}
.card .media::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(6,24,27,.85));z-index:1;opacity:.5;transition:opacity .5s}
.card:hover .media::before{opacity:1}
.card .badge{position:absolute;top:1.2rem;left:1.2rem;z-index:2;background:var(--gold-500);color:var(--petrol-900);padding:.4rem .9rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-family:'Cormorant Garamond',serif}
.card .fav{position:absolute;top:1.2rem;right:1.2rem;z-index:2;width:42px;height:42px;border-radius:50%;background:rgba(6,24,27,.6);border:1px solid var(--line);display:grid;place-items:center;color:var(--gold-300);transition:all .3s;cursor:pointer}
.card .fav:hover{background:var(--gold-500);color:var(--petrol-900);transform:scale(1.1)}
.card .price-overlay{position:absolute;left:1.4rem;bottom:1.4rem;right:1.4rem;z-index:2;display:flex;justify-content:space-between;align-items:end;color:var(--gold-100);transform:translateY(20px);opacity:0;transition:all .5s var(--ease)}
.card:hover .price-overlay{transform:none;opacity:1}
.card .price-overlay .price{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:var(--gold-300)}
.card .price-overlay .view{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;border-bottom:1px solid var(--gold-500);padding-bottom:.2rem}
.card .body{padding:1.6rem 1.8rem 2rem}
.card .loc{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-500);font-family:'Cormorant Garamond',serif;font-style:italic}
.card h3{margin:.4rem 0 1rem;color:var(--gold-100);font-size:1.5rem;transition:color .3s}
.card:hover h3{color:var(--gold-300)}
.card .specs{display:flex;gap:1.4rem;font-size:.85rem;color:rgba(245,239,226,.7);padding-top:1rem;border-top:1px solid var(--line)}
.card .specs span{display:flex;align-items:center;gap:.4rem}
.card .specs svg{stroke:var(--gold-500);width:18px;height:18px}
.card .price-static{display:none}

/* Story / about split */
.story{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;max-width:1300px;margin:0 auto}
.story-media{position:relative;aspect-ratio:4/5}
.story-media img{width:100%;height:100%;object-fit:cover}
.story-media::before{content:"";position:absolute;inset:-20px;border:1px solid var(--gold-500);z-index:-1;transform:translate(-20px,20px);transition:transform .6s var(--ease)}
.story-media:hover::before{transform:translate(20px,-20px)}
.story-text p{margin-bottom:1.2rem;font-size:1.05rem}
.story-text .signature{font-family:'Pinyon Script',cursive;font-size:3rem;color:var(--gold-500);margin-top:1.4rem;line-height:1}
@media(max-width:900px){.story{grid-template-columns:1fr;gap:3rem}}

/* Districts (CPH NV) */
.districts{background:linear-gradient(180deg,var(--petrol-900),var(--petrol-800))}
.districts-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.district{position:relative;aspect-ratio:3/4;overflow:hidden;cursor:pointer}
.district img{width:100%;height:100%;object-fit:cover;transition:transform 1.5s var(--ease),filter .8s;filter:brightness(.6) saturate(.9)}
.district:hover img{transform:scale(1.08);filter:brightness(.85) saturate(1.1)}
.district::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(6,24,27,.85));z-index:1}
.district .info{position:absolute;left:1.5rem;right:1.5rem;bottom:1.5rem;z-index:2;transform:translateY(20px);transition:transform .5s var(--ease)}
.district:hover .info{transform:translateY(0)}
.district .area{font-size:.75rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold-500)}
.district h3{font-size:1.5rem;margin:.3rem 0 .4rem}
.district .count{font-size:.85rem;color:rgba(245,239,226,.7);transform:translateY(15px);opacity:0;transition:all .5s var(--ease) .1s}
.district:hover .count{opacity:1;transform:none}
@media(max-width:900px){.districts-grid{grid-template-columns:repeat(2,1fr)}}

/* Process / approach */
.approach{background:var(--petrol-900);position:relative}
.approach::before{content:"M";position:absolute;top:10%;right:5%;font-family:'Pinyon Script',cursive;font-size:38rem;color:rgba(201,169,97,.04);line-height:1;pointer-events:none}
.steps{max-width:1100px;margin:0 auto;display:grid;gap:0}
.step{display:grid;grid-template-columns:auto 1fr;gap:3rem;padding:3rem 0;border-top:1px solid var(--line);transition:background .4s,padding-left .5s var(--ease)}
.step:last-child{border-bottom:1px solid var(--line)}
.step:hover{padding-left:2rem}
.step:hover h3{color:var(--gold-300)}
.step .num{font-family:'Cormorant Garamond',serif;font-size:3.5rem;color:var(--gold-500);font-style:italic;line-height:1;opacity:.7}
.step h3{font-size:2rem;margin-bottom:.6rem;transition:color .3s}

/* Testimonials */
.testimonials{background:linear-gradient(180deg,var(--petrol-800),var(--petrol-900));overflow:hidden}
.testimonial-track{display:flex;gap:2rem;max-width:1300px;margin:0 auto}
.testimonial{flex:1;background:var(--petrol-800);border:1px solid var(--line);padding:3rem 2.5rem;position:relative}
.testimonial::before{content:"\201C";position:absolute;top:-1rem;left:1.5rem;font-family:'Cormorant Garamond',serif;font-size:7rem;color:var(--gold-500);line-height:1}
.testimonial p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.25rem;color:var(--cream);margin-bottom:1.5rem;position:relative;z-index:1}
.testimonial .author{display:flex;align-items:center;gap:1rem;padding-top:1.5rem;border-top:1px solid var(--line)}
.testimonial .author strong{display:block;color:var(--gold-300);font-weight:500;font-family:'Cormorant Garamond',serif;font-size:1.1rem}
.testimonial .author span{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,239,226,.55)}
@media(max-width:900px){.testimonial-track{flex-direction:column}}

/* CTA banner */
.cta-banner{padding:8rem 6vw;text-align:center;background:var(--petrol-800);position:relative;overflow:hidden}
.cta-banner::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(201,169,97,.18),transparent 60%)}
.cta-banner-inner{position:relative;z-index:1;max-width:760px;margin:0 auto}
.cta-banner h2{margin-bottom:1.6rem}
.cta-banner h2 .script{display:block;font-size:1.2em;margin-bottom:-.3em}

/* Footer */
footer{background:var(--petrol-900);padding:5rem 6vw 2rem;border-top:1px solid var(--line)}
.footer-grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid var(--line)}
.footer-grid h4{font-family:'Cormorant Garamond',serif;font-size:1rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-500);margin-bottom:1.2rem}
.footer-grid ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-grid a{color:rgba(245,239,226,.7);font-size:.95rem}
.footer-grid p{font-size:.95rem;color:rgba(245,239,226,.65)}
.foot-logo{font-family:'Pinyon Script',cursive;font-size:3rem;color:var(--gold-500);line-height:1;margin-bottom:1rem;display:block}
.foot-bottom{max-width:1300px;margin:2rem auto 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.8rem;color:rgba(245,239,226,.5);letter-spacing:.15em;text-transform:uppercase}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-stagger.in > *{opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(1){transition-delay:0s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.1s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.2s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.3s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.4s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.5s}

/* Listing detail page */
.detail-hero{margin-top:0;padding:0;height:80vh;position:relative;overflow:hidden}
.detail-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.7)}
.detail-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,24,27,.5),rgba(6,24,27,.95));z-index:1}
.detail-hero-text{position:absolute;left:0;right:0;bottom:5rem;text-align:center;z-index:2;padding:0 6vw}
.detail-hero-text .eyebrow{margin-bottom:.4rem}
.detail-hero-text h1{margin-bottom:1rem;color:var(--gold-100)}
.detail-hero-text .price{font-family:'Cormorant Garamond',serif;font-size:2.4rem;color:var(--gold-500)}

.detail-body{max-width:1300px;margin:0 auto;padding:6rem 6vw;display:grid;grid-template-columns:1.6fr 1fr;gap:5rem}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:3rem}
.gallery img{aspect-ratio:4/3;object-fit:cover;cursor:pointer;transition:transform .8s var(--ease),filter .4s}
.gallery img:hover{transform:scale(1.02);filter:brightness(1.1)}
.gallery img:first-child{grid-column:span 2;aspect-ratio:16/9}
.detail-features{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem 2rem;list-style:none;margin:2rem 0}
.detail-features li{padding:.6rem 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;font-size:.95rem}
.detail-features li span:first-child{color:var(--gold-500);font-family:'Cormorant Garamond',serif;font-style:italic;letter-spacing:.1em}
.contact-card{position:sticky;top:6rem;background:var(--petrol-800);padding:2.5rem;border:1px solid var(--line);height:fit-content}
.contact-card .agent-pic{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid var(--gold-500);margin-bottom:1rem}
.contact-card h4{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--gold-100);margin-bottom:.2rem}
.contact-card .role{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-500);margin-bottom:1.5rem}
.contact-card form{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}
.contact-card input,.contact-card textarea{background:var(--petrol-900);border:1px solid var(--line);color:var(--cream);padding:.9rem 1rem;font-family:inherit;font-size:.95rem;outline:none;transition:border-color .3s}
.contact-card input:focus,.contact-card textarea:focus{border-color:var(--gold-500)}
.contact-card textarea{resize:vertical;min-height:100px}
@media(max-width:900px){.detail-body{grid-template-columns:1fr;gap:3rem}.contact-card{position:static}}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(6,24,27,.95);z-index:1000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(20px);padding:2rem}
.lightbox.open{display:flex;animation:fadeUp .4s var(--ease)}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;box-shadow:0 30px 120px rgba(0,0,0,.6)}
.lightbox .close{position:absolute;top:2rem;right:2rem;width:50px;height:50px;border:1px solid var(--gold-500);background:transparent;color:var(--gold-300);font-size:1.5rem;cursor:pointer;transition:all .3s}
.lightbox .close:hover{background:var(--gold-500);color:var(--petrol-900);transform:rotate(90deg)}

/* Form */
.form-section{display:grid;grid-template-columns:1fr 1fr;gap:5rem;max-width:1300px;margin:0 auto}
.form-section input,.form-section textarea{background:var(--petrol-800);border:1px solid var(--line);color:var(--cream);padding:1rem 1.2rem;font-family:inherit;font-size:1rem;outline:none;transition:border-color .3s;width:100%}
.form-section input:focus,.form-section textarea:focus{border-color:var(--gold-500)}
.form-section textarea{min-height:140px;resize:vertical}
.form-section form{display:flex;flex-direction:column;gap:1.2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.contact-info dl{display:grid;grid-template-columns:auto 1fr;gap:.8rem 2rem;margin-top:2rem}
.contact-info dt{color:var(--gold-500);font-family:'Cormorant Garamond',serif;font-style:italic;letter-spacing:.1em}
.contact-info dd{color:rgba(245,239,226,.85)}
@media(max-width:900px){.form-section{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}}

/* Marquee */
.marquee{overflow:hidden;padding:2rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--petrol-800)}
.marquee-track{display:flex;gap:3rem;animation:marquee 40s linear infinite;white-space:nowrap;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.6rem;color:var(--gold-500)}
.marquee-track span{display:inline-flex;align-items:center;gap:3rem}
.marquee-track span::after{content:"\2756";color:var(--gold-700);font-size:.8em}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Page hero (sub pages) */
.page-hero{padding:14rem 6vw 6rem;text-align:center;background:linear-gradient(180deg,var(--petrol-800),var(--petrol-900));position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center top,rgba(201,169,97,.12),transparent 60%)}
.page-hero h1{position:relative;z-index:1}
.page-hero p{position:relative;z-index:1;max-width:600px;margin:1.5rem auto 0;font-size:1.1rem}

/* Filter bar */
.filter-bar{max-width:1400px;margin:0 auto 3rem;display:flex;gap:1rem;flex-wrap:wrap;padding-bottom:2rem;border-bottom:1px solid var(--line)}
.filter-bar button{background:transparent;border:1px solid var(--line);color:var(--cream);padding:.7rem 1.6rem;font-family:'Cormorant Garamond',serif;font-style:italic;letter-spacing:.1em;cursor:pointer;transition:all .3s}
.filter-bar button:hover,.filter-bar button.active{background:var(--gold-500);color:var(--petrol-900);border-color:var(--gold-500)}
.filter-bar .count{margin-left:auto;color:var(--gold-500);font-family:'Cormorant Garamond',serif;font-style:italic;align-self:center}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
