/* ============================================================
   Christiano Property Management — Owner acquisition site
   Design system + section styles
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500&family=Manrope:wght@300;400;500;600;700;800&display=swap');

:root{
  /* Brand palette */
  --navy-900:#0a1320;
  --navy-800:#0e1b2e;
  --navy-700:#13243b;
  --navy-600:#1b3252;
  --gold:#c9a24b;
  --gold-300:#dcc07f;
  --gold-600:#a9853a;
  --cream:#f4f1ea;
  --cream-200:#ece7db;
  --paper:#fbfaf6;
  --ink:#1a2330;
  --ink-soft:#46566b;
  --line:rgba(14,27,46,.12);
  --line-on-dark:rgba(255,255,255,.14);

  --accent:var(--gold);

  --maxw:1280px;
  --gutter:clamp(20px,5vw,72px);

  --serif:'Playfair Display',Georgia,serif;
  --sans:'Manrope',system-ui,-apple-system,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow-soft:0 24px 60px -28px rgba(10,19,32,.45);
  --shadow-card:0 30px 70px -34px rgba(10,19,32,.55);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--gold);color:var(--navy-900)}

/* ---------- Typography helpers ---------- */
.eyebrow{
  font-size:.74rem;font-weight:700;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-600);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--gold)}
.eyebrow.center{justify-content:center}
.eyebrow.on-dark{color:var(--gold-300)}

h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.05;letter-spacing:-.01em}
.display{
  font-family:var(--serif);font-weight:800;
  font-size:clamp(2.6rem,6.4vw,5.6rem);line-height:.98;letter-spacing:-.02em;
}
.section-title{font-size:clamp(2rem,4.4vw,3.4rem);line-height:1.04;letter-spacing:-.015em}
.lead{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--ink-soft);font-weight:400;max-width:54ch}
.italic-accent{font-style:italic;font-weight:500;color:var(--gold-600)}

.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
section{position:relative}
.pad{padding-block:clamp(80px,11vw,150px)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.65em;
  font-weight:700;font-size:.92rem;letter-spacing:.01em;
  padding:1.05em 1.7em;border-radius:2px;
  transition:transform .4s var(--ease),background .3s var(--ease),color .3s var(--ease),box-shadow .4s var(--ease);
  white-space:nowrap;
}
.btn .arr{transition:transform .4s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn-gold{background:var(--gold);color:var(--navy-900);box-shadow:0 14px 30px -14px rgba(201,162,75,.7)}
.btn-gold:hover{background:var(--gold-300);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--line-on-dark);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.4)}
.btn-dark{background:var(--navy-800);color:#fff}
.btn-dark:hover{background:var(--navy-700);transform:translateY(-2px)}
.btn-lg{padding:1.2em 2.1em;font-size:1rem}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:90;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:22px var(--gutter);
  transition:padding .45s var(--ease),background .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  padding:12px var(--gutter);
  background:rgba(10,19,32,.82);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line-on-dark);
  box-shadow:0 10px 40px -24px rgba(0,0,0,.8);
}
.nav__logo{height:46px;transition:height .45s var(--ease)}
.nav.scrolled .nav__logo{height:34px}
.nav__logo img{height:100%;width:auto}
.nav__links{display:flex;align-items:center;gap:34px}
.nav__links a{
  font-size:.86rem;font-weight:600;letter-spacing:.02em;color:rgba(255,255,255,.78);
  position:relative;padding:4px 0;transition:color .3s
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--gold);transition:width .35s var(--ease)
}
.nav__links a:hover{color:#fff}
.nav__links a:hover::after{width:100%}
.nav__cta{display:flex;align-items:center;gap:14px}
.nav__phone{font-size:.86rem;font-weight:600;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:.5em}
.nav__phone:hover{color:#fff}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__burger span{width:24px;height:2px;background:#fff;transition:.3s}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  color:#fff;overflow:hidden;background:var(--navy-900);
}
.hero__media{position:absolute;inset:-12% 0 -12% 0;z-index:0;will-change:transform}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 38%}
.hero__scrim{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(10,19,32,.62) 0%,rgba(10,19,32,.28) 32%,rgba(10,19,32,.4) 58%,rgba(10,19,32,.92) 100%),
    linear-gradient(90deg,rgba(10,19,32,.7) 0%,rgba(10,19,32,.1) 60%);
}
.hero__inner{position:relative;z-index:3;width:100%;padding-bottom:clamp(56px,8vw,96px);padding-top:160px}
.hero__loc{margin-bottom:26px}
.hero h1{max-width:16ch}
.hero h1 .line{display:block;overflow:hidden;padding-bottom:.18em;margin-bottom:-.18em}
.hero h1 .line>span{display:block;transform:translateY(130%);opacity:0;transition:transform 1.05s var(--ease),opacity 1.05s var(--ease)}
.hero.in h1 .line>span{transform:translateY(0);opacity:1}
.hero h1 .line:nth-child(1)>span{transition-delay:.15s}
.hero h1 .line:nth-child(2)>span{transition-delay:.28s}
.hero h1 .line:nth-child(3)>span{transition-delay:.41s}
.hero__sub{
  max-width:46ch;margin-top:26px;font-size:clamp(1.05rem,1.5vw,1.28rem);
  color:rgba(255,255,255,.82);font-weight:400;
  opacity:0;transform:translateY(24px);transition:all .9s var(--ease) .62s
}
.hero.in .hero__sub{opacity:1;transform:none}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px;opacity:0;transform:translateY(24px);transition:all .9s var(--ease) .76s}
.hero.in .hero__actions{opacity:1;transform:none}
.hero__scroll{
  position:absolute;left:var(--gutter);bottom:30px;z-index:3;
  display:flex;align-items:center;gap:12px;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.6);opacity:0;transition:opacity 1s ease 1.2s
}
.hero.in .hero__scroll{opacity:1}
.hero__scroll .mouse{width:22px;height:34px;border:1px solid rgba(255,255,255,.4);border-radius:12px;position:relative}
.hero__scroll .mouse::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:2px;background:var(--gold);transform:translateX(-50%);animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}

