/* DoorGuard - "Premium Membership" design system (refined, distinct from MS Facility) */
:root{
  --paper:#f5f3ee; --paper-2:#efece4; --card:#ffffff;
  --ink:#16202e; --ink-2:#27313f; --text:#535a63; --muted:#838a93; --soft:#a7adb4;
  --orange:#f4631a; --orange-2:#d8530f; --orange-soft:#fbe7da;
  --blue:#1f6dff; --blue-ink:#0e4fd0;
  --line:#e6e2d8; --line-2:#eeebe3;
  --r:18px; --r-md:14px; --r-sm:11px; --pill:999px;
  --sh-soft:0 4px 16px rgba(20,28,42,.05);
  --sh:0 14px 34px rgba(20,28,42,.08);
  --sh-lg:0 30px 64px rgba(20,28,42,.13);
  --disp:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:17px}
body{font-family:var(--body);color:var(--text);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-weight:400}
a{color:inherit;text-decoration:none}img{display:block;max-width:100%}
h1,h2,h3,h4{font-family:var(--disp);color:var(--ink);line-height:1.08;font-weight:700;letter-spacing:-.022em;text-wrap:balance}
::selection{background:var(--ink);color:#fff}
.wrap{width:100%;max-width:1160px;margin:0 auto;padding:0 28px}

/* eyebrow label - quiet, refined */
.chip{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:transparent;padding:0}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--orange)}
.chip.mint,.chip.sky,.chip.peach{background:transparent;color:var(--muted)}

/* buttons - clean, flat, confident (no candy 3D) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--disp);font-weight:600;font-size:1rem;padding:.92rem 1.7rem;border-radius:12px;border:0;cursor:pointer;transition:transform .16s,box-shadow .2s,background .2s,border-color .2s}
.btn svg{width:18px;height:18px;transition:transform .2s}.btn:hover svg{transform:translateX(3px)}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 10px 22px rgba(244,99,26,.24)}
.btn-orange:hover{background:var(--orange-2);transform:translateY(-2px);box-shadow:0 16px 30px rgba(244,99,26,.3)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 10px 22px rgba(31,109,255,.22)}.btn-blue:hover{background:var(--blue-ink);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}.btn-dark:hover{background:var(--ink-2);transform:translateY(-2px)}
.btn-soft{background:#fff;color:var(--ink);box-shadow:inset 0 0 0 1px var(--line);}.btn-soft:hover{box-shadow:inset 0 0 0 1px var(--ink);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.45)}.btn-ghost:hover{background:rgba(255,255,255,.1)}

/* nav - slim, refined bar (not a fat pill) */
header{position:sticky;top:0;z-index:60;background:rgba(245,243,238,.82);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:.3s}
header.solid{border-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;height:74px}
.brand img{height:38px;width:auto}
.nav-links{display:flex;gap:2rem}
.nav-links a{font-weight:500;font-size:.96rem;color:var(--ink)}
.nav-links a:hover,.nav-links a.active{color:var(--orange)}
.nav-right{display:flex;align-items:center;gap:.8rem}
.nav-right .btn{padding:.62rem 1.25rem;font-size:.92rem;border-radius:11px}
.menu-btn{display:none;background:none;border:0;cursor:pointer;padding:6px}.menu-btn svg{width:26px;height:26px;color:var(--ink)}

