/* ============================================================
   Maria La Chinesiologa — Home (cinematic edition)
   Recreated from the Claude Design handoff (6X4Cu2…). Brand palette + type.
   ============================================================ */
:root{
  --navy:#143962; --navy-deep:#0E2A4A; --navy-soft:#2B4C75;
  --gold:#D4B66A; --gold-deep:#B89849; --gold-soft:#E4CE92;
  --ivory:#F6F0E2; --ivory-2:#EFE7D2; --cream:#FBF6E9; --line:#DDD3B7;

  --bg:var(--ivory); --bg-2:var(--ivory-2); --paper:var(--cream);
  --ink:var(--navy); --ink-soft:var(--navy-soft); --muted:#6B7C92;
  --accent:var(--gold-deep); --accent-soft:var(--gold-soft);

  --radius:4px;
  --serif:'Cormorant Garamond','Cormorant',Georgia,serif;
  --script:'Caveat',cursive;
  --sans:'Manrope',system-ui,-apple-system,sans-serif;
  --mono:'DM Mono',ui-monospace,monospace;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--bg);color:var(--ink)}
body{font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
a{color:inherit;text-decoration:none}
::selection{background:var(--ink);color:var(--paper)}

/* — type helpers — */
.serif{font-family:var(--serif);font-weight:400;letter-spacing:-.005em}
.script{font-family:var(--script);font-weight:500}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.it{font-style:italic}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
.eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--accent)}
.h-display{font-family:var(--serif);font-weight:300;font-size:clamp(48px,9vw,168px);line-height:.92;letter-spacing:-.02em}
.h-display .it{font-style:italic;font-weight:400}
.h-1{font-family:var(--serif);font-weight:300;font-size:clamp(40px,6vw,96px);line-height:.98;letter-spacing:-.015em}
.h-1 .it{font-style:italic;font-weight:400}
.lead{font-size:clamp(17px,1.4vw,22px);line-height:1.45;color:var(--ink-soft);max-width:56ch;text-wrap:pretty}

/* — buttons — */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;background:var(--ink);color:var(--paper);
  border-radius:999px;font-size:13px;letter-spacing:.04em;text-transform:uppercase;font-weight:500;
  transition:transform .5s var(--ease),background .3s var(--ease),color .3s var(--ease);white-space:nowrap}
.btn .arrow{transition:transform .5s var(--ease)}
.btn:hover{transform:translateY(-2px)}.btn:hover .arrow{transform:translateX(4px)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
/* gold-gradient prenota button */
.btn-gold{display:inline-flex;align-items:center;gap:12px;padding:22px 32px;font-size:13px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;cursor:pointer;border-radius:999px;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-deep) 100%);color:var(--navy-deep);
  border:1px solid rgba(228,206,146,.6);box-shadow:0 24px 60px -16px rgba(184,152,73,.45);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 30px 80px -16px rgba(184,152,73,.6)}
.btn-gold.sm{padding:12px 22px;font-size:12px;box-shadow:0 6px 20px -8px rgba(184,152,73,.4)}
.btn-outline-gold{display:inline-flex;align-items:center;gap:10px;padding:20px 32px;font-size:13px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;cursor:pointer;border-radius:999px;
  background:transparent;color:var(--gold);border:1px solid var(--gold);transition:all .3s var(--ease)}
.btn-outline-gold:hover{background:var(--gold);color:var(--navy-deep)}

/* — layout — */
.wrap{max-width:1480px;margin:0 auto;padding:0 40px}
.section{padding:120px 0;position:relative}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-4{gap:16px}
.ph{position:relative;background:var(--bg-2);overflow:hidden;color:var(--ink-soft);
  background-image:repeating-linear-gradient(135deg,rgba(20,57,98,.05) 0 1px,transparent 1px 14px)}
.ph::before{content:attr(data-label);position:absolute;inset:auto 0 12px 0;text-align:center;font-family:var(--mono);
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);opacity:.7}
.ph[data-tone="dark"]{background-color:var(--ink);color:var(--paper);
  background-image:repeating-linear-gradient(135deg,rgba(212,182,106,.10) 0 1px,transparent 1px 14px)}
.ph[data-tone="dark"]::before{color:rgba(246,240,226,.55)}
.ph[data-tone="accent"]{background-color:var(--gold-soft);
  background-image:repeating-linear-gradient(135deg,rgba(20,57,98,.10) 0 1px,transparent 1px 14px)}
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============================================================  NAV  */
.nav{position:fixed;inset:0 0 auto 0;z-index:50;padding:24px 0;background:transparent;
  border-bottom:1px solid transparent;color:var(--ink);
  transition:all .6s var(--ease),transform .8s var(--ease),opacity .6s var(--ease)}