/* Hero variant B — split editorial */
.hero[data-variant="split"]{align-items:stretch}
.hero[data-variant="split"] .hero__media{inset:-12% 0 -12% 42%}
.hero[data-variant="split"] .hero__scrim{
  background:linear-gradient(90deg,var(--navy-900) 30%,rgba(10,19,32,.55) 52%,rgba(10,19,32,.15) 100%);
}
.hero[data-variant="split"] .hero__inner{display:flex;align-items:flex-end}
.hero[data-variant="split"] .hero__col{max-width:680px}
.hero__panel{
  display:none;position:relative;z-index:3;align-self:flex-end;margin-left:auto;margin-bottom:clamp(56px,8vw,96px);
  background:rgba(255,255,255,.07);border:1px solid var(--line-on-dark);backdrop-filter:blur(8px);
  padding:26px 28px;width:min(280px,32vw);border-radius:3px;
}
.hero[data-variant="split"] .hero__panel{display:block}
.hero__panel .pk{font-size:2.4rem;font-family:var(--serif);font-weight:700;color:var(--gold-300);line-height:1}
.hero__panel .pl{font-size:.82rem;color:rgba(255,255,255,.72);margin-top:4px}
.hero__panel hr{border:none;border-top:1px solid var(--line-on-dark);margin:18px 0}

/* ============================================================
   STATS BAR
   ============================================================ */
.stats{background:var(--navy-800);color:#fff;position:relative;z-index:5}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{
  padding:clamp(34px,4vw,54px) clamp(20px,3vw,44px);
  border-right:1px solid var(--line-on-dark);position:relative;
}
.stat:last-child{border-right:none}
.stat__num{font-family:var(--serif);font-weight:700;font-size:clamp(2.6rem,4.6vw,4rem);line-height:1;letter-spacing:-.02em;display:flex;align-items:baseline;gap:.06em}
.stat__num .suf{color:var(--gold);font-size:.5em;font-weight:700}
.stat__label{margin-top:12px;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.62);font-weight:600}

/* ============================================================
   WHY CPM — pillars
   ============================================================ */
.why{background:var(--paper)}
.why__head{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:end;margin-bottom:64px}
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line)}
.pillar{
  padding:40px 32px 44px;border-right:1px solid var(--line);position:relative;
  transition:background .5s var(--ease);
}
.pillar:last-child{border-right:none}
.pillar:hover{background:#fff}
.pillar__no{font-family:var(--serif);font-size:.95rem;color:var(--gold-600);font-style:italic}
.pillar__icon{width:46px;height:46px;margin:22px 0 26px;color:var(--gold-600)}
.pillar__icon svg{width:100%;height:100%}
.pillar h3{font-size:1.4rem;margin-bottom:12px}
.pillar p{font-size:.96rem;color:var(--ink-soft)}
.pillar::after{content:"";position:absolute;left:0;bottom:-1px;height:2px;width:0;background:var(--gold);transition:width .5s var(--ease)}
.pillar:hover::after{width:100%}

/* ============================================================
   SERVICES
   ============================================================ */
.services{background:var(--navy-900);color:#fff;overflow:hidden}
.services__head{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:end;margin-bottom:60px}
.services__head .lead{color:rgba(255,255,255,.72)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-on-dark);border:1px solid var(--line-on-dark)}
.svc{
  background:var(--navy-800);padding:38px 34px 42px;
  transition:background .45s var(--ease),transform .45s var(--ease);position:relative
}
.svc:hover{background:var(--navy-700)}
.svc__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}
.svc__icon{width:40px;height:40px;color:var(--gold-300)}
.svc__idx{font-size:.78rem;letter-spacing:.2em;color:rgba(255,255,255,.4)}
.svc h3{font-size:1.32rem;margin-bottom:12px}
.svc p{font-size:.94rem;color:rgba(255,255,255,.66)}
.svc ul{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:9px}
.svc li{font-size:.86rem;color:rgba(255,255,255,.8);display:flex;gap:10px;align-items:flex-start}
.svc li svg{width:15px;height:15px;color:var(--gold);flex:none;margin-top:4px}

