/* AUTH */
.auth-bg{position:fixed;inset:0;background:rgba(15,23,42,.65);z-index:10000;display:none;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(12px) saturate(160%);-webkit-backdrop-filter:blur(12px) saturate(160%)}
.auth-bg.on{display:flex}
.auth-box{background:var(--sur);border:1px solid var(--brd);border-radius:20px;width:100%;max-width:400px;padding:32px 24px 24px;box-shadow:0 24px 64px rgba(0,0,0,.12),0 0 0 1px rgba(0,0,0,.04);animation:mi .18s cubic-bezier(.16,1,.3,1)}
[data-theme="dark"] .auth-box{box-shadow:0 24px 64px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.06)}
.auth-logo{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:700;margin-bottom:28px;letter-spacing:-.01em}
.auth-title{font-size:22px;font-weight:800;margin-bottom:6px;letter-spacing:-.03em}
.auth-sub{font-size:13px;color:var(--mut);margin-bottom:22px;line-height:1.5}
.auth-err{font-size:12px;color:var(--red);min-height:16px;margin-bottom:8px}
.auth-ok{font-size:12px;color:var(--acc);min-height:16px;margin-bottom:8px}
.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;background:var(--sur);border:1.5px solid var(--brd2);border-radius:10px;color:var(--txt);font-size:14px;font-weight:500;padding:12px;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1);font-family:inherit;margin-bottom:6px;letter-spacing:-.01em}
.google-btn:hover{border-color:var(--acc);box-shadow:0 3px 12px rgba(37,99,235,.1);transform:translateY(-1px)}
.auth-divider{display:flex;align-items:center;gap:12px;margin:16px 0;font-size:12px;color:var(--mut);font-weight:500;letter-spacing:.02em}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--brd)}
.auth-inp{width:100%;background:var(--sur2);border:1.5px solid var(--brd2);color:var(--txt);font-size:14px;padding:11px 14px;border-radius:10px;outline:none;transition:border-color .2s,box-shadow .2s;margin-bottom:10px;font-family:inherit}
.auth-inp:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
[data-theme="dark"] .auth-inp:focus{box-shadow:0 0 0 3px rgba(67,147,245,.12)}
.auth-btn{width:100%;background:var(--acc);border:none;color:#fff;font-size:14px;font-weight:600;padding:13px;border-radius:10px;transition:all .2s cubic-bezier(.16,1,.3,1);margin-top:4px;font-family:inherit;letter-spacing:-.01em}
.auth-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,99,235,.35)}
.auth-btn:active{transform:none;box-shadow:none}
.auth-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.auth-switch{font-size:13px;color:var(--mut);margin-top:18px;text-align:center;line-height:1.6}
.auth-switch a{color:var(--acc);cursor:pointer;font-weight:500;text-decoration:none}
.auth-switch a:hover{text-decoration:underline}
.auth-rm{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--mut);margin-bottom:12px;cursor:pointer;user-select:none}
.chk{width:15px;height:15px;border-radius:3px;border:1px solid var(--brd2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s}
.chk.on{background:var(--acc);border-color:var(--acc)}
.totp-inp{width:100%;background:var(--sur2);border:1px solid var(--brd2);color:var(--txt);font-family:'JetBrains Mono',monospace;font-size:22px;padding:13px;border-radius:9px;outline:none;text-align:center;letter-spacing:.25em;margin-bottom:10px}
.totp-inp:focus{border-color:var(--acc)}

/* APP LAYOUT */
.app{display:grid;grid-template-columns:200px 1fr;min-height:100vh}
.sb{background:var(--sur);border-right:1px solid var(--brd);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:50}
.sb-logo{padding:18px 16px;border-bottom:1px solid var(--brd);display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600}
.sb-sec{font-size:9px;font-weight:700;letter-spacing:.12em;color:var(--mut2);padding:14px 16px 4px;text-transform:uppercase}
.nav{display:flex;align-items:center;gap:9px;padding:8px 16px;font-size:13px;color:var(--mut);cursor:pointer;transition:all .1s;position:relative;user-select:none}
.nav:hover{color:var(--txt);background:var(--sur2)}
.nav.on{color:var(--txt);background:var(--sur2)}
.nav.on::before{content:'';position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--acc);border-radius:0 2px 2px 0}
.nav svg{width:14px;height:14px;flex-shrink:0;opacity:.5}.nav.on svg{opacity:1}
.nav-bdg{background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:8px;margin-left:auto}
.sb-bot{margin-top:auto;padding:12px 16px;border-top:1px solid var(--brd)}
.sb-email-row{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:7px}
.sb-email{font-size:11px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.sb-pro-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;background:rgba(184,240,74,.15);color:var(--acc);border:1px solid rgba(184,240,74,.3);white-space:nowrap;flex-shrink:0}
[data-theme="light"] .sb-pro-badge{background:rgba(90,158,10,.1);border-color:rgba(90,158,10,.25)}
.sb-links{display:flex;gap:8px}
.sb-link{background:none;border:none;font-size:11px;color:var(--mut2);padding:0;transition:color .1s}
.sb-link:hover{color:var(--txt)}.sb-link.danger:hover{color:var(--red)}

