:root{
  --bg:#0F0E0C; --bg2:#1A1916; --bg3:#252320; --bg4:#2F2D2A; --bg5:#3A3835;
  --ink:#F2EFE8; --ink1:#F2EFE8; --ink2:#B8B4AC; --ink3:#6E6B64; --ink4:#3A3835;
  --gold:#C9A84C; --gold-d:#7A6128; --gold-bg:rgba(201,168,76,.09);
  --teal:#2DC98A; --teal-d:#0E6B47; --teal-bg:rgba(45,201,138,.09);
  --red:#E05252; --red-d:#7A2020; --red-bg:rgba(224,82,82,.09);
  --amber:#E09040; --amber-bg:rgba(224,144,64,.09);
  --blue:#5B8DEF; --blue-bg:rgba(91,141,239,.09);
  --purple:#9B72EF; --purple-bg:rgba(155,114,239,.09);
  --border:rgba(242,239,232,.08); --border2:rgba(242,239,232,.15);
  --r:14px; --r-lg:20px; --nav-h:68px;
  --fd:'Playfair Display',Georgia,serif; --fb:'DM Sans',sans-serif;
  --fs:'DM Sans',sans-serif;
  --card:#1A1916;
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --section-v: 100px; --section-h: 40px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--bg);color:var(--ink);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
button{font-family:var(--fb);cursor:pointer}
input,textarea,select{font-family:var(--fb);font-size:16px}
a{text-decoration:none;color:inherit}
.page{display:none;min-height:100vh}
.l-section{padding:var(--section-v) var(--section-h);position:relative;z-index:1}

.page.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes scaleIn{from{transform:scale(.94);opacity:0}to{transform:none;opacity:1}}
#page-landing{background:var(--bg);overflow-x:hidden}

/* ── SPLASH SCREEN ── */
.splash-screen {
  position: fixed;
  inset: 0;
  background: var(--bg);
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.5s ease, visibility 0.5s;
}
.splash-screen.loaded {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.splash-content {
  text-align: center;
}
.splash-logo {
  width: 80px;
  height: 80px;
  border-radius: 20px;
  margin-bottom: 24px;
  box-shadow: 0 20px 40px rgba(0,0,0,0.4);
}
.splash-logo.pulse {
  animation: splash-pulse 2s infinite ease-in-out;
}
@keyframes splash-pulse {
  0% { transform: scale(0.95); opacity: 0.8; }
  50% { transform: scale(1.05); opacity: 1; }
  100% { transform: scale(0.95); opacity: 0.8; }
}
.splash-loader {
  width: 40px;
  height: 2px;
  background: var(--bg3);
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  border-radius: 2px;
}
.splash-loader::after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: var(--gold);
  animation: splash-load 1.5s infinite ease-in-out;
}
@keyframes splash-load {
  0% { left: -100%; }
  100% { left: 100%; }
}
.l-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 40px;display:flex;align-items:center;justify-content:space-between;transition:all .3s}
.l-nav.s{background:rgba(15,14,12,.92);border-bottom:1px solid var(--border);backdrop-filter:blur(14px)}
.l-logo{display:flex;align-items:center;gap:10px;font-family:'Playfair Display',Georgia,serif;font-size:20px;font-weight:400;letter-spacing:.8px}
.l-logo img{width:32px;height:32px;border-radius:8px;object-fit:cover}
.l-links{display:flex;gap:28px;align-items:center}
.l-links a{font-size:14px;color:var(--ink2);transition:color .15s}
.l-links a:hover{color:var(--ink)}
.btn-p{background:var(--gold);color:var(--bg);padding:10px 24px;border-radius:99px;border:none;cursor:pointer;font-size:14px;font-weight:500;letter-spacing:.3px;transition:all .15s}
.btn-p:hover{background:#DDB85A;transform:translateY(-1px)}
.btn-g{cursor:pointer;background:transparent;color:var(--ink2);padding:10px 20px;border-radius:99px;border:1px solid var(--border2);font-size:14px;transition:all .15s}
.btn-g:hover{color:var(--ink);background:var(--bg2)}
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;position:relative;z-index:1}
.hero-eye{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:22px;opacity:0;animation:fadeUp .6s .1s ease forwards}
.hero-h{font-family:var(--fd);font-size:clamp(46px,8vw,86px);line-height:1.04;letter-spacing:-.5px;color:var(--ink);margin-bottom:22px;max-width:780px;opacity:0;animation:fadeUp .7s .2s ease forwards}
.hero-h em{font-style:italic;color:var(--gold)}
.hero-sub{font-size:18px;color:var(--ink2);line-height:1.6;max-width:480px;margin:0 auto 12px;animation:fadeUp .6s .3s ease both}
.hero-safe-num{font-family:var(--fd);font-size:clamp(52px,10vw,96px);color:var(--teal);line-height:1;letter-spacing:-3px;margin:20px 0 6px;animation:fadeUp .6s .35s ease both}
.hero-safe-label{font-size:13px;color:var(--ink3);letter-spacing:.05em;text-transform:uppercase;margin-bottom:30px;animation:fadeUp .5s .4s ease both}
.hero-cta{display:flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp .7s .5s ease forwards}
.hero-cta .btn-p{padding:14px 36px;font-size:16px}
.hero-note{font-size:12px;color:var(--ink3);margin-top:14px}
.preview-calc{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px;max-width:560px;margin:40px auto 0;animation:fadeUp .6s .5s ease both}
.pc-title{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--gold);margin-bottom:18px}
.pc-fields{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:16px}
.pc-field label{display:block;font-size:10px;color:var(--ink3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px}
.pc-field input{width:100%;padding:9px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);color:var(--ink);font-size:15px;outline:none;transition:border-color .15s;font-family:var(--fb)}
.pc-field input:focus{border-color:var(--gold)}
.pc-result{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.pc-res-item{background:var(--bg3);border-radius:var(--r);padding:12px;text-align:center}
.pc-res-val{font-family:var(--fd);font-size:22px;color:var(--ink);line-height:1;margin-bottom:3px}
.pc-res-val.teal{color:var(--teal)}
.pc-res-val.amber{color:var(--amber)}
.pc-res-lbl{font-size:10px;color:var(--ink3);text-transform:uppercase;letter-spacing:.06em}
.pc-cta{margin-top:16px;text-align:center;font-size:13px;color:var(--ink3)}
.pc-cta a{color:var(--gold);cursor:pointer;text-decoration:underline}
.stats-bar{padding:40px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;justify-content:center;gap:60px;flex-wrap:wrap;position:relative;z-index:1;opacity:0;animation:fadeUp .7s .7s ease forwards}
.s-item{text-align:center}
.s-num{font-family:var(--fd);font-size:34px;color:var(--ink);line-height:1;margin-bottom:3px}
.s-desc{font-size:12px;color:var(--ink3)}
.before-after{max-width:900px;margin:0 auto}

.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:40px}
.ba-col{border-radius:var(--r-lg);padding:30px 28px;border:1px solid var(--border)}
.ba-col.before{background:var(--bg2)}
.ba-col.after{background:linear-gradient(135deg,rgba(45,201,138,.08),rgba(201,168,76,.05));border-color:rgba(45,201,138,.2)}
.ba-head{display:flex;align-items:center;gap:10px;margin-bottom:20px}
.ba-badge{font-size:11px;font-weight:500;padding:3px 10px;border-radius:99px;letter-spacing:.08em}
.ba-badge.before{background:rgba(224,82,82,.12);color:var(--red)}
.ba-badge.after{background:rgba(45,201,138,.12);color:var(--teal)}
.ba-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;font-size:14px;color:var(--ink2);line-height:1.5}
.ba-item::before{content:'';width:6px;height:6px;border-radius:50%;margin-top:6px;flex-shrink:0}
.ba-col.before .ba-item::before{background:var(--red);opacity:.5}
.ba-col.after .ba-item::before{background:var(--teal)}
.features{max-width:1080px;margin:0 auto}