/* ============================================================
   PROCESS — 4 steps
   ============================================================ */
.process{background:var(--cream)}
.process__head{text-align:center;max-width:60ch;margin:0 auto 70px}
.process__head .lead{margin-inline:auto}
.steps{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.steps::before{content:"";position:absolute;left:0;right:0;top:39px;height:1px;background:var(--line);z-index:0}
.step{position:relative;z-index:1}
.step__dot{
  width:78px;height:78px;border-radius:50%;background:var(--paper);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:1.7rem;font-weight:700;color:var(--navy-800);
  margin-bottom:26px;transition:all .5s var(--ease)
}
.step.reveal-in .step__dot{background:var(--navy-800);color:var(--gold-300);border-color:var(--navy-800)}
.step h3{font-size:1.22rem;margin-bottom:10px}
.step p{font-size:.92rem;color:var(--ink-soft)}
.step__time{margin-top:14px;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-600);font-weight:700}

/* ============================================================
   CALCULATOR
   ============================================================ */
.calc{background:var(--navy-800);color:#fff;position:relative;overflow:hidden}
.calc__bg{position:absolute;inset:0;z-index:0;opacity:.16;will-change:transform}
.calc__bg img{width:100%;height:120%;object-fit:cover;object-position:center}
.calc__wrap{position:relative;z-index:2;display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(36px,5vw,84px);align-items:center}
.calc__head .lead{color:rgba(255,255,255,.72)}
.calc__controls{margin-top:34px;display:flex;flex-direction:column;gap:26px}
.field label{display:block;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6);font-weight:700;margin-bottom:12px}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{
  padding:.62em 1.05em;border:1px solid var(--line-on-dark);border-radius:2px;
  font-size:.85rem;font-weight:600;color:rgba(255,255,255,.82);transition:all .3s var(--ease)
}
.chip:hover{border-color:rgba(255,255,255,.4)}
.chip.active{background:var(--gold);color:var(--navy-900);border-color:var(--gold)}
.range-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.range-row .val{font-family:var(--serif);font-size:1.3rem;color:var(--gold-300);font-weight:700}
input[type=range]{
  -webkit-appearance:none;appearance:none;width:100%;height:3px;border-radius:3px;
  background:linear-gradient(90deg,var(--gold) var(--p,60%),rgba(255,255,255,.18) var(--p,60%));outline:none
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;border:4px solid var(--gold);cursor:pointer;
  box-shadow:0 4px 12px rgba(0,0,0,.4);transition:transform .2s
}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}
input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#fff;border:4px solid var(--gold);cursor:pointer}

.calc__result{
  background:linear-gradient(165deg,var(--navy-700),var(--navy-900));
  border:1px solid var(--line-on-dark);border-radius:4px;padding:clamp(32px,3.4vw,48px);
  box-shadow:var(--shadow-card);position:relative;overflow:hidden
}
.calc__result::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-300))}
.calc__result .rlabel{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:700}
.calc__big{font-family:var(--serif);font-weight:800;font-size:clamp(3rem,6vw,4.6rem);line-height:1;letter-spacing:-.02em;margin:10px 0 4px;color:#fff}
.calc__big .cur{color:var(--gold);font-size:.55em;vertical-align:top;margin-right:.08em}
.calc__per{color:rgba(255,255,255,.6);font-size:.95rem}
.calc__break{margin-top:30px;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line-on-dark)}
.calc__break .row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--line-on-dark);font-size:.95rem}
.calc__break .row span:first-child{color:rgba(255,255,255,.66)}
.calc__break .row span:last-child{font-weight:700}
.calc__break .row.net span:last-child{color:var(--gold-300);font-family:var(--serif);font-size:1.15rem}
.calc__note{margin-top:18px;font-size:.78rem;color:rgba(255,255,255,.45);line-height:1.5}