.nav.scrolled{padding:14px 0;background:rgba(246,240,226,.78);
  backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);border-bottom:1px solid var(--line)}
.nav.hidden{transform:translateY(-110%);opacity:0;pointer-events:none}
.wordmark{display:inline-flex;align-items:center;gap:12px}
.wordmark img{height:52px;width:auto;object-fit:contain}
.wordmark .wm-text{display:flex;flex-direction:column;gap:2px;line-height:1}
.wordmark .wm-1{font-family:var(--serif);font-style:italic;font-size:21px;color:var(--ink);letter-spacing:-.005em}
.wordmark .wm-2{font-family:var(--sans);font-weight:500;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);opacity:.75}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{padding:10px 18px;font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);position:relative;transition:color .3s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:'';position:absolute;left:50%;bottom:2px;width:4px;height:4px;border-radius:50%;background:var(--gold);transform:translateX(-50%)}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-ico{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;
  color:var(--ink-soft);transition:color .3s var(--ease),background .3s var(--ease)}
.nav-ico:hover{color:var(--ink);background:rgba(20,57,98,.06)}
.nav-cart{position:relative}
.nav-cart__count{position:absolute;top:3px;right:3px;min-width:15px;height:15px;padding:0 4px;border-radius:999px;
  background:var(--gold-deep);color:var(--navy-deep);font-family:var(--mono);font-size:9px;
  display:flex;align-items:center;justify-content:center;line-height:1}
.nav-cart__count[data-count="0"]{display:none}
/* hamburger + mobile menu */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;border:0;background:none;cursor:pointer;padding:10px}
.nav-burger span{display:block;width:100%;height:2px;background:var(--ink);border-radius:2px;transition:transform .35s var(--ease),opacity .2s var(--ease)}
.nav.open .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav-burger span:nth-child(2){opacity:0}
.nav.open .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:none;border-top:1px solid var(--line);background:var(--bg)}
.nav.open .nav-mobile{display:block}
.nav-mobile .wrap{display:flex;flex-direction:column;padding-top:6px;padding-bottom:22px}
.nav-mobile a{padding:16px 2px;font-family:var(--sans);font-size:18px;color:var(--ink);border-bottom:1px solid var(--line)}
.nav-mobile a:last-child{border-bottom:0}
.nav-mobile .nav-mobile__acc{color:var(--accent);font-weight:600;letter-spacing:.02em}

/* ============================================================  HERO (cinematic)  */
.hero{position:relative;height:380vh;background:var(--navy-deep);transition:background-color .25s linear}
.hero-sticky{position:sticky;top:0;height:100vh;overflow:hidden;transition:background-color .25s linear}
.hero-grain{position:absolute;inset:0;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>")}
.hero-orb{position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);width:90vmin;height:90vmin;
  pointer-events:none;mix-blend-mode:screen;filter:blur(20px);
  background:radial-gradient(circle at 50% 50%,rgba(228,206,146,.4) 0%,rgba(212,182,106,.15) 30%,transparent 60%)}
.hero-sil{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);height:min(94vh,880px);width:auto;
  z-index:2;transition:transform .08s linear,opacity .35s var(--ease)}
.hero-sil img{height:100%;width:auto;object-fit:contain;display:block;animation:silhBreath 9s ease-in-out infinite}
@keyframes silhBreath{0%,100%{transform:scale(1)}50%{transform:scale(1.018)}}

.hero-h{position:absolute;inset:auto 0 auto 0;top:12%;pointer-events:none;z-index:4}
.hero-h h1{font-family:var(--serif);font-weight:300;font-size:clamp(56px,9vw,168px);line-height:.92;
  letter-spacing:-.025em;max-width:13ch;color:var(--ivory)}
.hero-h .w{display:inline-block;opacity:0;margin-right:.18em;font-weight:300}
.hero-h .w.tight{margin-right:0}
.hero-h .w.accent{font-style:italic;font-weight:400}
.hero-greet{position:absolute;inset:auto 0 auto 0;bottom:32%;pointer-events:none;z-index:4;opacity:0}
.hero-greet .script{font-size:clamp(36px,4vw,64px);line-height:1;color:var(--gold)}
.hero-sub{position:absolute;inset:auto 0 22% 0;z-index:4;max-width:60%;opacity:0}
.hero-sub p{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(18px,1.6vw,26px);
  line-height:1.4;color:var(--ivory);opacity:.85;max-width:46ch}
