/* ============================================================
   SUZANA PERIĆ — MAISON one-page (burgundy / oxblood + gold)
   Recreated to match approved reference layout.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Jost:wght@300;400;500;600&display=swap');

:root{
  --wine:       #380f18;   /* primary background */
  --wine-deep:  #260910;   /* darker sections / footer */
  --wine-card:  #441420;   /* lifted cards */
  --wine-card2: #4e1825;
  --gold:       #c8a05a;
  --gold-2:     #e6c98e;
  --cream:      #f1e7db;
  --rose:       #cbabad;   /* muted body text */
  --rose-dim:   #9c7e82;
  --line:       rgba(200,160,90,.30);
  --line-soft:  rgba(241,231,219,.12);
  --shadow:     0 30px 80px rgba(0,0,0,.45);
  --font-d: 'Cormorant Garamond', Georgia, serif;
  --font-s: 'Jost', system-ui, sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:84px;}
body{
  background:var(--wine);
  color:var(--cream);
  font-family:var(--font-s);
  font-weight:300;
  font-size:16px;
  line-height:1.7;
  letter-spacing:.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;}

/* ---------- helpers ---------- */
.wrap{width:min(1320px,92vw);margin-inline:auto;}
section{position:relative;}
.eyebrow{font-family:var(--font-s);font-weight:400;font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);}
.serif{font-family:var(--font-d);}
.display{font-family:var(--font-d);font-weight:300;line-height:1.02;letter-spacing:.005em;}
.center{text-align:center;}
.gold{color:var(--gold);}
.muted{color:var(--rose);}

/* section title block (centered, used over each column) */
.sec-head{display:flex;flex-direction:column;align-items:center;gap:.9rem;margin-bottom:2.6rem;}
.sec-head .line{width:54px;height:1px;background:var(--gold);opacity:.7;}
.sec-head h2{font-family:var(--font-d);font-weight:300;font-size:clamp(1.9rem,3.2vw,2.9rem);letter-spacing:.02em;color:var(--cream);}
.sec-head.left{align-items:flex-start;text-align:left;}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--font-s);font-weight:400;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
  padding:.95rem 1.7rem;border:1px solid var(--gold);color:var(--gold);background:transparent;cursor:pointer;
  transition:background .4s,color .4s,border-color .4s;white-space:nowrap;}
.btn:hover{background:var(--gold);color:var(--wine-deep);}
.btn.solid{background:var(--gold);color:var(--wine-deep);}
.btn.solid:hover{background:var(--gold-2);border-color:var(--gold-2);}
.btn.sm{padding:.7rem 1.2rem;font-size:.62rem;}

/* discover micro-link */
.discover{font-family:var(--font-s);font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:.5rem;}
.discover::after{content:'';width:18px;height:1px;background:var(--gold);transition:width .4s;}
a.discover:hover::after,.card:hover .discover::after{width:30px;}

/* ===================================================== HEADER */
.head{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;padding:.7rem clamp(1rem,4vw,2.6rem);
  background:linear-gradient(180deg,rgba(30,7,13,.97),rgba(30,7,13,.55) 55%,rgba(30,7,13,0));
  transition:background .45s,box-shadow .45s,padding .45s;}
/* .head.scrolled uses a ::before (not backdrop-filter on .head itself) so it doesn't
   become a new containing block for fixed children — that broke the mobile nav drawer. */
.head.scrolled{background:transparent;box-shadow:0 1px 0 var(--line-soft),0 18px 40px rgba(0,0,0,.4);
  padding-block:.5rem;}
.head.scrolled::before{content:'';position:absolute;inset:0;z-index:-1;
  background:rgba(33,8,14,.96);backdrop-filter:blur(12px);}