/* ============================================================
   PLATFORMS
   ============================================================ */
.plat{background:var(--paper)}
.plat__head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:48px}
.plat__reach{display:grid;grid-template-columns:auto 1fr;gap:clamp(24px,4vw,56px);align-items:center;padding:clamp(30px,4vw,48px);background:var(--navy-900);border-radius:8px;color:#fff;margin-bottom:24px}
.plat__reach-fig{font-family:var(--serif);font-weight:800;font-size:clamp(3.4rem,7.5vw,5.8rem);line-height:.85;color:var(--gold-300);white-space:nowrap}
.plat__reach-fig .suf{font-size:.42em;vertical-align:baseline;margin-left:.04em}
.plat__reach-copy{font-size:clamp(1.02rem,1.5vw,1.26rem);line-height:1.55;color:rgba(255,255,255,.68);max-width:54ch}
.plat__reach-copy strong{color:#fff;font-weight:700}
.plat__channels{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.chan{background:var(--paper);padding:32px 28px 36px;position:relative;transition:background .3s var(--ease)}
.chan::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--chan);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.chan:hover{background:var(--cream)}
.chan:hover::before{transform:scaleX(1)}
.chan__head{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:1.22rem;font-weight:600;color:var(--ink)}
.chan__head .chan__dot{width:10px;height:10px;border-radius:50%;background:var(--chan);flex:none}
.chan__fig{font-family:var(--serif);font-weight:800;font-size:clamp(2.3rem,3.4vw,3rem);line-height:1;margin:18px 0 14px;color:var(--navy-800)}
.chan__role{font-size:.92rem;line-height:1.55;color:var(--ink-soft)}

/* ============================================================
   TESTIMONIAL (gold)
   ============================================================ */
.quote{background:var(--gold);color:var(--navy-900);position:relative;overflow:hidden}
.quote__mark{position:absolute;font-family:var(--serif);font-size:30rem;line-height:1;color:rgba(10,19,32,.07);top:-6rem;left:2vw;pointer-events:none}
.quote__inner{position:relative;z-index:2;max-width:60ch;text-align:center;margin-inline:auto}
.quote blockquote{font-family:var(--serif);font-weight:500;font-size:clamp(1.6rem,3.4vw,2.9rem);line-height:1.22;letter-spacing:-.01em}
.quote__cite{margin-top:34px;display:flex;align-items:center;gap:16px;justify-content:center}
.quote__cite .av{width:54px;height:54px;border-radius:50%;background:var(--navy-800);color:var(--gold-300);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;font-size:1.2rem}
.quote__cite .meta{text-align:left}
.quote__cite .nm{font-weight:800;font-size:1rem}
.quote__cite .rl{font-size:.85rem;color:rgba(10,19,32,.66)}
.quote__stars{display:flex;gap:4px;justify-content:center;margin-bottom:22px;color:var(--navy-800)}
.quote__stars svg{width:20px;height:20px}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{background:var(--navy-900);color:#fff;overflow:hidden}
.contact__wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,6vw,96px)}
.contact__aside .lead{color:rgba(255,255,255,.74)}
.contact__points{margin-top:38px;display:flex;flex-direction:column;gap:22px}
.cpoint{display:flex;gap:16px;align-items:flex-start}
.cpoint__ic{width:42px;height:42px;flex:none;border:1px solid var(--line-on-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-300)}
.cpoint__ic svg{width:18px;height:18px}
.cpoint b{display:block;font-size:.98rem;margin-bottom:2px}
.cpoint span{font-size:.9rem;color:rgba(255,255,255,.6)}
.cpoint a{color:rgba(255,255,255,.78)}
.cpoint a:hover{color:var(--gold-300)}

.form{
  background:var(--paper);color:var(--ink);border-radius:5px;padding:clamp(30px,3.6vw,48px);
  box-shadow:var(--shadow-card);position:relative;overflow:hidden
}
.form__title{font-family:var(--serif);font-size:1.7rem;margin-bottom:6px}
.form__sub{font-size:.92rem;color:var(--ink-soft);margin-bottom:28px}
.form__grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form__full{grid-column:1/-1}
.flabel{display:block;font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--ink-soft);margin-bottom:8px}
.input,.select,.textarea{
  width:100%;padding:.9em 1em;border:1px solid var(--line);border-radius:3px;background:#fff;
  font-family:inherit;font-size:.95rem;color:var(--ink);transition:border-color .3s,box-shadow .3s
}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.18)}
.textarea{resize:vertical;min-height:96px}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2346566b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1em center;padding-right:2.4em}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg input{position:absolute;opacity:0;pointer-events:none}
.seg label{
  flex:1;min-width:110px;text-align:center;padding:.85em .6em;border:1px solid var(--line);border-radius:3px;
  font-size:.9rem;font-weight:600;cursor:pointer;transition:all .25s var(--ease);background:#fff
}
.seg label small{display:block;font-weight:500;color:var(--ink-soft);font-size:.76rem;margin-top:2px}
.seg input:checked+label{border-color:var(--navy-800);background:var(--navy-800);color:#fff}
.seg input:checked+label small{color:var(--gold-300)}
.seg input:focus-visible+label{box-shadow:0 0 0 3px rgba(201,162,75,.3)}
.form__submit{margin-top:6px}
.form .btn-gold{width:100%;justify-content:center}
.form__legal{font-size:.78rem;color:var(--ink-soft);margin-top:14px;text-align:center}

/* success state */
.form__success{
  position:absolute;inset:0;background:var(--paper);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:40px;opacity:0;visibility:hidden;transform:scale(.98);transition:all .5s var(--ease);z-index:5
}
.form__success.show{opacity:1;visibility:visible;transform:none}
.form__success .tick{width:78px;height:78px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;margin-bottom:24px;animation:pop .6s var(--ease)}
.form__success .tick svg{width:36px;height:36px;color:var(--navy-900)}
@keyframes pop{0%{transform:scale(0)}60%{transform:scale(1.12)}100%{transform:scale(1)}}
.form__success h3{font-family:var(--serif);font-size:1.9rem;margin-bottom:10px}
.form__success p{color:var(--ink-soft);max-width:38ch;margin-bottom:24px}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--navy-900);color:rgba(255,255,255,.7);border-top:1px solid var(--line-on-dark)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-block:clamp(56px,7vw,80px)}
.footer__logo{height:54px;width:auto;margin-bottom:22px}
.footer__brand p{font-size:.92rem;max-width:34ch;color:rgba(255,255,255,.6)}
.footer__col h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-300);margin-bottom:18px;font-weight:700}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer__col a,.footer__col li{font-size:.92rem;color:rgba(255,255,255,.66)}
.footer__col a:hover{color:#fff}
.footer__bottom{
  display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
  padding-block:24px;border-top:1px solid var(--line-on-dark);font-size:.8rem;color:rgba(255,255,255,.45)
}
.footer__reg{display:flex;flex-wrap:wrap;gap:6px 22px}

/* ============================================================
   Reveal animations
   ============================================================ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.reveal-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero h1 .line>span,.hero__sub,.hero__actions{opacity:1!important;transform:none!important}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .why__head,.services__head{grid-template-columns:1fr}
  .pillars{grid-template-columns:repeat(2,1fr)}
  .pillar:nth-child(2){border-right:none}
  .pillar{border-bottom:1px solid var(--line)}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .plat__channels{grid-template-columns:repeat(2,1fr)}
  .plat__reach{grid-template-columns:1fr;text-align:center}
  .plat__reach-copy{margin-inline:auto}
  .calc__wrap{grid-template-columns:1fr}
  .contact__wrap{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav__links,.nav__phone{display:none}
  .nav__burger{display:flex}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat{border-bottom:1px solid var(--line-on-dark)}
  .pillars,.steps,.svc-grid{grid-template-columns:1fr}
  .pillar,.svc{border-right:none}
  .steps::before{display:none}
  .plat__head,.footer__top{grid-template-columns:1fr}
  .form__grid{grid-template-columns:1fr}
  .hero[data-variant="split"] .hero__media{inset:-12% 0 -12% 0}
  .hero[data-variant="split"] .hero__panel{display:none}
  .hero[data-variant="split"] .hero__scrim{background:linear-gradient(180deg,rgba(10,19,32,.5),rgba(10,19,32,.92))}
}
@media (max-width:520px){
  .stats__grid{grid-template-columns:1fr}
  .stat{border-right:none}
  .plat__channels{grid-template-columns:1fr}
}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:95;background:var(--navy-900);
  display:flex;flex-direction:column;justify-content:center;gap:28px;padding:0 var(--gutter);
  transform:translateY(-100%);transition:transform .5s var(--ease);
}
.mobile-menu.open{transform:none}
.mobile-menu a{font-family:var(--serif);font-size:2rem;color:#fff}
.mobile-menu a:hover{color:var(--gold-300)}
.mobile-menu .close{position:absolute;top:24px;right:var(--gutter);color:#fff;font-size:2rem}