.sec-lbl{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;text-align:center}
.sec-title{font-family:var(--fd);font-size:clamp(30px,4vw,46px);text-align:center;color:var(--ink);margin-bottom:56px;line-height:1.2}
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2px}
.feat-card{background:var(--bg2);padding:34px 30px;border:1px solid var(--border);transition:all .2s}
.feat-card:hover{background:var(--bg3);border-color:var(--border2)}
.feat-card:first-child{border-radius:var(--r-lg) 0 0 0}
.feat-card:nth-child(3){border-radius:0 var(--r-lg) 0 0}
.feat-card:nth-child(4){border-radius:0 0 0 var(--r-lg)}
.feat-card:last-child{border-radius:0 0 var(--r-lg) 0}
.feat-card.clickable{cursor:pointer;position:relative}
.feat-card.clickable:hover{background:var(--bg3);border-color:var(--gold);transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.3)}
.feat-card.clickable::after{content:'→';position:absolute;bottom:24px;right:24px;font-size:18px;color:var(--gold);opacity:0;transition:all .2s;transform:translateX(-10px)}
.feat-card.clickable:hover::after{opacity:1;transform:none}
.feat-icon{font-size:28px;margin-bottom:14px;line-height:1}
.feat-t{font-size:17px;font-weight:500;margin-bottom:9px}
.feat-b{font-size:13px;color:var(--ink2);line-height:1.7}
.clickable-feature{cursor:pointer;transition:color .15s}
.clickable-feature:hover{color:var(--gold)!important}
.how{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:52px}
.step-c{width:46px;height:46px;border-radius:50%;border:1px solid var(--gold-d);color:var(--gold);font-family:var(--fd);font-size:19px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.step-t{font-size:15px;font-weight:500;margin-bottom:7px}
.step-b{font-size:13px;color:var(--ink2);line-height:1.7;max-width:240px;margin:0 auto}
.pricing{max-width:1020px;margin:0 auto}

.billing-toggle{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:40px}
.billing-toggle span{font-size:13px;color:var(--ink2)}
.billing-toggle span.active{color:var(--ink);font-weight:500}
.toggle-track{width:48px;height:26px;background:var(--bg3);border:1px solid var(--border2);border-radius:99px;cursor:pointer;position:relative;transition:background .2s}
.toggle-track.on{background:var(--bg4);border-color:var(--gold)}
.toggle-thumb{width:18px;height:18px;background:var(--ink3);border-radius:50%;position:absolute;top:3px;left:4px;transition:all .25s cubic-bezier(0.4, 0, 0.2, 1)}
.toggle-track.on .toggle-thumb{transform:translateX(22px);background:var(--gold)}
.billing-save-badge{background:rgba(45,201,138,.15);color:var(--teal);border:1px solid rgba(45,201,138,.25);border-radius:99px;font-size:11px;font-weight:500;padding:2px 10px}
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:stretch}
.price-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:30px 26px;position:relative;display:flex;flex-direction:column;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1)}
.price-card .price-feats{flex:1}
/* Tier Themes */
.price-card.trial{border-color:rgba(45,201,138,.3);background:linear-gradient(135deg,var(--bg2),rgba(45,201,138,.04))}
.price-card.trial .btn-p{background:var(--teal)}
.price-card.trial .btn-p:hover{background:#3BDCA0}
.price-card.trial .price-outcome{color:var(--teal)}


.price-card.featured{border:2px solid var(--gold);background:linear-gradient(135deg,var(--bg2),rgba(201,168,76,.08));box-shadow:0 20px 40px -12px rgba(201,168,76,.25);z-index:2}
.price-card.featured .btn-p{background:var(--gold)}
.price-card.featured .btn-p:hover{background:#DDB85A}
.price-card.featured .price-outcome{color:var(--gold)}
.price-card.featured .price-badge{background:var(--gold)}

/* @media(min-width:681px){.price-card.featured{transform:scale(1.04)}} */

.price-card.premium .price-badge{background:var(--purple)}

.price-card.enterprise{border-color:rgba(45,201,138,.35);background:linear-gradient(135deg,var(--bg2),rgba(45,201,138,.04))}
.price-card.enterprise .btn-p{background:var(--teal)}
.price-card.enterprise .btn-p:hover{background:#3BDCA0}
.price-card.enterprise .price-outcome{color:var(--teal)}
.price-card.enterprise .price-badge{background:var(--teal)}


.price-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--bg);padding:3px 14px;border-radius:99px;font-size:11px;font-weight:500;white-space:nowrap}
.price-badge.teal{background:var(--teal);color:var(--bg)}
.price-tier{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink3);margin-bottom:10px}
.price-val{font-family:'Playfair Display',Georgia,serif;font-size:48px;line-height:1;margin-bottom:4px}
.price-val span{font-size:18px;color:var(--ink3)}
.price-billed{font-size:11px;color:var(--ink3);margin-bottom:10px;min-height:16px}
.price-outcome{font-size:15px;color:var(--gold);font-style:italic;margin-bottom:10px}
.price-outcome.teal{color:var(--teal)}
.price-desc{font-size:13px;color:var(--ink2);margin-bottom:20px;line-height:1.6}
.price-feats{list-style:none;margin-bottom:22px}
.price-feats li{font-size:13px;color:var(--ink2);padding:5px 0;border-bottom:1px solid var(--border)}
.price-feats li:last-child{border-bottom:none}
.price-feats li.clickable-feature{cursor:pointer;transition:all .15s}
.price-feats li.clickable-feature:hover{color:var(--gold);background:rgba(201,168,76,.03);padding-left:4px}
.price-feats li.clickable-feature::after{content:' →';opacity:0;transition:all .15s}
.price-feats li.clickable-feature:hover::after{opacity:1}
.land-cta{padding:var(--section-v) var(--section-h);text-align:center;border-top:1px solid var(--border);background:radial-gradient(ellipse 55% 35% at 50% 50%,rgba(201,168,76,.07) 0%,transparent 70%)}
.land-cta h2{font-family:var(--fd);font-size:clamp(30px,5vw,52px);margin-bottom:18px}
.land-cta p{font-size:15px;color:var(--ink2);margin-bottom:36px}
.land-footer{padding:28px 40px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--ink3);flex-wrap:wrap;gap:10px}
.land-footer a{color:var(--ink3);text-decoration:none;transition:all .2s;border-bottom:1px solid transparent}
.land-footer a:hover{color:var(--gold);border-bottom-color:rgba(201,168,76,.3)}
.land-footer a:active{transform:scale(.95);opacity:.7}
.l-menu-btn{display:none;background:none;border:none;color:var(--ink2);padding:4px;cursor:pointer}
.mobile-menu{display:none;flex-direction:column;gap:12px;padding:16px 20px 20px;background:var(--bg2);border-bottom:1px solid var(--border);position:fixed;top:50px;left:0;right:0;z-index:200}.mobile-menu.on{display:flex}
.mobile-menu.on{display:flex}
.mobile-menu a{font-size:15px;color:var(--ink2);padding:6px 0;border-bottom:1px solid var(--border)}
.use-case-calc{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;max-width:520px;margin:32px auto 0;text-align:left;animation:fadeUp .6s .45s ease both}
.ucc-title{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--gold);margin-bottom:14px;text-align:center}
.ucc-fields{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px}
.ucc-field label{display:block;font-size:10px;color:var(--ink3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px}
.ucc-field input{width:100%;padding:9px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);color:var(--ink);font-size:15px;outline:none;transition:border-color .15s;font-family:var(--fb)}
.ucc-field input:focus{border-color:var(--gold)}
.ucc-result{background:var(--bg3);border-radius:var(--r);padding:14px 16px;margin-bottom:12px;text-align:center}
.ucc-res-main{display:flex;align-items:baseline;justify-content:center;gap:10px;margin-bottom:5px}
.ucc-label{font-size:12px;color:var(--ink3)}
.ucc-num{font-family:var(--fd);font-size:42px;color:var(--teal);letter-spacing:-2px;line-height:1}
.ucc-res-sub{display:flex;gap:8px;justify-content:center;font-size:12px;color:var(--ink3)}
.ucc-cta{font-size:13px;color:var(--ink3);text-align:center}
.ucc-cta a{color:var(--gold);cursor:pointer;text-decoration:underline}
.compare-section{max-width:900px;margin:0 auto}

.compare-table{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.ct-head,.ct-row{display:grid;grid-template-columns:130px 1fr 1fr 1fr 1fr 1fr}
.ct-head{background:var(--bg3);border-bottom:1px solid var(--border)}
.ct-cell{padding:11px 14px;font-size:12px;color:var(--ink2)}
.ct-head .ct-cell{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink3)}
.ct-app{font-weight:500;color:var(--ink)}
.ct-row{border-bottom:1px solid var(--border)}
.ct-row:last-child{border-bottom:none}
.ct-row:hover{background:var(--bg2)}
.ct-monivo{background:rgba(45,201,138,.04)}
.ct-monivo .ct-app{color:var(--teal)}
.tick{color:var(--teal)}
.cross{color:var(--ink3);opacity:.6}
.minus{color:var(--amber)}
.ucc-score-bar{height:6px;background:var(--bg3);border-radius:3px;overflow:hidden;margin-bottom:0}
.ucc-score-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--red),var(--amber),var(--teal));transition:width .6s ease}
.ap-btn{padding:6px 12px;border-radius:99px;border:1px solid var(--border);background:var(--bg2);font-size:12px;color:var(--ink2);cursor:pointer;transition:all .14s;white-space:nowrap}
.ap-btn:hover{border-color:var(--border2);color:var(--ink)}
.ap-btn.on{background:var(--gold-bg);border-color:var(--gold-d);color:var(--gold)}
.ht-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}
.ht-bar{width:100%;border-radius:3px 3px 0 0;min-height:4px;background:var(--teal);transition:height .5s ease}
.ht-label{font-size:9px;color:var(--ink3);text-align:center}
.bm-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.bm-cat{font-size:12px;color:var(--ink2);width:72px;flex-shrink:0}
.bm-bars{flex:1;display:flex;flex-direction:column;gap:3px}
.bm-bar-wrap{position:relative;height:16px;background:var(--bg2);border-radius:3px;overflow:hidden}
.bm-bar-you{height:100%;border-radius:3px;transition:width .5s}
.bm-bar-avg{position:absolute;top:0;height:100%;background:rgba(255,255,255,.08);border-radius:3px}
.bm-labels{display:flex;justify-content:space-between;font-size:9px;color:var(--ink3)}
.bm-badge{font-size:10px;padding:1px 7px;border-radius:99px;flex-shrink:0}
.bm-badge.good{background:var(--teal-bg);color:var(--teal)}
.bm-badge.over{background:var(--amber-bg);color:var(--amber)}
.si-row{display:flex;justify-content:space-between;align-items:baseline;padding:5px 0;border-bottom:1px solid var(--border);font-size:13px}
.si-row:last-child{border:none}
.si-label{color:var(--ink2)}
.si-val{font-family:var(--fd);font-size:16px;color:var(--teal)}
.si-cta{margin-top:10px;padding:8px 12px;background:var(--teal-bg);border:1px solid rgba(45,201,138,.2);border-radius:var(--r);font-size:12px;color:var(--teal);line-height:1.5}
.shock-section{max-width:960px;margin:0 auto;text-align:center}