/* Mobile bottom navigation */
.mob-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--sur);border-top:1px solid var(--brd);z-index:200;padding:8px 0 max(8px,env(safe-area-inset-bottom))}
.mob-bottom-nav-inner{display:grid;grid-template-columns:repeat(5,1fr)}
.mob-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 0;cursor:pointer;color:var(--mut);transition:color .15s;border:none;background:none;font-family:inherit}
.mob-nav-item.on{color:var(--acc)}
.mob-nav-item svg{width:20px;height:20px}
.mob-nav-item span{font-size:9px;font-weight:500;letter-spacing:.02em}
.mob-bar{display:none;align-items:center;justify-content:space-between;padding:10px 16px;background:rgba(var(--sur-rgb,255,255,255),.9);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--brd);position:sticky;top:0;z-index:100;gap:12px}
[data-theme="dark"] .mob-bar{background:rgba(22,27,34,.9)}
.mob-logo{font-size:14px;font-weight:600;display:flex;align-items:center;gap:7px}
.burger{background:none;border:none;color:var(--txt);padding:4px;display:flex;flex-direction:column;gap:4px}
.burger span{display:block;width:18px;height:2px;background:currentColor;border-radius:2px}
.mob-nav{display:none;position:fixed;inset:0;top:52px;background:var(--sur);z-index:200;overflow-y:auto;flex-direction:column}
.mob-nav.open{display:flex}
.main{display:flex;flex-direction:column;min-width:0;overflow-x:hidden}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:11px 22px;border-bottom:1px solid var(--brd);background:var(--sur);position:sticky;top:0;z-index:40;gap:10px}
.tools-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;padding:8px 10px;font-size:13px;color:var(--txt);cursor:pointer;border-radius:8px;font-family:inherit;transition:background .15s,color .15s}
.tools-item:hover{background:var(--sur2);color:var(--acc)}
.tools-item svg{flex-shrink:0;opacity:.6;transition:opacity .15s}
.tools-item:hover svg{opacity:1}
.pg-title{font-size:14px;font-weight:600}
.tb-r{display:flex;align-items:center;gap:7px}
.btn{font-family:'Inter',sans-serif;font-size:12px;font-weight:500;padding:6px 13px;border-radius:7px;border:none;transition:all .1s;white-space:nowrap}
.btn-sm{padding:5px 11px;font-size:11px}
.btn-xs{padding:3px 8px;font-size:11px}
.btn-out{background:transparent;border:1px solid var(--brd2);color:var(--mut)}
.btn-out:hover{color:var(--txt);background:var(--sur2)}
.btn-acc{background:var(--acc);font-weight:600}
[data-theme="dark"] .btn-acc{color:#0c0c0c}[data-theme="light"] .btn-acc{color:#fff}
.btn-acc:hover{filter:brightness(1.1)}.btn-acc:disabled{opacity:.5;cursor:not-allowed}
.btn-red{background:transparent;border:1px solid rgba(240,74,74,.3);color:var(--red)}
.btn-red:hover{background:rgba(240,74,74,.08)}
.btn-pur{background:rgba(160,122,240,.1);border:1px solid rgba(160,122,240,.25);color:var(--pur)}
.btn-blu{background:rgba(74,144,240,.1);border:1px solid rgba(74,144,240,.25);color:var(--blu)}
.theme-btn{width:30px;height:17px;border-radius:9px;background:var(--sur2);border:1px solid var(--brd2);cursor:pointer;display:flex;align-items:center;padding:2px;flex-shrink:0}
.theme-btn .tt{width:11px;height:11px;border-radius:50%;background:var(--acc);transition:transform .2s}
[data-theme="light"] .theme-btn .tt{transform:translateX(13px)}
.pg{display:none;padding:20px 22px;flex-direction:column;gap:16px;animation:fi .15s ease}
.pg.on{display:flex}
@keyframes fi{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}
@keyframes mi{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
@keyframes sp{to{transform:rotate(360deg)}}
.onb-card{background:var(--sur2);border:1px solid var(--brd);border-radius:12px;padding:16px;cursor:pointer;transition:border-color .15s,transform .15s;position:relative}.onb-card:hover{border-color:var(--acc);transform:translateY(-2px)}.onb-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}.onb-ttl{font-size:13px;font-weight:600;margin-bottom:4px}.onb-sub{font-size:11px;color:var(--mut);line-height:1.5}.onb-badge{position:absolute;top:10px;right:10px;font-size:9px;font-weight:600;background:var(--acc);color:var(--acc-dk);padding:2px 7px;border-radius:99px;letter-spacing:.04em}
.lp-feat-card:hover{box-shadow:0 8px 32px rgba(124,109,250,.12);transform:translateY(-3px)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}

/* CARDS */
.card{background:var(--sur);border:1px solid var(--brd);border-radius:11px;overflow:hidden}
.card-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--brd);gap:10px}
.card-ttl{font-size:13px;font-weight:600}
.card-sub{font-size:11px;color:var(--mut);margin-top:1px}