.brand{display:flex;align-items:center;gap:.62rem;flex:none;}
.brand-mark{height:42px;width:auto;filter:drop-shadow(0 1px 3px rgba(0,0,0,.5));}
.brand-word{height:19px;width:auto;filter:drop-shadow(0 1px 3px rgba(0,0,0,.45));}
.nav{display:flex;align-items:center;gap:clamp(.7rem,1.5vw,1.5rem);}
.nav a{font-family:var(--font-s);font-size:.66rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--rose);transition:color .3s;position:relative;padding:.3rem 0;}
.nav a:hover,.nav a.active{color:var(--gold);}
.nav-cta{display:flex;align-items:center;gap:1rem;flex:none;}
.lang{font-family:var(--font-s);font-size:.62rem;letter-spacing:.16em;color:var(--rose);background:none;border:1px solid var(--line);padding:.35rem .6rem;cursor:pointer;transition:.3s;text-transform:uppercase;}
.lang:hover{color:var(--gold);border-color:var(--gold);}
.socials{display:flex;gap:.7rem;}
.socials a{color:var(--rose);transition:color .3s;}
.socials a:hover{color:var(--gold);}
.socials svg{width:16px;height:16px;display:block;}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;}
.burger span{width:24px;height:1.5px;background:var(--cream);transition:.3s;}

/* ===================================================== HERO */
.hero{display:grid;grid-template-columns:1.05fr 1fr;min-height:100vh;}
.hero-text{display:flex;flex-direction:column;justify-content:center;gap:1.5rem;
  padding:7rem clamp(2rem,5vw,5.5rem) 4rem;
  background:
    radial-gradient(120% 90% at 20% 30%,rgba(90,26,40,.55),transparent 60%),
    linear-gradient(180deg,var(--wine-deep),var(--wine) 55%,#2e0b13);
  position:relative;}
.hero-crest{width:62px;height:auto;opacity:.97;margin-bottom:.6rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));}
.hero-est{font-family:var(--font-s);font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);}
.hero h1{font-family:var(--font-d);font-weight:300;font-size:clamp(3rem,6.6vw,6rem);line-height:.95;letter-spacing:.02em;color:var(--cream);}
.hero .tag{font-family:var(--font-d);font-style:italic;font-weight:300;font-size:clamp(1.25rem,2.2vw,1.85rem);color:var(--rose);letter-spacing:.02em;}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.8rem;}
.hero-cities{font-family:var(--font-s);font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--rose-dim);margin-top:1.6rem;}
.hero-photo{position:relative;overflow:hidden;background:var(--wine-deep);}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center 18%;}
.hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(46,11,19,.85),transparent 28%);}

/* ===================================================== IDEA STORY */
.idea-story{
  padding-block:clamp(3.5rem,7vw,6.5rem);
  background:
    radial-gradient(90% 80% at 18% 20%,rgba(104,31,47,.36),transparent 62%),
    linear-gradient(180deg,#2e0b13 0%,var(--wine) 52%,var(--wine-deep) 100%);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.idea-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(280px,.78fr);gap:clamp(2rem,5vw,5.5rem);align-items:center;}
.idea-copy{max-width:760px;}
.idea-copy h2{font-family:var(--font-d);font-weight:300;font-size:clamp(2.2rem,4.8vw,4.4rem);line-height:1.04;color:var(--cream);margin:.75rem 0 1.7rem;}
.idea-copy p{color:var(--rose);font-size:clamp(.95rem,1.15vw,1.05rem);line-height:1.88;margin-bottom:1rem;}
.idea-copy blockquote{position:relative;margin-top:1.8rem;padding:1.35rem 0 0 2rem;border-top:1px solid var(--line);
  font-family:var(--font-d);font-style:italic;font-weight:300;font-size:clamp(1.45rem,2.6vw,2.35rem);line-height:1.18;color:var(--gold-2);}
.idea-copy blockquote::before{content:'“';position:absolute;left:0;top:.82rem;color:var(--gold);font-size:2.4rem;line-height:1;}
.idea-photo{position:relative;align-self:stretch;min-height:clamp(520px,58vw,780px);overflow:hidden;background:var(--wine-deep);box-shadow:var(--shadow);}
.idea-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:brightness(.92) contrast(1.03) saturate(.94);}
.idea-photo .frame{position:absolute;inset:16px;border:1px solid var(--line);pointer-events:none;}

/* ===================================================== THE MAISON */
.band{padding-block:clamp(3.5rem,7vw,6.5rem);}
.band.deep{background:var(--wine-deep);}
.maison-grid{display:grid;grid-template-columns:.85fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;}
.maison-portrait{position:relative;}
.maison-portrait img{width:100%;aspect-ratio:3/3.7;object-fit:cover;filter:grayscale(1) contrast(1.05) brightness(.95);}
.maison-portrait .frame{position:absolute;inset:14px;border:1px solid var(--line);pointer-events:none;}
.maison-portrait .sig{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);font-family:var(--font-d);font-style:italic;font-size:1.6rem;color:var(--gold-2);opacity:.85;}
.maison-copy h2{font-family:var(--font-d);font-weight:300;font-size:clamp(2rem,4vw,3.4rem);line-height:1.08;color:var(--cream);margin:.6rem 0 1.4rem;}
.maison-copy p{color:var(--rose);max-width:54ch;margin-bottom:1.1rem;}
.maison-copy .btn{margin-top:1rem;}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);margin-top:clamp(2.5rem,5vw,4rem);border-top:1px solid var(--line);}
.stat{padding:1.8rem 1rem;text-align:center;border-left:1px solid var(--line-soft);}
.stat:first-child{border-left:0;}
.stat b{display:block;font-family:var(--font-d);font-weight:400;font-size:clamp(1.6rem,3vw,2.4rem);color:var(--gold-2);line-height:1;}
.stat span{display:block;font-family:var(--font-s);font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:var(--rose-dim);margin-top:.7rem;}