.shock-section .sec-title em{font-style:italic;color:var(--red)}
.shock-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:44px;text-align:left}
.shock-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px 20px;transition:border-color .2s}
.shock-item:hover{border-color:var(--border2)}
.shock-item.shock-total{background:linear-gradient(135deg,rgba(45,201,138,.08),rgba(201,168,76,.05));border-color:rgba(45,201,138,.2)}
.shock-icon{font-size:24px;margin-bottom:10px}
.shock-cat{font-size:11px;text-transform:uppercase;letter-spacing:.09em;color:var(--ink3);margin-bottom:6px}
.shock-amt{font-family:var(--fd);font-size:34px;color:var(--ink);line-height:1;margin-bottom:5px}
.shock-amt span{font-size:14px;color:var(--ink3)}
.shock-big{font-size:40px;color:var(--teal)}
.shock-sub{font-size:12px;color:var(--ink3);line-height:1.5}
.health-section{max-width:900px;margin:0 auto}

.health-demo{display:grid;grid-template-columns:160px 1fr;gap:48px;align-items:center;margin-top:48px;max-width:700px;margin-left:auto;margin-right:auto}
.hd-score-wrap{position:relative;width:140px;height:140px;flex-shrink:0}
.hd-score-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.hd-score-num{font-family:var(--fd);font-size:44px;line-height:1;color:var(--ink)}
.hd-score-lbl{font-size:12px;color:var(--ink3)}
.hd-factor{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.hd-factor-label{font-size:12px;color:var(--ink2);width:130px;flex-shrink:0}
.hd-factor-bar{flex:1;height:5px;background:var(--bg3);border-radius:3px;overflow:hidden}
.hd-factor-bar div{height:100%;border-radius:3px;transition:width .5s}
.hd-factor-val{font-size:12px;color:var(--ink3);width:24px;text-align:right}
.hd-note{font-size:11px;color:var(--ink3);margin-top:4px;font-style:italic}
.forecast-viz-section{max-width:900px;margin:0 auto}

.fv-demo{display:grid;grid-template-columns:1fr auto 1fr;gap:20px;align-items:center;margin-top:44px}
.fv-scenario{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px}
.fv-scenario.better{border-color:rgba(45,201,138,.25);background:linear-gradient(135deg,rgba(45,201,138,.06),transparent)}
.fv-label{font-size:12px;color:var(--ink3);margin-bottom:14px;text-transform:uppercase;letter-spacing:.08em}
.fv-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:12px;color:var(--ink2)}
.fv-bar-row span:first-child{width:54px;flex-shrink:0}
.fv-bar-row span:last-child{width:38px;text-align:right;flex-shrink:0}
.fv-bar-wrap{flex:1;height:8px;background:var(--bg3);border-radius:4px;overflow:hidden}
.fv-bar{height:100%;border-radius:4px;transition:width .6s}
.fv-result{font-size:13px;color:var(--ink2);margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}
.fv-result.better{color:var(--teal)}
.fv-result strong{color:var(--ink)}
.fv-delta{display:inline-block;background:var(--teal-bg);color:var(--teal);font-size:11px;padding:1px 7px;border-radius:99px;margin-left:6px}
.fv-arrow{font-size:24px;color:var(--ink3);text-align:center}
.trust-bar{display:flex;gap:20px;flex-wrap:wrap;justify-content:center;margin-top:20px;animation:fadeUp .5s .6s ease both}
.trust-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink3)}
.trust-item svg{opacity:.5;flex-shrink:0}
.product-preview{max-width:1160px;margin:0 auto}