.hero-sub p .hl{color:var(--gold)}
.hero-cta{position:absolute;inset:auto 0 6% 0;z-index:4;opacity:0}
.hero-cta .kicker{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);opacity:.7;margin-bottom:14px}
.hero-cta .row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.hero-cta .note{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(14px,1.2vw,18px);color:var(--gold-soft);opacity:.75;max-width:34ch}
.hero-cta .btn-gold{padding:22px 32px;animation:ctaPulse 3s ease-in-out infinite;
  box-shadow:0 30px 80px -16px rgba(228,206,146,.55),inset 0 1px 0 rgba(255,255,255,.3)}
@keyframes ctaPulse{0%,100%{box-shadow:0 30px 80px -16px rgba(228,206,146,.55),inset 0 1px 0 rgba(255,255,255,.3);transform:translateY(0)}
  50%{box-shadow:0 40px 100px -16px rgba(228,206,146,.85),inset 0 1px 0 rgba(255,255,255,.4);transform:translateY(-2px)}}
.hero-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:9px;z-index:6;pointer-events:none}.hero-cue__label{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);text-shadow:0 2px 14px rgba(0,0,0,.5)}.hero-cue__chevs{position:relative;width:30px;height:40px;display:block}.hero-cue__chevs i{position:absolute;left:50%;width:20px;height:20px;border-right:3px solid var(--gold);border-bottom:3px solid var(--gold);opacity:0;animation:cueChev 1.6s ease-in-out infinite}.hero-cue__chevs i:nth-child(1){top:0;animation-delay:0s}.hero-cue__chevs i:nth-child(2){top:13px;animation-delay:.28s}@keyframes cueChev{0%{opacity:0;transform:translate(-50%,-6px) rotate(45deg)}50%{opacity:1}100%{opacity:0;transform:translate(-50%,9px) rotate(45deg)}}@media (max-width:680px){.hero-cue__label{font-size:11px}.hero-cue__chevs{width:26px;height:36px}.hero-cue__chevs i{width:17px;height:17px}}
/* hero text shadow while on dark */
.hero.is-dark .hero-h h1{text-shadow:0 6px 40px rgba(0,0,0,.4)}
.hero.is-dark .hero-h .w.accent{filter:drop-shadow(0 0 20px rgba(212,182,106,.5))}
.hero.is-dark .hero-greet .script{text-shadow:0 0 32px rgba(228,206,146,.45)}
.hero.is-light .hero-h h1{color:var(--ink)}
.hero.is-light .hero-greet .script{color:var(--accent)}
.hero.is-light .hero-sub p{color:var(--ink)}
.hero.is-light .hero-sub p .hl{color:var(--accent)}
.hero.is-light .hero-cta .kicker,.hero.is-light .hero-cta .note{color:var(--ink-soft)}
.hero.is-light .hero-h .w.accent{color:var(--accent)!important}

/* ============================================================  NUMBERS  */
.numbers{background:var(--ivory);padding:160px 0 180px;position:relative;overflow:hidden}
.numbers .decor{position:absolute;pointer-events:none}
.numbers .decor.a{top:60px;right:-80px;width:360px;opacity:.5;transform:rotate(20deg)}
.numbers .decor.b{bottom:40px;left:-60px;width:280px;opacity:.4;transform:rotate(-12deg)}
.numbers h2{text-align:center;font-size:clamp(56px,7vw,128px);max-width:18ch;margin:12px auto 100px;text-wrap:balance}
.numbers__grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.numbers__cell{padding:60px 32px;text-align:center}
.numbers__cell+.numbers__cell{border-left:1px solid var(--line)}
.numbers__big{font-family:var(--serif);font-weight:300;font-size:clamp(80px,9vw,168px);line-height:1;letter-spacing:-.02em;color:var(--ink);margin-bottom:16px}
.numbers__lbl{font-family:var(--mono);color:var(--accent);font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:4px}
.numbers__det{font-family:var(--serif);font-size:18px;font-style:italic;color:var(--ink-soft)}