/* ===================================================== TWO-COLUMN MODULE (collections | atelier etc) */
.twocol{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(1.6rem,3.5vw,3.4rem);align-items:start;}
.panel{border:1px solid var(--line-soft);background:linear-gradient(180deg,rgba(78,24,37,.4),rgba(56,15,24,.15));padding:clamp(1.4rem,2.5vw,2.4rem);}

/* collection cards */
.col-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.card{position:relative;display:block;overflow:hidden;background:var(--wine-deep);cursor:pointer;}
.card img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1),filter .5s;filter:brightness(.82) saturate(.95);}
.card:hover img{transform:scale(1.06);filter:brightness(.95);}
.card-cap{position:absolute;inset:auto 0 0 0;padding:1.1rem 1.2rem;background:linear-gradient(180deg,transparent,rgba(25,7,12,.92));}
.card-cap h4{font-family:var(--font-d);font-weight:400;font-size:1.15rem;letter-spacing:.04em;color:var(--cream);line-height:1.1;}
.card-cap .discover{margin-top:.5rem;}

/* atelier image grid */
.atelier-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:1.4rem;}
.atelier-grid .ph{overflow:hidden;background:var(--wine-deep);}
.atelier-grid .ph img{width:100%;height:100%;aspect-ratio:1/1;object-fit:cover;filter:brightness(.85) saturate(.9);transition:transform 1s,filter .5s;}
.atelier-grid .ph:hover img{transform:scale(1.05);filter:brightness(1);}
.atelier-grid .ph.tall{grid-row:span 2;}
.atelier-grid .ph.tall img{aspect-ratio:1/2.06;}

/* intro text block inside panel */
.panel-intro p{color:var(--rose);max-width:46ch;margin-bottom:1.2rem;}

/* ===================================================== WORLD OF SUZANA */
.world-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}
.world-tile{position:relative;overflow:hidden;background:var(--wine-deep);aspect-ratio:3/4.2;}
.world-tile img{width:100%;height:100%;object-fit:cover;filter:brightness(.7) saturate(.9);transition:transform 1.1s,filter .5s;}
.world-tile:hover img{transform:scale(1.07);filter:brightness(.9);}
.world-tile span{position:absolute;left:0;right:0;bottom:14px;text-align:center;font-family:var(--font-s);font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);z-index:2;}
.world-tile::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(20,6,10,.85));}

/* about */
.about-grid{display:grid;grid-template-columns:1fr .8fr;gap:clamp(1.6rem,3.5vw,3rem);align-items:center;}
@media(max-width:1080px){.about-grid{grid-template-columns:1fr!important;}}
.about-copy p{color:var(--rose);max-width:50ch;margin-bottom:1rem;font-size:.92rem;}
.about-copy .sign{font-family:var(--font-d);font-style:italic;font-size:2rem;color:var(--gold-2);margin-top:1rem;}
.about-photo img{width:100%;aspect-ratio:3/3.7;object-fit:cover;filter:contrast(1.03);}
.about-photo{position:relative;}
.about-photo .frame{position:absolute;inset:14px;border:1px solid var(--line);pointer-events:none;}