.screens-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.screen-card{display:flex;flex-direction:column;gap:14px}
.screen-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--gold);text-align:center}
.screen-mock{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;flex:1}
.screen-desc{font-size:13px;color:var(--ink2);line-height:1.6;text-align:center}
.sm-topbar{display:flex;gap:5px;padding:10px 12px;background:rgba(255,255,255,.03);border-bottom:1px solid var(--border)}
.sm-dot{width:6px;height:6px;border-radius:50%;background:var(--border2)}
.sm-sts-card{background:linear-gradient(135deg,rgba(45,201,138,.12),rgba(201,168,76,.06));border-bottom:1px solid rgba(45,201,138,.15);padding:14px}
.sm-sts-eye{font-size:8px;text-transform:uppercase;letter-spacing:.1em;color:var(--teal);margin-bottom:4px}
.sm-sts-num{font-family:var(--fd);font-size:36px;color:var(--ink);letter-spacing:-1px;line-height:1;margin-bottom:3px}
.sm-sts-sub{font-size:10px;color:var(--ink2);margin-bottom:8px}
.sm-sts-bar{height:3px;background:rgba(45,201,138,.15);border-radius:2px;overflow:hidden}
.sm-sts-fill{height:100%;background:var(--teal);border-radius:2px}
.sm-score-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border)}
.sm-score-ring{position:relative;width:44px;height:44px;flex-shrink:0}
.sm-score-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:13px}
.sm-score-text{flex:1}
.sm-score-title{font-size:11px;font-weight:500;margin-bottom:4px}
.sm-score-pills{display:flex;gap:4px;flex-wrap:wrap}
.sm-pill{font-size:9px;padding:1px 6px;border-radius:99px}
.sm-pill.g{background:rgba(45,201,138,.15);color:var(--teal)}
.sm-pill.a{background:rgba(201,168,76,.15);color:var(--gold)}
.sm-forecast{padding:10px 14px}
.sm-fc-row{display:flex;justify-content:space-between;font-size:11px;color:var(--ink2);padding:3px 0;border-bottom:1px solid var(--border)}
.sm-fc-row:last-child{border:none}
.sm-fc-row.bold{color:var(--ink);font-weight:500}
.sm-fc-row .teal{color:var(--teal)}
.sm-income-anchor{padding:12px 14px;border-bottom:1px solid var(--border)}
.sm-ia-label{font-size:8px;text-transform:uppercase;letter-spacing:.09em;color:var(--ink3);margin-bottom:8px}
.sm-ia-flow{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:center;gap:4px;margin-bottom:8px}
.sm-ia-item{text-align:center}
.sm-ia-val{font-family:var(--fd);font-size:14px;line-height:1;margin-bottom:2px}
.sm-ia-val.teal{color:var(--teal)}
.sm-ia-val.amber{color:var(--amber)}
.sm-ia-lbl{font-size:8px;color:var(--ink3);text-transform:uppercase}
.sm-ia-sep{font-size:12px;color:var(--ink3);text-align:center}
.sm-cf-bar{height:5px;background:var(--bg3);border-radius:3px;overflow:hidden;display:flex;margin-bottom:5px}
.sm-cf-leg{display:flex;gap:8px;font-size:8px;color:var(--ink3)}
.sm-cf-leg i{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:3px;vertical-align:middle}
.sm-daily-big{font-family:var(--fd);font-size:20px;padding:8px 14px;border-bottom:1px solid var(--border);color:var(--teal)}
.sm-daily-big span{font-size:11px;color:var(--ink3);font-family:var(--fb)}
.sm-cat-rows{padding:8px 14px}
.sm-cat-row{display:flex;align-items:center;gap:6px;margin-bottom:7px;font-size:10px;color:var(--ink2)}
.sm-cat-row span:first-child{width:72px;flex-shrink:0}
.sm-cat-row span:last-child{width:60px;text-align:right;flex-shrink:0}
.sm-cat-bar{flex:1;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.sm-cat-bar div{height:100%;border-radius:2px}
.sm-streak{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border)}
.sm-streak-num{font-size:13px;font-weight:500;color:var(--gold)}
.sm-streak-sub{font-size:10px;color:var(--ink3)}
.sm-reco-card{padding:10px 14px;border-bottom:1px solid var(--border)}
.sm-reco-head{display:flex;justify-content:space-between;align-items:flex-start;gap:6px;margin-bottom:5px}
.sm-reco-title{font-size:11px;font-weight:500;color:var(--ink);flex:1}
.sm-reco-imp{font-size:8px;padding:2px 5px;border-radius:99px;flex-shrink:0}
.sm-reco-imp.h{background:rgba(45,201,138,.15);color:var(--teal)}
.sm-reco-imp.m{background:rgba(201,168,76,.15);color:var(--gold)}
.sm-reco-body{font-size:10px;color:var(--ink2);line-height:1.5;margin-bottom:4px}
.sm-reco-save{font-family:var(--fd);font-size:14px;color:var(--teal)}
.sm-subs-card{padding:10px 14px;background:rgba(201,168,76,.05)}
.sm-subs-label{font-size:10px;color:var(--ink2);margin-bottom:3px}
.sm-subs-val{font-size:12px;font-weight:500;color:var(--ink)}
.subs-detect-card{background:rgba(201,168,76,.07);border:1px solid var(--gold-d);border-radius:var(--r-lg);padding:16px;margin-bottom:14px}
.subs-detect-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;margin-bottom:10px}
.subs-detect-badge{font-size:10px;padding:2px 8px;border-radius:99px;background:var(--gold-bg);color:var(--gold)}
.sub-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.sub-row:last-child{border:none}
.sub-name{color:var(--ink2)}
.sub-amt{font-family:var(--fd);font-size:14px;color:var(--ink)}
.sub-flag{font-size:10px;padding:1px 7px;border-radius:99px}
.sub-flag.warn{background:var(--amber-bg);color:var(--amber)}
.sub-flag.ok{background:var(--teal-bg);color:var(--teal)}
.goal-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:border-color .14s}
.goal-card:hover{border-color:var(--border2)}
.goal-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.goal-icon{font-size:18px}
.goal-name{font-size:13px;font-weight:500;flex:1}
.goal-pct{font-size:12px;color:var(--ink3)}
.goal-bar-wrap{height:5px;background:var(--bg3);border-radius:3px;overflow:hidden;margin-bottom:5px}
.goal-bar-fill{height:100%;border-radius:3px;transition:width .5s;background:var(--teal)}
.goal-amounts{display:flex;justify-content:space-between;font-size:11px;color:var(--ink3)}
.goal-empty{color:var(--ink3);font-size:13px;padding:12px 0;text-align:center;border:1px dashed var(--border);border-radius:var(--r);cursor:pointer}
.badge-chip{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;font-size:11px;font-weight:500;border:1px solid}
.badge-chip.gold{background:rgba(201,168,76,.12);color:var(--gold);border-color:var(--gold-d)}
.badge-chip.teal{background:var(--teal-bg);color:var(--teal);border-color:rgba(45,201,138,.25)}
.badge-chip.blue{background:var(--blue-bg);color:var(--blue);border-color:rgba(91,141,239,.25)}
.wr-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;animation:fadeUp .2s ease}
.wr-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.wr-title{font-family:var(--fd);font-size:18px}
.wr-date{font-size:11px;color:var(--ink3)}
.wr-row{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.wr-row:last-child{border:none}
.wr-label{color:var(--ink2)}
.wr-val{font-family:var(--fd);font-size:15px}
.wr-val.over{color:var(--red)}
.wr-val.under{color:var(--teal)}
.wr-cats{margin-top:12px}
.wr-cat-row{display:flex;align-items:center;gap:8px;margin-bottom:7px;font-size:12px;color:var(--ink2)}
.wr-cat-bar{flex:1;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.wr-cat-fill{height:100%;border-radius:2px;background:var(--gold)}
.wr-opp{margin-top:12px;padding:10px 12px;background:var(--teal-bg);border:1px solid rgba(45,201,138,.2);border-radius:var(--r);font-size:13px;color:var(--teal)}
#page-signup,#page-signin{min-height:100vh;display:none;align-items:center;justify-content:center;padding:24px;background:var(--bg)}
#page-signup.active,#page-signin.active,#page-scan.active,#page-payment.active{display:flex}
.auth-card{width:100%;max-width:440px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:40px;animation:fadeUp .4s ease}
.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:26px;font-size:18px;font-weight:500;letter-spacing:.08em}
.auth-logo b{color:var(--gold);font-weight:400}
.auth-h{font-family:var(--fd);font-size:26px;margin-bottom:5px}
.auth-s{font-size:13px;color:var(--ink2);margin-bottom:24px}
.field{margin-bottom:14px}
.field label{display:block;font-size:11px;color:var(--ink2);margin-bottom:5px;letter-spacing:.05em;text-transform:uppercase}
.field input,.field select{width:100%;padding:11px 13px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);color:var(--ink);font-size:14px;outline:none;transition:border-color .15s;-webkit-appearance:none;appearance:none}
.field input:focus,.field select:focus{border-color:var(--gold)}
.field input::placeholder{color:var(--ink3)}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.auth-btn{cursor:pointer;width:100%;padding:13px;background:var(--gold);color:var(--bg);border:none;border-radius:var(--r);font-size:15px;font-weight:500;margin-top:6px;transition:all .15s;letter-spacing:.3px}
.auth-btn:hover{background:#DDB85A}
.auth-btn:active{transform:scale(.98)}
.auth-sw{text-align:center;margin-top:18px;font-size:13px;color:var(--ink3)}
.auth-sw a{color:var(--gold);cursor:pointer}
.auth-sw a:hover{text-decoration:underline}
.auth-err{background:var(--red-bg);border:1px solid var(--red-d);border-radius:var(--r);padding:9px 13px;font-size:13px;color:var(--red);margin-bottom:14px;display:none}
.m-field{margin-bottom:0}
.m-field label{display:block;font-size:10px;color:var(--ink3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.m-field input{width:100%;padding:10px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);color:var(--ink);font-size:14px;outline:none;transition:border-color .15s;font-family:var(--fb);min-width:0}
.m-field input:focus{border-color:var(--gold)}
.budget-setup{margin-top:18px;padding-top:18px;border-top:1px solid var(--border)}
.budget-setup > p{font-size:13px;color:var(--ink2);margin-bottom:14px;line-height:1.6}
.budget-hint{font-size:11px;color:var(--ink3);margin-top:5px}
.income-field{display:flex;align-items:center;gap:8px}
.income-field span{color:var(--ink3);font-size:16px}
.income-field input{flex:1}
#page-app{background:var(--bg)}
#page-app.active{display:block}
.app-top{position:fixed;top:0;left:0;right:0;z-index:80;background:rgba(15,14,12,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);padding:0 20px;height:54px;display:flex;align-items:center;justify-content:space-between}
.top-logo{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:500;letter-spacing:.08em}
.top-logo b{color:var(--gold);font-weight:400}
.top-r{display:flex;align-items:center;gap:10px}
.av{width:30px;height:30px;border-radius:50%;background:var(--gold-bg);border:1px solid var(--gold-d);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;color:var(--gold);cursor:pointer}
.top-home{font-size:11px;color:var(--ink3);background:none;border:1px solid var(--border);border-radius:99px;cursor:pointer;padding:4px 10px;margin-right:6px;transition:color .15s}
.top-home:hover{color:var(--ink)}
.top-so{font-size:11px;color:var(--ink3);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s}
.top-so:hover{color:var(--ink)}
.app-nav{position:fixed;bottom:0;left:0;right:0;z-index:80;height:var(--nav-h);background:rgba(15,14,12,.96);backdrop-filter:blur(14px);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0)}
.nav-b{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px 8px;border:none;background:none;color:var(--ink3);font-size:10px;letter-spacing:.04em;cursor:pointer;transition:color .15s;flex:1;font-family:var(--fb)}
.nav-label{font-size:10px;font-weight:600;letter-spacing:.04em;line-height:1}
.nav-sub{font-size:9px;font-weight:400;letter-spacing:0;color:var(--ink3);opacity:.7;line-height:1;text-align:center;white-space:nowrap}
.nav-b.on .nav-sub{opacity:1;color:var(--gold)}
.nav-b svg{width:20px;height:20px;stroke:currentColor}
.nav-b.on{color:var(--gold)}
.app-scr{display:none;padding:68px 20px calc(var(--nav-h) + 16px);min-height:100vh;animation:fadeUp .22s ease}
.app-scr.on{display:block}
.scr-head{padding-top:10px;margin-bottom:18px}
.scr-title{font-family:var(--fd);font-size:24px;margin-bottom:3px}
.scr-sub{font-size:13px;color:var(--ink3)}
.divider{height:1px;background:var(--border);margin:14px 0}
.tag{display:inline-block;padding:2px 9px;border-radius:99px;font-size:11px;font-weight:500;letter-spacing:.04em}
.tag-g{background:var(--teal-bg);color:var(--teal)}
.tag-a{background:var(--amber-bg);color:var(--amber)}
.tag-r{background:var(--red-bg);color:var(--red)}
.tag-b{background:var(--gold-bg);color:var(--gold)}
.tag-u{background:var(--blue-bg);color:var(--blue)}
.tag-p{background:var(--purple-bg);color:var(--purple)}
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px}
.card+.card{margin-top:10px}
.log-greet{font-size:13px;color:var(--ink3);margin-top:4px;margin-bottom:3px}
.log-date-label{font-family:var(--fd);font-size:21px;margin-bottom:4px}
.daily-avail{display:flex;align-items:center;gap:8px;margin-bottom:20px}
.da-amount{font-size:24px;font-weight:500;color:var(--teal)}
.da-amount.warn{color:var(--amber)}
.da-amount.over{color:var(--red)}
.da-label{font-size:13px;color:var(--ink3)}
.cat-row{display:flex;gap:7px;overflow-x:auto;padding-bottom:4px;margin-bottom:18px;scrollbar-width:none}
.cat-row::-webkit-scrollbar{display:none}
.cp{flex-shrink:0;padding:7px 13px;border-radius:99px;border:1px solid var(--border);background:var(--bg2);font-size:13px;color:var(--ink2);cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .12s;white-space:nowrap}
.cp.on{background:var(--gold);color:var(--bg);border-color:var(--gold)}
.amt-zone{text-align:center;padding:12px 0 18px}
.amt-big{font-family:var(--fd);font-size:64px;color:var(--ink);letter-spacing:-2px;line-height:1;min-height:70px;display:flex;align-items:center;justify-content:center}
.amt-big .cur{font-size:26px;color:var(--ink3);margin-top:6px;margin-right:2px}
.npad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.nk{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:14px 0;text-align:center;font-family:var(--fd);font-size:22px;color:var(--ink);cursor:pointer;user-select:none;transition:all .1s}
.nk:active,.nk.fl{background:var(--bg4);transform:scale(.95)}
.nk.del{font-family:var(--fb);font-size:15px;color:var(--ink2)}
.note-in{width:100%;padding:10px 13px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);color:var(--ink);font-size:14px;outline:none;margin-bottom:11px;transition:border-color .15s}
.note-in::placeholder{color:var(--ink3)}
.note-in:focus{border-color:var(--border2)}
.log-btn{width:100%;padding:14px;background:var(--gold);color:var(--bg);border:none;border-radius:var(--r);font-size:15px;font-weight:500;transition:all .15s;letter-spacing:.3px}
.log-btn:hover:not(:disabled){background:#DDB85A}
.log-btn:active:not(:disabled){transform:scale(.98)}
.log-btn:disabled{opacity:.3;cursor:not-allowed}
.toast{margin-top:12px;padding:13px 15px;border-radius:var(--r);border:1px solid transparent;opacity:0;transform:translateY(5px);transition:all .28s}
.toast.on{opacity:1;transform:none}
.toast.s{background:var(--teal-bg);border-color:rgba(45,201,138,.22)}
.toast.w{background:var(--amber-bg);border-color:rgba(224,144,64,.22)}
.toast.d{background:var(--red-bg);border-color:rgba(224,82,82,.22)}
.toast-lbl{font-size:10px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;margin-bottom:4px}
.toast.s .toast-lbl{color:var(--teal)}
.toast.w .toast-lbl{color:var(--amber)}
.toast.d .toast-lbl{color:var(--red)}
.toast-msg{font-size:13px;color:var(--ink);line-height:1.55}
.td-hero{padding:12px 0 20px;border-bottom:1px solid var(--border);margin-bottom:18px}
.td-big{font-family:var(--fd);font-size:52px;letter-spacing:-2px;line-height:1;margin-bottom:3px}
.td-sub{font-size:13px;color:var(--ink3);margin-bottom:14px}
.prog-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;margin-bottom:16px}
.pc-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.pc-label{font-size:13px;color:var(--ink2)}
.pc-val{font-size:13px;font-weight:500}
.pc-val.g{color:var(--teal)}
.pc-val.w{color:var(--amber)}
.pc-val.r{color:var(--red)}
.prog{height:5px;background:var(--bg3);border-radius:3px;overflow:hidden}
.prog-f{height:100%;border-radius:3px;background:var(--teal);transition:width .6s ease,background .3s}
.prog-f.w{background:var(--amber)}
.prog-f.r{background:var(--red)}
.pc-status{font-size:11px;color:var(--ink3);margin-top:6px}
.entry-list{margin-bottom:14px}
.e-hd{display:flex;justify-content:space-between;margin-bottom:10px}
.e-hd-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink3)}
.e-row{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid var(--border)}
.e-row:last-child{border-bottom:none}
.e-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.e-info{flex:1}
.e-cat{font-size:13px;color:var(--ink)}
.e-note{font-size:11px;color:var(--ink3);margin-top:1px}
.e-right{text-align:right}
.e-amt{font-family:var(--fd);font-size:15px}
.e-time{font-size:10px;color:var(--ink3);margin-top:1px}
.e-new{animation:slideRight .28s ease}
@keyframes slideRight{from{opacity:0;transform:translateX(8px)}to{opacity:1;transform:none}}
.empty-s{text-align:center;padding:44px 0;color:var(--ink3);font-size:13px;line-height:1.9}
.bgt-month-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;padding-top:8px}
.bgt-month{font-family:var(--fd);font-size:20px}
.bgt-edit-btn{padding:6px 14px;border-radius:99px;border:1px solid var(--border2);background:transparent;font-size:12px;color:var(--ink2);transition:all .14s}
.bgt-edit-btn:hover{background:var(--bg2);color:var(--ink)}
.bgt-hero{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;margin-bottom:18px}
.bgt-totals{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;margin-bottom:14px}
.bgt-tot-item{text-align:center;padding:4px 0}
.bgt-tot-item+.bgt-tot-item{border-left:1px solid var(--border)}
.bgt-tot-val{font-family:var(--fd);font-size:22px;line-height:1;margin-bottom:3px}
.bgt-tot-lbl{font-size:11px;color:var(--ink3);text-transform:uppercase;letter-spacing:.06em}
.bgt-ring-wrap{position:relative;width:100px;height:100px;margin:0 auto 10px}
.ring-svg{transform:rotate(-90deg)}
.ring-track{fill:none;stroke:var(--bg3);stroke-width:8}
.ring-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .8s ease}
.ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring-pct{font-family:var(--fd);font-size:20px;line-height:1}
.ring-pct-lbl{font-size:10px;color:var(--ink3)}
.daily-pill{text-align:center;margin-top:8px}
.dp-val{font-size:22px;font-weight:500;color:var(--ink)}
.dp-lbl{font-size:12px;color:var(--ink3);margin-top:2px}
.bgt-group{margin-bottom:14px}
.bgt-group-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 0 8px;cursor:pointer;user-select:none}
.bgt-group-title{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink3);display:flex;align-items:center;gap:8px}
.bgt-group-arrow{font-size:10px;color:var(--ink3);transition:transform .2s}
.bgt-group-arrow.open{transform:rotate(180deg)}
.bgt-group-total{font-size:14px;font-weight:500;color:var(--ink2)}
.bgt-items{overflow:hidden;transition:max-height .3s ease}
.bgt-item{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border)}
.bgt-item:last-child{border-bottom:none}
.bgt-item-left{flex:1}
.bgt-item-name{font-size:14px;color:var(--ink);margin-bottom:2px}
.bgt-item-meta{font-size:11px;color:var(--ink3)}
.bgt-item-bar{flex:1;max-width:80px}
.bgt-item-bar-wrap{height:3px;background:var(--bg3);border-radius:2px;overflow:hidden}
.bgt-item-bar-fill{height:100%;border-radius:2px;transition:width .5s}
.bgt-item-right{text-align:right;min-width:70px}
.bgt-item-amt{font-family:var(--fd);font-size:16px;color:var(--ink)}
.bgt-item-spent{font-size:11px;color:var(--ink3);margin-top:2px}
.bgt-item-input{font-family:var(--fd);font-size:16px;color:var(--gold);background:transparent;border:none;outline:none;text-align:right;width:80px;border-bottom:1px solid var(--gold-d)}
.bgt-item-input:focus{border-color:var(--gold)}
.bgt-add-btn{width:100%;padding:9px;background:transparent;border:1px dashed var(--border2);border-radius:var(--r);font-size:13px;color:var(--ink3);margin-top:8px;transition:all .14s}
.bgt-add-btn:hover{border-color:var(--border2);color:var(--ink);background:var(--bg2)}
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;align-items:flex-end;justify-content:center}
.modal-bg.on{display:flex}
.modal{background:var(--bg2);border-radius:24px 24px 0 0;padding:22px 20px 40px;width:100%;max-width:440px;max-height:85vh;overflow-y:auto;animation:slideUp .25s ease}
.modal-handle{width:34px;height:4px;border-radius:2px;background:var(--bg4);margin:0 auto 18px}
.modal-title{font-family:var(--fd);font-size:20px;margin-bottom:4px}
.modal-sub{font-size:13px;color:var(--ink3);margin-bottom:20px}
.modal-field{margin-bottom:12px}
.modal-field label{display:block;font-size:11px;color:var(--ink2);margin-bottom:5px;letter-spacing:.05em;text-transform:uppercase}
.modal-field input,.modal-field select{width:100%;padding:10px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);color:var(--ink);font-size:14px;outline:none;transition:border-color .15s}
.modal-field input:focus,.modal-field select:focus{border-color:var(--gold)}
.modal-field input::placeholder{color:var(--ink3)}
.modal-2col{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.modal-save{width:100%;padding:13px;background:var(--gold);color:var(--bg);border:none;border-radius:var(--r);font-size:15px;font-weight:500;margin-top:8px;transition:all .15s}
.modal-save:hover{background:#DDB85A}
.modal-cancel{width:100%;padding:11px;background:transparent;border:1px solid var(--border2);border-radius:var(--r);font-size:14px;color:var(--ink2);margin-top:8px;transition:all .14s}
.modal-cancel:hover{background:var(--bg3);color:var(--ink)}
.modal-danger{width:100%;padding:11px;background:transparent;border:1px solid rgba(224,82,82,.3);border-radius:var(--r);font-size:13px;color:var(--red);margin-top:18px;transition:all .14s}
.modal-danger:hover{background:var(--red-bg)}
.period-row{display:flex;gap:6px;margin-bottom:20px;padding-top:6px;flex-wrap:wrap}
.per-btn{padding:6px 14px;border-radius:99px;border:1px solid var(--border);background:transparent;font-size:12px;color:var(--ink2);cursor:pointer;transition:all .12s;font-family:var(--fb)}
.per-btn.on{background:var(--gold);color:var(--bg);border-color:var(--gold)}
.rpt-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:9px;margin-bottom:18px}
.rp-stat{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:13px 15px}
.rp-val{font-family:var(--fd);font-size:24px;line-height:1;margin-bottom:3px}
.rp-lbl{font-size:10px;color:var(--ink3);text-transform:uppercase;letter-spacing:.07em}
.chart-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;margin-bottom:14px}
.chart-lbl{font-size:12px;color:var(--ink2);margin-bottom:14px}
.bar-chart{display:flex;align-items:flex-end;gap:3px;height:110px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;-ms-overflow-style:none}
.bar-chart::-webkit-scrollbar{display:none}
.b-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;min-width:13px}
.b-bar{width:100%;border-radius:3px 3px 0 0;transition:height .5s ease;min-height:3px;background:var(--bg3)}
.b-bar.pk{background:var(--gold)}
.b-bar.td{background:var(--teal)}
.b-lbl{font-size:9px;color:var(--ink3)}
.cb-section{margin-bottom:14px}
.cb-title{font-size:11px;text-transform:uppercase;letter-spacing:.09em;color:var(--ink3);margin-bottom:12px}
.cb-row{display:flex;align-items:center;gap:9px;margin-bottom:10px}
.cb-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.cb-name{font-size:13px;color:var(--ink);flex:1}
.cb-bw{width:70px;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.cb-bf{height:100%;border-radius:2px;transition:width .5s}
.cb-pct{font-size:11px;color:var(--ink3);min-width:30px;text-align:right}
.cb-amt{font-family:var(--fd);font-size:13px;color:var(--ink);min-width:46px;text-align:right}
.hm-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;margin-bottom:14px}
.hm-grid{display:flex;gap:4px;margin-top:12px}
.hm-col{display:flex;flex-direction:column;gap:3px;align-items:center}
.hm-cell{width:16px;height:16px;border-radius:3px;background:var(--bg3)}
.hm-lbl{font-size:9px;color:var(--ink3);margin-top:3px}
.vs-bgt-row{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.vs-item{flex:1;min-width:120px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:12px 13px}
.vs-cat{font-size:12px;color:var(--ink2);margin-bottom:2px}
.vs-vals{display:flex;align-items:baseline;gap:4px}
.vs-spent{font-family:var(--fd);font-size:18px;color:var(--ink)}
.vs-budgeted{font-size:12px;color:var(--ink3)}
.vs-prog{height:3px;background:var(--bg3);border-radius:2px;overflow:hidden;margin-top:6px}
.vs-pf{height:100%;border-radius:2px;transition:width .5s}
.reco-hd{padding:12px 0 18px;border-bottom:1px solid var(--border);margin-bottom:18px}
.reco-title{font-family:var(--fd);font-size:24px;margin-bottom:3px}
.reco-sub{font-size:13px;color:var(--ink3)}
.ai-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:99px;background:var(--gold-bg);border:1px solid var(--gold-d);font-size:11px;color:var(--gold);margin-bottom:16px;letter-spacing:.04em}
.ai-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2s infinite}
.gen-btn{width:100%;padding:13px;border-radius:var(--r);border:1px solid var(--gold-d);background:var(--gold-bg);color:var(--gold);font-size:14px;font-weight:500;transition:all .15s;margin-bottom:18px;font-family:var(--fb)}
.gen-btn:hover:not(:disabled){background:rgba(201,168,76,.15)}
.gen-btn:active:not(:disabled){transform:scale(.98)}
.gen-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.loading-r{display:flex;align-items:center;gap:10px;padding:14px;background:var(--bg2);border-radius:var(--r);border:1px solid var(--border);font-size:13px;color:var(--ink2);margin-bottom:16px}
.spinner{width:17px;height:17px;border-radius:50%;border:2px solid var(--bg3);border-top-color:var(--gold);animation:spin .7s linear infinite;flex-shrink:0}
.reco-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;margin-bottom:12px;animation:scaleIn .35s ease}
.rc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.rc-title{font-size:15px;font-weight:500;color:var(--ink);line-height:1.35;flex:1;padding-right:10px}
.rc-imp{font-size:10px;padding:3px 8px;border-radius:99px;font-weight:500;letter-spacing:.04em;flex-shrink:0}
.rc-imp.h{background:var(--teal-bg);color:var(--teal)}
.rc-imp.m{background:var(--amber-bg);color:var(--amber)}
.rc-imp.i{background:var(--gold-bg);color:var(--gold)}
.rc-body{font-size:13px;color:var(--ink2);line-height:1.7;margin-bottom:12px}
.rc-save{font-family:var(--fd);font-size:20px;color:var(--teal);margin-bottom:2px}
.rc-save-l{font-size:11px;color:var(--ink3)}
.rc-action{margin-top:12px;padding:9px 15px;border-radius:var(--r);background:transparent;border:1px solid var(--border2);color:var(--ink2);font-size:12px;width:100%;transition:all .12s;font-family:var(--fb)}
.rc-action:hover{background:var(--bg3);color:var(--ink)}
.sk-banner{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;margin-bottom:18px;display:flex;align-items:center;gap:14px}
.sk-dots{display:flex;gap:5px;margin-top:8px}
.sd{width:26px;height:26px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--ink3);font-weight:500}
.sd.done{background:var(--teal-bg);border-color:var(--teal-d);color:var(--teal)}
.sd.today{background:var(--gold);border-color:var(--gold);color:var(--bg)}
.sk-num{font-family:var(--fd);font-size:30px;color:var(--gold);line-height:1;margin-bottom:2px}
.sk-lbl{font-size:12px;color:var(--ink2)}
.reco-empty{text-align:center;padding:36px 0;color:var(--ink3);font-size:13px;line-height:1.9;display:none}
.dc-rent{background:#E09040}
.dc-mortgage{background:#E09040}
.dc-utilities{background:#5B8DEF}
.dc-gas{background:#9B72EF}
.dc-groceries{background:#C9A84C}
.dc-dining{background:#2DC98A}
.dc-coffee{background:#C9A84C}
.dc-lunch{background:#2DC98A}
.dc-transport{background:#9B72EF}
.dc-car{background:#9B72EF}
.dc-insurance{background:#5B8DEF}
.dc-health{background:#5B8DEF}
.dc-shopping{background:#D4537E}
.dc-fun{background:#5DCAA5}
.dc-subscriptions{background:#E05252}
.dc-savings{background:#2DC98A}
.dc-investments{background:#C9A84C}
.dc-debt{background:#E05252}
.dc-other{background:#6E6B64}
.dc-bank{background:#6E6B64}
.l-logo span{color:var(--ink);letter-spacing:.12em;font-size:17px;font-family:var(--fb);font-weight:500}
.nav-logo-img{height:38px;width:38px;border-radius:10px;object-fit:cover;transition:transform .2s}
.nav-logo-img:hover{transform:scale(1.05)}
.hero-logo-wrap{margin-bottom:24px;animation:fadeUp .5s .05s ease both}
.hero-logo-img{width:90px;height:90px;border-radius:22px;object-fit:cover;box-shadow:0 0 60px rgba(201,168,76,.25)}
.hero-primary-btn{display:flex;align-items:center;gap:8px;padding:14px 36px;font-size:16px}
.hero-scroll-hint{margin-top:32px;color:var(--ink3);animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
.feat-n{display:none}
.testi-stars{color:var(--gold);font-size:13px;margin-bottom:10px;letter-spacing:2px}
.pricing-section{max-width:800px;margin:0 auto}
.pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:0}
.pricing-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:32px 28px;position:relative}
.pricing-card-pro{border:2px solid var(--gold-d);background:linear-gradient(135deg,var(--bg2) 0%,rgba(201,168,76,.05) 100%)}
.price-pro-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--bg);padding:3px 14px;border-radius:99px;font-size:11px;font-weight:500;letter-spacing:.06em;white-space:nowrap}
.price-features{list-style:none;padding:0;margin-bottom:24px}
.price-features li{font-size:13px;color:var(--ink2);padding:5px 0;border-bottom:1px solid var(--border);line-height:1.5}
.price-features li:last-child{border-bottom:none}
.cta-logo-wrap{display:flex;justify-content:center}
.top-logo-img{width:26px;height:26px;border-radius:7px;object-fit:cover}
.mobile-menu.open{display:flex}
#page-landing::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");pointer-events:none;z-index:0;opacity:.5}
.l-logo b{color:var(--gold);font-weight:400}
.btn-p:active{transform:scale(.97)}
.hero-s{font-size:17px;color:var(--ink2);line-height:1.75;max-width:460px;margin:0 auto 36px;opacity:0;animation:fadeUp .7s .35s ease forwards}
.how-in{max-width:880px;margin:0 auto}
.step{text-align:center}
.testi{max-width:980px;margin:0 auto}
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px}
.testi-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:26px}
.testi-q{font-family:var(--fd);font-style:italic;font-size:15px;color:var(--ink);line-height:1.65;margin-bottom:18px}
.testi-a{font-size:12px;color:var(--ink3)}
.testi-a strong{color:var(--ink2);display:block;margin-bottom:2px}
@keyframes dotPulse{0%,100%{opacity:.35;transform:scale(1)}50%{opacity:1;transform:scale(1.3);background:rgba(201,168,76,.9)}}
.bgt-section-divider{
  display:flex;align-items:center;gap:12px;margin:22px 0 14px;
}
.bgt-section-divider-line{flex:1;height:1px;background:var(--border)}
.bgt-section-badge{
  display:flex;align-items:center;gap:7px;padding:5px 14px;
  border-radius:99px;border:1px solid;font-size:11px;font-weight:500;
  letter-spacing:.07em;text-transform:uppercase;white-space:nowrap;
}
.bgt-section-badge.monthly{border-color:var(--blue-bg);color:var(--blue);background:var(--blue-bg)}
.bgt-section-badge.daily{border-color:var(--gold-bg);color:var(--gold);background:var(--gold-bg)}
.bgt-section-badge.financial{border-color:var(--teal-bg);color:var(--teal);background:var(--teal-bg)}
.bgt-section-desc{font-size:12px;color:var(--ink3);margin-bottom:14px;line-height:1.6;padding:0 2px}
.cat-card{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r);padding:13px 14px;
  margin-bottom:8px;cursor:pointer;transition:border-color .15s;
  display:flex;align-items:center;gap:12px;
}
.cat-card:hover{border-color:var(--border2)}
.cat-card-icon{
  width:36px;height:36px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:17px;flex-shrink:0;background:var(--bg3);
}
.cat-card-body{flex:1;min-width:0}
.cat-card-name{font-size:14px;color:var(--ink);margin-bottom:2px;font-weight:500}
.cat-card-sub{font-size:11px;color:var(--ink3);line-height:1.4}
.cat-card-right{text-align:right;flex-shrink:0}
.cat-card-amt{font-family:'Playfair Display',Georgia,serif;font-size:17px;color:var(--ink)}
.cat-card-freq{font-size:10px;color:var(--ink3);margin-top:1px}
.cat-card-prog{height:3px;background:var(--bg4);border-radius:2px;overflow:hidden;margin-top:7px}
.cat-card-prog-fill{height:100%;border-radius:2px;transition:width .5s ease}
.section-total-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:4px 2px 10px;
}
.section-total-label{font-size:12px;color:var(--ink3)}
.section-total-val{font-family:'Playfair Display',Georgia,serif;font-size:20px;color:var(--ink)}
.bgt-summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}
.bsc{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;text-align:center}
.bsc-val{font-family:'Playfair Display',Georgia,serif;font-size:22px;line-height:1;margin-bottom:4px}
.bsc-lbl{font-size:10px;color:var(--ink3);text-transform:uppercase;letter-spacing:.07em}
.bsc-sub{font-size:10px;color:var(--ink3);margin-top:3px}
.daily-banner{
  background:linear-gradient(135deg,rgba(45,201,138,.1) 0%,rgba(201,168,76,.08) 100%);
  border:1px solid rgba(45,201,138,.2);border-radius:var(--r-lg);
  padding:16px 18px;margin-bottom:20px;
  display:flex;align-items:center;justify-content:space-between;
}
.daily-banner-val{font-family:'Playfair Display',Georgia,serif;font-size:34px;color:var(--teal);line-height:1}
.daily-banner-lbl{font-size:12px;color:var(--ink2);margin-top:3px}
.daily-banner-right{text-align:right}
.daily-banner-days{font-size:13px;color:var(--ink2)}
.daily-banner-elapsed{font-size:11px;color:var(--ink3);margin-top:2px}
.bgt-group,.bgt-group-hd,.bgt-items{all:unset}
.health-score-ring{position:relative;width:88px;height:88px;flex-shrink:0}
.health-ring-svg{transform:rotate(-90deg)}
.health-ring-track{fill:none;stroke:var(--bg3);stroke-width:7}
.health-ring-fill{fill:none;stroke-width:7;stroke-linecap:round;transition:stroke-dashoffset 1s ease,stroke .4s}
.health-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.health-score-num{font-family:'Playfair Display',Georgia,serif;font-size:22px;line-height:1;color:var(--ink)}
.health-score-lbl{font-size:9px;color:var(--ink3);text-transform:uppercase;letter-spacing:.06em}
.health-score-card{display:flex;align-items:center;gap:14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;margin-bottom:12px}
.health-score-title{font-size:15px;font-weight:500;color:var(--ink);margin-bottom:3px}
.health-score-sub{font-size:12px;color:var(--ink2);line-height:1.5}
.health-factors{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.hf-pill{font-size:10px;padding:2px 8px;border-radius:99px;background:var(--bg3);color:var(--ink3);border:1px solid var(--border)}
.hf-pill.good{background:var(--teal-bg);color:var(--teal);border-color:rgba(45,201,138,.2)}
.hf-pill.warn{background:var(--amber-bg);color:var(--amber);border-color:rgba(224,144,64,.2)}
.hf-pill.bad{background:var(--red-bg);color:var(--red);border-color:rgba(224,82,82,.2)}
.sts-hero{background:linear-gradient(135deg,rgba(45,201,138,.12) 0%,rgba(201,168,76,.08) 100%);border:1px solid rgba(45,201,138,.22);border-radius:var(--r-lg);padding:20px 18px;margin-bottom:14px}
.sts-label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--teal);margin-bottom:6px;font-weight:500}
.sts-amount{font-family:'Playfair Display',Georgia,serif;font-size:56px;color:var(--ink);line-height:1;letter-spacing:-2px;margin-bottom:4px}
.sts-sub{font-size:13px;color:var(--ink2);line-height:1.55}
.sts-context{font-size:12px;color:var(--ink3);margin-top:8px;padding-top:8px;border-top:1px solid rgba(45,201,138,.15)}
.sts-bar-wrap{height:4px;background:rgba(45,201,138,.15);border-radius:2px;overflow:hidden;margin-top:10px}
.sts-bar-fill{height:100%;border-radius:2px;background:var(--teal);transition:width .6s ease}
.income-anchor{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;margin-bottom:16px}
.ia-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.ia-title{font-size:12px;text-transform:uppercase;letter-spacing:.09em;color:var(--ink3)}
.ia-edit{font-size:12px;color:var(--gold);background:none;border:none;cursor:pointer;padding:0;font-family:var(--fb)}
.if-item{text-align:center}
.if-val{font-family:'Playfair Display',Georgia,serif;font-size:20px;color:var(--ink);line-height:1;margin-bottom:3px}
.if-lbl{font-size:10px;color:var(--ink3);text-transform:uppercase;letter-spacing:.06em;line-height:1.3}
.if-val.income-col{color:var(--teal)}
.if-val.expense-col{color:var(--amber)}
.if-val.available-col{color:var(--ink)}
.if-arrow{color:var(--ink3);font-size:14px;text-align:center}
.cf-bar{height:8px;background:var(--bg3);border-radius:4px;overflow:hidden;display:flex;margin-bottom:10px}
.cf-seg{height:100%;transition:width .5s ease}
.cf-legend{display:flex;gap:12px;flex-wrap:wrap}
.cf-leg-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--ink3)}
.cf-leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.cfh-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;margin-bottom:10px}
.cfh-label{font-size:12px;color:var(--ink3);margin-bottom:2px}
.cfh-val{font-family:'Playfair Display',Georgia,serif;font-size:22px;color:var(--ink)}
.cfh-status{display:flex;align-items:center;gap:6px;margin-top:4px;font-size:12px}
.cfh-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.cfh-right{text-align:right}
.cfh-pct{font-family:'Playfair Display',Georgia,serif;font-size:28px}
.cfh-pct-lbl{font-size:11px;color:var(--ink3);margin-top:2px}
.progress-hist{margin-bottom:16px}
.ph-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.ph-month{font-size:12px;color:var(--ink3);width:32px;flex-shrink:0}
.ph-bar-wrap{flex:1;height:20px;background:var(--bg2);border-radius:4px;overflow:hidden;position:relative}
.ph-bar-fill{height:100%;border-radius:4px;transition:width .5s ease;display:flex;align-items:center;padding-left:8px}
.ph-bar-label{font-size:11px;font-weight:500;position:absolute;left:8px;top:50%;transform:translateY(-50%);white-space:nowrap}
.ph-delta{font-size:11px;min-width:44px;text-align:right}
.ph-delta.imp{color:var(--teal)}
.ph-delta.worse{color:var(--red)}
.forecast-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;margin-bottom:14px}
.fc-title{font-size:12px;text-transform:uppercase;letter-spacing:.09em;color:var(--ink3);margin-bottom:12px}
.fc-row{display:flex;justify-content:space-between;align-items:baseline;padding:5px 0;border-bottom:1px solid var(--border)}
.fc-row:last-child{border-bottom:none}
.fc-label{font-size:13px;color:var(--ink2)}
.fc-val{font-family:'Playfair Display',Georgia,serif;font-size:16px;color:var(--ink)}
.fc-val.pos{color:var(--teal)}
.fc-val.neg{color:var(--red)}
.bucket-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.bucket-icon{font-size:18px;flex-shrink:0;width:28px;text-align:center}
.alloc-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.alloc-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.alloc-name{font-size:13px;color:var(--ink);flex:1}
.alloc-bar-wrap{width:80px;height:5px;background:var(--bg3);border-radius:3px;overflow:hidden}
.alloc-bar-fill{height:100%;border-radius:3px;transition:width .5s}
.alloc-pct{font-size:12px;color:var(--ink3);min-width:36px;text-align:right}
.alloc-amt{font-family:'Playfair Display',Georgia,serif;font-size:13px;color:var(--ink);min-width:52px;text-align:right}
.daily-msg{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:10px 13px;margin-bottom:14px}
.dm-top{font-size:13px;color:var(--ink);line-height:1.5;margin-bottom:3px}
.dm-sub{font-size:11px;color:var(--ink3)}

@media(max-width:480px){
  .shock-grid{grid-template-columns:1fr}
  .hero-h{font-size:clamp(32px,9vw,44px)}
  .ucc-title{font-size:11px}
  .auth-card{padding:28px 20px}
  .field-2{grid-template-columns:1fr}
  #page-scan .auth-card{padding:24px 16px}
}
@media(max-width:380px){
  .app-scr{padding:56px 12px calc(var(--nav-h) + 10px)}
  .amt-big{font-size:46px}
  .nk{padding:10px 0;font-size:18px}
  .nav-b{font-size:8px;padding:4px 2px}.nav-label{font-size:8px}.nav-sub{font-size:7px}
  .sts-amount{font-size:44px}
}
/* ══════════ MOBILE OVERRIDES ══════════ */

/* Landing page mobile */
@media(max-width:680px){
  .l-nav{padding:14px 20px}
  .l-links{display:none!important}
  .l-menu-btn{display:block!important}
  .hero{padding:90px 18px 50px}
  .hero-h{font-size:clamp(34px,9vw,52px)}
  .use-case-calc{padding:18px}
  .ucc-fields{grid-template-columns:1fr!important}
  .ucc-result{text-align:center}
  .stats-bar{gap:24px;padding:24px 18px}
  .shock-grid{grid-template-columns:1fr 1fr!important}
  .before-after,.features,.forecast-viz-section,.health-section,.shock-section,.product-preview,.pricing,.how,.compare-section,.l-section,.land-cta,.pricing-section,.testi{padding:64px 20px!important}
  
  .ba-grid{grid-template-columns:1fr!important}
  .price-grid{grid-template-columns:1fr!important;gap:20px}
  .steps{grid-template-columns:1fr!important;gap:24px}
  .screens-grid{grid-template-columns:1fr!important}
  .compare-section{padding:52px 18px}
  .ct-head,.ct-row{grid-template-columns:90px 1fr 1fr!important}
  .ct-cell:nth-child(4),.ct-cell:nth-child(5),.ct-cell:nth-child(6){display:none!important}
  .fv-demo{grid-template-columns:1fr!important}
  .fv-arrow{display:none}
  .health-demo{grid-template-columns:1fr!important;text-align:center}
  .hd-score-wrap{margin:0 auto}
  .land-cta{padding:60px 18px}
  .land-footer{flex-direction:column;text-align:center;padding:20px 18px}
  .trust-bar{gap:10px;padding:0 18px}
  .sec-title{font-size:clamp(24px,6vw,36px)}
}

/* Auth pages mobile */
@media(max-width:480px){
  .auth-card{padding:24px 18px;border-radius:16px}
  .field-2{grid-template-columns:1fr!important}
  .m-field-2{grid-template-columns:1fr!important}
}

/* App shell mobile */
@media(max-width:680px){
  .app-top{padding:0 14px;height:50px}
  .top-logo{font-size:16px}
  .top-home{display:none}
  .app-scr{padding:58px 14px calc(var(--nav-h) + 12px + env(safe-area-inset-bottom,0px))!important}
  .app-nav{height:60px;padding:0 2px}
  :root { --nav-h: 60px; }
  .nav-b{font-size:9px;padding:5px 6px;gap:2px}
  .nav-b svg{width:18px;height:18px}
  .scr-title{font-size:20px}
  .amt-big{font-size:52px}
  .nk{padding:12px 0;font-size:20px}
  .feat-grid{grid-template-columns:1fr!important}
  .bgt-summary-cards{grid-template-columns:1fr 1fr!important}
  .modal{padding:24px 18px}
  .m-field-2{grid-template-columns:1fr!important}
  .cat-card-grid{grid-template-columns:1fr!important}
  .reco-grid{grid-template-columns:1fr!important}
  
  .compare-table{font-size:11px}
  .health-score-card{flex-direction:column;align-items:center;text-align:center}
  .ia-flow{gap:6px}
  .ia-sep{font-size:14px}
  .bgt-income-val{font-size:20px}
  .ap-btn{font-size:11px;padding:5px 10px}
}

/* Very small screens */
@media(max-width:360px){
  .hero-h{font-size:30px}
  .npad{gap:5px}
  .nk{padding:10px 0;font-size:18px}
  .amt-big{font-size:44px}
  .ucc-num{font-size:32px}
}

/* Mobile touch fix */
button,a{touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.nk,.cp{-webkit-appearance:none;appearance:none;font-family:inherit}

/* ── Demo timer badge ── */
#demo-timer-badge {
  display: none;
  align-items: center;
  gap: 5px;
  background: var(--gold-bg);
  border: 1px solid var(--gold-d);
  border-radius: 99px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--gold);
  font-family: var(--fb);
  white-space: nowrap;
}
#demo-timer-badge.urgent {
  background: rgba(224,82,82,0.12);
  border-color: rgba(224,82,82,0.3);
  color: #E05252;
  animation: pulse-badge 1s ease-in-out infinite;
}
@keyframes pulse-badge {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.6; }
}

/* ── 7-day trial badge ── */
#trial-days-badge {
  display: none;
  align-items: center;
  gap: 5px;
  background: var(--teal-bg);
  border: 1px solid var(--teal-d);
  border-radius: 99px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--teal);
  font-family: var(--fb);
  white-space: nowrap;
  cursor: default;
}
#trial-days-badge.warn {
  background: rgba(224,144,64,.12);
  border-color: rgba(224,144,64,.35);
  color: var(--amber);
}
#trial-days-badge.urgent {
  background: rgba(224,82,82,0.12);
  border-color: rgba(224,82,82,0.3);
  color: #E05252;
  animation: pulse-badge 1.2s ease-in-out infinite;
}

