/* ============================================================
   Quboolia — The Future Marriage Universe
   Design system: luxury Islamic-modern (emerald · gold · cream)
   ============================================================ */
:root{
  --emerald-900:#0d241e;
  --emerald-800:#123329;
  --emerald-700:#194037;
  --emerald-600:#245247;
  --emerald-500:#316d5e;
  --gold-600:#bd9527;
  --gold-500:#d4af37;
  --gold-400:#e7c869;
  --rose:#c77d7d;
  --cream:#faf6ef;
  --cream-2:#f3ecdf;
  --ink:#10231d;
  --ink-soft:#3c4a44;
  --line:rgba(0,63,53,.15);
  --white:#ffffff;

  --shadow-sm:0 2px 10px rgba(0,42,35,.07);
  --shadow:0 14px 40px rgba(0,42,35,.13);
  --shadow-lg:0 30px 80px rgba(0,42,35,.22);
  --radius:18px;
  --radius-lg:26px;
  --maxw:min(1800px,90vw);
  --serif:"Bodoni Moda","Didot","Bodoni 72",Georgia,serif;
  --sans:"Montserrat",system-ui,-apple-system,sans-serif;
  --arabic:"Amiri","Scheherazade New",serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
em{font-style:normal;color:var(--gold-600)}
img{max-width:100%;display:block}
section{position:relative}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--sans);font-weight:700;font-size:.95rem;
  border:none;border-radius:999px;padding:.8rem 1.5rem;cursor:pointer;
  display:inline-flex;align-items:center;gap:.5rem;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(.99)}