/* METRICS */
.mets{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.met{background:var(--sur);border:1px solid var(--brd);border-radius:11px;padding:14px 16px}
.met-lbl{font-size:10px;font-weight:600;color:var(--mut);margin-bottom:5px;text-transform:uppercase;letter-spacing:.07em}
.met-val{font-size:24px;font-weight:600;letter-spacing:-.02em;line-height:1.1}
.met-note{font-size:11px;color:var(--mut);margin-top:3px}

/* SUBSCRIPTION ROWS */
.sub-row{display:flex;align-items:center;gap:11px;padding:11px 16px;border-bottom:1px solid var(--brd);transition:background .1s}
.sub-row:last-child{border-bottom:none}.sub-row:hover{background:var(--sur2)}
.sub-ic{width:32px;height:32px;border-radius:8px;background:var(--sur2);border:1px solid var(--brd2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.sub-inf{flex:1;min-width:0}
.sub-nm{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.sub-meta{font-size:11px;color:var(--mut);margin-top:1px}
.sub-rt{display:flex;align-items:center;gap:6px;flex-shrink:0}
.sub-pr{font-size:13px;font-weight:600;font-family:'JetBrains Mono',monospace;white-space:nowrap}
.bdg{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;white-space:nowrap}
.bdg-red{background:rgba(240,74,74,.1);color:var(--red);border:1px solid rgba(240,74,74,.2)}
.bdg-ora{background:rgba(240,138,74,.1);color:var(--ora);border:1px solid rgba(240,138,74,.2)}
.bdg-grn{background:rgba(184,240,74,.08);color:var(--acc);border:1px solid rgba(184,240,74,.15)}
[data-theme="light"] .bdg-grn{background:rgba(90,158,10,.08);border-color:rgba(90,158,10,.2)}
.bdg-blu{background:rgba(74,144,240,.1);color:var(--blu);border:1px solid rgba(74,144,240,.2)}
.bdg-gry{background:var(--sur2);color:var(--mut);border:1px solid var(--brd2)}
.bdg-pur{background:rgba(160,122,240,.1);color:var(--pur);border:1px solid rgba(160,122,240,.2)}
.del-btn{background:none;border:none;color:var(--mut2);font-size:14px;padding:3px 6px;border-radius:4px;transition:all .1s;line-height:1}
.del-btn:hover{color:var(--red);background:rgba(240,74,74,.08)}

/* MODALS */
.mbg{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:400;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);padding:16px}
.mbg.on{display:flex}
.modal{background:var(--sur);border:1px solid var(--brd2);border-radius:13px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:mi .16s ease;box-shadow:var(--shadow)}
.modal.wide{max-width:600px}
.mhdr{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--brd);position:sticky;top:0;background:var(--sur);z-index:1}
.mttl{font-size:13px;font-weight:600}
.mclose{background:none;border:none;color:var(--mut);font-size:17px;padding:2px 6px;border-radius:4px}
.mclose:hover{color:var(--txt);background:var(--sur2)}
.mbody{padding:18px;display:flex;flex-direction:column;gap:12px}
.mfoot{padding:12px 18px;border-top:1px solid var(--brd);display:flex;justify-content:flex-end;gap:8px}
.fg{display:flex;flex-direction:column;gap:4px}
.flbl{font-size:11px;font-weight:500;color:var(--mut)}
.finp,.fsel{background:var(--sur2);border:1px solid var(--brd2);color:var(--txt);font-family:'Inter',sans-serif;font-size:13px;padding:8px 11px;border-radius:7px;outline:none;width:100%;transition:border-color .1s}
.finp:focus,.fsel:focus{border-color:var(--acc)}
.fsel option{background:var(--sur2);color:var(--txt)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* EMPTY STATE */
.empty{padding:44px 20px;text-align:center}
.empty-ic{font-size:26px;margin-bottom:10px;opacity:.35}
.empty-tt{font-size:14px;font-weight:600;margin-bottom:5px}
.empty-sb{font-size:12px;color:var(--mut);margin-bottom:16px;max-width:280px;margin-left:auto;margin-right:auto;line-height:1.6}

/* SPINNER */
.ld{display:flex;align-items:center;justify-content:center;gap:9px;padding:28px;color:var(--mut);font-size:12px}
.spin{width:14px;height:14px;border:2px solid var(--brd2);border-top-color:var(--acc);border-radius:50%;animation:sp .8s linear infinite}

/* MANAGE PANEL */
.panel-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:500;display:none;justify-content:flex-end;backdrop-filter:blur(3px)}
.panel-bg.on{display:flex}
.panel{background:var(--sur);border-left:1px solid var(--brd);width:100%;max-width:400px;height:100vh;overflow-y:auto;display:flex;flex-direction:column;animation:slideIn .2s ease}
.panel-hdr{padding:14px 18px;border-bottom:1px solid var(--brd);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--sur);z-index:1}
.panel-ttl{font-size:13px;font-weight:600}
.panel-close{background:none;border:none;color:var(--mut);font-size:17px;padding:2px 6px;border-radius:4px}
.panel-close:hover{color:var(--txt)}
.panel-body{padding:16px;flex:1;display:flex;flex-direction:column;gap:12px}
.panel-sub-ic{width:44px;height:44px;border-radius:11px;background:var(--sur2);border:1px solid var(--brd2);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}
.p-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.p-action{background:var(--sur2);border:1px solid var(--brd2);border-radius:9px;padding:11px;cursor:pointer;transition:all .15s;text-align:left}
.p-action:hover{border-color:var(--brd);background:var(--sur)}
.p-action.loading{opacity:.6;pointer-events:none}
.p-action.locked{opacity:.6}
.p-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--mut);margin-bottom:2px}
.p-ttl{font-size:12px;font-weight:600}
.p-sub{font-size:11px;color:var(--mut);margin-top:1px}
.p-result{display:flex;flex-direction:column;gap:10px}
.p-sect{background:var(--sur2);border:1px solid var(--brd2);border-radius:9px;padding:12px}
.p-sect-ttl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--mut);margin-bottom:8px}
.verdict{border-radius:8px;padding:11px 13px}
.verdict.keep{background:rgba(184,240,74,.08);border:1px solid rgba(184,240,74,.2)}
.verdict.negotiate{background:rgba(240,138,74,.08);border:1px solid rgba(240,138,74,.2)}
.verdict.cancel{background:rgba(240,74,74,.08);border:1px solid rgba(240,74,74,.2)}
.mini-g{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mini-b{background:var(--sur);border:1px solid var(--brd);border-radius:7px;padding:9px 11px}
.mini-lbl{font-size:10px;font-weight:600;color:var(--mut);text-transform:uppercase;letter-spacing:.07em;margin-bottom:2px}
.mini-val{font-size:15px;font-weight:600}
.alt-item{display:flex;align-items:flex-start;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--brd);gap:8px}
.alt-item:last-child{border-bottom:none}
.alt-nm{font-size:12px;font-weight:500}
.alt-why{font-size:11px;color:var(--mut);margin-top:1px}
.alt-price{font-size:12px;font-weight:600;font-family:'JetBrains Mono',monospace;color:var(--acc);text-align:right;white-space:nowrap}
.step{display:flex;gap:8px;padding:7px 0;border-bottom:1px solid var(--brd);align-items:flex-start}
.step:last-child{border-bottom:none}
.step-n{width:18px;height:18px;border-radius:4px;background:var(--sur);border:1px solid var(--brd2);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-family:'JetBrains Mono',monospace}
.step-ins{font-size:12px;line-height:1.5}
.step-warn{font-size:11px;color:var(--ora);margin-top:2px}