/* ── Trial-expired overlay ── */
#trial-expired-wall {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(15,14,12,0.97);
  backdrop-filter: blur(10px);
  align-items: center;
  justify-content: center;
  padding: 24px;
}

/* ── OTP boxes ── */
.otp-box {
  width: 46px; height: 54px;
  text-align: center;
  font-family: var(--fd);
  font-size: 24px;
  background: var(--bg3);
  border: 2px solid var(--border2);
  border-radius: var(--r);
  color: var(--ink);
  outline: none;
  transition: border-color .15s;
}
.otp-box:focus { border-color: var(--gold); }
.otp-box.filled { border-color: var(--teal); }

/* ── Password strength ── */
.pw-strength { height: 4px; border-radius: 2px; margin-top: 6px; background: var(--bg3); overflow: hidden; }
.pw-strength-bar { height: 100%; border-radius: 2px; transition: width .3s, background .3s; width: 0; }
.pw-hint { font-size: 11px; color: var(--ink3); margin-top: 5px; line-height: 1.5; }

/* ── LANDING COMPONENTS (SYNCED FROM INTEGRATED) ── */
.sec-lbl {
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
  text-align: center;
}

.land-cta {
  padding: 110px 40px;
  text-align: center;
  border-top: 1px solid var(--border);
  background: radial-gradient(ellipse 55% 35% at 50% 50%, rgba(201,168,76,.07) 0%, transparent 70%);
}
.land-cta h2 {
  font-family: var(--fd);
  font-size: clamp(30px, 5vw, 52px);
  margin-bottom: 18px;
}
.land-cta p {
  font-size: 15px;
  color: var(--ink2);
  margin-bottom: 36px;
}