/* ===== HERO (centered, calm) ===== */
.hero2{position:relative;text-align:center;padding:60px 0 30px}
.hero2 .wrap{position:relative;z-index:1}
.hero2 .chip{justify-content:center;margin-bottom:20px}
.hero2 h1{font-size:clamp(2.5rem,5.4vw,4rem);margin:0 auto;max-width:15ch;font-weight:800;letter-spacing:-.03em;line-height:1.04}
.hero2 h1 .u{color:var(--orange)}
.hero2 .sub{font-size:1.18rem;color:var(--text);max-width:560px;margin:22px auto 30px;line-height:1.55}
.hero2-cta{display:flex;gap:13px;justify-content:center;flex-wrap:wrap}
.hero2-assure{display:flex;gap:10px 26px;justify-content:center;flex-wrap:wrap;margin-top:24px;color:var(--muted);font-weight:500;font-size:.92rem}
.hero2-assure span{display:inline-flex;align-items:center;gap:8px}.hero2-assure svg{width:16px;height:16px;color:var(--orange)}
/* hero photo - clean, single refined price tag */
.showcase{position:relative;max-width:1000px;margin:50px auto 0}
.showcase .photo{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:21/9;box-shadow:var(--sh-lg)}
.showcase .photo img{width:100%;height:100%;object-fit:cover}
.seal{position:absolute;z-index:3;left:24px;bottom:24px;background:rgba(22,32,46,.86);backdrop-filter:blur(6px);color:#fff;border-radius:14px;padding:14px 20px;display:flex;align-items:baseline;gap:6px;box-shadow:var(--sh)}
.seal b{font-family:var(--disp);font-size:1.7rem;font-weight:800;line-height:1}.seal small{font-size:.82rem;font-weight:500;opacity:.8}
.fchip{display:none}
@media(max-width:760px){.showcase .photo{aspect-ratio:4/3}}

/* ===== sections ===== */
section.sec{padding:84px 0;position:relative}
.sec.tint{background:#fff}
.sec.peach{background:var(--paper-2)}
.sec.bluewash{background:#fff}
.sec.dark{background:var(--ink)}
.sec-head{max-width:660px;margin:0 auto 50px;text-align:center}
.sec-head .chip{justify-content:center;margin-bottom:16px}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:800;letter-spacing:-.025em}
.sec-head p{color:var(--muted);font-size:1.1rem;margin-top:15px;line-height:1.55}
.wave{display:none}

/* ===== step ribbon (how it works) - refined numerals ===== */
.ribbon{display:grid;grid-template-columns:repeat(3,1fr);gap:0;max-width:980px;margin:0 auto;border-top:1px solid var(--line)}
.step2{position:relative;padding:34px 30px 0;border-right:1px solid var(--line)}
.step2:last-child{border-right:0}
.step2 .num{font-family:var(--disp);font-weight:800;font-size:1.1rem;color:var(--orange);letter-spacing:.06em;margin-bottom:14px}
.step2 .num:before{content:"";display:block;width:34px;height:2px;background:var(--orange);margin-bottom:14px}
.step2 h3{font-size:1.28rem;margin-bottom:8px;font-weight:700}.step2 p{color:var(--muted);font-size:1rem}
@media(max-width:760px){.ribbon{grid-template-columns:1fr}.step2{border-right:0;border-bottom:1px solid var(--line);padding:28px 0}}

/* ===== feature grid (what you get) - restrained, one dark hero tile ===== */
.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:18px}
.btile{background:#fff;border:1px solid var(--line-2);border-radius:var(--r);padding:32px;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.btile:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.btile .emoji{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;margin-bottom:20px;background:var(--paper);color:var(--ink)}
.btile .emoji svg{width:26px;height:26px}
.btile h3{font-size:1.3rem;margin-bottom:9px;font-weight:700}.btile p{color:var(--muted);font-size:1rem}
.btile.big{grid-column:span 2;background:var(--ink);border-color:var(--ink);color:#fff;justify-content:flex-end;min-height:300px;position:relative;overflow:hidden}
.btile.big h3{color:#fff;font-size:1.7rem}.btile.big p{color:#aeb8c4;max-width:46ch}
.btile.big .emoji{background:rgba(255,255,255,.1);color:var(--orange)}
.btile.tall{grid-row:span 2;justify-content:flex-end}
.btile.tall .emoji{background:var(--orange-soft);color:var(--orange-2)}
.e-orange .emoji{background:var(--orange-soft);color:var(--orange-2)}
.e-blue .emoji{background:var(--paper);color:var(--ink)}
.e-mint .emoji,.e-lilac .emoji{background:var(--paper);color:var(--ink)}
@media(max-width:820px){.bento{grid-template-columns:1fr 1fr}.btile.big{grid-column:span 2}.btile.tall{grid-row:auto}}
@media(max-width:520px){.bento{grid-template-columns:1fr}.btile.big{grid-column:auto}}

/* ===== cost comparison ===== */
.compare{max-width:780px;margin:0 auto;background:#fff;border:1px solid var(--line-2);border-radius:var(--r);padding:36px 36px 30px}
.crow{display:grid;grid-template-columns:180px 1fr 80px;align-items:center;gap:20px;padding:11px 0}
.crow .l{font-weight:600;color:var(--ink);font-size:.98rem}
.crow .t{height:10px;border-radius:99px;background:var(--paper-2);overflow:hidden}
.crow .f{display:block;height:100%;border-radius:99px;background:var(--orange)}
.crow .a{font-family:var(--disp);font-weight:700;color:var(--ink);text-align:right}
.crow.win{border-top:1px solid var(--line);margin-top:8px;padding-top:18px}
.crow.win .l{color:var(--ink);font-weight:700}.crow.win .f{background:var(--ink)}.crow.win .a{color:var(--ink)}
.crow.win .l .star{display:inline-block;margin-left:9px;background:var(--ink);color:#fff;font-size:.58rem;font-weight:700;letter-spacing:.05em;padding:3px 8px;border-radius:5px;vertical-align:middle}
.compare .note{text-align:center;color:var(--muted);font-size:.96rem;margin-top:18px;padding-top:16px;border-top:1px solid var(--line-2)}.compare .note b{color:var(--ink)}
@media(max-width:560px){.crow{grid-template-columns:120px 1fr 62px;gap:12px}.crow .l{font-size:.86rem}}

/* ===== pricing card ===== */
.price2{position:relative;max-width:440px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-lg);padding:44px 40px;text-align:center}
.price2 .sticker{display:inline-block;background:var(--orange-soft);color:var(--orange-2);font-weight:700;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;padding:6px 14px;border-radius:99px;margin-bottom:18px}
.price2 .big{font-family:var(--disp);font-size:4.2rem;font-weight:800;color:var(--ink);line-height:1;letter-spacing:-.03em}
.price2 .big span{font-size:1.05rem;font-weight:600;color:var(--soft)}
.price2 .per{color:var(--muted);margin:8px 0 26px;font-weight:500}
.price2 ul{list-style:none;text-align:left;display:grid;gap:14px;margin-bottom:28px}
.price2 li{display:flex;align-items:center;gap:12px;font-weight:500;color:var(--ink);font-size:1rem}
.price2 li .tick{width:22px;height:22px;border-radius:50%;background:var(--ink);display:grid;place-items:center;flex-shrink:0}
.price2 li .tick svg{width:13px;height:13px;color:#fff}
.price2 .btn{width:100%}.price2 .fine{color:var(--soft);font-size:.86rem;margin-top:16px}

/* ===== promises strip ===== */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rcard{background:#fff;border:1px solid var(--line-2);border-radius:var(--r);padding:30px}
.rcard .stars{display:none}
.rcard .av{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-family:var(--disp);font-weight:700;color:#fff;font-size:1.05rem;background:var(--ink)!important;margin-bottom:18px}
.rcard p{color:var(--muted);font-size:1rem}
.rcard .who b{font-family:var(--disp);color:var(--ink)}
@media(max-width:820px){.reviews{grid-template-columns:1fr}}

/* ===== accordion FAQ ===== */
.acc{max-width:780px;margin:0 auto;border-top:1px solid var(--line)}
.acc details{border-bottom:1px solid var(--line)}
.acc summary{list-style:none;cursor:pointer;padding:22px 4px;font-family:var(--disp);font-weight:600;color:var(--ink);font-size:1.1rem;display:flex;justify-content:space-between;align-items:center;gap:14px}
.acc summary::-webkit-details-marker{display:none}
.acc summary .pm{width:24px;height:24px;flex-shrink:0;position:relative;transition:.2s}
.acc summary .pm:before,.acc summary .pm:after{content:"";position:absolute;background:var(--orange);border-radius:2px}
.acc summary .pm:before{left:50%;top:5px;width:2px;height:14px;transform:translateX(-50%)}
.acc summary .pm:after{top:50%;left:5px;height:2px;width:14px;transform:translateY(-50%)}
.acc details[open] summary .pm{transform:rotate(135deg)}
.acc details p{padding:0 4px 24px;color:var(--muted);font-size:1.02rem;max-width:64ch}

/* ===== final CTA - confident dark card ===== */
.joincard{position:relative;max-width:1000px;margin:0 auto;background:var(--ink);border-radius:24px;padding:64px 48px;text-align:center;overflow:hidden}
.joincard:before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(closest-side,rgba(244,99,26,.18),transparent);top:-180px;right:-120px}
.joincard .chip{color:#c4b6ab}.joincard .chip .dot{background:var(--orange)}
.joincard h2{position:relative;color:#fff;font-size:clamp(2rem,4vw,3rem);font-weight:800;max-width:17ch;margin:14px auto 0;letter-spacing:-.025em}
.joincard p{position:relative;color:#b7bec7;font-size:1.14rem;margin:16px auto 30px;max-width:480px}
.joincard .hero2-cta{position:relative}

/* ===== footer - clean, light ===== */
footer{background:#fff;border-top:1px solid var(--line);padding:60px 0 34px;color:var(--muted);font-size:.95rem}
.foot{display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px}
.foot .brand img{height:42px}
.foot .tagline{color:var(--muted);max-width:440px;line-height:1.55}
.foot nav{display:flex;gap:12px 28px;flex-wrap:wrap;justify-content:center}
.foot nav a{font-weight:500;color:var(--ink)}.foot nav a:hover{color:var(--orange)}
.foot .bottom{width:100%;border-top:1px solid var(--line-2);padding-top:22px;margin-top:6px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--soft);font-size:.86rem}
.foot .bottom a{color:var(--muted)}

/* ===== sub-page chrome (legacy classes, refined) ===== */
.pagehero{position:relative;text-align:center;padding:54px 0 30px}
.pagehero>.wrap{position:relative;z-index:1;display:block;grid-template-columns:none;text-align:center}
.pagehero .crumb{font-weight:500;font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;color:var(--soft)}.pagehero .crumb a:hover{color:var(--orange)}.pagehero .crumb b{color:var(--orange)}
.pagehero h1{font-size:clamp(2.3rem,4.8vw,3.5rem);margin:14px auto 0;max-width:18ch;font-weight:800;letter-spacing:-.028em}
.pagehero h1 em{font-style:normal;color:var(--orange)}
.pagehero p.lede{font-size:1.16rem;color:var(--text);margin:18px auto 26px;max-width:580px;line-height:1.55}
.pagehero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.pagehero .art{max-width:1000px;margin:36px auto 0;border-radius:var(--r);overflow:hidden;aspect-ratio:21/9;box-shadow:var(--sh-lg)}
.pagehero .art img{width:100%;height:100%;object-fit:cover}
.pagehero .art:after{display:none}

section.block{padding:74px 0}
section.block.alt{background:#fff}
.block .sec-head{text-align:center}

.tag{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:transparent;padding:0}
.tag .dot{width:7px;height:7px;border-radius:50%;background:var(--orange)}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:#fff;border:1px solid var(--line-2);border-radius:var(--r);padding:30px;transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.card .ic{width:50px;height:50px;border-radius:13px;background:var(--paper);display:grid;place-items:center;margin-bottom:18px}
.card .ic svg{width:25px;height:25px;color:var(--ink)}
.card:nth-child(3n+2) .ic{background:var(--orange-soft)}.card:nth-child(3n+2) .ic svg{color:var(--orange-2)}
.card h3{font-family:var(--disp);font-size:1.24rem;color:var(--ink);margin-bottom:8px;font-weight:700}.card p{color:var(--muted);font-size:.98rem}
@media(max-width:820px){.cards{grid-template-columns:1fr}}

.qa-grid,.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 48px;max-width:920px;margin:0 auto;border-top:1px solid var(--line)}
.qa{padding:24px 0;border-bottom:1px solid var(--line)}
.qa h3{font-family:var(--disp);font-size:1.06rem;color:var(--ink);margin-bottom:8px;display:flex;gap:10px;font-weight:700}
.qa h3 svg{width:18px;height:18px;color:var(--orange);flex-shrink:0;margin-top:3px}
.qa p{color:var(--muted);font-size:.98rem;padding-left:28px}
@media(max-width:760px){.qa-grid,.faq-grid{grid-template-columns:1fr}}

.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split.rev .splitimg{order:2}
.splitimg{border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--sh-lg)}
.splitimg:after{display:none}.splitimg img{width:100%;height:100%;object-fit:cover}
.checklist{list-style:none;display:grid;gap:10px;margin-top:20px}
.checklist li{display:flex;align-items:center;gap:13px;color:var(--ink);font-weight:500;font-size:1.02rem}
.checklist li .ck{width:24px;height:24px;border-radius:50%;background:var(--ink);display:grid;place-items:center;flex-shrink:0}
.checklist li .ck svg{width:13px;height:13px;color:#fff}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:32px}.splitimg{order:-1}}

.inc-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:24px}
.inc-list li{display:flex;align-items:center;gap:12px;font-weight:500;color:var(--ink);font-size:1rem}
.inc-list li .ck{width:22px;height:22px;border-radius:50%;background:var(--ink);display:grid;place-items:center;flex-shrink:0}
.inc-list li .ck svg{width:12px;height:12px;color:#fff}
@media(max-width:620px){.inc-list{grid-template-columns:1fr}}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.step{padding:32px 28px 0;border-right:1px solid var(--line)}.step:last-child{border-right:0}
.step .n{font-family:var(--disp);font-weight:800;font-size:1.1rem;color:var(--orange);margin-bottom:14px}
.step .n:before{content:"";display:block;width:34px;height:2px;background:var(--orange);margin-bottom:14px}
.step h3{font-family:var(--disp);font-size:1.24rem;color:var(--ink);margin-bottom:8px;font-weight:700}.step p{color:var(--muted);font-size:.98rem}
@media(max-width:760px){.steps{grid-template-columns:1fr}.step{border-right:0;border-bottom:1px solid var(--line);padding:26px 0}}

.pc{position:relative;max-width:440px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-lg);padding:44px 40px;text-align:center}
.pc .amt{font-family:var(--disp);font-size:4.2rem;font-weight:800;color:var(--ink);line-height:1;letter-spacing:-.03em}.pc .amt span{font-size:1.05rem;font-weight:600;color:var(--soft)}
.pc .per{color:var(--muted);margin:8px 0 26px;font-weight:500}
.pc ul{list-style:none;text-align:left;display:grid;gap:14px;margin-bottom:28px}
.pc li{display:flex;align-items:center;gap:12px;font-weight:500;color:var(--ink)}.pc li svg{width:18px;height:18px;color:var(--ink);flex-shrink:0}
.pc .btn{width:100%}.pc .fine{color:var(--soft);font-size:.86rem;margin-top:16px}

.cform{max-width:640px;margin:0 auto;display:grid;gap:16px;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:32px}
.cform .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cform label{font-family:var(--disp);font-weight:600;color:var(--ink);font-size:.88rem;display:block;margin-bottom:6px}
.cform input,.cform select,.cform textarea{width:100%;padding:13px 15px;border:1px solid var(--line);background:#fff;border-radius:11px;font-family:var(--body);font-size:1rem;color:var(--ink);font-weight:500}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(22,32,46,.08)}
@media(max-width:620px){.cform .row{grid-template-columns:1fr}}

.final{background:transparent;text-align:center;padding:10px 0 74px}
.final>.wrap{position:relative;max-width:1000px;background:var(--ink);border-radius:24px;padding:60px 48px;overflow:hidden}
.final>.wrap:before{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(closest-side,rgba(244,99,26,.16),transparent);top:-160px;right:-110px}
.final h2{color:#fff;font-size:clamp(2rem,4vw,2.8rem);max-width:17ch;margin:0 auto;position:relative;font-weight:800;letter-spacing:-.025em}
.final p{color:#b7bec7;font-size:1.1rem;margin:14px auto 28px;max-width:480px;position:relative}
.final .tag{color:#c4b6ab!important;position:relative;background:transparent!important}
.final .pagehero-cta,.final .hero2-cta{justify-content:center;position:relative}
.final .btn-soft{background:transparent;color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.45)}

.mbar{display:none}
@media(max-width:860px){
  .nav-links{display:none}.menu-btn{display:block}
  .mobile-open .nav-links{display:flex;position:absolute;top:74px;left:14px;right:14px;flex-direction:column;background:#fff;padding:18px 22px;gap:14px;border-radius:var(--r);box-shadow:var(--sh)}
  .mbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:70;background:#fff;border-top:1px solid var(--line);padding:11px 20px;gap:12px;align-items:center;justify-content:space-between}
  .mbar b{font-family:var(--disp);color:var(--ink)}.mbar .btn{padding:.6rem 1.2rem}
  body{padding-bottom:72px}
}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* token aliases for inline-style pages */
:root{ --coral:var(--orange); --coral-2:var(--orange-2); --shadow:var(--sh); --shadow-lg:var(--sh-lg); --font:var(--body); --bg:var(--paper); --radius:var(--r); --radius-sm:var(--r-sm); --sky:#eef3fb; --sky-2:#e2ecfb; --blue-2:var(--blue-ink); --blue-deep:#0e4fd0; }

/* ===== richer components ===== */
/* hero: large photo + floating plan card */
.showcase{max-width:1080px}
.showcase .photo{aspect-ratio:16/9}
.showcase .plan-card{position:absolute;left:-20px;bottom:-30px;z-index:3;width:330px;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-lg);padding:22px 24px;text-align:left}
.showcase .plan-card .h{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:15px;padding-bottom:13px;border-bottom:1px solid var(--line-2)}
.showcase .plan-card .h b{font-family:var(--disp);color:var(--ink);font-size:1rem;font-weight:700}
.showcase .plan-card .h .p{font-family:var(--disp);color:var(--ink);font-weight:800;font-size:1.35rem}.showcase .plan-card .h .p span{font-size:.78rem;font-weight:600;color:var(--soft)}
.showcase .plan-card ul{list-style:none;display:grid;gap:11px}
.showcase .plan-card li{display:flex;align-items:center;gap:10px;font-size:.92rem;color:var(--text);font-weight:500}
.showcase .plan-card li svg{width:16px;height:16px;color:var(--orange);flex-shrink:0}
@media(max-width:760px){.showcase .plan-card{position:static;width:auto;margin:16px auto 0;left:0;bottom:0}}

/* trust strip */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:30px 28px}
.trust .ti{text-align:center}
.trust .ti b{display:block;font-family:var(--disp);color:var(--ink);font-weight:800;font-size:1.4rem;letter-spacing:-.02em}
.trust .ti span{color:var(--muted);font-size:.9rem}
@media(max-width:680px){.trust .wrap{grid-template-columns:1fr 1fr;gap:24px 18px}}

/* lifestyle full-bleed band */
.band{position:relative;min-height:480px;display:flex;align-items:center;overflow:hidden}
.band img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.band:after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(14,18,26,.82),rgba(14,18,26,.38) 58%,rgba(14,18,26,.22))}
.band .wrap{position:relative;z-index:2}
.band .inner{max-width:540px;color:#fff;padding:66px 0}
.band .chip{color:#e7c9b6}.band .chip .dot{background:var(--orange)}
.band h2{color:#fff;font-size:clamp(2rem,3.8vw,2.9rem);font-weight:800;letter-spacing:-.025em;margin:14px 0 16px;line-height:1.08}
.band p{color:#d7dbe0;font-size:1.14rem;margin-bottom:28px;max-width:430px;line-height:1.55}

/* photo tile in bento (replaces flat dark big tile) */
.btile.photo{position:relative;padding:0;overflow:hidden;border:0;min-height:320px;display:flex}
.btile.photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.btile.photo:after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 30%,rgba(14,18,26,.85))}
.btile.photo .cap{position:relative;z-index:2;margin-top:auto;padding:30px}
.btile.photo .cap h3{color:#fff;font-size:1.55rem;margin-bottom:8px}.btile.photo .cap p{color:#d7dbe0;max-width:42ch}
.btile.photo:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}

/* section intro that's left-aligned (richer rhythm) */
.lead{max-width:620px;margin-bottom:44px}
.lead .chip{margin-bottom:14px}
.lead h2{font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:800;letter-spacing:-.025em}
.lead p{color:var(--muted);font-size:1.12rem;margin-top:14px;line-height:1.55}