/* gold buttons: stroke by default → fill with gold on hover (site-wide) */
.btn--gold{background:transparent;color:#9c7a1f;border:2px solid var(--gold-500);box-shadow:none}
.btn--gold:hover,.btn--gold:focus-visible{background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:#1a1206;border-color:transparent;transform:translateY(-2px);box-shadow:0 12px 30px rgba(184,134,47,.42)}
/* brighter gold stroke when sitting on dark sections */
.hero .btn--gold:not(:hover),.film .btn--gold:not(:hover),.finale .btn--gold:not(:hover),.diff .btn--gold:not(:hover),.appdl .btn--gold:not(:hover),.cta .btn--gold:not(:hover),.news__inner .btn--gold:not(:hover),.auth__aside .btn--gold:not(:hover),.pagehead .btn--gold:not(:hover){color:var(--gold-400);border-color:var(--gold-400)}
.btn--ghost{background:rgba(255,255,255,.7);color:var(--emerald-800);border:1px solid var(--line)}
.btn--ghost:hover{background:#fff;transform:translateY(-2px)}
/* outline: stroke by default, fills on hover */
.btn--outline{background:transparent;color:var(--emerald-700);border:1.5px solid var(--emerald-700)}
.btn--outline:hover{background:var(--emerald-700);color:#fff;border-color:var(--emerald-700);transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,63,53,.22)}
.btn--outline .ic{transition:color .18s ease}
/* gold outline for use over light sections where gold reads better */
.btn--outline-gold{background:transparent;color:var(--gold-700,#9c7a1f);border:1.5px solid var(--gold-500)}
.btn--outline-gold:hover{background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:#1a1206;border-color:transparent;transform:translateY(-2px);box-shadow:0 12px 30px rgba(184,134,47,.4)}
/* light outline for dark backgrounds */
.btn--outline-light{background:transparent;color:var(--cream,#faf6ef);border:1.5px solid rgba(231,200,105,.6)}
.btn--outline-light:hover{background:var(--cream,#faf6ef);color:var(--emerald-800);border-color:transparent;transform:translateY(-2px)}
.btn--lg{padding:1rem 1.9rem;font-size:1.02rem}
.btn--sm{padding:.45rem .9rem;font-size:.82rem}
.btn--block{width:100%;justify-content:center}

/* ---------- Eyebrow / heads ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:var(--emerald-700);background:rgba(14,94,78,.08);
  padding:.4rem .85rem;border-radius:999px;margin-bottom:1.1rem;
}
.eyebrow.center{margin-left:auto;margin-right:auto}
.eyebrow.light{color:var(--gold-400);background:rgba(224,192,116,.12)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--gold-500);box-shadow:0 0 0 4px rgba(201,162,75,.25)}
.section-head{max-width:760px;margin:0 auto 3rem;text-align:center;padding:0 1.2rem}
.section-title{font-family:var(--serif);font-weight:700;font-size:clamp(2rem,4.4vw,3.2rem);line-height:1.2;letter-spacing:.005em;word-spacing:.04em}
.section-title.light{color:var(--cream)}
.section-sub{margin-top:1.1rem;font-size:1.08rem;line-height:1.75;color:var(--ink-soft)}
.section-sub.light{color:rgba(250,246,239,.78)}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:.3s}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;padding:.8rem 1.2rem;
  display:flex;align-items:center;gap:1.5rem;
}
.nav.scrolled{background:rgba(250,246,239,.92);backdrop-filter:blur(16px);box-shadow:var(--shadow-sm);border-bottom:1px solid var(--line)}
/* Bismillah blessing strip */
.bismillah{display:flex;align-items:center;justify-content:center;gap:1.1rem;
  background:var(--emerald-900);border-bottom:1px solid rgba(181,147,76,.22);
  padding:.5rem 1rem;overflow:hidden;transition:max-height .4s ease,padding .4s ease,opacity .3s ease;max-height:60px}
.bismillah__ar{font-family:var(--arabic);font-weight:400;color:var(--gold-400);font-size:1.18rem;line-height:1;direction:rtl;letter-spacing:.01em}
.bismillah__orn{color:var(--gold-500);font-size:.7rem;opacity:.75}
.nav.scrolled .bismillah{max-height:0;padding:0;opacity:0;border:none}
.brand{display:flex;align-items:center;gap:.55rem;font-weight:800;font-size:1.3rem;letter-spacing:-.02em}
.brand__mark{font-size:1.5rem;color:var(--gold-500)}
.brand__name span{color:var(--gold-600)}
/* logo wordmark in nav (light over hero, dark when scrolled) */
.brand--logo{gap:0}
.brand__img{height:32px;width:124px;display:block;object-fit:contain;object-position:left center;flex:0 0 auto}
.brand__img--dark{display:none}
.nav.scrolled .brand__img--light{display:none}
.nav.scrolled .brand__img--dark{display:block}
/* language dropdown */
.nav__lang{position:relative}
.lang__btn{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--sans);font-weight:700;font-size:.82rem;
  color:var(--cream);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);padding:.42rem .7rem;border-radius:999px;cursor:pointer;transition:.18s}
.lang__btn .ic{width:15px;height:15px}
.lang__btn:hover{background:rgba(255,255,255,.2)}
.nav.scrolled .lang__btn,body.app-page .lang__btn{color:var(--emerald-800);background:rgba(0,63,53,.06);border-color:var(--line)}
.nav.scrolled .lang__btn:hover,body.app-page .lang__btn:hover{background:rgba(0,63,53,.1)}
.lang__menu{position:absolute;right:0;top:135%;background:#fff;border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow-lg);
  padding:.35rem;min-width:140px;display:none;flex-direction:column;gap:.1rem;z-index:70}
.lang__menu.open{display:flex;animation:rise .2s ease}
.lang__menu a{font-size:.9rem;font-weight:600;color:var(--ink);padding:.55rem .75rem;border-radius:9px;text-decoration:none}
.lang__menu a:hover{background:rgba(0,63,53,.06);color:var(--emerald-700)}
.lang__menu a.on{background:rgba(0,63,53,.07);color:var(--emerald-700)}
.lang__menu a[lang]{font-family:var(--arabic);font-size:1.05rem}
.i18n-rtl{font-family:var(--arabic);direction:rtl}
@media(max-width:980px){.nav__lang{display:none}}
.footer__logo{display:inline-block;margin-bottom:.5rem}
.footer__logo img{height:46px;width:auto;display:block}
.footer__tagline{font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-400);margin-bottom:1.1rem}
.footer__tagline span{font-family:var(--arabic);font-size:1rem;letter-spacing:0;text-transform:none;margin-left:.5rem;opacity:.9}
.nav__links{display:flex;gap:1.4rem;margin-left:1rem;font-weight:600;font-size:.92rem}
.nav__links a{color:rgba(250,246,239,.9);transition:.2s;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.nav__links a:hover{color:var(--gold-400)}
.nav.scrolled .nav__links a{color:var(--ink-soft);text-shadow:none}
.nav.scrolled .nav__links a:hover{color:var(--emerald-700)}
.nav__cta{margin-left:auto;display:flex;gap:.6rem}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav__burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ---------- HERO ---------- */
.hero{position:relative;padding:9.5rem 1.2rem 0;overflow:hidden;
  background:radial-gradient(120% 90% at 80% -10%,var(--emerald-700) 0%,var(--emerald-800) 38%,var(--emerald-900) 100%)}
.hero__pattern{position:absolute;inset:0;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23c9a24b' stroke-opacity='0.10' stroke-width='1'%3E%3Cpath d='M30 0l30 30-30 30L0 30z'/%3E%3Cpath d='M30 12l18 18-18 18-18-18z'/%3E%3Ccircle cx='30' cy='30' r='6'/%3E%3C/g%3E%3C/svg%3E")}
.hero__glow{position:absolute;top:-20%;right:-10%;width:60vw;height:60vw;background:radial-gradient(circle,rgba(201,162,75,.22),transparent 60%);pointer-events:none}
.hero__inner{position:relative;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;padding-bottom:4rem}
.hero__copy .eyebrow{color:var(--gold-400);background:rgba(224,192,116,.12)}
.hero__title{font-family:var(--serif);color:var(--cream);font-size:clamp(2.6rem,5.6vw,4.6rem);line-height:1.12;font-weight:700;letter-spacing:.005em;word-spacing:.04em}
.hero__title em{color:var(--gold-400)}
.hero__sub{color:rgba(250,246,239,.82);font-size:1.12rem;max-width:36rem;margin:1.5rem 0 2rem}
.hero__sub strong{color:var(--cream)}
.hero__actions{display:flex;gap:.9rem;flex-wrap:wrap}
.hero__trust{display:flex;align-items:center;gap:.9rem;margin-top:2.3rem;max-width:34rem}
.hero__trust p{color:rgba(250,246,239,.72);font-size:.9rem}
.hero__trust strong{color:var(--gold-400)}
.avatars{display:flex;align-items:center}
.avatars span{width:40px;height:40px;border-radius:50%;background-size:cover;background-position:center top;border:2.5px solid var(--cream);margin-left:-12px;box-shadow:0 3px 10px rgba(0,0,0,.3);transition:transform .25s ease}
.avatars span:first-child{margin-left:0}
.avatars:hover span{transform:translateY(-2px)}
.avatars__more{display:grid;place-items:center;min-width:40px;height:40px;border-radius:999px;margin-left:-12px;padding:0 .55rem;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:#1a1206;font-family:var(--sans);font-size:.74rem;font-weight:800;
  border:2.5px solid var(--cream);box-shadow:0 3px 10px rgba(0,0,0,.3)}

/* hero card / passport */
.hero__card{position:relative}
.passport{background:linear-gradient(160deg,rgba(255,255,255,.97),rgba(243,236,223,.95));border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-lg);border:1px solid rgba(201,162,75,.4);position:relative;overflow:hidden}
.passport::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='40' height='40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 0l20 20-20 20L0 20z' fill='none' stroke='%230e5e4e' stroke-opacity='0.05'/%3E%3C/svg%3E");pointer-events:none}
.passport__top{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;color:var(--emerald-700);position:relative}
.passport__crest{font-size:1.1rem;color:var(--gold-600)}
.passport__label{letter-spacing:.04em;text-transform:uppercase}
.passport__verified{margin-left:auto;background:var(--emerald-700);color:#fff;padding:.2rem .6rem;border-radius:999px;font-size:.72rem}
.passport__id{display:flex;gap:1rem;align-items:center;margin:1.1rem 0;position:relative}
.passport__photo{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--emerald-600),var(--emerald-800));color:#fff;display:grid;place-items:center;font-size:1.8rem;font-family:var(--serif);font-weight:700}
.passport__photo--img{background:none;overflow:hidden;border:2px solid var(--gold-500)}
.passport__photo--img img{width:100%;height:100%;object-fit:cover}
.passport__id h3{font-family:var(--serif);font-size:1.5rem}
.passport__id p{font-size:.86rem;color:var(--ink-soft)}
.passport__deen{color:var(--emerald-700)!important;font-weight:600}
.passport__score{display:flex;align-items:center;gap:1rem;padding:1rem;background:rgba(14,94,78,.05);border-radius:14px;position:relative}
.passport__scorelabel{font-weight:700;font-size:.9rem}
.passport__scoredesc{font-size:.78rem;color:var(--ink-soft)}
.passport__checks{list-style:none;display:grid;grid-template-columns:1fr 1fr 1fr;gap:.4rem;margin-top:1rem;position:relative}
.passport__checks li{font-size:.74rem;font-weight:600;color:var(--emerald-700);background:rgba(14,94,78,.07);padding:.35rem .5rem;border-radius:8px}
.ring{--p:0;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;
  background:conic-gradient(var(--gold-500) calc(var(--p)*1%),rgba(14,94,78,.12) 0);position:relative}
.ring::after{content:"";position:absolute;inset:6px;border-radius:50%;background:var(--cream);z-index:1}
.ring span{position:relative;z-index:2;font-weight:800;color:var(--emerald-800);font-size:1.05rem}
.ring--sm{width:46px;height:46px}.ring--sm span{font-size:.85rem}
.hero__floaty{position:absolute;background:rgba(255,255,255,.96);padding:.6rem .9rem;border-radius:12px;font-size:.82rem;font-weight:700;box-shadow:var(--shadow);color:var(--emerald-800)}
.hero__floaty--1{top:8%;left:-8%;animation:float 5s ease-in-out infinite}
.hero__floaty--2{bottom:10%;right:-6%;animation:float 5s ease-in-out infinite .8s}
@keyframes float{50%{transform:translateY(-12px)}}

/* marquee */
.hero__marquee{position:relative;overflow:hidden;border-top:1px solid rgba(201,162,75,.2);border-bottom:1px solid rgba(201,162,75,.2);padding:.9rem 0;background:rgba(0,0,0,.2)}
.marquee__track{display:flex;gap:1.6rem;white-space:nowrap;width:max-content;animation:marquee 28s linear infinite;color:rgba(224,192,116,.85);font-weight:600;font-size:.92rem;letter-spacing:.02em}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- WHY DIFFERENT BAND (replaces generic stats) ---------- */
.diff{position:relative;background:radial-gradient(120% 140% at 0 0,var(--emerald-800),var(--emerald-900));overflow:hidden;padding:4.5rem 1.2rem}
.diff__pattern{position:absolute;inset:0;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg width='52' height='52' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M26 0l26 26-26 26L0 26z' fill='none' stroke='%23c49a3a' stroke-opacity='0.08'/%3E%3C/svg%3E")}
.diff__inner{position:relative;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:.95fr 1.25fr;gap:3rem;align-items:center}
.diff__lead{color:var(--cream)}
.diff__lead h2{font-family:var(--serif);font-size:clamp(1.9rem,3.4vw,2.9rem);line-height:1.12;margin:.6rem 0 1rem}
.diff__lead h2 em{color:var(--gold-400)}
.diff__lead p{color:rgba(250,246,239,.82);line-height:1.7;margin-bottom:1.6rem;max-width:34rem}
.diff__grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.diffcard{background:rgba(255,255,255,.05);border:1px solid rgba(231,200,105,.2);border-radius:var(--radius);padding:1.4rem;
  color:var(--cream);transition:transform .3s cubic-bezier(.2,.8,.2,1),border-color .3s,background .3s}
.diffcard:hover{transform:translateY(-5px);border-color:rgba(231,200,105,.5);background:rgba(255,255,255,.08)}
.diffcard__ic{display:grid;place-items:center;width:46px;height:46px;border-radius:13px;margin-bottom:.9rem;
  background:linear-gradient(135deg,rgba(212,175,55,.25),rgba(212,175,55,.08));color:var(--gold-400)}
.diffcard__ic .ic{width:24px;height:24px}
.diffcard b{display:block;font-family:var(--serif);font-size:1.18rem;color:var(--cream);margin-bottom:.35rem}
.diffcard span{font-size:.86rem;color:rgba(250,246,239,.72);line-height:1.55}
@media(max-width:880px){.diff__inner{grid-template-columns:1fr;gap:2rem}}
@media(max-width:560px){.diff__grid{grid-template-columns:1fr}}

/* ---------- FEATURES ---------- */
.features{padding:5.5rem 1.2rem}
.features__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.fcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm);transition:.25s;position:relative;overflow:hidden}
.fcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.fcard__num{position:absolute;top:1.1rem;right:1.3rem;font-family:var(--serif);font-size:2.4rem;color:rgba(201,162,75,.25);font-weight:700}
.fcard__icon{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:1.5rem;background:linear-gradient(135deg,rgba(14,94,78,.1),rgba(201,162,75,.16));margin-bottom:1rem}
.fcard h3{font-family:var(--serif);font-size:1.5rem;margin-bottom:.5rem}
.fcard p{font-size:.93rem;color:var(--ink-soft)}
.fcard__tag{display:inline-block;margin-top:1rem;font-size:.74rem;font-weight:700;color:var(--emerald-700);background:rgba(14,94,78,.08);padding:.3rem .7rem;border-radius:999px}

/* ---------- card glass shared ---------- */
.card-glass{background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.8rem}
.card-glass--dark{background:rgba(255,255,255,.07);border:1px solid rgba(224,192,116,.25);backdrop-filter:blur(10px)}

/* ---------- BUILDER ---------- */
.builder{padding:5rem 1.2rem;background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.builder__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:.92fr 1.08fr;gap:3rem;align-items:start}
.builder__intro{position:sticky;top:6rem}
.ticks{list-style:none;margin-top:1.4rem;display:grid;gap:.7rem}
.meet__copy>.btn,.appdl__copy>.btn{margin-top:1.9rem}
.ticks li{position:relative;padding-left:1.8rem;font-weight:600;color:var(--ink-soft)}
.ticks li::before{content:"✓";position:absolute;left:0;width:1.25rem;height:1.25rem;background:var(--emerald-700);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:.7rem}
.bform{display:grid;gap:1rem}
.bform__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.bform label,.sim label{display:grid;gap:.4rem;font-size:.82rem;font-weight:700;color:var(--emerald-800)}
.bform input,.bform select,.sim select{font-family:var(--sans);font-size:.95rem;padding:.7rem .85rem;border:1px solid var(--line);border-radius:11px;background:#fff;color:var(--ink);font-weight:500}
.bform input:focus,.bform select:focus,.sim select:focus{outline:2px solid var(--gold-500);outline-offset:1px}
.bform__full{grid-column:1/-1}
.bresult{margin-top:1.5rem;animation:rise .5s ease}
.bresult__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem}
.bresult__ai{font-size:.8rem;font-weight:700;color:var(--gold-600)}
.biocard{background:linear-gradient(160deg,#fff,#f7f1e6);border:1px solid rgba(201,162,75,.35);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm);position:relative}
.biocard h3{font-family:var(--serif);font-size:1.8rem;color:var(--emerald-800)}
.biocard .biocard__meta{color:var(--ink-soft);font-size:.9rem;margin-bottom:1rem}
.biocard p{margin-bottom:.7rem;font-size:.96rem}
.biocard__quote{font-family:var(--serif);font-size:1.2rem;font-style:italic;color:var(--emerald-700);border-left:3px solid var(--gold-500);padding-left:1rem;margin:1rem 0}
.biocard__chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.8rem}
.biocard__chips span{font-size:.75rem;font-weight:600;background:rgba(14,94,78,.08);color:var(--emerald-700);padding:.3rem .7rem;border-radius:999px}
.typing::after{content:"▍";animation:blink 1s steps(2) infinite;color:var(--gold-600)}
@keyframes blink{50%{opacity:0}}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------- PROFILES ---------- */
.profiles{padding:5rem 1.2rem}
.profiles__filters{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:2.2rem}
.chip{font-family:var(--sans);font-weight:700;font-size:.85rem;border:1px solid var(--line);background:#fff;color:var(--ink-soft);padding:.5rem 1rem;border-radius:999px;cursor:pointer;transition:.2s}
.chip:hover{border-color:var(--gold-500)}
.chip.is-active{background:var(--emerald-700);color:#fff;border-color:var(--emerald-700)}
.profiles__grid{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:nowrap;gap:1.2rem;overflow-x:auto;scroll-snap-type:x mandatory;padding:.4rem .2rem 1.4rem;scrollbar-width:thin;scrollbar-color:var(--gold-500) transparent}
.profiles__grid::-webkit-scrollbar{height:8px}
.profiles__grid::-webkit-scrollbar-thumb{background:var(--gold-500);border-radius:4px}
.profiles__grid::-webkit-scrollbar-track{background:rgba(0,63,53,.08);border-radius:4px}
.profiles__grid>.pcard{flex:0 0 270px;scroll-snap-align:start}
.profiles__hint{max-width:var(--maxw);margin:.2rem auto 0;text-align:center;font-size:.82rem;color:var(--ink-soft);opacity:.7}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.25s}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.pcard__top{height:120px;position:relative;display:grid;place-items:center}
.pcard__top--photo{display:block;height:280px;background-size:cover;background-position:center top}
.pcard__top--photo::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,40,34,.32),transparent 45%)}
.pcard__av{width:74px;height:74px;border-radius:50%;border:3px solid #fff;display:grid;place-items:center;font-family:var(--serif);font-size:2rem;color:#fff;font-weight:700;box-shadow:var(--shadow-sm)}
.pcard__verified{position:absolute;top:.7rem;right:.7rem;background:var(--emerald-700);color:#fff;font-size:.68rem;font-weight:700;padding:.25rem .55rem;border-radius:999px}
.pcard__body{padding:1.1rem}
.pcard__name{font-family:var(--serif);font-size:1.3rem;display:flex;align-items:center;gap:.4rem;text-decoration:none;color:var(--ink);transition:.15s}
a.pcard__name:hover{color:var(--gold-600)}
.pcard__meta{font-size:.84rem;color:var(--ink-soft);margin:.2rem 0 .7rem}
.pcard__deen{font-size:.76rem;font-weight:600;color:var(--emerald-700);background:rgba(14,94,78,.07);display:inline-block;padding:.25rem .6rem;border-radius:999px;margin-bottom:.8rem}
.pcard__trust{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;color:var(--ink-soft);border-top:1px solid var(--line);padding-top:.8rem}
.pcard__trustbar{flex:1;height:6px;border-radius:3px;background:rgba(14,94,78,.12);overflow:hidden}
.pcard__trustbar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold-500),var(--emerald-600))}
.pcard__btn{margin-top:.9rem;width:100%;justify-content:center}

/* ---------- COMPAT ---------- */
.compat{padding:5rem 1.2rem;background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.compat__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:3rem;align-items:start}
.compat__intro{position:sticky;top:6rem}
.compat__note{margin-top:1.4rem;font-size:.88rem;font-weight:600;color:var(--emerald-700);background:rgba(14,94,78,.07);padding:.7rem 1rem;border-radius:12px}
.quiz__progress{height:6px;background:rgba(14,94,78,.12);border-radius:3px;overflow:hidden;margin-bottom:1.5rem}
.quiz__progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold-500),var(--emerald-600));transition:width .4s ease}
.quiz__q{font-family:var(--serif);font-size:1.5rem;margin-bottom:1.2rem;color:var(--emerald-800)}
.quiz__opts{display:grid;gap:.7rem}
.quiz__opt{text-align:left;font-family:var(--sans);font-weight:600;font-size:.95rem;padding:.9rem 1.1rem;border:1px solid var(--line);background:#fff;border-radius:13px;cursor:pointer;transition:.18s;color:var(--ink)}
.quiz__opt:hover{border-color:var(--gold-500);background:#fffdf8;transform:translateX(4px)}
.quiz__step{font-size:.78rem;font-weight:700;color:var(--ink-soft);margin-bottom:.6rem;text-transform:uppercase;letter-spacing:.05em}
.compat__result{animation:rise .5s ease}
.compat__result h3{font-family:var(--serif);font-size:1.7rem;margin-bottom:1.2rem;display:flex;align-items:center;gap:.6rem}
.compat__result h3 span{font-size:1rem;font-weight:800;color:#fff;background:var(--emerald-700);padding:.2rem .7rem;border-radius:999px}
.bars{display:grid;gap:1rem;margin-bottom:1.3rem}
.bar__row{display:grid;gap:.35rem}
.bar__top{display:flex;justify-content:space-between;font-size:.85rem;font-weight:700}
.bar__track{height:9px;background:rgba(14,94,78,.1);border-radius:5px;overflow:hidden}
.bar__fill{height:100%;border-radius:5px;width:0;transition:width 1s cubic-bezier(.2,.8,.2,1)}
.compat__verdict{font-size:.95rem;color:var(--ink-soft);background:rgba(201,162,75,.1);padding:1rem;border-radius:12px;margin-bottom:1.2rem;border-left:3px solid var(--gold-500)}

/* ---------- FAMILY ---------- */
.family{padding:5rem 1.2rem}
.family__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.familyroom{padding:1.4rem}
.familyroom__head{display:flex;justify-content:space-between;font-weight:700;color:var(--emerald-800);margin-bottom:1rem}
.familyroom__live{color:var(--emerald-600);font-size:.8rem}
.familyroom__members{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-bottom:1.1rem}
.member{display:flex;align-items:center;gap:.6rem;background:rgba(14,94,78,.05);padding:.5rem .7rem;border-radius:11px}
.member__av{width:36px;height:36px;border-radius:50%;background:var(--c);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.95rem}
.member strong{font-size:.86rem;display:block;line-height:1.2}
.member small{font-size:.72rem;color:var(--ink-soft)}
.familyroom__chat{display:grid;gap:.6rem;margin-bottom:1.1rem}
.fmsg{font-size:.86rem;padding:.7rem .9rem;border-radius:13px;max-width:90%}
.fmsg b{display:block;font-size:.72rem;color:var(--gold-600);margin-bottom:.2rem}
.fmsg--them{background:rgba(14,94,78,.08);justify-self:start;border-bottom-left-radius:4px}
.fmsg--me{background:rgba(201,162,75,.14);justify-self:end;text-align:right;border-bottom-right-radius:4px}
.fmsg--me b{color:var(--emerald-700)}
.fmsg--sys{justify-self:center;background:var(--emerald-800);color:var(--cream);font-size:.78rem;font-weight:600;text-align:center;max-width:100%}
.familyroom__score{display:flex;align-items:center;justify-content:space-between;background:rgba(14,94,78,.05);padding:.8rem 1rem;border-radius:12px;font-weight:700;color:var(--emerald-800)}

/* ---------- FUTURE SIM ---------- */
.future{padding:5.5rem 1.2rem;background:radial-gradient(120% 100% at 50% 0,var(--emerald-700),var(--emerald-900));overflow:hidden}
.future__pattern{position:absolute;inset:0;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23c9a24b' stroke-opacity='0.10'%3E%3Cpath d='M30 0l30 30-30 30L0 30z'/%3E%3C/g%3E%3C/svg%3E")}
.future__app{position:relative;max-width:980px;margin:0 auto;display:grid;gap:1.6rem}
.sim{padding:1.8rem}
.sim__title{font-family:var(--serif);color:var(--cream);font-size:1.4rem;margin-bottom:1.2rem}
.sim label{color:var(--gold-400)}
.sim select{background:rgba(255,255,255,.95)}
.sim__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.4rem}
.sim__report{animation:rise .5s ease;background:rgba(255,255,255,.97);border-radius:var(--radius-lg);padding:1.8rem;box-shadow:var(--shadow-lg)}
.sim__reporthead{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}
.sim__reporthead h3{font-family:var(--serif);font-size:1.7rem;color:var(--emerald-800)}
.sim__overall{text-align:right}
.sim__overall span{font-size:.78rem;color:var(--ink-soft);display:block}
.sim__overall strong{font-size:1.2rem;color:var(--emerald-700)}
.timeline{display:grid;gap:1rem;position:relative}
.tnode{display:grid;grid-template-columns:auto 1fr;gap:1.1rem;align-items:start}
.tnode__year{font-family:var(--serif);font-weight:700;font-size:1.05rem;color:#fff;background:var(--emerald-700);width:64px;height:64px;border-radius:14px;display:grid;place-items:center;text-align:center;line-height:1.1;flex:0 0 auto}
.tnode__body{background:var(--cream);border:1px solid var(--line);border-radius:13px;padding:.9rem 1.1rem}
.tnode__body h4{font-size:1rem;margin-bottom:.3rem}
.tnode__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem}
.tag{font-size:.72rem;font-weight:700;padding:.25rem .6rem;border-radius:999px}
.tag--good{background:rgba(14,94,78,.12);color:var(--emerald-700)}
.tag--risk{background:rgba(199,125,125,.18);color:#9c4a4a}
.tag--watch{background:rgba(201,162,75,.18);color:var(--gold-600)}
.sim__cta{margin-top:1.6rem;padding-top:1.4rem;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:1.2rem;flex-wrap:wrap}
.sim__cta p{font-size:.88rem;color:var(--ink-soft);max-width:32rem}

/* ---------- PRICING ---------- */
.pricing{padding:5.5rem 1.2rem;background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.pricing__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;align-items:stretch}
.plan{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:.25s;position:relative}
.plan:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.plan--featured{border:2px solid var(--gold-500);box-shadow:var(--shadow)}
.plan__badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:#1a1206;font-size:.72rem;font-weight:800;padding:.3rem .9rem;border-radius:999px}
.plan__name{font-family:var(--serif);font-size:1.4rem;color:var(--emerald-800)}
.plan__price{font-size:2.1rem;font-weight:800;margin:.4rem 0;color:var(--ink)}
.plan__price small{font-size:.85rem;font-weight:600;color:var(--ink-soft)}
.plan__desc{font-size:.86rem;color:var(--ink-soft);margin-bottom:1rem;min-height:2.6rem}
.plan__feats{list-style:none;display:grid;gap:.55rem;margin-bottom:1.3rem;flex:1}
.plan__feats li{font-size:.85rem;padding-left:1.5rem;position:relative;color:var(--ink-soft)}
.plan__feats li::before{content:"✓";position:absolute;left:0;color:var(--emerald-600);font-weight:800}
.pricing__foot{text-align:center;margin-top:2rem;font-size:.88rem;color:var(--ink-soft)}

/* ---------- WHY ---------- */
.why{padding:5rem 1.2rem}
.why__inner{max-width:var(--maxw);margin:0 auto;text-align:center}
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2.6rem}
.why__card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;text-align:left;box-shadow:var(--shadow-sm);transition:.25s}
.why__card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.why__card span{font-size:2rem;display:block;margin-bottom:.7rem}
.why__card h4{font-family:var(--serif);font-size:1.3rem;margin-bottom:.4rem;color:var(--emerald-800)}
.why__card p{font-size:.88rem;color:var(--ink-soft)}

/* ---------- CTA ---------- */
.cta{padding:5.5rem 1.2rem}
.cta__inner{max-width:880px;margin:0 auto;text-align:center;background:radial-gradient(120% 120% at 50% 0,var(--emerald-700),var(--emerald-900));border-radius:var(--radius-lg);padding:3.5rem 2rem;color:var(--cream);position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.cta__crest{font-size:2.4rem;color:var(--gold-400);display:block;margin-bottom:.6rem}
.cta__inner h2{font-family:var(--serif);font-size:clamp(1.8rem,3.6vw,2.8rem);line-height:1.1}
.cta__inner p{color:rgba(250,246,239,.8);margin:1rem 0 1.8rem}
.cta__tag{font-family:var(--serif);font-style:italic;color:var(--gold-400)!important;margin-top:1.6rem!important;font-size:1.1rem}

/* ---------- enable-alerts prompt ---------- */
.notifprompt{position:fixed;left:50%;bottom:1.5rem;transform:translateX(-50%) translateY(160%);z-index:120;
  display:flex;align-items:center;gap:.9rem;max-width:min(440px,92vw);background:#fff;border:1px solid var(--line);
  border-radius:16px;box-shadow:0 18px 50px rgba(10,40,34,.25);padding:.9rem 1rem;transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.notifprompt.show{transform:translateX(-50%) translateY(0)}
.notifprompt__ic{font-size:1.6rem;flex:0 0 auto}
.notifprompt div>b{display:block;font-size:.92rem;color:var(--emerald-800)}
.notifprompt div>span{font-size:.8rem;color:var(--ink-soft);line-height:1.4}
.notifprompt__btns{display:flex;align-items:center;gap:.4rem;margin-left:auto;flex:0 0 auto}
.notifprompt__x{width:28px;height:28px;border:none;background:rgba(0,63,53,.06);border-radius:50%;cursor:pointer;font-size:1.1rem;color:var(--ink-soft);line-height:1}
.notifprompt__x:hover{background:rgba(0,63,53,.12)}
@media(max-width:520px){.notifprompt{flex-wrap:wrap}.notifprompt__btns{margin-left:0;width:100%;justify-content:flex-end}}

/* ---------- back-to-top button (all pages) ---------- */
#toTop{position:fixed;right:1.4rem;bottom:1.6rem;z-index:95;width:50px;height:50px;border-radius:50%;border:none;cursor:pointer;
  display:grid;place-items:center;color:#1a1206;background:linear-gradient(135deg,var(--gold-500),var(--gold-600));
  box-shadow:0 12px 32px rgba(184,134,47,.45);opacity:0;transform:translateY(18px) scale(.9);pointer-events:none;
  transition:opacity .3s ease,transform .3s cubic-bezier(.2,.8,.2,1)}
#toTop.show{opacity:1;transform:none;pointer-events:auto}
#toTop:hover{transform:translateY(-3px) scale(1.06);box-shadow:0 16px 40px rgba(184,134,47,.55)}
#toTop:active{transform:translateY(0) scale(.98)}

/* ---------- PRESENCE (online now / last seen) ---------- */
@keyframes presencePulse{0%{box-shadow:0 0 0 0 rgba(51,194,127,.55)}70%{box-shadow:0 0 0 6px rgba(51,194,127,0)}100%{box-shadow:0 0 0 0 rgba(51,194,127,0)}}
.srcard__on,.chitem__on,.mcard__online,.pcard__on{animation:presencePulse 2s infinite}
.srcard__online{position:absolute;top:.6rem;right:.6rem;z-index:3;display:inline-flex;align-items:center;gap:.3rem;
  font-size:.68rem;font-weight:800;color:#fff;background:rgba(15,140,90,.92);padding:.24rem .5rem .24rem .42rem;border-radius:999px;backdrop-filter:blur(4px)}
.srcard__online::before{content:"";width:7px;height:7px;border-radius:50%;background:#7df3bf;animation:presencePulse 2s infinite}
.srcard__seen{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;color:var(--ink-soft);margin-top:.2rem}
.srcard__seen::before{content:"";width:6px;height:6px;border-radius:50%;background:#c2c8c4}
/* live "online now" counter */
.online-count{display:inline-flex;align-items:center;gap:.45rem;font-size:.85rem;font-weight:700;color:#0f8c5a}
.online-count .dot{width:9px;height:9px;border-radius:50%;background:#33c27f;animation:presencePulse 2s infinite}
/* you're-online dot on the account chip */
.acct__av{position:relative}
.acct__on{position:absolute;right:-1px;bottom:-1px;width:10px;height:10px;border-radius:50%;background:#33c27f;border:2px solid #fff;animation:presencePulse 2s infinite}

/* ---------- FOOTER ---------- */
.footer{background:var(--emerald-900);color:rgba(250,246,239,.7);padding:0 1.2rem 1.5rem}
/* trust & security certificate strip */
.trustbar{margin:0 -1.2rem;padding:1.1rem 1.2rem;background:rgba(0,0,0,.18);border-bottom:1px solid rgba(231,200,105,.16)}
.trustbar__inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1.2rem 2rem;flex-wrap:wrap}
.trustbar__seals{display:flex;flex-wrap:wrap;gap:.5rem .9rem}
.tseal{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:700;color:rgba(250,246,239,.92);
  background:rgba(255,255,255,.05);border:1px solid rgba(231,200,105,.22);padding:.4rem .8rem;border-radius:999px}
.tseal .ic{width:15px;height:15px;color:var(--gold-400)}
.trustbar__pay{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}
.trustbar__paylabel{font-size:.72rem;font-weight:700;color:rgba(250,246,239,.6);margin-right:.2rem}
.paychip{font-family:var(--sans);font-size:.7rem;font-weight:800;letter-spacing:.02em;color:#0d241e;background:#fff;
  padding:.32rem .55rem;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.25);line-height:1}
.paychip--visa{color:#1a1f71}.paychip--mc{color:#eb001b}.paychip--upi{color:#097939}.paychip--amex{color:#2e77bb}.paychip--applepay{color:#000}
.footer .footer__inner{padding-top:3rem}
@media(max-width:680px){.trustbar__inner{justify-content:center;text-align:center}.trustbar__seals{justify-content:center}}
.footer__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 2fr;gap:3rem}
.footer__brand .brand{color:var(--cream);margin-bottom:1rem}
.footer__brand p{font-size:.9rem;max-width:24rem}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.footer__cols h5{color:var(--gold-400);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.9rem}
.footer__cols a{display:block;font-size:.88rem;margin-bottom:.5rem;transition:.2s}
.footer__cols a:hover{color:var(--cream)}
.footer__bar{max-width:var(--maxw);margin:2.5rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(250,246,239,.12);display:flex;justify-content:space-between;font-size:.8rem;flex-wrap:wrap;gap:.6rem}

/* ---------- MODAL ---------- */
.modal{position:fixed;inset:0;z-index:90;display:grid;place-items:center;padding:1.2rem}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(8,54,44,.55);backdrop-filter:blur(4px)}
.modal__panel{position:relative;width:100%;max-width:440px;animation:rise .35s ease;background:#fff}
.modal__x{position:absolute;top:1rem;right:1rem;width:34px;height:34px;border-radius:50%;border:none;background:rgba(14,94,78,.08);font-size:1.3rem;cursor:pointer;color:var(--ink-soft)}
.modal__body h3{font-family:var(--serif);font-size:1.7rem;color:var(--emerald-800);margin-bottom:.4rem}
.modal__body p{font-size:.92rem;color:var(--ink-soft);margin-bottom:1.2rem}
.modal__plan{background:rgba(201,162,75,.1);border:1px solid rgba(201,162,75,.3);border-radius:13px;padding:1rem;margin-bottom:1.2rem;display:flex;justify-content:space-between;align-items:center}
.modal__plan strong{font-size:1.5rem;color:var(--emerald-800)}
.mfield{display:grid;gap:.4rem;margin-bottom:1rem;font-size:.82rem;font-weight:700;color:var(--emerald-800)}
.mfield input{padding:.7rem .85rem;border:1px solid var(--line);border-radius:11px;font-family:var(--sans);font-size:.95rem}
.mfield input:focus{outline:2px solid var(--gold-500)}

/* ---------- TOAST ---------- */
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(20px);background:var(--emerald-800);color:var(--cream);padding:.9rem 1.4rem;border-radius:13px;font-weight:600;font-size:.9rem;box-shadow:var(--shadow-lg);z-index:100;opacity:0;transition:.35s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast[hidden]{display:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .nav__links{display:none}
  .hero__inner,.builder__inner,.compat__inner,.family__inner,.footer__inner{grid-template-columns:1fr}
  .builder__intro,.compat__intro{position:static}
  .hero__card{max-width:420px;margin:0 auto}
  .stats__inner,.features__grid,.profiles__grid,.pricing__grid,.why__grid,.footer__cols,.sim__grid{grid-template-columns:repeat(2,1fr)}
  .nav__cta .btn--ghost{display:none}
  .nav__burger{display:flex}
  .nav__links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--cream);padding:1.2rem;box-shadow:var(--shadow);gap:1rem}
}
@media(max-width:600px){
  .hero{padding-top:7rem}
  .stats__inner,.features__grid,.profiles__grid,.pricing__grid,.why__grid,.sim__grid,.bform__row{grid-template-columns:1fr}
  .hero__floaty{display:none}
  .footer__bar{flex-direction:column;text-align:center}
  .sim__cta,.familyroom__members{grid-template-columns:1fr}
}

/* ============================================================
   ULTRA-PRO POLISH — premium micro-interactions & finish
   ============================================================ */
::selection{background:var(--gold-500);color:#1a1206}
::-moz-selection{background:var(--gold-500);color:#1a1206}
html{scroll-behavior:smooth}
*{scrollbar-width:thin;scrollbar-color:var(--gold-600) transparent}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--gold-600),var(--emerald-600));border-radius:99px;border:3px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(var(--gold-500),var(--emerald-700));background-clip:content-box}

/* accessible focus rings */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--gold-500);outline-offset:3px;border-radius:8px}

/* page enters with a soft fade */
@keyframes pgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
main{animation:pgIn .55s cubic-bezier(.2,.8,.2,1) both}

/* scroll-progress bar */
#scrollProgress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;pointer-events:none;
  background:linear-gradient(90deg,var(--gold-400),var(--gold-600) 45%,var(--emerald-600));
  box-shadow:0 0 14px rgba(212,175,55,.55);transition:width .12s linear}

/* premium nav lift when scrolled */
.nav{transition:background .35s ease,box-shadow .35s ease,padding .3s ease,backdrop-filter .35s}
.nav.scrolled{box-shadow:0 10px 34px rgba(0,42,35,.13)}

/* gold buttons get a moving sheen on hover */
.btn--gold{position:relative;overflow:hidden;isolation:isolate}
.btn--gold::after{content:"";position:absolute;inset:0;z-index:-1;transform:translateX(-130%) skewX(-18deg);
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);transition:transform .7s cubic-bezier(.2,.8,.2,1)}
.btn--gold:hover::after{transform:translateX(130%) skewX(-18deg)}

/* premium card finish — lift + gold ring + smoother easing */
.pcard,.srcard,.plan,.story,.feature,.pfcard,.pfsim,.review,.mcard,.cosum,.copay{
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s ease,border-color .35s ease}
.pcard:hover,.srcard:hover,.plan:hover,.pfsim:hover,.feature:hover,.story:hover,.mcard:hover{
  box-shadow:0 24px 60px rgba(0,42,35,.18);border-color:rgba(212,175,55,.5)}

/* photo zoom inside cards (clipped by card overflow:hidden) */
.pcard__top--photo,.srcard__top--photo,.pfsim__ph,.mcard__photo--img{transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.pcard:hover .pcard__top--photo,.srcard:hover .srcard__top--photo,.pfsim:hover .pfsim__ph,.mcard:hover .mcard__photo--img{transform:scale(1.07)}

/* scroll-reveal (opt-in via .reveal-up, toggled by shell.js) */
.reveal-up{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal-up.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){main,.reveal-up{animation:none!important;opacity:1!important;transform:none!important}}