/* UPGRADE MODAL */
.upg-hdr{background:linear-gradient(135deg,rgba(184,240,74,.07),transparent);border-bottom:1px solid var(--brd);padding:22px 18px;text-align:center}
.upg-ic{width:46px;height:46px;background:var(--acc);border-radius:11px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center}
.upg-ttl{font-size:18px;font-weight:600;margin-bottom:5px}
.upg-sub{font-size:12px;color:var(--mut);line-height:1.6}
.upg-perks{padding:16px 18px;display:flex;flex-direction:column;gap:9px}
.upg-perk{display:flex;align-items:flex-start;gap:9px;font-size:12px;line-height:1.5}
.upg-perk-ic{width:20px;height:20px;border-radius:50%;background:rgba(124,109,250,.15);border:1px solid rgba(124,109,250,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.upg-price{padding:14px 18px;border-top:1px solid var(--brd);text-align:center}
.upg-price-big{font-size:28px;font-weight:700;margin-bottom:3px}
.upg-price-big span{font-size:13px;font-weight:400;color:var(--mut)}

/* PROFILE PANEL */
.profile-panel{position:fixed;top:0;right:0;width:300px;height:100vh;background:var(--sur);border-left:1px solid var(--brd);z-index:8000;transform:translateX(100%);transition:transform .25s ease;overflow-y:auto;display:flex;flex-direction:column}
.profile-panel.on{transform:translateX(0)}
.pp-hdr{padding:14px 18px;border-bottom:1px solid var(--brd);display:flex;align-items:center;justify-content:space-between}
.pp-avatar{width:48px;height:48px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#0c0c0c;margin:0 auto 10px}
.pp-sect{background:var(--sur2);border:1px solid var(--brd2);border-radius:9px;overflow:hidden}
.pp-row{display:flex;align-items:center;justify-content:space-between;padding:10px 13px;border-bottom:1px solid var(--brd);font-size:12px;gap:8px}
.pp-row:last-child{border-bottom:none}
.pp-lbl{color:var(--mut);font-size:11px;flex-shrink:0}
.udots{display:flex;gap:3px;margin-top:4px}
.udot{width:7px;height:7px;border-radius:2px;background:var(--brd2)}
.udot.used{background:var(--acc)}

/* CHAT */
.chat-wrap{display:flex;flex-direction:column;height:calc(100vh - 52px)}
.chat-msgs{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px}
.cmsg{display:flex;gap:8px;max-width:600px}
.cmsg.user{flex-direction:row-reverse;align-self:flex-end}
.cav{width:28px;height:28px;border-radius:50%;background:var(--sur2);border:1px solid var(--brd2);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.cmsg.ai .cav{background:var(--acc);color:#0c0c0c;border-color:var(--acc)}
.cmsg-name{font-size:10px;color:var(--mut);margin-bottom:3px}
.cmsg.user .cmsg-name{text-align:right}
.cbub{background:var(--sur);border:1px solid var(--brd);border-radius:11px;padding:9px 13px;font-size:13px;line-height:1.6;word-break:break-word}
.cmsg.user .cbub{background:var(--acc);border-color:var(--acc)}
[data-theme="dark"] .cmsg.user .cbub{color:#0c0c0c}
.chat-bottom{border-top:1px solid var(--brd);background:var(--sur)}
.chat-usage{display:none}
.chat-bar{padding:12px 18px;display:flex;gap:7px;align-items:flex-end}
.chat-inp{flex:1;background:var(--sur2);border:1px solid var(--brd2);color:var(--txt);font-family:'Inter',sans-serif;font-size:13px;padding:9px 12px;border-radius:9px;outline:none;resize:none;max-height:120px;transition:border-color .1s}
.chat-inp:focus{border-color:var(--acc)}
.chat-send{background:var(--acc);border:none;width:36px;height:36px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:filter .1s}
[data-theme="dark"] .chat-send{color:#0c0c0c}
.chat-send:hover{filter:brightness(1.1)}.chat-send:disabled{opacity:.4;cursor:not-allowed}
.typing-dots{display:flex;gap:4px;padding:3px 0}
.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--mut);display:inline-block;animation:td .9s infinite}
.typing-dots span:nth-child(2){animation-delay:.15s}.typing-dots span:nth-child(3){animation-delay:.3s}
@keyframes td{0%,100%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}
.sug-wrap{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;padding:0 16px 14px}
.sug{background:var(--sur2);border:1px solid var(--brd2);color:var(--mut);font-size:11px;padding:6px 12px;border-radius:7px;cursor:pointer;transition:all .1s}
.sug:hover{color:var(--txt);border-color:var(--brd)}

/* INSIGHTS */
.ins-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ins-card{background:var(--sur);border:1px solid var(--brd);border-radius:11px;padding:16px}
.ins-card.wide{grid-column:1/-1}
.ins-lbl{font-size:10px;font-weight:600;color:var(--mut);text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px}
.ins-val{font-size:26px;font-weight:600;letter-spacing:-.02em}
.ins-note{font-size:11px;color:var(--mut);margin-top:3px}
.bar-row{display:flex;align-items:center;gap:9px;margin-bottom:7px;font-size:12px}
.bar-lbl{min-width:76px;color:var(--mut);text-transform:capitalize;flex-shrink:0}
.bar-track{flex:1;height:5px;background:var(--sur2);border-radius:3px;overflow:hidden}
.bar-fill{height:100%;border-radius:3px;background:var(--acc);transition:width .5s ease}
.bar-amt{min-width:44px;text-align:right;color:var(--mut);font-size:11px}
.pro-gate{padding:40px 18px;text-align:center}
.pro-gate-ic{font-size:26px;margin-bottom:10px;opacity:.4}
.pro-gate-tt{font-size:14px;font-weight:600;margin-bottom:5px}
.pro-gate-sb{font-size:12px;color:var(--mut);margin-bottom:16px;max-width:260px;margin-left:auto;margin-right:auto;line-height:1.6}

/* COMMUNITY */
.comm-cats{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}
.comm-cat-btn{background:var(--sur2);border:1px solid var(--brd2);color:var(--mut);font-size:11px;padding:5px 11px;border-radius:6px;cursor:pointer;transition:all .1s}
.comm-cat-btn.on{background:var(--acc);border-color:var(--acc);color:#0c0c0c}
[data-theme="light"] .comm-cat-btn.on{color:#fff}
.comm-post{background:var(--sur);border:1px solid var(--brd);border-radius:10px;padding:13px 15px;margin-bottom:7px}
.comm-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;gap:7px;flex-wrap:wrap}
.comm-author{font-size:11px;color:var(--mut)}
.comm-body{font-size:13px;line-height:1.6;margin-bottom:9px;word-break:break-word}
.comm-foot{display:flex;align-items:center;gap:9px}
.upvote-btn{background:none;border:1px solid var(--brd2);color:var(--mut);font-size:11px;padding:3px 9px;border-radius:5px;cursor:pointer;transition:all .1s;display:flex;align-items:center;gap:4px}
.upvote-btn:hover{color:var(--acc);border-color:var(--acc)}
.upvote-btn.voted{color:var(--acc);border-color:var(--acc);background:rgba(184,240,74,.08)}

/* SETTINGS */
.sset{background:var(--sur);border:1px solid var(--brd);border-radius:14px;overflow:hidden;margin-bottom:0}
.sset-ttl{font-size:10px;font-weight:700;color:var(--mut);padding:12px 18px;border-bottom:1px solid var(--brd);background:var(--sur2);text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:8px}
.srow{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--brd);gap:16px;transition:background .15s}
.srow:hover{background:var(--sur2)}
.srow:last-child{border-bottom:none}
.snm{font-size:13.5px;font-weight:600;margin-bottom:2px;letter-spacing:-.01em}
.ssb{font-size:12px;color:var(--mut);line-height:1.5}
.tog{width:36px;height:20px;border-radius:10px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}
.tog.on{background:var(--acc)}.tog.off{background:var(--sur2);border:1px solid var(--brd2)}
.tthumb{width:14px;height:14px;border-radius:50%;background:white;position:absolute;top:3px;transition:left .2s}
.tog.on .tthumb{left:19px}.tog.off .tthumb{left:3px}

/* STAFF */
.svc-card{background:var(--sur2);border:1px solid var(--brd2);border-radius:8px;margin-bottom:9px;overflow:hidden}
.stat-row{display:flex;justify-content:space-between;align-items:center;padding:8px 13px;border-bottom:1px solid var(--brd);font-size:12px}
.stat-row:last-child{border-bottom:none}
.stat-lbl{color:var(--mut)}.stat-val{font-weight:500}
.staff-inp{width:100%;background:var(--sur2);border:1px solid var(--brd2);color:var(--txt);font-family:'JetBrains Mono',monospace;font-size:18px;padding:9px;border-radius:7px;outline:none;text-align:center;letter-spacing:.2em;margin-bottom:9px}
.staff-inp:focus{border-color:var(--acc)}
.user-tbl{width:100%;border-collapse:collapse;font-size:11px}
.user-tbl th{padding:7px 11px;text-align:left;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--mut);border-bottom:1px solid var(--brd)}
.user-tbl td{padding:8px 11px;border-bottom:1px solid var(--brd);color:var(--mut)}
.user-tbl tr:last-child td{border-bottom:none}
.user-tbl tbody tr:hover td{background:var(--sur2)}

/* HIKE BANNER */
.hike-banner{background:rgba(240,74,74,.06);border:1px solid rgba(240,74,74,.2);border-radius:9px;padding:11px 15px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.hike-ttl{font-size:12px;font-weight:600;color:var(--red);margin-bottom:1px}
.hike-sub{font-size:11px;color:var(--mut)}
.dupe-banner{background:rgba(160,122,240,.06);border:1px solid rgba(160,122,240,.2);border-radius:9px;padding:11px 15px;margin-bottom:8px}
.savings-banner{background:rgba(184,240,74,.06);border:1px solid rgba(184,240,74,.2);border-radius:9px;padding:11px 15px;margin-bottom:8px;display:flex;align-items:center;gap:10px}

/* PLAID */
.prow{display:flex;align-items:center;gap:9px;padding:9px 0;border-bottom:1px solid var(--brd);cursor:pointer}
.prow:last-child{border-bottom:none}
.pchk{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--brd2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s}
.pchk.on{background:var(--acc);border-color:var(--acc)}

/* ── MOBILE BOTTOM NAV (shared styles, outside media query) ── */
.mob-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:300}
.mob-bottom-nav-inner{display:flex;justify-content:space-around;align-items:center;background:rgba(var(--sur-rgb,255,255,255),.85);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--brd);padding:8px 4px calc(10px + env(safe-area-inset-bottom))}
[data-theme="dark"] .mob-bottom-nav-inner{background:rgba(22,27,34,.88)}
.mob-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:5px 14px;cursor:pointer;color:var(--mut);transition:color .2s;border:none;background:none;font-family:inherit;min-width:52px;border-radius:10px}
.mob-nav-item:active{opacity:.7}
.mob-nav-item.on{color:var(--acc)}
.mob-nav-item svg{width:22px;height:22px}
.mob-nav-item.on svg{stroke-width:2.5}
.mob-nav-item span{font-size:9px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}
.mob-add-btn{position:relative;top:-6px}
.mob-add-circle{width:46px;height:46px;background:var(--acc);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(124,109,250,.45),0 0 0 4px var(--bg);transition:transform .15s,box-shadow .15s}
.mob-add-btn:active .mob-add-circle{transform:scale(.9);box-shadow:0 2px 8px rgba(124,109,250,.3)}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  /* Layout */
  .app{grid-template-columns:1fr}
  .sb{display:none}
  .mob-bar{display:flex}
  .mob-bottom-nav{display:block}
  .main{padding-bottom:72px}
  .main{overflow-x:hidden}

  /* Pages */
  .pg{padding:12px 14px}
  .mets{grid-template-columns:1fr 1fr;gap:8px}
  .mets .met{padding:14px 14px}
  .mets .met-val{font-size:22px;letter-spacing:-.03em}
  .mets .met-lbl{font-size:10px}
  #d-extras{grid-template-columns:1fr}

  /* Cards */
  .card{border-radius:12px}
  .card-hdr{padding:14px 16px}

  /* Subscription rows */
  .sub-row{padding:12px 14px}
  .sub-ic{width:34px;height:34px;font-size:13px;border-radius:10px}
  .sub-nm{font-size:14px}
  .sub-meta{font-size:11px}
  .sub-pr{font-size:14px;font-weight:700}
  .sub-rt{gap:8px}
  .sub-rt .btn-manage{padding:6px 12px;font-size:11px;font-weight:600}
  .del-btn{display:none}

  /* Topbar */
  .topbar{padding:10px 16px;gap:8px}
  .pg-title{font-size:16px;font-weight:700;letter-spacing:-.02em}
  .theme-btn{display:none}
  .mob-hide{display:none!important}

  /* Modals - sheet from bottom */
  .mbg{align-items:flex-end}
  .modal{max-width:100%;margin:0;border-radius:20px 20px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:92vh;overflow-y:auto}
  .mhdr{position:sticky;top:0;background:var(--sur);z-index:1;border-radius:20px 20px 0 0}
  .mhdr::before{content:'';display:block;width:36px;height:4px;background:var(--brd2);border-radius:99px;margin:10px auto 0}

  /* Forms */
  .frow{grid-template-columns:1fr}
  .finp{font-size:16px}
  .auth-inp{font-size:16px}

  /* Landing responsive — handled in dedicated landing breakpoints above */

  /* Onboarding cards */
  .onb-card-grid{grid-template-columns:1fr!important}

  /* Upgrade */
  .upg-perks{padding:12px 14px}
  .p-actions{grid-template-columns:1fr 1fr}

  /* Insights */
  .ins-grid{grid-template-columns:1fr}
  .ins-metric-row{grid-template-columns:1fr 1fr!important}

  /* Chat */
  .chat-wrap{height:calc(100dvh - 130px)}

  /* Panel */
  .panel{max-width:100%;border-radius:20px 20px 0 0}
  .profile-panel{width:100%}

  /* Savings banner - bigger on mobile */
  .savings-banner{flex-direction:column;gap:8px}

  /* Topbar tools */
  .tb-r{gap:6px}
}
@media(max-width:480px){
  .mets{grid-template-columns:1fr 1fr}
  .ins-metric-row{grid-template-columns:1fr!important}
  .lp-h1{font-size:24px}
  .lp-stats{grid-template-columns:1fr 1fr}
  .sub-rt .btn:not(.btn-manage){display:none}
  .trust-strip{grid-template-columns:1fr 1fr}
  .feat-grid,.steps-grid,.pricing-grid{grid-template-columns:1fr}
  .advisor-card{padding:20px}
  .mystery-section{padding:24px 20px}
  .sec-title{font-size:24px}
}