/* ============================================================  CITIES  */
.cities{background:var(--navy-deep);color:var(--ivory);padding:160px 0 180px;position:relative;overflow:hidden}
.cities__glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 70% 50% at 30% 50%,rgba(212,182,106,.18) 0%,transparent 60%)}
.cities__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative}
.cities .eyebrow{color:var(--gold-soft)}.cities .eyebrow .dot{background:var(--gold)}
.cities h2{font-size:clamp(72px,9vw,160px);color:var(--ivory);margin:24px 0 40px;letter-spacing:-.02em}
.cities h2 .it{color:var(--gold)}
.cities__intro{font-family:var(--serif);font-style:italic;font-weight:300;font-size:24px;line-height:1.4;color:var(--gold-soft);max-width:38ch;margin-bottom:48px}
.cities__list{display:flex;flex-direction:column}
.city-row{display:grid;grid-template-columns:1fr auto;align-items:center;padding:32px 0;border-top:1px solid rgba(228,206,146,.2);
  text-align:left;cursor:pointer;transition:padding .5s var(--ease)}
.city-row:last-of-type{border-bottom:1px solid rgba(228,206,146,.2)}
.city-row .name{font-family:var(--serif);font-weight:300;font-size:clamp(40px,4.6vw,72px);line-height:1;letter-spacing:-.02em;color:var(--ivory);transition:all .5s var(--ease)}
.city-row .meta{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-top:8px;color:var(--gold-soft);opacity:.6}
.city-row .note{font-family:var(--serif);font-style:italic;font-size:12px;color:var(--gold-soft);opacity:.45;transform:translateX(-8px);transition:all .5s var(--ease)}
.city-row.active{padding-left:24px}
.city-row.active .name{font-style:italic;color:var(--gold)}
.city-row.active .note{opacity:1;transform:translateX(0)}
.city-row[data-citta-request]{cursor:pointer}
.city-row[data-citta-request]:hover .name{color:var(--gold)}
.city-row[data-citta-request]:hover .note{opacity:1;transform:translateX(0)}
.cities__more{margin-top:26px;font-family:var(--serif);font-style:italic;font-size:16px;color:var(--gold-soft)}
.cities__more-btn{background:none;border:0;color:var(--gold);font-family:inherit;font-style:italic;font-size:16px;cursor:pointer;padding:0 0 2px;border-bottom:1px solid var(--gold)}
.cities__more-btn:hover{color:var(--ivory);border-color:var(--ivory)}

/* ============================================================  METHOD  */
.method{background:var(--ivory);padding:160px 0;position:relative;overflow:hidden}
.method .leaf{position:absolute;top:40px;right:60px;width:200px;opacity:.5;transform:rotate(35deg);pointer-events:none}
.method__head{margin-bottom:80px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end}
.method__head h2{font-size:clamp(64px,8vw,144px);margin-top:24px;letter-spacing:-.02em}
.method__head .sub{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(20px,1.8vw,28px);line-height:1.4;color:var(--ink-soft);max-width:38ch}
.method__grid{display:grid;grid-template-columns:repeat(4,1fr)}
.mcard{padding:48px 32px;background:transparent;color:var(--ink);position:relative;min-height:440px;
  transition:all .5s var(--ease);display:flex;flex-direction:column;overflow:hidden}
.mcard+.mcard{border-left:1px solid var(--line)}
.mcard:hover{background:var(--ink);color:var(--ivory)}
.mcard__decor{position:absolute;right:-20px;top:-20px;width:120px;height:120px;opacity:.12;transition:all .8s var(--ease);pointer-events:none}
.mcard:hover .mcard__decor{opacity:.4;filter:brightness(2);transform:rotate(8deg) scale(1.1)}
.mcard__top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:60px}
.mcard__n{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--accent);transition:color .5s var(--ease)}
.mcard:hover .mcard__n{color:var(--gold-soft)}
.mcard__icon{width:36px;height:36px;transition:filter .5s var(--ease)}
.mcard:hover .mcard__icon{filter:invert(82%) sepia(35%) saturate(380%) hue-rotate(8deg)}
.mcard h3{font-family:var(--serif);font-weight:300;font-size:clamp(30px,2.7vw,46px);line-height:1.02;letter-spacing:-.015em;margin-bottom:20px;overflow-wrap:break-word;hyphens:auto}
.mcard p{font-size:15px;line-height:1.5;opacity:.7;max-width:30ch;flex:1;transition:opacity .5s var(--ease)}
.mcard:hover p{opacity:.85}

/* ============================================================  QUOTE SCENE  */
.qscene{background:var(--navy);color:var(--ivory);padding:180px 0;position:relative;overflow:hidden;text-align:center}
.qscene__sil{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);height:90%;width:auto;opacity:.10;
  filter:drop-shadow(0 0 40px rgba(212,182,106,.4));pointer-events:none}