/* ===================================================== PRESS */
.press-logos{display:flex;flex-wrap:wrap;gap:1.4rem 2.2rem;align-items:center;justify-content:center;margin-bottom:1.8rem;}
.press-logos span{font-family:var(--font-d);font-weight:500;font-size:1.3rem;letter-spacing:.08em;color:var(--rose);opacity:.75;}
.press-covers{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;}
.cover{position:relative;overflow:hidden;background:var(--wine-deep);aspect-ratio:3/4;}
.cover img{width:100%;height:100%;object-fit:cover;filter:brightness(.85) saturate(.9);transition:transform 1s;}
.cover:hover img{transform:scale(1.05);}
.cover .mh{position:absolute;top:8px;left:0;right:0;text-align:center;font-family:var(--font-d);font-weight:600;font-size:.85rem;letter-spacing:.12em;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.6);z-index:2;}

/* ===================================================== APPOINTMENTS / FORM */
.form-panel{background:var(--wine-card);border:1px solid var(--line);padding:clamp(1.6rem,3vw,2.6rem);}
.form-panel h3{font-family:var(--font-d);font-weight:300;font-size:clamp(1.5rem,2.6vw,2.1rem);color:var(--cream);margin-bottom:.4rem;}
.form-panel .sub{color:var(--rose);font-size:.86rem;margin-bottom:1.6rem;}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.2rem;}
.field{display:flex;flex-direction:column;gap:.4rem;}
.field.full{grid-column:1/-1;}
.field label{font-family:var(--font-s);font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rose-dim);}
.field input,.field select,.field textarea{
  font-family:var(--font-s);font-size:.9rem;color:var(--cream);background:rgba(20,6,10,.5);
  border:1px solid var(--line-soft);padding:.8rem .9rem;transition:border-color .3s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);}
.field textarea{resize:vertical;min-height:90px;}
.field select{appearance:none;cursor:pointer;}
.field option{background:var(--wine-deep);}
.form-panel .btn{margin-top:1.4rem;width:100%;}

.appt-aside img{width:100%;height:100%;object-fit:cover;filter:brightness(.8);}
.appt-aside{position:relative;overflow:hidden;min-height:260px;}
.appt-aside .ov{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;
  background:linear-gradient(180deg,rgba(38,9,16,.55),rgba(38,9,16,.8));text-align:center;padding:2rem;}
.appt-aside .ov img{width:54px;height:auto;filter:none;margin-bottom:.5rem;}
.appt-aside .ov b{font-family:var(--font-d);font-weight:400;font-size:1.4rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream);}
.appt-aside .ov small{font-family:var(--font-s);font-size:.56rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);}