.land-footer {
  padding: 28px 40px;
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: var(--ink3);
  flex-wrap: wrap;
  gap: 10px;
}

/* ── TESTIMONIALS ── */
.testimonials {
  padding: 88px 40px;
  max-width: 1080px;
  margin: 0 auto;
}
.t-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px;
  margin-top: 48px;
}
.t-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 32px;
  transition: border-color .2s;
}
.t-card:hover { border-color: var(--border2); }
.t-stars {
  font-size: 14px;
  color: var(--gold);
  margin-bottom: 16px;
  letter-spacing: 2px;
}
.t-quote {
  font-size: 15px;
  color: var(--ink2);
  line-height: 1.75;
  margin-bottom: 24px;
}
.t-person {
  display: flex;
  align-items: center;
  gap: 12px;
}
.t-av {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 500;
  flex-shrink: 0;
}
.t-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
}
.t-role {
  font-size: 12px;
  color: var(--ink3);
  margin-top: 2px;
}

@media (max-width: 480px) {
  .land-cta { padding: 80px 24px; }
  .land-footer { justify-content: center; text-align: center; }
  .t-grid { grid-template-columns: 1fr; }
  .t-card { padding: 24px; }
}

/* ═══ NAVIGATION DROPDOWN ═══ */
.nav-dropdown {
  position: relative;
  display: inline-block;
}