.qscene .wrap{position:relative}
.qscene .script{font-size:clamp(40px,5vw,80px);color:var(--gold);margin-bottom:32px;line-height:1}
.qscene blockquote{font-family:var(--serif);font-weight:300;font-size:clamp(40px,5.2vw,88px);line-height:1.1;
  max-width:22ch;margin:0 auto;letter-spacing:-.015em;text-wrap:balance}
.qscene blockquote .it{color:var(--gold-soft)}
.qscene .by{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;margin-top:60px;color:var(--gold-soft);opacity:.7}

/* ============================================================  APP SHOWCASE  */
.app{background:var(--bg-2);overflow:hidden}
.app .grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.app h2{margin-top:24px;margin-bottom:28px}.app .lead{margin-bottom:36px}
.app ul{list-style:none;display:flex;flex-direction:column;gap:14px}
.app ul li{display:flex;align-items:center;gap:12px;font-size:15px}
.app ul li span{width:24px;height:1px;background:var(--accent)}
.app .stores{display:flex;gap:12px;margin-top:36px}
.app .store{display:inline-block;padding:12px 18px;border:1px solid var(--ink);border-radius:6px;font-size:12px;color:inherit;text-decoration:none;cursor:pointer;transition:background .25s var(--ease),color .25s var(--ease)}
.app .store:hover{background:var(--ink);color:var(--paper)}
.app .store:hover .mono{opacity:.7}
.app .store .mono{font-size:9px;opacity:.6}.app .store b{display:block;margin-top:4px;font-size:14px;font-weight:500}
.app__phones{position:relative;height:620px;perspective:1500px}
.app__phones::before{content:"";position:absolute;left:50%;top:50%;width:520px;height:520px;transform:translate(-50%,-50%);background:radial-gradient(closest-side,rgba(214,160,61,.25),rgba(214,160,61,0) 70%);filter:blur(20px);z-index:0;pointer-events:none}
.app__phone{position:absolute;will-change:transform;background:transparent;overflow:hidden;border-radius:42px;box-shadow:0 2px 6px rgba(14,42,74,.08),0 14px 32px -8px rgba(14,42,74,.28),0 38px 80px -16px rgba(14,42,74,.32);transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.app__phone--1{left:50%;top:50%;width:300px;height:600px;transform:translate(-60%,-50%) rotate(-5deg);z-index:2}
.app__phone--2{left:calc(50% + 110px);top:calc(50% - 130px);width:230px;height:460px;transform:rotate(7deg);z-index:1;border-radius:34px;box-shadow:0 2px 6px rgba(14,42,74,.06),0 12px 28px -8px rgba(14,42,74,.22),0 30px 60px -14px rgba(14,42,74,.25)}
.app__phone img{display:block;width:100%;height:100%;object-fit:cover;object-position:50% 50%}

/* ============================================================  TESTIMONIALS  */
.tst-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:80px}
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tst{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:32px;min-height:280px;
  display:flex;flex-direction:column;justify-content:space-between;transition:transform .6s var(--ease),background .6s var(--ease),color .6s var(--ease)}
.tst:hover{background:var(--ink);color:var(--paper);transform:translateY(-4px)}
.tst .mark{font-family:var(--serif);font-size:36px;line-height:1;margin-bottom:24px;opacity:.3}
.tst .text{font-family:var(--serif);font-size:22px;line-height:1.3;flex:1;text-wrap:pretty}
.tst .by{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-top:24px;display:flex;justify-content:space-between;opacity:.6}

/* ============================================================  FAQ  */
.faq{background:var(--paper)}
.faq .grid{display:grid;grid-template-columns:1fr 1.4fr;gap:80px}
.faq h2{margin-top:24px}
.faq__item{border-top:1px solid var(--line);padding:24px 0}
.faq__q{width:100%;display:flex;justify-content:space-between;align-items:center;text-align:left}
.faq__q .qt{font-family:var(--serif);font-size:24px;letter-spacing:-.01em}
.faq__q .pm{font-size:22px;transition:transform .4s var(--ease)}
.faq__item.open .faq__q .pm{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;opacity:0;padding-top:0;color:var(--ink-soft);font-size:16px;max-width:50ch;
  transition:max-height .6s var(--ease),opacity .4s var(--ease),padding .4s var(--ease)}
.faq__item.open .faq__a{max-height:200px;opacity:1;padding-top:12px}
.faq__end{border-top:1px solid var(--line)}