/* ===================================================== CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3.5rem);align-items:center;}
.contact-list{display:flex;flex-direction:column;gap:1.6rem;}
.cline{display:flex;gap:1rem;align-items:flex-start;}
.cline .ic{color:var(--gold);flex:none;margin-top:3px;}
.cline .ic svg{width:18px;height:18px;}
.cline b{display:block;font-family:var(--font-s);font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:var(--rose-dim);margin-bottom:.3rem;}
.cline span{color:var(--cream);font-size:.95rem;}
.map{position:relative;min-height:300px;border:1px solid var(--line-soft);overflow:hidden;
  background:
    repeating-linear-gradient(0deg,transparent 0 38px,rgba(200,160,90,.05) 38px 39px),
    repeating-linear-gradient(90deg,transparent 0 38px,rgba(200,160,90,.05) 38px 39px),
    radial-gradient(120% 120% at 60% 40%,#3a1019,#240810);}
.map .pin{position:absolute;left:54%;top:46%;transform:translate(-50%,-100%);color:var(--gold);}
.map .pin svg{width:30px;height:30px;}
.map .pin::after{content:'';position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);width:18px;height:5px;border-radius:50%;background:rgba(0,0,0,.5);filter:blur(2px);}

/* ===================================================== FOOTER */
.foot{background:var(--wine-deep);padding-block:clamp(2.8rem,5vw,4.5rem);border-top:1px solid var(--line-soft);}
.foot-top{display:flex;flex-direction:column;align-items:center;gap:.8rem;text-align:center;padding-bottom:2.6rem;border-bottom:1px solid var(--line-soft);}
.foot-top img{width:58px;height:auto;}
.foot-word{width:min(320px,72vw)!important;height:auto;margin-bottom:.3rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.35));}
.foot-top b{font-family:var(--font-d);font-weight:400;font-size:1.5rem;letter-spacing:.24em;text-transform:uppercase;color:var(--cream);}
.foot-top small{font-family:var(--font-s);font-size:.58rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);}
.foot-cols{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem;padding-block:2.6rem;}
.foot-col h5{font-family:var(--font-s);font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem;}
.foot-col a{display:block;color:var(--rose);font-size:.84rem;padding:.28rem 0;transition:color .3s;}
.foot-col a:hover{color:var(--cream);}
.news{display:flex;border:1px solid var(--line);margin-top:.6rem;}
.news input{flex:1;background:transparent;border:0;color:var(--cream);font-family:var(--font-s);font-size:.8rem;padding:.6rem .8rem;}
.news input:focus{outline:none;}
.news button{background:transparent;border:0;border-left:1px solid var(--line);color:var(--gold);padding:0 .9rem;cursor:pointer;}
.foot-base{text-align:center;padding-top:2rem;font-family:var(--font-s);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--rose-dim);}

/* ===================================================== INTRO */
.intro{position:fixed;inset:0;z-index:1000;overflow:hidden;}
.intro.done{pointer-events:none;}
.intro-panel{position:absolute;left:0;right:0;height:50%;background:var(--wine-deep);z-index:1;
  transition:transform 1.05s cubic-bezier(.76,0,.24,1);}
.intro-panel.top{top:0;}
.intro-panel.bottom{bottom:0;}
.intro.lift .intro-panel.top{transform:translateY(-100%);}
.intro.lift .intro-panel.bottom{transform:translateY(100%);}
.intro-core{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;
  background:radial-gradient(120% 90% at 50% 40%,rgba(90,26,40,.5),transparent 62%);
  transition:opacity .7s ease;}
.intro.lift .intro-core{opacity:0;}
.intro-mark{width:96px;height:auto;opacity:0;transform:translateY(14px) scale(.92);
  filter:drop-shadow(0 4px 18px rgba(0,0,0,.45));
  animation:introMark 1.1s cubic-bezier(.2,.7,.2,1) .15s forwards;}
.intro-rule{display:flex;align-items:center;gap:.8rem;opacity:0;animation:introFade .7s ease .7s forwards;}
.intro-rule .r{display:block;width:0;height:1px;background:var(--gold);animation:introRule 1s cubic-bezier(.2,.7,.2,1) .8s forwards;}
.intro-rule .dot{width:5px;height:5px;border:1px solid var(--gold);transform:rotate(45deg);flex:none;}
.intro-name{font-family:var(--font-d);font-weight:300;font-size:clamp(2.6rem,7vw,5rem);line-height:1;letter-spacing:.04em;
  color:var(--cream);opacity:0;transform:translateY(16px);animation:introUp .9s cubic-bezier(.2,.7,.2,1) .95s forwards;}
.intro-est{font-family:var(--font-s);font-size:.66rem;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);
  opacity:0;transform:translateY(10px);animation:introUp .9s cubic-bezier(.2,.7,.2,1) 1.2s forwards;}
.intro-skip{position:absolute;right:1.6rem;bottom:1.4rem;z-index:3;background:transparent;border:0;cursor:pointer;
  font-family:var(--font-s);font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--rose-dim);
  opacity:0;animation:introFade .6s ease 1.6s forwards;transition:color .3s;}
.intro-skip:hover{color:var(--gold);}
@keyframes introMark{to{opacity:1;transform:none;}}
@keyframes introUp{to{opacity:1;transform:none;}}
@keyframes introFade{to{opacity:1;}}
@keyframes introRule{to{width:56px;}}
body.intro-lock{overflow:hidden;height:100vh;}
@media(prefers-reduced-motion:reduce){
  .intro-mark,.intro-rule,.intro-rule .r,.intro-name,.intro-est,.intro-skip{animation:none;opacity:1;transform:none;}
  .intro-rule .r{width:56px;}
}