.dropdown-trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  color: var(--teal);
  background: transparent;
  border: 1px solid rgba(45,201,138,0.3);
  padding: 6px 14px;
  border-radius: 99px;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
  font-family: var(--fb);
  font-weight: 500;
  height: 32px;
}

.dropdown-trigger:hover {
  background: rgba(45,201,138,0.08);
  border-color: var(--teal);
}

.dropdown-content {
  visibility: hidden;
  opacity: 0;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(10px);
  margin-top: 12px;
  background: rgba(26, 25, 23, 0.95);
  border: 1px solid var(--border);
  border-radius: 16px;
  min-width: 230px;
  box-shadow: 0 15px 40px rgba(0,0,0,0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  z-index: 2000;
  padding: 10px;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.nav-dropdown:hover .dropdown-content,
.dropdown-content.show {
  visibility: visible;
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

/* Triangle indicator */
.dropdown-content::before {
  content: '';
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 6px solid var(--border);
}

.dropdown-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  color: var(--ink2);
  text-decoration: none;
  font-size: 14px;
  border-radius: 10px;
  transition: all 0.15s ease;
  white-space: nowrap;
}

.dropdown-item:hover {
  background: rgba(201, 168, 76, 0.12);
  color: var(--gold);
  transform: translateX(4px);
}

.dropdown-item span {
  font-size: 16px;
}

/* Mobile hide dropdown */
@media (max-width: 800px) {
  .nav-dropdown { display: none; }
  .price-grid { grid-template-columns: 1fr 1fr!important; gap: 15px; }
}

@media (max-width: 600px) {
  .price-grid { grid-template-columns: 1fr!important; }
}

