/* ===== SoldNearYou — shared styles ===== */
:root{
  --primary:#2A5C45; --primary-d:#224b39;
  --accent:#E8B84B; --accent-d:#d6a52f; --accent-ink:#946612;
  --dark:#152E20; --surface:#EEF3EB; --surface-2:#e3ebdd;
  --muted:#5a6960; --line:#dde5d8; --white:#fff; --ink:#1c2b22;
  --radius:18px; --radius-sm:12px;
  --shadow-sm:0 1px 2px rgba(21,46,32,.06),0 2px 8px rgba(21,46,32,.05);
  --shadow:0 8px 28px rgba(21,46,32,.10);
  --shadow-lg:0 24px 60px rgba(21,46,32,.16);
  --maxw:1140px;
  --font-h:'Barlow','Helvetica Neue',Arial,sans-serif;
  --font-b:'DM Sans',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
section[id],span#top{scroll-margin-top:84px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
body{font-family:var(--font-b);color:var(--ink);background:var(--white);line-height:1.62;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,.h{font-family:var(--font-h);font-weight:700;line-height:1.12;letter-spacing:-.018em;color:var(--dark)}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--font-b);font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--primary)}
.section{padding:104px 0}
.lead{font-size:19px;color:var(--muted);max-width:48ch}
.center{text-align:center;margin-left:auto;margin-right:auto}
.stack-head{max-width:660px}
.stack-head h2{font-size:clamp(30px,3.9vw,46px)}
.stack-head .lead{margin-top:18px}
.stack-head.center .lead{margin-left:auto;margin-right:auto}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-h);font-weight:600;font-size:16.5px;border-radius:999px;padding:14px 26px;cursor:pointer;border:2px solid transparent;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,color .15s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 6px 18px rgba(42,92,69,.28)}
.btn-primary:hover{background:var(--primary-d);box-shadow:0 10px 26px rgba(42,92,69,.34);transform:translateY(-1px)}
.btn-ghost{background:#fff;color:var(--primary);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--primary);background:var(--surface)}
.btn-gold{background:var(--accent);color:var(--dark);box-shadow:0 6px 18px rgba(232,184,75,.34)}
.btn-gold:hover{background:var(--accent-d);transform:translateY(-1px)}
.btn-sm{padding:10px 18px;font-size:15px}

/* NAV */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.84);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid transparent;transition:border-color .2s,box-shadow .2s}
header.nav.scrolled{border-color:var(--line);box-shadow:0 1px 0 rgba(21,46,32,.04)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.brand{display:flex;align-items:center;gap:10px}
.brand .logomark{width:30px;height:31px;flex:0 0 auto}
.brand .word{font-family:var(--font-h);font-weight:700;font-size:21px;color:var(--dark);letter-spacing:-.02em}
.brand .word b{color:var(--primary);font-weight:700}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-weight:500;font-size:15.5px;color:var(--ink);opacity:.82;transition:opacity .15s,color .15s}
.nav-links a:hover{opacity:1;color:var(--primary)}
.nav-links a.active{opacity:1;color:var(--primary);font-weight:600}
.nav-cta{display:flex;align-items:center;gap:12px}
.menu-btn{display:none;background:none;border:0;cursor:pointer;padding:11px;margin:-3px}
.menu-btn span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;margin:4px 0;transition:.25s}