/* ===================================================== LIGHTBOX */
.lbx{position:fixed;inset:0;z-index:300;background:rgba(20,5,9,.97);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;}
.lbx.open{opacity:1;visibility:visible;}
.lbx figure{margin:0;display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:92vw;max-height:88vh;}
.lbx img{max-width:92vw;max-height:80vh;object-fit:contain;box-shadow:var(--shadow);opacity:0;transition:opacity .35s;}
.lbx img.ready{opacity:1;}
.lbx figcaption{display:flex;gap:1rem;font-family:var(--font-s);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rose-dim);}
.lbx figcaption b{color:var(--gold);font-weight:400;}
.lbx-btn{position:absolute;background:transparent;border:1px solid var(--line);color:var(--cream);cursor:pointer;display:grid;place-items:center;line-height:1;transition:.3s;}
.lbx-btn:hover{border-color:var(--gold);color:var(--gold);}
.lbx-close{top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem);width:46px;height:46px;font-size:1.4rem;}
.lbx-prev,.lbx-next{top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:1.7rem;}
.lbx-prev{left:clamp(.6rem,3vw,2.2rem);}
.lbx-next{right:clamp(.6rem,3vw,2.2rem);}

/* ===================================================== REVEAL ANIM */
@media(prefers-reduced-motion:no-preference){
  [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1);}
  [data-reveal].in{opacity:1;transform:none;}
  [data-reveal][data-d="1"]{transition-delay:.1s;}
  [data-reveal][data-d="2"]{transition-delay:.2s;}
  [data-reveal][data-d="3"]{transition-delay:.3s;}
}

/* ===================================================== RESPONSIVE */
@media(max-width:1080px){
  .nav{display:none;}
  .socials{display:none;}
  .burger{display:flex;}
  .twocol{grid-template-columns:1fr!important;}
  .hero{grid-template-columns:1fr;}
  .hero-photo{min-height:62vh;order:-1;}
  .hero-photo::after{background:linear-gradient(0deg,rgba(46,11,19,.9),transparent 35%);}
  .hero-text{padding-top:5rem;}
  .idea-grid{grid-template-columns:1fr;}
  .idea-photo{min-height:auto;aspect-ratio:4/5;max-width:720px;width:100%;margin-inline:auto;}
  .twocol,.maison-grid,.about-grid,.contact-grid{grid-template-columns:1fr;}
  .world-grid{grid-template-columns:repeat(3,1fr);}
  .press-covers{grid-template-columns:repeat(3,1fr);}
  .foot-cols{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:680px){
  .stats{grid-template-columns:1fr 1fr;}
  .stat:nth-child(odd){border-left:0;}
  .stat:nth-child(n+3){border-top:1px solid var(--line-soft);}
  .col-cards{grid-template-columns:1fr 1fr;}
  .world-grid{grid-template-columns:repeat(2,1fr);}
  .press-covers{grid-template-columns:repeat(3,1fr);}
  .press-logos{gap:1rem 1.4rem;}
  .press-logos span{font-size:1rem;}
  .foot-cols{grid-template-columns:1fr 1fr;}
  .fgrid{grid-template-columns:1fr;}
  .hero h1{font-size:clamp(2.6rem,11vw,3.6rem);}
  .idea-copy p{font-size:.92rem;line-height:1.76;}
  .idea-copy blockquote{padding-left:1.4rem;}
  .idea-photo{aspect-ratio:3/4;}
}
/* mobile nav drawer */
.nav.open{display:flex;position:fixed;inset:0;flex-direction:column;align-items:center;justify-content:center;gap:1.6rem;
  background:rgba(33,8,14,.98);backdrop-filter:blur(10px);z-index:99;}
.nav.open a{font-size:.95rem;letter-spacing:.24em;padding:.55rem 1rem;}
@media(max-width:1080px){ .lang{padding:.5rem .8rem;font-size:.66rem;} .head{gap:.8rem;} }