/* ============================================================  FINAL CTA  */
.final{background:var(--ivory);text-align:center;padding:200px 0}
.final .script{font-size:clamp(48px,5vw,80px);color:var(--accent);margin-bottom:12px}
.final h2{font-size:clamp(64px,9vw,168px);margin:0 auto 56px;max-width:14ch;text-wrap:balance}

/* ============================================================  FOOTER  */
.foot{background:var(--navy-deep);color:var(--ivory);padding:80px 0 40px}
.foot__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;margin-bottom:80px}
.foot__brand .wordmark .wm-1{color:var(--accent)}.foot__brand .wordmark .wm-2{color:var(--ivory)}
.foot__brand p{margin-top:32px;opacity:.6;max-width:32ch}
.foot__col .mono{opacity:.5;margin-bottom:20px}
.foot__col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot__col a{font-size:14px;opacity:.8}.foot__col a:hover{opacity:1}
.foot__big{font-family:var(--serif);font-size:clamp(80px,14vw,240px);line-height:.9;letter-spacing:-.03em;margin-bottom:60px;opacity:.9}
.foot__big .it{font-style:italic;color:var(--accent-soft)}
.foot__bar{display:flex;justify-content:space-between;font-family:var(--mono);opacity:.5;font-size:10px;flex-wrap:wrap;gap:10px}

/* ============================================================  RESPONSIVE  */
@media (max-width:1080px){
  .cities__grid,.method__head,.app .grid,.faq .grid{grid-template-columns:1fr;gap:40px}
  .foot__grid{grid-template-columns:1fr 1fr;gap:40px}
  .method__grid,.numbers__grid{grid-template-columns:1fr 1fr}
  .numbers__cell:nth-child(3),.mcard:nth-child(3){border-left:none}
  .numbers__cell:nth-child(n+3){border-top:1px solid var(--line)}
}
@media (max-width:860px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav-right .btn-gold.sm{display:none}
  .nav-ico--account{display:none}
  .tst-grid{grid-template-columns:1fr}
  .app__phones{height:420px}
  .hero-sub{max-width:90%}
}
@media (max-width:760px){
  .wrap{padding:0 20px}.section{padding:80px 0}
  .numbers__grid,.method__grid{grid-template-columns:1fr}
  .numbers__cell,.mcard{border-left:none!important;border-top:1px solid var(--line)}
  .mcard{min-height:auto}
  .foot__grid{grid-template-columns:1fr;gap:32px}.foot__bar{flex-direction:column}

  .nav-ico--account{display:none}

  /* HERO — keep the cinematic scroll animation, sized for phones */
  .hero-sil{height:auto;width:min(66vw,300px)}
  .hero-sil img{width:100%;height:auto}
  .hero-h{top:11%}
  .hero-h h1{font-size:clamp(36px,10.5vw,52px);max-width:14ch}
  .hero-greet{bottom:34%}
  .hero-greet .script{font-size:clamp(28px,8vw,44px)}
  .hero-sub{bottom:23%;max-width:none}
  .hero-sub p{font-size:clamp(15px,4.2vw,19px);max-width:none}
  .hero-cta{bottom:5%}
  .hero-cta .kicker{margin-bottom:10px}
  .hero-cta .row{flex-direction:column;align-items:flex-start;gap:10px}
  .hero-cta .btn-gold{white-space:normal;font-size:12px;padding:14px 20px;line-height:1.3}
  .hero-cta .note{font-size:12px;max-width:none}

  /* tame the oversized display headings on phones */
  .numbers{padding:88px 0}
  .numbers h2{font-size:clamp(40px,11vw,56px);margin:8px auto 44px}
  .numbers__big{font-size:clamp(64px,22vw,100px)}
  .cities{padding:88px 0}
  .cities h2{font-size:clamp(44px,13vw,66px)}
  .cities__intro{font-size:20px}
  .method{padding:88px 0}
  .method__head h2{font-size:clamp(40px,11vw,60px)}
  .qscene{padding:110px 0}
  .qscene blockquote{font-size:clamp(32px,8.5vw,54px)}
  .qscene .script,.final .script{font-size:clamp(34px,9vw,54px)}
  .final{padding:120px 0}
  .final h2{font-size:clamp(44px,12vw,74px)}

  /* app phones fit the screen */
  .app__phones{height:340px}
  .app__phone--1{width:185px;height:370px}
  .app__phone--2{width:135px;height:270px;left:calc(50% + 55px);top:calc(50% - 55px)}
}