/* HERO */
.hero{position:relative;background:radial-gradient(1200px 560px at 80% -10%,#f6f0dd 0%,rgba(246,240,221,0) 55%),linear-gradient(180deg,var(--surface) 0%,#fff 100%);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(42,92,69,.07) 1px,transparent 0);background-size:26px 26px;-webkit-mask-image:linear-gradient(180deg,#000,transparent 70%);mask-image:linear-gradient(180deg,#000,transparent 70%);pointer-events:none}
.hero-inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:58px;align-items:center;padding-top:84px;padding-bottom:92px}
.hero h1{font-size:clamp(37px,5.2vw,60px);letter-spacing:-.025em}
.hero h1 .hl{color:var(--primary);background-image:linear-gradient(transparent 58%,rgba(232,184,75,.55) 58%,rgba(232,184,75,.55) 92%,transparent 92%);padding:0 2px}
.hero p.sub{margin-top:24px;font-size:20px;color:var(--muted);max-width:50ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-trust{display:flex;flex-wrap:wrap;gap:16px 26px;margin-top:32px;color:var(--muted);font-size:14.5px;font-weight:500}
.hero-trust span{display:inline-flex;align-items:center;gap:8px}
.hero-trust svg{width:18px;height:18px;color:var(--primary);flex:0 0 auto}

/* PAGE INTRO (product / pricing headers) */
.page-intro{position:relative;background:radial-gradient(900px 420px at 82% -30%,#f6f0dd 0%,rgba(246,240,221,0) 60%),var(--surface);border-bottom:1px solid var(--line);overflow:hidden}
.page-intro::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(42,92,69,.06) 1px,transparent 0);background-size:26px 26px;-webkit-mask-image:linear-gradient(180deg,#000,transparent 80%);mask-image:linear-gradient(180deg,#000,transparent 80%)}
.page-intro .wrap{position:relative;padding-top:64px;padding-bottom:64px;text-align:center}
.page-intro h1{font-size:clamp(34px,4.6vw,52px)}
.page-intro p{margin:16px auto 0;font-size:19px;color:var(--muted);max-width:54ch}

/* phone frame */
.hero-visual{position:relative;display:flex;justify-content:center}
.phone{position:relative;width:306px;background:#0e2017;border-radius:42px;padding:11px;box-shadow:var(--shadow-lg);border:1px solid #0a1610}
.phone-screen{background:var(--surface);border-radius:32px;overflow:hidden;position:relative;aspect-ratio:9/19}
.phone-notch{position:absolute;top:9px;left:50%;transform:translateX(-50%);width:96px;height:20px;background:#0e2017;border-radius:0 0 14px 14px;z-index:5}
.phone .shot-img{width:100%;height:100%;object-fit:cover;display:block}
.phone-fallback{display:none}
.phone.noimg .phone-fallback{display:block}
.pcat-top{background:var(--dark);color:#fff;padding:18px 14px 12px}
.pcat-store{display:flex;align-items:center;gap:8px;font-family:var(--font-h);font-weight:600;font-size:15px}
.pcat-dot{width:22px;height:22px;border-radius:7px;background:var(--accent);display:grid;place-items:center;color:var(--dark);flex:0 0 auto}
.pcat-dot svg{width:13px;height:13px}
.pcat-chips{display:flex;gap:6px;margin-top:12px;overflow:hidden}
.pchip{font-size:11px;font-weight:600;background:rgba(255,255,255,.12);color:#eaf2e6;padding:5px 10px;border-radius:999px;white-space:nowrap}
.pchip.on{background:var(--accent);color:var(--dark)}
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:9px;padding:12px}
.pcard{background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}
.pthumb{aspect-ratio:1/.82;display:grid;place-items:center}
.pthumb svg{width:42%;height:42%;opacity:.9}
.pmeta{padding:8px 9px 10px}
.pmeta .t{font-family:var(--font-h);font-weight:600;font-size:12px;color:var(--dark);line-height:1.15}
.pmeta .sku{font-size:9.5px;color:var(--muted);margin-top:2px;letter-spacing:.02em}
.pmeta .pr{font-family:var(--font-h);font-weight:700;font-size:13.5px;color:var(--primary);margin-top:5px}
.pmeta .pr.call{color:var(--muted);font-weight:600;font-size:11.5px}
.float-badge{position:absolute;background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:11px 14px;display:flex;align-items:center;gap:10px;font-weight:600;font-size:13.5px;color:var(--dark);z-index:6}
.fb-1{top:30px;left:-30px}
.fb-2{bottom:64px;right:-26px}
.fb-ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:0 0 auto;color:#fff}
.fb-ic svg{width:17px;height:17px}

/* TYPES */
.types{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.types .wrap{padding-top:32px;padding-bottom:32px;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:16px 36px}
.types .label{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600}
.type-pill{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-h);font-weight:600;font-size:18px;color:var(--dark)}
.type-pill svg{width:20px;height:20px;color:var(--primary)}

/* PROBLEM */
.problem{background:var(--dark);color:#dfe9e1;position:relative;overflow:hidden}
.problem::after{content:"";position:absolute;right:-120px;top:-120px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(232,184,75,.16),transparent 65%)}
.problem h2{color:#fff;font-size:clamp(29px,3.7vw,44px)}
.problem .eyebrow{color:var(--accent)}
.prob-head{max-width:700px;margin-bottom:54px}
.prob-head p{color:#aebfb2;font-size:19px;margin-top:18px}
.prob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.prob-card{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius);padding:28px 24px}
.prob-ic{width:46px;height:46px;border-radius:13px;background:rgba(232,184,75,.14);color:var(--accent);display:grid;place-items:center;margin-bottom:18px}
.prob-ic svg{width:23px;height:23px}
.prob-card h3{color:#fff;font-size:19px;margin-bottom:8px;font-weight:600}
.prob-card p{color:#a9bbae;font-size:15px;line-height:1.55}
.prob-kicker{margin-top:52px;text-align:center;font-family:var(--font-h);font-weight:600;font-size:clamp(21px,2.5vw,28px);color:#fff;line-height:1.35}
.prob-kicker b{color:var(--accent);font-weight:700}

/* SOLUTION */
.sol-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.sol-points{margin-top:30px;display:flex;flex-direction:column;gap:20px}
.sol-point{display:flex;gap:14px;align-items:flex-start}
.sol-check{width:28px;height:28px;border-radius:9px;background:var(--surface-2);color:var(--primary);display:grid;place-items:center;flex:0 0 auto;margin-top:2px}
.sol-check svg{width:16px;height:16px}
.sol-point h4{font-size:17.5px;margin-bottom:3px;font-weight:600}
.sol-point p{font-size:15.5px;color:var(--muted)}
.url-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.url-bar{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 15px;font-family:var(--font-h);font-size:15px;color:var(--dark);box-shadow:var(--shadow-sm)}
.url-bar svg{width:16px;height:16px;color:var(--primary);flex:0 0 auto}
.url-bar .slug{color:var(--primary);font-weight:600}
.url-bar .q{color:var(--accent-ink);font-weight:600}
.url-list{margin-top:14px;display:flex;flex-direction:column;gap:11px}
.url-note{font-size:13px;color:var(--muted);margin-top:18px;display:flex;gap:8px;align-items:flex-start}
.url-note svg{width:16px;height:16px;color:var(--primary);flex:0 0 auto;margin-top:2px}

/* FLOOR (mobile-first) */
.floor{background:var(--surface)}
.floor-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:64px;align-items:center}
.floor-badges{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:30px}
.floor-badge{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
.floor-badge .fi{width:36px;height:36px;border-radius:10px;background:var(--surface);color:var(--primary);display:grid;place-items:center;flex:0 0 auto}
.floor-badge .fi svg{width:19px;height:19px}
.floor-badge h4{font-size:15.5px;font-weight:600;margin-bottom:1px}
.floor-badge p{font-size:13.5px;color:var(--muted);line-height:1.45}
.floor-visual{display:flex;justify-content:center;position:relative}
.addmock{padding:0}
.add-top{background:var(--dark);color:#fff;padding:18px 16px 14px;display:flex;align-items:center;gap:10px}
.add-top .bk{font-size:18px;opacity:.8}
.add-top .ti{font-family:var(--font-h);font-weight:600;font-size:15px}
.add-body{padding:14px}
.add-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:14px}
.add-photos .ph{aspect-ratio:1;border-radius:9px;background:#e7eadf;display:grid;place-items:center}
.add-photos .ph svg{width:38%;color:#9aa888}
.add-photos .ph.add{background:#fff;border:1.5px dashed var(--line);color:var(--primary)}
.add-fld{margin-bottom:11px}
.add-fld label{display:block;font-size:10.5px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.add-fld .inp{background:#fff;border:1.5px solid var(--line);border-radius:9px;padding:10px 11px;font-family:var(--font-h);font-weight:600;font-size:13.5px;color:var(--dark)}
.add-fld .inp.muted{color:var(--muted);font-weight:500}
.add-row2{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.add-pub{margin-top:6px;background:var(--primary);color:#fff;text-align:center;font-family:var(--font-h);font-weight:600;font-size:14px;padding:12px;border-radius:10px}

/* DEMO */
.demo{background:linear-gradient(180deg,#fff 0%,var(--surface) 100%)}
.demo-head{text-align:center;max-width:680px;margin:0 auto}
.demo-head h2{font-size:clamp(29px,3.8vw,46px)}
.demo-head p{color:var(--muted);font-size:19px;margin-top:16px}
.demo-stage-wrap{margin-top:38px}
.demo-coach{display:flex;align-items:center;justify-content:center;gap:12px;margin:0 auto 20px;max-width:580px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:11px 20px;box-shadow:var(--shadow-sm);font-weight:500;font-size:15px;color:var(--ink)}
.demo-coach .step-num{width:26px;height:26px;border-radius:50%;background:var(--primary);color:#fff;font-family:var(--font-h);font-weight:700;display:grid;place-items:center;font-size:14px;flex:0 0 auto}
.demo-coach.done .step-num{background:var(--accent);color:var(--dark)}
.demo-stage{background:var(--dark);border-radius:22px;padding:14px;box-shadow:var(--shadow-lg)}
.demo-bar{display:flex;align-items:center;gap:8px;padding:4px 8px 12px}
.demo-bar .dots{display:flex;gap:6px}
.demo-bar .dots i{width:11px;height:11px;border-radius:50%;display:block}
.demo-bar .tag{margin-left:auto;font-size:12px;color:#9db0a3;font-weight:600;letter-spacing:.04em}
.demo-panes{display:grid;grid-template-columns:1fr 1fr;gap:14px;aspect-ratio:16/9}
.pane{background:#fff;border-radius:14px;overflow:hidden;display:flex;flex-direction:column;min-height:0;position:relative}
.pane-head{display:flex;align-items:center;gap:9px;padding:11px 14px;border-bottom:1px solid var(--line);flex:0 0 auto}
.pane-head .ico{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;color:#fff;flex:0 0 auto}
.pane-head .ti{font-family:var(--font-h);font-weight:600;font-size:14.5px;color:var(--dark);line-height:1.1}
.pane-head .ti small{display:block;font-family:var(--font-b);font-weight:500;font-size:11px;color:var(--muted)}
.pane-body{flex:1 1 auto;overflow:auto;padding:12px}
.live-pill{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--primary);background:var(--surface);padding:4px 9px;border-radius:999px}
.live-pill i{width:7px;height:7px;border-radius:50%;background:var(--primary);display:block;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.7)}}
.adm-row{display:flex;align-items:center;gap:10px;padding:9px;border:1px solid var(--line);border-radius:11px;margin-bottom:9px;background:#fff}
.adm-row:last-child{margin-bottom:0}
.adm-thumb{width:40px;height:40px;border-radius:8px;display:grid;place-items:center;flex:0 0 auto}
.adm-thumb svg{width:21px;height:21px;opacity:.92}
.adm-info{min-width:0;flex:1 1 auto}
.adm-info .t{font-family:var(--font-h);font-weight:600;font-size:13.5px;color:var(--dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adm-info .m{font-size:11px;color:var(--muted);display:flex;gap:7px;align-items:center;flex-wrap:wrap;margin-top:2px}
.adm-price{font-family:var(--font-h);font-weight:700;font-size:13.5px;color:var(--primary)}
.badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:999px;letter-spacing:.02em}
.badge.active{background:rgba(42,92,69,.12);color:var(--primary)}
.badge.hidden{background:#eceeec;color:var(--muted)}
.edit-btn{font-family:var(--font-h);font-weight:600;font-size:12.5px;color:var(--primary);background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:9px 13px;cursor:pointer;flex:0 0 auto;transition:.15s;display:inline-flex;align-items:center;gap:5px;min-height:36px}
.edit-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.edit-btn svg{width:13px;height:13px}
.pulse-hint{position:relative}
.pulse-hint::after{content:"";position:absolute;inset:-4px;border-radius:11px;border:2px solid var(--accent);animation:ring 1.5s infinite;pointer-events:none}
@keyframes ring{0%{opacity:.9;transform:scale(1)}70%{opacity:0;transform:scale(1.12)}100%{opacity:0}}
.editor{border:1px solid var(--accent);background:#fffdf6;border-radius:12px;padding:13px;margin-bottom:10px;box-shadow:0 6px 18px rgba(232,184,75,.18)}
.editor h5{font-family:var(--font-h);font-weight:600;font-size:13.5px;color:var(--dark);margin-bottom:10px;display:flex;align-items:center;gap:7px}
.editor h5 svg{width:15px;height:15px;color:var(--accent-d)}
.fld{margin-bottom:10px}
.fld label{display:block;font-size:11px;font-weight:600;color:var(--muted);margin-bottom:4px;letter-spacing:.02em;text-transform:uppercase}
.price-input{display:flex;align-items:center;border:2px solid var(--line);border-radius:9px;overflow:hidden;background:#fff;transition:border-color .15s}
.price-input:focus-within{border-color:var(--primary)}
.price-input .cur{padding:0 10px;color:var(--muted);font-family:var(--font-h);font-weight:700;font-size:15px;background:var(--surface);align-self:stretch;display:flex;align-items:center}
.price-input input{border:0;outline:0;padding:10px;font-family:var(--font-h);font-weight:700;font-size:15px;color:var(--dark);width:100%;background:transparent}
.seg{display:flex;gap:6px;flex-wrap:wrap}
.seg button{flex:1 1 auto;font-size:12px;font-weight:600;font-family:var(--font-b);padding:8px;border-radius:8px;border:1.5px solid var(--line);background:#fff;color:var(--muted);cursor:pointer;transition:.15s;white-space:nowrap}
.seg button.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.editor-actions{display:flex;gap:8px;margin-top:4px}
.editor-actions button{flex:1 1 auto;font-family:var(--font-h);font-weight:600;font-size:13px;border-radius:9px;padding:10px;cursor:pointer;border:1.5px solid var(--line);background:#fff;color:var(--muted)}
.editor-actions .save{background:var(--primary);color:#fff;border-color:var(--primary)}
.cust-top{background:var(--dark);margin:-12px -12px 12px;padding:11px 13px}
.cust-store{display:flex;align-items:center;gap:8px;color:#fff;font-family:var(--font-h);font-weight:600;font-size:13.5px}
.cust-store .d{width:20px;height:20px;border-radius:6px;background:var(--accent);display:grid;place-items:center;color:var(--dark)}
.cust-store .d svg{width:12px;height:12px}
.cust-chips{display:flex;gap:5px;margin-top:9px;flex-wrap:wrap}
.cchip{font-size:10px;font-weight:600;color:#dfe9e1;background:rgba(255,255,255,.1);padding:4px 9px;border-radius:999px}
.cchip.on{background:var(--accent);color:var(--dark)}
.cust-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ccard{background:#fff;border:1px solid var(--line);border-radius:11px;overflow:hidden}
.ccard.flash{animation:flash 1.1s ease}
@keyframes flash{0%{box-shadow:0 0 0 0 rgba(232,184,75,0)}25%{box-shadow:0 0 0 3px rgba(232,184,75,.6);transform:translateY(-2px)}100%{box-shadow:0 0 0 0 rgba(232,184,75,0)}}
.cthumb{aspect-ratio:1/.78;display:grid;place-items:center;position:relative}
.cthumb svg{width:38%;height:38%;opacity:.92}
.cstock{position:absolute;top:7px;left:7px;font-size:9px;font-weight:600;background:rgba(255,255,255,.92);color:var(--muted);padding:3px 7px;border-radius:999px}
.cinfo{padding:8px 10px 11px}
.cinfo .t{font-family:var(--font-h);font-weight:600;font-size:12.5px;color:var(--dark);line-height:1.15}
.cinfo .sku{font-size:9.5px;color:var(--muted);margin-top:2px}
.cinfo .pr{font-family:var(--font-h);font-weight:700;font-size:14px;color:var(--primary);margin-top:5px}
.cinfo .pr.call{color:var(--muted);font-weight:600;font-size:11.5px}
.demo-foot{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:center;margin-top:26px}
.demo-reset{font-family:var(--font-h);font-weight:600;font-size:14px;color:var(--muted);background:none;border:0;cursor:pointer;display:inline-flex;gap:7px;align-items:center}
.demo-reset svg{width:16px;height:16px}

/* GALLERY */
.gallery{background:#fff}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.shot{border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff}
.shot .browser-bar{display:flex;align-items:center;gap:6px;padding:9px 12px;background:#f4f6f2;border-bottom:1px solid var(--line)}
.shot .browser-bar i{width:9px;height:9px;border-radius:50%;display:block}
.shot .browser-bar .url{margin-left:8px;font-size:11px;color:var(--muted);font-family:var(--font-h);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.shot .shot-img{width:100%;display:block}
.shot-fallback{display:block}
.shot.hasimg .shot-fallback{display:none}
.gal-fallback{padding:14px;background:var(--surface);min-height:230px}
.gal-cap{margin-top:16px;text-align:center}
.gal-cap h4{font-size:17px;font-weight:600;margin-bottom:3px}
.gal-cap p{font-size:14px;color:var(--muted)}
.mini-chips{display:flex;gap:5px;margin-bottom:10px;flex-wrap:wrap}
.mini-chips span{font-size:10px;font-weight:600;background:#fff;border:1px solid var(--line);color:var(--muted);padding:4px 9px;border-radius:999px}
.mini-chips span.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mini-card{background:#fff;border:1px solid var(--line);border-radius:9px;overflow:hidden}
.mini-thumb{aspect-ratio:1/.7;display:grid;place-items:center}
.mini-thumb svg{width:36%;opacity:.9}
.mini-meta{padding:6px 8px 8px}
.mini-meta .t{font-family:var(--font-h);font-weight:600;font-size:11px;color:var(--dark)}
.mini-meta .pr{font-family:var(--font-h);font-weight:700;font-size:12px;color:var(--primary);margin-top:2px}
.mini-detail .big{aspect-ratio:16/10;border-radius:10px;background:#e1ece6;display:grid;place-items:center;margin-bottom:10px}
.mini-detail .big svg{width:30%;color:#4f8a6e}
.mini-detail .dt{font-family:var(--font-h);font-weight:700;font-size:15px;color:var(--dark)}
.mini-detail .dsku{font-size:11px;color:var(--muted);margin:3px 0 8px}
.mini-detail .dpr{font-family:var(--font-h);font-weight:700;font-size:18px;color:var(--primary)}
.mini-detail .dcall{display:inline-flex;align-items:center;gap:6px;margin-top:10px;background:var(--primary);color:#fff;font-family:var(--font-h);font-weight:600;font-size:12px;padding:8px 12px;border-radius:8px}
.mini-detail .dcall svg{width:13px;height:13px}
.mini-dash .stat-row{display:flex;gap:7px;margin-bottom:10px}
.mini-dash .stat{flex:1;background:#fff;border:1px solid var(--line);border-radius:9px;padding:9px}
.mini-dash .stat .n{font-family:var(--font-h);font-weight:700;font-size:16px;color:var(--dark)}
.mini-dash .stat .l{font-size:9.5px;color:var(--muted)}
.mini-row{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:9px;padding:7px;margin-bottom:7px}
.mini-row .rt{width:28px;height:28px;border-radius:6px;flex:0 0 auto}
.mini-row .ri{flex:1;min-width:0}
.mini-row .ri .t{font-family:var(--font-h);font-weight:600;font-size:11.5px;color:var(--dark)}
.mini-row .ri .s{font-size:9.5px;color:var(--muted)}
.mini-row .rb{font-size:9px;font-weight:600;padding:2px 7px;border-radius:999px;background:rgba(42,92,69,.12);color:var(--primary)}

/* HOW */
.how{background:var(--surface)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px;counter-reset:s}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow-sm)}
.step .n{counter-increment:s;font-family:var(--font-h);font-weight:700;font-size:15px;width:38px;height:38px;border-radius:12px;background:var(--primary);color:#fff;display:grid;place-items:center;margin-bottom:18px}
.step .n::before{content:"0" counter(s)}
.step h3{font-size:19px;margin-bottom:8px;font-weight:600}
.step p{font-size:15px;color:var(--muted)}
.step .sku-chip{display:inline-block;margin-top:13px;font-family:var(--font-h);font-weight:600;font-size:12.5px;color:var(--primary);background:var(--surface);border:1px dashed var(--primary);border-radius:7px;padding:4px 10px;letter-spacing:.03em}

/* FEATURES (card grid) */
.feat{background:#fff}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px}
.fcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:var(--shadow-sm)}
.fcard .fic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:16px;color:#fff}
.fcard .fic svg{width:22px;height:22px}
.fcard .fic.shop{background:var(--primary)}
.fcard .fic.own{background:var(--accent);color:var(--dark)}
.ftag{display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:3px 9px;border-radius:999px;margin-bottom:13px}
.ftag.shop{background:rgba(42,92,69,.1);color:var(--primary)}
.ftag.own{background:rgba(232,184,75,.2);color:var(--accent-ink)}
.fcard h4{font-size:18px;font-weight:600;margin-bottom:6px}
.fcard p{font-size:14.5px;color:var(--muted);line-height:1.5}
.ftag.soon{background:rgba(232,184,75,.15);color:var(--accent-ink)}
.fic.soon{background:rgba(42,92,69,.1);color:var(--primary)}
/* badge used inline in tier lists and comparison table */
.badge-soon{display:inline-block;font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-ink);background:rgba(232,184,75,.2);border:1px solid rgba(232,184,75,.4);padding:2px 8px;border-radius:999px;margin-left:5px;vertical-align:middle}
.li-soon{opacity:.75}
.soon-col{color:var(--accent-ink);font-weight:600;font-size:13px;font-style:italic}
/* ROADMAP section */
.road-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:44px}
.road-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:26px 22px;text-align:center}
.road-ic{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;margin:0 auto 14px;background:rgba(42,92,69,.1);color:var(--primary)}
.road-ic svg{width:24px;height:24px}
.road-card h4{font-size:17px;font-weight:600;margin-bottom:7px}
.road-card p{font-size:14px;color:var(--muted);line-height:1.5;margin-bottom:16px}
.road-soon{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--accent-ink);background:rgba(232,184,75,.15);border:1px solid rgba(232,184,75,.35);padding:4px 12px;border-radius:999px}
.road-soon::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);display:block;animation:pulse 1.8s infinite}
/* building-next strip on home */
.building-next{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.bn-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:28px}
.bn-card{display:flex;align-items:flex-start;gap:14px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px}
.bn-ic{flex-shrink:0;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:rgba(42,92,69,.1);color:var(--primary)}
.bn-ic svg{width:20px;height:20px}
.bn-card h4{font-size:15px;font-weight:600;margin-bottom:3px}
.bn-card p{font-size:13.5px;color:var(--muted);line-height:1.45}

/* BROWSE */
.browse{background:linear-gradient(165deg,var(--primary) 0%,#1d4533 60%,var(--dark) 100%);color:#eaf2e6;position:relative;overflow:hidden}
.browse::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.07) 1px,transparent 0);background-size:30px 30px;opacity:.6}
.browse-head{position:relative;text-align:center;max-width:660px;margin:0 auto}
.browse .eyebrow{color:var(--accent)}
.browse h2{color:#fff;font-size:clamp(29px,3.8vw,46px)}
.browse-head p{color:#c3d4c8;font-size:19px;margin-top:16px}
.soon-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(232,184,75,.18);border:1px solid rgba(232,184,75,.5);color:var(--accent);font-weight:600;font-size:13px;letter-spacing:.05em;text-transform:uppercase;padding:7px 15px;border-radius:999px;margin-bottom:20px}
.soon-tag i{width:8px;height:8px;border-radius:50%;background:var(--accent);display:block;animation:pulse 1.8s infinite}
.loc-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:46px}
.loc-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:24px 22px;cursor:pointer;transition:transform .2s,background .2s,border-color .2s;text-align:left}
.loc-card:hover{transform:translateY(-4px);background:rgba(255,255,255,.12);border-color:rgba(232,184,75,.5)}
.loc-ic{width:46px;height:46px;border-radius:13px;background:rgba(232,184,75,.16);color:var(--accent);display:grid;place-items:center;margin-bottom:18px}
.loc-ic svg{width:24px;height:24px}
.loc-card h3{color:#fff;font-size:20px;margin-bottom:3px;font-weight:600}
.loc-card .sub{color:#b7c9bc;font-size:13.5px;margin-bottom:16px}
.loc-stores{display:flex;align-items:center;gap:8px;font-size:13px;color:#d8e4db;font-weight:500}
.loc-stores .av{display:flex}
.loc-stores .av i{width:22px;height:22px;border-radius:50%;border:2px solid #2a5340;margin-left:-8px;display:block;background:var(--accent)}
.loc-stores .av i:first-child{margin-left:0}
.loc-stores .av i:nth-child(2){background:#7fae8e}
.loc-stores .av i:nth-child(3){background:#cdb277}
.browse-cta{position:relative;text-align:center;margin-top:42px}

/* COMPARE */
.compare{background:var(--surface)}
.cmp-head{max-width:660px;margin:0 auto 46px;text-align:center}
.cmp-wrap{border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--line)}
.cmp-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;background:#fff}
.cmp-grid .cell{padding:16px 14px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);font-size:14.5px;display:flex;align-items:center;justify-content:center;text-align:center}
/* Header cells counted within .cmp-head-row (5 children; last = Resale POS) */
.cmp-head-row .cell:last-child{border-right:0}
/* Body cells are direct children of .cmp-grid. .cmp-head-row is child #1, so
   Resale POS cells land on 5n+1 (children 6, 11, 16...) not 5n (5, 10, 15...) */
.cmp-grid > .cell:nth-child(5n+1){border-right:0}
.cmp-head-row .cell{background:var(--dark);color:#fff;font-family:var(--font-h);font-weight:700;font-size:16px;text-align:center}
.cmp-head-row .cell.own{background:var(--primary)}
.cmp-head-row .cell:first-child{background:var(--dark)}
.cmp-grid .feature{font-weight:600;color:var(--dark);font-family:var(--font-b);justify-content:flex-start;font-size:15px}
.cmp-grid .feature .ast{color:var(--accent-ink);font-weight:700;margin-left:1px}
.cmp-grid .cell.own-col{background:rgba(42,92,69,.06);font-weight:600}
.cmp-grid .cell.txt{color:var(--muted);font-weight:600;font-size:13.5px}
.yes{color:var(--primary)} .no{color:#b9433f;opacity:.65}
.cmp-grid .cell svg{width:22px;height:22px}
.cmp-grid > .cell:nth-last-child(-n+5){border-bottom:0}
.cmp-grid .cell.price{font-family:var(--font-h);font-weight:700;font-size:15px;color:var(--dark)}
.cmp-grid .cell.price.own-col{color:var(--primary)}
.cmp-grid .feature.lead-feat{font-weight:700}
.cmp-foot{margin-top:18px;font-size:12.5px;color:var(--muted);max-width:90ch;line-height:1.6}
/* MOBILE COMPARISON CARDS */
.cmp-mobile{display:none;margin-top:32px}
.cmob-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}
.cmob-head{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--dark);padding:16px}
.cmob-hbrand{display:flex;flex-direction:column;font-family:var(--font-h);font-weight:700;font-size:14px;color:#fff;flex:1}
.cmob-hbrand small{font-size:11px;font-weight:400;opacity:.6;margin-top:3px;font-family:var(--font-b)}
.cmob-hbrand.sny{color:var(--accent)}
.cmob-hbrand.them{text-align:right}
.cmob-hvs{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35);flex-shrink:0}
.cmob-labels{display:grid;grid-template-columns:1fr 46px 46px;padding:7px 16px 5px;background:var(--surface);border-bottom:1px solid var(--line)}
.cmob-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;text-align:center;color:var(--muted)}
.cmob-lbl.sny{color:var(--primary)}
.cmob-row{display:grid;grid-template-columns:1fr 46px 46px;align-items:center;padding:11px 16px;border-bottom:1px solid var(--line)}
.cmob-feat{font-size:13px;font-weight:500;color:var(--dark);line-height:1.3}
.cmob-v{display:flex;align-items:center;justify-content:center}
.cmob-yes{font-size:18px;font-weight:700;color:var(--primary);line-height:1}
.cmob-no{font-size:16px;font-weight:700;color:#b9433f;opacity:.6;line-height:1}
.cmob-partial{font-size:10.5px;font-weight:600;color:var(--muted);text-align:center;line-height:1.3}
.cmob-soon-v{font-size:10px;font-weight:700;color:var(--accent-ink);text-align:center;line-height:1.4;font-style:italic}
.cmob-price{display:grid;grid-template-columns:1fr 46px 46px;align-items:center;padding:12px 16px;background:var(--surface);border-top:2px solid var(--line)}
.cmob-price-feat{font-size:13.5px;font-weight:700;color:var(--dark)}
.cmob-price-sny{font-family:var(--font-h);font-weight:700;font-size:14px;color:var(--primary);text-align:center}
.cmob-price-them{font-family:var(--font-h);font-weight:700;font-size:13px;color:var(--muted);text-align:center}

/* PRICING */
.pricing{background:#fff}
.price-wrap{display:grid;grid-template-columns:1.12fr .88fr;gap:26px;margin-top:52px;align-items:stretch}
.price-card{background:var(--dark);color:#fff;border-radius:24px;padding:44px;position:relative;overflow:hidden}
.price-card::after{content:"";position:absolute;right:-90px;bottom:-90px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(232,184,75,.18),transparent 65%)}
.price-card .eyebrow{color:var(--accent)}
.price-amt{display:flex;align-items:baseline;gap:8px;margin:16px 0 6px}
.price-amt .n{font-family:var(--font-h);font-weight:700;font-size:66px;line-height:1;color:#fff}
.price-amt .per{color:#aebfb2;font-size:18px;font-weight:500}
.price-card .tagline{color:#c3d4c8;font-size:16px;max-width:36ch}
.price-feats{position:relative;list-style:none;margin:26px 0 30px;display:grid;grid-template-columns:1fr 1fr;gap:13px 18px}
.price-feats li{display:flex;gap:9px;align-items:flex-start;font-size:14.5px;color:#dbe7df}
.price-feats svg{width:18px;height:18px;color:var(--accent);flex:0 0 auto;margin-top:2px}
.price-card .btn{position:relative}
.price-side{display:flex;flex-direction:column;gap:18px}
.pside-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:26px;flex:1 1 auto}
.pside-card h3{font-size:20px;margin-bottom:8px;display:flex;align-items:center;gap:10px;font-weight:600}
.pside-card h3 svg{width:22px;height:22px;color:var(--primary);flex:0 0 auto}
.pside-card p{font-size:15px;color:var(--muted)}
.addons{margin-top:26px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.addon{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px}
.addon h4{font-size:16.5px;font-weight:600;display:flex;gap:9px;align-items:center;margin-bottom:6px}
.addon h4 svg{width:19px;height:19px;color:var(--primary);flex:0 0 auto}
.addon p{font-size:14px;color:var(--muted);line-height:1.5}
.addon .pill{display:inline-block;margin-top:10px;font-family:var(--font-h);font-weight:700;color:var(--primary);font-size:13px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:4px 11px}

/* PRICING TIERS */
.billing-toggle{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px;gap:4px;margin:26px auto 0}
.billing-toggle button{font-family:var(--font-h);font-weight:600;font-size:14.5px;border:0;background:none;color:var(--muted);padding:9px 18px;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.15s}
.billing-toggle button.on{background:#fff;color:var(--primary);box-shadow:var(--shadow-sm)}
.billing-toggle .save{font-size:11px;font-weight:700;color:var(--accent-ink);background:rgba(232,184,75,.22);padding:2px 8px;border-radius:999px}
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px;align-items:stretch}
.tier{position:relative;background:#fff;border:1px solid var(--line);border-radius:20px;padding:32px 28px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}
.tier.pop{border:2px solid var(--primary);box-shadow:var(--shadow-lg)}
.tier .nm{font-family:var(--font-h);font-weight:700;font-size:20px;color:var(--dark);display:flex;align-items:center;justify-content:space-between;gap:10px}
.badge-pop{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--dark);background:var(--accent);padding:4px 11px;border-radius:999px}
.tier .desc{font-size:14px;color:var(--muted);margin-top:7px;min-height:42px}
.tier .price{margin:16px 0 2px}
.per-m,.per-a{display:flex;align-items:baseline;gap:6px}
.per-a{display:none}
.pricing.annual .per-m{display:none}
.pricing.annual .per-a{display:flex}
.tier .price .n{font-family:var(--font-h);font-weight:700;font-size:46px;line-height:1;color:var(--dark)}
.tier .price .per{font-size:15px;color:var(--muted);font-weight:500}
.tier .seat{font-size:13px;color:var(--muted);margin-bottom:20px;min-height:20px}
.tier .was{font-family:var(--font-h);font-weight:600;font-size:24px;color:var(--muted);text-decoration:line-through;opacity:.7;align-self:center}
.tier .intro-note{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--accent-ink);margin-top:9px}
.tier .intro-note svg{width:14px;height:14px;flex:0 0 auto}
.intro-banner{display:flex;align-items:center;justify-content:center;gap:8px;text-align:center;margin:20px auto 0;font-size:14.5px;font-weight:600;color:var(--accent-ink)}
.intro-banner svg{width:17px;height:17px;flex:0 0 auto}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin:4px 0 26px}
.tier li{display:flex;gap:9px;font-size:14.5px;color:var(--ink);align-items:flex-start;line-height:1.4}
.tier li svg{width:17px;height:17px;color:var(--primary);flex:0 0 auto;margin-top:3px}
.tier li.muted{color:var(--muted)}
.tier li.muted svg{color:var(--line)}
.tier li.star{font-weight:600;color:var(--dark)}
.tier li.star svg{color:var(--accent-d)}
.tier li small{display:block;font-weight:400;font-size:12.5px;color:var(--muted);margin-top:1px}
.tier .btn{margin-top:auto;justify-content:center;width:100%}
.tier .from{font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:500;text-transform:uppercase;letter-spacing:.06em}
.price-notes{margin-top:24px;display:flex;flex-direction:column;gap:8px}
.seat-nudge{display:flex;align-items:flex-start;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 18px;font-size:14.5px;color:var(--ink);max-width:760px}
.seat-nudge svg{width:20px;height:20px;color:var(--primary);flex:0 0 auto;margin-top:2px}
.price-foot{font-size:13px;color:var(--muted);max-width:760px}
.price-incl{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.price-incl span{font-size:12.5px;font-weight:600;color:var(--primary);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 13px}

/* FAQ */
.faq{background:var(--surface)}
.faq-grid{max-width:800px;margin:48px auto 0}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;background:none;border:0;cursor:pointer;padding:24px 4px;text-align:left;font-family:var(--font-h);font-weight:600;font-size:18.5px;color:var(--dark)}
.faq-q .pm{width:30px;height:30px;border-radius:9px;background:#fff;border:1px solid var(--line);color:var(--primary);display:grid;place-items:center;flex:0 0 auto;transition:.2s}
.faq-q .pm svg{width:17px;height:17px;transition:transform .25s}
.faq-item.open .pm{background:var(--primary);color:#fff;border-color:var(--primary)}
.faq-item.open .pm svg{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a p{padding:0 4px 24px;color:var(--muted);font-size:16px;max-width:66ch}

/* FINAL */
.final{background:linear-gradient(160deg,var(--primary),#1d4634);color:#fff;position:relative;overflow:hidden}
.final::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.08) 1px,transparent 0);background-size:28px 28px}
.final-inner{position:relative;text-align:center;max-width:700px;margin:0 auto}
.final h2{color:#fff;font-size:clamp(31px,4.2vw,52px)}
.final p{color:#cfe0d4;font-size:20px;margin:20px auto 32px;max-width:50ch}
.final-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final small{display:block;margin-top:22px;color:#acc4b4;font-size:14px}

/* FOOTER */
footer.ft{background:var(--dark);color:#9db0a3;padding:58px 0 32px}
.ft-top{display:flex;justify-content:space-between;gap:44px;flex-wrap:wrap;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1)}
.ft-brand{max-width:330px}
.ft-brand .logo-word{width:200px;margin-bottom:16px}
.ft-brand p{font-size:14.5px;color:#90a497;line-height:1.6}
.ft-cols{display:flex;gap:56px;flex-wrap:wrap}
.ft-col h5{font-family:var(--font-h);font-weight:600;color:#fff;font-size:14px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:15px}
.ft-col a{display:block;font-size:14.5px;color:#9db0a3;margin-bottom:11px;transition:color .15s}
.ft-col a:hover{color:var(--accent)}
.ft-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:26px;font-size:13.5px;color:#7e9387}
.ft-bot a:hover{color:var(--accent)}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{animation:none!important;scroll-behavior:auto}}

/* PRODUCT PAGE HERO */
.prod-hero .hero-inner{grid-template-columns:1fr 1.4fr;padding-top:92px;padding-bottom:100px;align-items:center}
.prod-hero h1{font-size:clamp(34px,4.8vw,56px);letter-spacing:-.025em}
.prod-mockup{position:relative;width:calc(100% + 60px);max-width:none}
.prod-mockup img{width:100%;display:block}
/* Placeholder shown while image is missing (remove once assets/product-hero.png is in place) */
.prod-mockup-ph{display:none;aspect-ratio:16/10;border-radius:18px;background:linear-gradient(135deg,var(--dark) 0%,var(--primary) 100%);align-items:center;justify-content:center;flex-direction:column;gap:12px;color:rgba(255,255,255,.55);font-family:var(--font-h);font-size:15px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.prod-mockup.noimg .prod-mockup-ph{display:flex}
.prod-mockup.noimg img{display:none}

@media (max-width:1024px){
  .hero-inner{grid-template-columns:1fr 1fr;gap:36px}
  .loc-grid{grid-template-columns:repeat(2,1fr)}
  .gal-grid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .addons{grid-template-columns:1fr}
}
@media (max-width:880px){
  .nav-links{display:none}
  .menu-btn{display:block}
  .nav-links.open{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;background:#fff;border-bottom:1px solid var(--line);padding:20px 24px;gap:18px;box-shadow:var(--shadow)}
  .hero-inner{grid-template-columns:1fr;padding-top:32px;padding-bottom:48px}
  .hero-visual{margin-top:10px}
  /* product hero: stack copy above, image below at natural size */
  .prod-hero .hero-inner{grid-template-columns:1fr}
  .prod-mockup{width:100%;margin-top:32px}
  .phone{width:262px}
  .fb-1{left:-10px;top:18px}.fb-2{right:-6px;bottom:48px}
  .sol-grid{grid-template-columns:1fr;gap:40px}
  .floor-grid{grid-template-columns:1fr;gap:40px}
  .floor-visual{order:-1}
  .feat-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .prob-grid{grid-template-columns:1fr}
  .price-wrap{grid-template-columns:1fr}
  .tiers{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto}
  .section{padding:72px 0}
  .demo-panes{grid-template-columns:1fr;aspect-ratio:auto;gap:12px}
  .pane{min-height:336px}
  .cmp-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .cmp-grid{min-width:880px}
}
@media (max-width:560px){
  body{font-size:16px}
  .wrap{padding:0 18px}
  .nav-inner{padding:0 18px}
  .hero h1{font-size:35px}
  .hero p.sub{font-size:17.5px}
  .btn{font-size:16px;padding:13px 22px}
  .hero-cta .btn{flex:1 1 100%;justify-content:center}
  .floor-badges{grid-template-columns:1fr}
  .loc-grid{grid-template-columns:1fr}
  .price-feats{grid-template-columns:1fr}
  .price-card{padding:30px 24px}
  .price-amt .n{font-size:54px}
  .types .wrap{gap:12px 20px}
  .type-pill{font-size:16px}
  .demo-coach{font-size:13.5px;padding:10px 15px;gap:9px}
  .float-badge{font-size:12px;padding:9px 11px}
  .faq-q{font-size:16.5px}
  .ft-top{gap:30px}.ft-cols{gap:34px}
  .page-intro .wrap{padding-top:46px;padding-bottom:46px}
}
/* DEMO REQUEST FORM */
.final-inner{max-width:800px} /* allow form card room */
.final p{margin-bottom:10px}  /* tighten gap above form card */

.demo-form-wrap{max-width:520px;margin:28px auto 0;background:#fff;border-radius:20px;padding:30px 32px 32px;box-shadow:0 8px 40px rgba(21,46,32,.30);text-align:left}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-field{margin-bottom:15px;display:flex;flex-direction:column;gap:6px}
.form-field:last-of-type{margin-bottom:0}
.form-field label,.form-field>span{font-size:13px;font-weight:700;color:var(--dark);letter-spacing:.01em;text-transform:uppercase}
.form-field input[type=text],
.form-field input[type=email],
.form-field input[type=tel]{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:11px 14px;font-family:var(--font-b);font-size:15px;color:var(--ink);background:#fff;outline:none;transition:border-color .15s,box-shadow .15s}
.form-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(42,92,69,.12)}
.form-field input::placeholder{color:#b4c0b8}
.form-radios{display:flex;gap:10px;flex-wrap:wrap;margin-top:2px}
.radio-opt{display:flex;align-items:center;gap:7px;font-size:14.5px;font-weight:500;color:var(--ink);cursor:pointer;background:var(--surface);border:1.5px solid var(--line);border-radius:999px;padding:7px 15px;transition:border-color .15s,background .15s;user-select:none}
.radio-opt input[type=radio]{display:none}
.radio-opt.selected,.radio-opt:has(input:checked){border-color:var(--primary);background:rgba(42,92,69,.1);color:var(--primary);font-weight:600}
.form-submit{width:100%;justify-content:center;margin-top:18px;font-size:16px;padding:15px 24px}
.form-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}

.form-success{text-align:center;padding:10px 0 6px}
.form-success-ic{width:54px;height:54px;border-radius:50%;background:rgba(42,92,69,.12);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.form-success h3{font-size:21px;color:var(--dark);margin-bottom:8px}
.form-success p{font-size:15px;color:var(--muted);line-height:1.55}

.form-error-msg{display:none;align-items:center;gap:8px;color:#b9433f;font-size:14px;font-weight:600;margin-top:10px;padding:10px 14px;background:rgba(185,67,63,.07);border-radius:10px}
.form-error-msg:not([hidden]){display:flex}
.form-error-msg a{color:#b9433f;text-decoration:underline}

@media(max-width:700px){
  .cmp-wrap{display:none}
  .cmp-mobile{display:flex;flex-direction:column;gap:14px}
  .demo-form-wrap{padding:24px 20px}
  .form-row{grid-template-columns:1fr}
}
