*{box-sizing:border-box;margin:0;padding:0}
:root,html{
  --font-ui:'DM Sans',system-ui,sans-serif;
  --font-body:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --content-wide:min(100%,920px);
}
:root,html[data-theme="dark"]{
  color-scheme:dark;
  --bg0:#040810;--bg1:#080f1c;--bg2:#0d1726;--bg3:#111f35;--bg4:#162240;
  --acc:#00e5a0;--acc-hover:#00d99a;--acc2:#0ea5e9;--acc3:#f59e0b;--acc4:#ef4444;
  --text1:#e8f4f8;--text2:#8ba8c0;--text3:#4a6a8a;
  --border:#1a2d45;--border2:#253d5a;
  --green:#10b981;--red:#ef4444;--gold:#f59e0b;
  --nav-bg:rgba(4,8,16,0.92);
  --row-hover:rgba(255,255,255,0.04);
  --selected-row:rgba(0,229,160,0.1);
  --tip-overlay:rgba(4,8,16,0.8);
  --acc-muted:color-mix(in srgb,var(--acc)12%,transparent);
  --on-primary:#0a1625;
  --meta-theme:#040810;
  --nav-h:62px;
  --hero-grad:linear-gradient(160deg,#040810 0%,#08132a 40%,#0a1a35 100%);
  --login-grad:radial-gradient(ellipse at 50% 30%,#0a1a35 0%,#040810 70%);
  --cta-grad:linear-gradient(180deg,#040810 0%,#06101f 100%);
  --glow-1:radial-gradient(circle,rgba(0,229,160,0.08) 0%,transparent 70%);
  --glow-2:radial-gradient(circle,rgba(14,165,233,0.07) 0%,transparent 70%);
  --hl-badge:color-mix(in srgb,var(--acc)10%,transparent);
  --section-pad:max(20px,env(safe-area-inset-left));
  --chart-grid:rgba(255,255,255,0.05);
  --chart-area-fill:rgba(0,229,160,0.1);
  --radius:10px;--radius-lg:14px;
  scrollbar-color:var(--border2) var(--bg0);
}
html[data-theme="light"]{
  color-scheme:light;
  /* Cool shell + white surfaces — fintech, high contrast */
  --bg0:#f0f2f5;--bg1:#ffffff;--bg2:#f7f8fa;--bg3:#eef1f4;--bg4:#e4e8ec;
  --acc:#0d9488;--acc-hover:#0f766e;--acc2:#0284c7;--acc3:#c2410c;--acc4:#dc2626;
  --text1:#0b1220;--text2:#4b5567;--text3:#7d8794;
  --border:#e4e7ec;--border2:#d1d5dc;
  --green:#059669;--red:#dc2626;--gold:#c2410c;
  --nav-bg:rgba(255,255,255,0.97);
  --row-hover:color-mix(in srgb,var(--acc)6%,#ffffff);
  --selected-row:color-mix(in srgb,var(--acc)12%,#ffffff);
  --tip-overlay:rgba(255,255,255,0.92);
  --acc-muted:color-mix(in srgb,var(--acc)9%,#ffffff);
  --on-primary:#ffffff;
  --meta-theme:#f0f2f5;
  /* Subtle mint wash on hero (readable on projectors) */
  --hero-grad:linear-gradient(165deg,#f7faf9 0%,#eef2f0 35%,#e8eeec 100%);
  --login-grad:radial-gradient(ellipse 100% 80% at 50% 0%,#e0f2f1 0%,#f0f2f5 55%,#f0f2f5 100%);
  --cta-grad:linear-gradient(180deg,#f5f6f8 0%,#e8ebed 100%);
  --glow-1:radial-gradient(circle at 30% 20%,color-mix(in srgb,var(--acc)14%,transparent) 0%,transparent 60%);
  --glow-2:radial-gradient(circle at 80% 80%,color-mix(in srgb,var(--acc2)10%,transparent) 0%,transparent 55%);
  --hl-badge:color-mix(in srgb,var(--acc)10%,#f7faf9);
  --chart-grid:color-mix(in srgb,var(--text1)6%,#ffffff);
  --chart-area-fill:rgba(13,148,136,0.16);
  /* Elevation (cards & chrome) */
  --shadow-sm:0 1px 2px rgba(11,18,32,0.04),0 1px 3px rgba(11,18,32,0.06);
  --shadow-md:0 4px 6px -1px rgba(11,18,32,0.05),0 8px 24px -4px rgba(11,18,32,0.1);
  --shadow-nav:0 1px 0 rgba(11,18,32,0.05),0 4px 20px -2px rgba(11,18,32,0.08);
  scrollbar-color:var(--border2) var(--bg0);
}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg0);
  color:var(--text1);
  overflow-x:hidden;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"kern"1;
  text-rendering:optimizeLegibility;
  padding-left:max(0px,env(safe-area-inset-left));
  padding-right:max(0px,env(safe-area-inset-right));
}
.mono,.font-mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.font-ui{font-family:var(--font-ui)}
.tnum{font-variant-numeric:tabular-nums}
h1,h2,h3,.font-heading{font-family:var(--font-ui);letter-spacing:-0.02em}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg0)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
#navbar{
  position:sticky;top:0;z-index:1000;
  background:var(--nav-bg);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  padding:0 var(--section-pad);
  min-height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:nowrap;
  transition:background 0.25s,border-color 0.25s;
}
.nav-end{display:flex;align-items:center;gap:8px;flex:1;justify-content:flex-end;min-width:0;position:relative;flex-wrap:nowrap}
.nav-logo{
  font-family:var(--font-ui);font-weight:700;font-size:1.1rem;color:var(--acc);
  letter-spacing:-0.02em;display:flex;align-items:center;gap:8px;flex-shrink:0;cursor:pointer;user-select:none
}
.nav-logo .tag{
  font-family:var(--font-mono);font-size:10px;color:var(--acc3);
  background:color-mix(in srgb,var(--gold)12%,transparent);
  border:1px solid color-mix(in srgb,var(--gold)32%,transparent);
  padding:2px 8px;border-radius:4px;letter-spacing:1px
}
.theme-toggle{
  flex-shrink:0;width:42px;min-width:42px;height:42px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:10px;border:1px solid var(--border2);background:var(--bg2);
  color:var(--text1);cursor:pointer;transition:background 0.2s,border-color 0.2s;
}
.theme-toggle:hover{background:var(--bg3);border-color:var(--acc)}
.theme-toggle:focus-visible{outline:2px solid var(--acc);outline-offset:2px}
.theme-toggle .ti-sun,.theme-toggle .ti-moon{font-size:19px;line-height:1;opacity:0.92}
html[data-theme="light"] .theme-toggle .ti-sun{display:none}
html[data-theme="light"] .theme-toggle .ti-moon{display:block}
html[data-theme="dark"] .theme-toggle .ti-sun{display:block}
html[data-theme="dark"] .theme-toggle .ti-moon{display:none}
.nav-collapse{
  display:flex;align-items:center;justify-content:flex-end;flex:1;min-width:0
}
.nav-burger{
  display:none;flex-shrink:0;width:42px;min-width:42px;height:42px;align-items:center;justify-content:center;
  border-radius:10px;border:1px solid var(--border2);background:var(--bg2);
  color:var(--text1);font-size:20px;line-height:1;cursor:pointer;transition:background 0.2s,border-color 0.2s;
}
.nav-burger:hover{background:var(--bg3);border-color:var(--acc)}
.nav-burger:focus-visible{outline:2px solid var(--acc);outline-offset:2px}
.nav-app-btn{
  flex-shrink:0;white-space:nowrap;font-size:12px;font-weight:700;font-family:var(--font-ui);
  padding:8px 14px;min-height:40px;border-radius:8px;text-decoration:none;
  border:1px solid var(--acc);color:var(--acc);background:var(--acc-muted);
  display:inline-flex;align-items:center;justify-content:center;transition:all 0.2s;box-sizing:border-box
}
.nav-app-btn:hover{border-color:var(--acc-hover);color:var(--on-primary);background:var(--acc)}
.nav-app-link-mobile{display:none !important}
.nav-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.nav-link{
  background:transparent;border:1px solid var(--border2);color:var(--text2);
  padding:8px 16px;min-height:40px;border-radius:8px;font-size:12px;
  font-family:var(--font-ui);font-weight:600;cursor:pointer;transition:all 0.2s;
  text-decoration:none;display:inline-flex;align-items:center;gap:5px;box-sizing:border-box
}
.nav-link:hover{border-color:var(--acc);color:var(--acc);background:var(--acc-muted)}
.nav-link.active{border-color:var(--acc);color:var(--acc);background:var(--acc-muted)}
.nav-link.gold{border-color:color-mix(in srgb,var(--gold)50%,var(--border2));color:var(--acc3)}
.nav-link.gold:hover,.nav-link.gold.active{border-color:var(--acc3);background:color-mix(in srgb,var(--gold)10%,transparent)}
.btn-primary{
  background:var(--acc);color:var(--on-primary);border:none;
  padding:8px 20px;min-height:40px;border-radius:7px;font-size:13px;
  font-family:var(--font-ui);font-weight:700;cursor:pointer;transition:all 0.2s;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;box-sizing:border-box
}
.btn-primary:hover{background:var(--acc-hover);transform:translateY(-1px)}
.btn-primary.red{background:var(--red);color:#fff}
.btn-primary.red:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn-primary.gold{background:var(--gold);color:var(--bg0)}
html[data-theme="light"] .btn-primary.gold{color:#fff}
.btn-outline{
  background:transparent;color:var(--acc);border:1px solid var(--acc);
  padding:8px 20px;min-height:40px;border-radius:7px;font-size:13px;
  font-family:var(--font-ui);font-weight:700;cursor:pointer;transition:all 0.2s;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;box-sizing:border-box
}
.btn-outline:hover{background:var(--acc-muted);transform:translateY(-1px)}
.badge-notif{
  background:var(--acc);color:var(--on-primary);border-radius:50%;
  width:17px;height:17px;font-size:9px;font-family:var(--font-mono);font-weight:700;
  display:flex;align-items:center;justify-content:center;position:absolute;top:-5px;right:-5px
}
html[data-theme="light"] .badge-notif{color:#fff}
.notif-wrapper{position:relative}
@media(max-width:768px){
  .nav-app-btn{display:none !important}
  .nav-app-link-mobile{display:flex !important}
  .nav-burger{display:inline-flex}
  .nav-collapse{
    position:absolute;left:0;right:0;top:100%;
    display:none;flex-direction:column;align-items:stretch;
    padding:12px 16px 18px;
    background:var(--nav-bg);
    -webkit-backdrop-filter:blur(16px);
    backdrop-filter:blur(16px);
    border-bottom:1px solid var(--border);
    box-shadow:0 12px 32px color-mix(in srgb,var(--text1)10%,transparent);
  }
  .nav-collapse.open{display:flex;z-index:999;flex:unset}
  .nav-right{flex-direction:column;width:100%;align-items:stretch;gap:10px;flex-wrap:nowrap}
  .nav-right .nav-link,.nav-right .btn-primary{width:100%;min-height:44px;justify-content:center}
  .notif-wrapper{width:100%;display:flex;justify-content:center;position:relative}
  .notif-wrapper .nav-link{width:100%;justify-content:center}
  .notif-wrapper .badge-notif{right:auto;margin-left:6px;top:50%;transform:translateY(-50%)}
  .search-bar{flex:1;min-width:0}
  .search-input{min-width:0}
}
@media(min-width:769px){
  .nav-burger{display:none !important}
}

/* PAGES */
.page{display:none;animation:fadeIn 0.3s ease}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* CARDS */
.card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:border-color 0.2s}
.card:hover{border-color:var(--border2)}
.card-sm{background:var(--bg2);border-radius:var(--radius);padding:14px}

/* PILLS */
.pill{padding:3px 10px;border-radius:20px;font-size:11px;font-family:var(--font-mono);font-weight:600;display:inline-flex;align-items:center}
.pill.buy{background:color-mix(in srgb,var(--green)18%,transparent);color:var(--green)}
.pill.sell{background:color-mix(in srgb,var(--red)18%,transparent);color:var(--red)}
.pill.hold{background:color-mix(in srgb,var(--gold)18%,transparent);color:var(--gold)}
.pill.up{background:color-mix(in srgb,var(--green)12%,transparent);color:var(--green)}
.pill.down{background:color-mix(in srgb,var(--red)12%,transparent);color:var(--red)}

/* =================== LANDING PAGE =================== */
#hero{
  background:var(--hero-grad);
  padding:clamp(48px,9vw,88px) 24px clamp(56px,7vw,80px);
  text-align:center;position:relative;overflow:hidden;
}
#hero::after{
  content:'';position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  width:min(100%,640px);height:1px;
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--acc)40%,var(--border)),transparent);
  pointer-events:none;opacity:0.65;
}
.hero-glow-1{position:absolute;top:-60px;left:50%;transform:translateX(-200px);width:400px;height:400px;background:var(--glow-1);pointer-events:none}
.hero-glow-2{position:absolute;bottom:0;right:5%;width:300px;height:300px;background:var(--glow-2);pointer-events:none}
.live-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--hl-badge);
  border:1px solid color-mix(in srgb,var(--acc)28%,var(--border2));
  padding:6px 14px;border-radius:20px;margin-bottom:22px;
  font-family:var(--font-mono);font-size:11px;color:var(--acc);letter-spacing:0.5px
}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--acc);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}
/* Display: clear hierarchy (no ultra-wide type) */
.hero-h1{
  font-family:var(--font-ui);
  display:flex;flex-direction:column;align-items:center;gap:0.55rem;
  max-width:var(--content-wide);margin:0 auto 1.5rem;
  line-height:1.2;
}
.hero-h1 .hero-line1{
  font-size:clamp(0.8rem,1.35vw,0.95rem);
  font-weight:600;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--text2);
  max-width:30rem;line-height:1.4;
}
.hero-h1 .highlight{
  display:block;
  font-size:clamp(1.65rem,4vw,2.65rem);
  font-weight:700;letter-spacing:-0.03em;
  line-height:1.15;
  color:var(--acc);
  margin-top:0.15em;
}
.hero-sub{color:var(--text2);font-size:clamp(0.95rem,1.6vw,1.1rem);max-width:32rem;margin:0 auto 1.75rem;line-height:1.75}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:3rem;max-width:32rem;margin-left:auto;margin-right:auto}
.hero-ticker{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,150px),1fr));
  gap:clamp(10px,2.5vw,16px);
  max-width:var(--content-wide);
  width:100%;
  margin:0 auto;
  padding:0 4px;
}
.ticker-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:left;transition:all 0.25s;cursor:pointer}
.ticker-card:hover{border-color:color-mix(in srgb,var(--acc)45%,var(--border));transform:translateY(-2px)}
.ticker-card.up{border-left:3px solid var(--green)}
.ticker-card.down{border-left:3px solid var(--red)}
.ticker-sym{font-family:var(--font-mono);font-weight:600;font-size:13px}
.ticker-price{font-family:var(--font-mono);font-size:17px;font-weight:500;margin:4px 0 2px}
.ticker-name{font-size:10px;color:var(--text3)}
.ticker-chg{font-family:var(--font-mono);font-size:10px}
.chg-up{color:var(--green)}.chg-down{color:var(--red)}

/* SECTIONS */
.section{padding:clamp(40px,8vw,64px) 24px}
.section-label{
  font-family:var(--font-mono);
  font-size:10px;
  font-weight:500;
  letter-spacing:0.1em;
  text-transform:uppercase;
  margin-bottom:0.75rem;
  display:block;
  color:var(--text3);
}
.section-label.green{color:var(--acc)}
.section-label.blue{color:var(--acc2)}
.section-label.gold{color:var(--acc3)}
.section-h2{
  font-family:var(--font-ui);
  font-size:clamp(1.35rem,2.4vw,1.85rem);
  font-weight:700;
  line-height:1.25;
  margin-bottom:0.6em;
  color:var(--text1);
}
.section-sub{color:var(--text2);font-size:clamp(0.95rem,1.5vw,1.05rem);line-height:1.7;max-width:36rem}
.section-center{text-align:center;margin:0 auto}
.inner{max-width:var(--content-wide);margin:0 auto}

/* FEATURES */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,250px),1fr));gap:1.1rem 1.25rem;margin-top:2.5rem}
.feat-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;transition:all 0.25s}
.feat-card:hover{border-color:color-mix(in srgb,var(--acc)40%,var(--border));transform:translateY(-3px)}
.feat-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:2.75rem;height:2.75rem;border-radius:12px;
  margin-bottom:1rem;
  background:var(--acc-muted);
  color:var(--acc);
  font-size:1.1rem;
  line-height:1;
}
.feat-title{font-family:var(--font-ui);font-weight:600;font-size:1rem;letter-spacing:-0.01em;margin-bottom:0.5rem;color:var(--text1)}
.feat-desc{color:var(--text2);font-size:0.9rem;line-height:1.65}

/* HOW IT WORKS */
.hiw-bg{background:var(--bg1);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.hiw-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:32px;margin-top:40px}
.hiw-num{font-family:var(--font-mono);font-size:36px;font-weight:600;color:var(--acc);opacity:0.45;margin-bottom:14px}
.hiw-title{font-family:var(--font-ui);font-weight:700;font-size:15px;margin-bottom:8px}
.hiw-desc{color:var(--text2);font-size:13px;line-height:1.65}

/* TIPS PREVIEW */
.tip-preview-card{position:relative;border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;margin-bottom:14px}
.tip-inner{background:var(--bg1);padding:18px}
.tip-blurred .tip-inner{filter:blur(5px);pointer-events:none;user-select:none}
.tip-lock{position:absolute;inset:0;background:var(--tip-overlay);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.lock-icon{font-size:30px}
.lock-msg{font-family:var(--font-ui);font-weight:700;font-size:14px;text-align:center;max-width:220px;line-height:1.4}
.tip-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.tip-meta{display:flex;align-items:center;gap:10px}
.tip-date{font-family:var(--font-mono);font-size:10px;color:var(--text3)}
.tip-prices{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.tip-price-box{background:var(--bg2);padding:10px 12px;border-radius:8px}
.tp-label{font-size:10px;color:var(--text3);margin-bottom:3px;letter-spacing:0.5px}
.tp-val{font-family:var(--font-mono);font-weight:600;font-size:14px}
.tp-val.green{color:var(--green)}.tp-val.red{color:var(--red)}
.tip-reason{font-size:13px;color:var(--text2);line-height:1.6}
.analyst{font-size:11px;color:var(--text3)}

/* TESTIMONIALS */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-top:40px}
.testi-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}
.testi-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,color-mix(in srgb,var(--acc)22%,transparent),color-mix(in srgb,var(--acc2)20%,transparent));border:1px solid color-mix(in srgb,var(--acc)35%,var(--border2));display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--acc);flex-shrink:0}
.testi-name{font-weight:500;font-size:13px;margin-bottom:2px}
.testi-role{font-size:11px;color:var(--text3)}
.testi-text{color:var(--text2);font-size:13px;line-height:1.65;font-style:italic;margin:14px 0 10px}
.stars{color:var(--gold);font-size:12px}

/* CTA */
.cta-section{padding:64px 24px;text-align:center;background:var(--cta-grad)}
.cta-h2{font-family:var(--font-ui);font-weight:700;font-size:clamp(1.2rem,2.5vw,1.9rem);line-height:1.2;letter-spacing:-0.02em;margin-bottom:0.65em}
.cta-sub{color:var(--text2);font-size:14px;margin-bottom:28px}

/* FOOTER */
footer{border-top:1px solid var(--border);padding:18px 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-logo{font-family:var(--font-ui);font-weight:700;font-size:1.05rem;letter-spacing:-0.02em;color:var(--acc)}
.footer-note{font-family:var(--font-mono);font-size:10px;color:var(--text3)}

/* =================== LOGIN PAGE =================== */
#login-page{min-height:calc(100vh - var(--nav-h));display:flex;align-items:center;justify-content:center;padding:30px 16px;background:var(--login-grad)}
.auth-box{width:100%;max-width:440px}
.auth-tabs{display:flex;gap:6px;margin-bottom:16px;background:var(--bg2);border-radius:10px;padding:4px}
.auth-tab{flex:1;border:none;background:transparent;color:var(--text3);font-family:var(--font-ui);font-weight:600;font-size:13px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .2s}
.auth-tab.active{background:var(--bg1);color:var(--acc);box-shadow:0 1px 4px color-mix(in srgb,var(--text3) 15%, transparent)}
.auth-panel{display:none}
.auth-panel.active{display:block}
.auth-alert{background:color-mix(in srgb,var(--red) 12%,transparent);border:1px solid color-mix(in srgb,var(--red) 35%,var(--border));color:var(--red);font-size:13px;padding:10px 12px;border-radius:8px;margin-bottom:12px;text-align:center}
.auth-link-btn{border:none;background:none;padding:0;color:var(--acc);font:inherit;font-weight:600;cursor:pointer;text-decoration:underline}
.auth-switch{text-align:center;font-size:13px;color:var(--text2);margin-top:14px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.form-row-2{grid-template-columns:1fr}}
.auth-logo{font-family:var(--font-ui);font-weight:700;font-size:1.45rem;letter-spacing:-0.02em;color:var(--acc);text-align:center;margin-bottom:6px}
.auth-title{font-family:var(--font-ui);font-weight:700;font-size:22px;text-align:center;margin-bottom:6px}
.auth-sub{color:var(--text2);font-size:13px;text-align:center;margin-bottom:28px;line-height:1.5}
.auth-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}
.tab-switch{display:flex;background:var(--bg2);border-radius:8px;padding:3px;margin-bottom:22px}
.tab-btn{flex:1;padding:8px;border-radius:6px;border:none;cursor:pointer;font-size:13px;font-family:var(--font-ui);font-weight:600;transition:all 0.2s}
.tab-btn.active{background:var(--bg3);color:var(--text1)}
.tab-btn:not(.active){background:transparent;color:var(--text3)}
.form-group{margin-bottom:16px}
.form-label{display:block;font-family:var(--font-mono);font-size:10px;color:var(--text3);letter-spacing:0.8px;margin-bottom:7px}
.form-input{width:100%;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;padding:11px 14px;color:var(--text1);font-size:13px;font-family:var(--font-body);outline:none;transition:border-color 0.2s}
.form-input:focus{border-color:var(--acc)}
.form-input::placeholder{color:var(--text3)}
select.form-input{cursor:pointer}
.form-input option{background:var(--bg2)}
.forgot{text-align:right;font-size:12px;color:var(--acc);cursor:pointer;margin-top:6px;margin-bottom:4px}
.submit-btn{width:100%;padding:13px;font-size:14px;border-radius:8px;margin-top:6px;justify-content:center}
.auth-switch{text-align:center;font-size:12px;color:var(--text3);margin-top:14px}
.auth-switch span{color:var(--acc);cursor:pointer}
.demo-hint{margin-top:16px;background:var(--acc-muted);border:1px solid color-mix(in srgb,var(--acc)32%,var(--border2));border-radius:8px;padding:12px 16px}
.hint-label{font-family:var(--font-mono);font-size:10px;color:var(--acc);margin-bottom:4px;letter-spacing:0.8px}
.hint-text{font-size:12px;color:var(--text2)}
.hint-text code{color:var(--acc);font-family:var(--font-mono)}

/* =================== DASHBOARD =================== */
#dashboard-page{padding:20px max(12px,env(safe-area-inset-right)) 20px max(12px,env(safe-area-inset-left));max-width:1080px;margin:0 auto}
.flow-guide{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:color-mix(in srgb,var(--acc) 10%,var(--bg1));border:1px solid color-mix(in srgb,var(--acc) 28%,var(--border));border-radius:var(--radius-lg);padding:12px 14px;margin-bottom:16px}
.flow-guide.hidden{display:none}
.flow-guide-title{font-family:var(--font-ui);font-weight:700;font-size:13px;color:var(--acc);display:block;margin-bottom:6px}
.flow-steps{margin:0;padding-left:18px;font-size:12px;color:var(--text2);line-height:1.65}
.flow-steps li{margin-bottom:2px}
.flow-guide-close{flex-shrink:0;background:var(--bg2);border:1px solid var(--border);color:var(--text3);width:28px;height:28px;border-radius:6px;cursor:pointer}
.flash-welcome{background:color-mix(in srgb,var(--acc) 12%,var(--bg1));border:1px solid color-mix(in srgb,var(--acc) 30%,var(--border));color:var(--text1);padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px}
.section-hint{font-size:12px;color:var(--text3);margin:0 0 10px;font-family:var(--font-mono)}
.setup-alert{padding:14px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);font-size:13px;color:var(--text2);line-height:1.6}
.setup-alert code{font-family:var(--font-mono);font-size:11px;background:var(--bg1);padding:2px 6px;border-radius:4px}
.dash-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.dash-title{font-family:var(--font-ui);font-weight:700;font-size:1.2rem;letter-spacing:-0.02em}
.live-indicator{font-family:var(--font-mono);font-size:10px;color:var(--acc);margin-top:3px}
.dash-right{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end;min-width:0;flex-wrap:wrap}
.search-bar{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:8px 14px;display:flex;align-items:center;gap:8px}
.search-icon{color:var(--text3);font-size:13px}
.search-input{background:transparent;border:none;outline:none;color:var(--text1);font-size:13px;flex:1;min-width:120px;max-width:200px;font-family:var(--font-body)}
.search-input::placeholder{color:var(--text3)}
.user-avatar{
  width:40px;min-width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,color-mix(in srgb,var(--acc)22%,transparent),color-mix(in srgb,var(--acc2)20%,transparent));
  border:1px solid color-mix(in srgb,var(--acc)40%,var(--border2));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-size:12px;color:var(--acc);cursor:pointer;flex-shrink:0
}

/* INDEX CARDS */
.index-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:20px}
.idx-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius);padding:14px 12px;transition:border-color .2s,box-shadow .2s}
.idx-card-clickable{cursor:pointer}
.idx-card-clickable:hover{border-color:color-mix(in srgb,var(--acc)40%,var(--border));box-shadow:0 4px 16px color-mix(in srgb,var(--acc)12%,transparent)}
.idx-card-active{border-color:var(--acc);box-shadow:0 0 0 1px var(--acc)}
.idx-tap-hint{color:var(--acc);font-size:9px}
.idx-name{font-family:var(--font-mono);font-size:10px;color:var(--text3);margin-bottom:6px;letter-spacing:0.5px}
.option-chain-panel{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;margin-bottom:20px}
.option-chain-panel.hidden{display:none}
.oc-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}
.oc-title{font-family:var(--font-ui);font-weight:700;font-size:16px}
.oc-meta{font-family:var(--font-mono);font-size:11px;color:var(--text3);margin-top:4px}
.oc-close{background:var(--bg2);border:1px solid var(--border);color:var(--text2);width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:14px;line-height:1}
.oc-close:hover{border-color:var(--acc);color:var(--acc)}
.oc-loading,.oc-error{font-family:var(--font-mono);font-size:12px;padding:12px 0}
.oc-error{color:var(--red)}
.oc-table-wrap{overflow-x:auto;max-height:420px;overflow-y:auto}
.oc-table{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:11px}
.oc-table th,.oc-table td{padding:6px 8px;text-align:right;border-bottom:1px solid var(--border)}
.oc-table th{color:var(--text3);font-weight:500;position:sticky;top:0;background:var(--bg1);z-index:1}
.oc-th-ce{text-align:center;color:var(--green)}
.oc-th-pe{text-align:center;color:var(--red)}
.oc-th-strike{text-align:center;color:var(--text2)}
.oc-strike{font-weight:600;color:var(--text);background:var(--bg2)}
.oc-atm td{background:color-mix(in srgb,var(--acc)8%,var(--bg1))}
.oc-ltp{font-weight:600}
.idx-val{font-family:var(--font-mono);font-size:16px;font-weight:500;margin-bottom:3px}
.idx-chg{font-family:var(--font-mono);font-size:11px}

/* CHART AREA */
.chart-watchlist-grid{display:grid;grid-template-columns:1fr 210px;gap:16px;margin-bottom:20px;align-items:start}
@media(max-width:600px){.chart-watchlist-grid{grid-template-columns:1fr}}
.chart-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}
.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px}
.chart-title{font-family:var(--font-ui);font-weight:700;font-size:15px}
.chart-tabs{display:flex;gap:6px}
.chart-tab{padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text3);font-size:11px;font-family:var(--font-mono);cursor:pointer;transition:all 0.2s}
.chart-tab.active{border-color:var(--acc);color:var(--acc);background:var(--acc-muted)}
.chart-canvas-wrap{width:100%;height:200px;position:relative}
#stockChart{display:block}

/* WATCHLIST */
.wl-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}
.wl-title{font-family:var(--font-ui);font-weight:700;font-size:14px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}
.wl-count{font-family:var(--font-mono);font-size:11px;color:var(--acc);background:var(--acc-muted);padding:2px 8px;border-radius:10px}
.wl-item{background:var(--bg2);border-radius:8px;padding:10px;margin-bottom:8px;cursor:pointer;transition:all 0.2s;border:1px solid transparent}
.wl-item:hover{border-color:color-mix(in srgb,var(--acc)30%,var(--border));background:var(--bg3)}
.wl-item.active{border-color:color-mix(in srgb,var(--acc)45%,var(--border2));background:var(--bg3)}
.wl-row1{display:flex;justify-content:space-between;margin-bottom:3px}
.wl-sym{font-family:var(--font-mono);font-weight:600;font-size:12px}
.wl-price{font-family:var(--font-mono);font-size:12px;color:var(--text2)}
.wl-add{border:1px dashed var(--border2);background:transparent;color:var(--text3);border-radius:8px;padding:8px;font-size:11px;font-family:var(--font-mono);cursor:pointer;width:100%;transition:all 0.2s}
.wl-add:hover{border-color:var(--acc);color:var(--acc)}

/* STOCK TABLE */
.table-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:20px;overflow-x:auto}
.table-title{font-family:var(--font-ui);font-weight:700;font-size:15px;margin-bottom:16px}
table{width:100%;border-collapse:collapse;min-width:520px}
thead tr{border-bottom:1px solid var(--border)}
th{text-align:left;padding:8px 10px;color:var(--text3);font-size:10px;font-family:var(--font-mono);font-weight:500;letter-spacing:0.5px;white-space:nowrap}
th.right{text-align:right}
td{padding:10px;font-family:var(--font-mono);font-size:12px;border-bottom:1px solid color-mix(in srgb,var(--border)70%,transparent);white-space:nowrap}
tr:last-child td{border-bottom:none}
tr.stock-row{cursor:pointer;transition:background 0.15s}
tr.stock-row:hover{background:var(--row-hover)}
tr.stock-row.selected{background:var(--selected-row)}
.td-sym{color:var(--acc);font-weight:600}
.td-name{color:var(--text2);font-size:11px;font-family:var(--font-body)}
.td-price{color:var(--text1);font-weight:500}
.td-star{text-align:right;padding-right:12px}
.star-btn{background:none;border:none;cursor:pointer;font-size:14px;transition:transform 0.2s}
.star-btn:hover{transform:scale(1.25)}
.star-btn.active{color:var(--gold)}
.star-btn:not(.active){color:var(--text3)}

/* TIPS */
.tips-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}
.tips-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px}
.tips-title{font-family:var(--font-ui);font-weight:700;font-size:15px}
.tips-count{font-family:var(--font-mono);font-size:11px;color:var(--acc)}
.tip-item{background:var(--bg2);border-radius:var(--radius);padding:16px;margin-bottom:12px;border-left:3px solid transparent}
.tip-item.buy{border-left-color:var(--green)}.tip-item.sell{border-left-color:var(--red)}.tip-item.hold{border-left-color:var(--gold)}
.tip-item:last-child{margin-bottom:0}
.tip-h{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.tip-stock-info{display:flex;align-items:center;gap:10px}
.tip-sym{font-family:var(--font-mono);font-weight:600;font-size:15px}
.tip-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.tip-box{background:var(--bg3);padding:10px 12px;border-radius:8px}

/* =================== ADMIN PANEL =================== */
#admin-page{padding:20px max(12px,env(safe-area-inset-right)) 20px max(12px,env(safe-area-inset-left));max-width:860px;margin:0 auto}
.admin-header{display:flex;align-items:center;gap:14px;margin-bottom:24px;flex-wrap:wrap}
.admin-badge{background:rgba(245,158,11,0.12);border:1px solid rgba(245,158,11,0.35);border-radius:8px;padding:5px 14px;font-family:var(--font-mono);font-size:11px;color:var(--gold);letter-spacing:0.8px}
.admin-title{font-family:var(--font-ui);font-weight:700;font-size:1.2rem;letter-spacing:-0.02em}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}
.stat-card{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.stat-label{font-family:var(--font-mono);font-size:10px;color:var(--text3);margin-bottom:7px;letter-spacing:0.5px}
.stat-val{font-family:var(--font-ui);font-weight:700;font-size:1.6rem;letter-spacing:-0.02em;color:var(--acc)}
.post-form{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px}
.form-title{font-family:var(--font-ui);font-weight:700;font-size:16px;color:var(--gold);margin-bottom:20px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:500px){.form-grid-2{grid-template-columns:1fr}}
.success-msg{background:rgba(16,185,129,0.08);border:1px solid rgba(16,185,129,0.25);border-radius:8px;padding:10px 14px;margin-bottom:16px;font-family:var(--font-mono);font-size:12px;color:var(--green);display:none}
.success-msg.show{display:block}
.published-list{background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}
.pub-item{background:var(--bg2);border-radius:var(--radius);padding:14px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;border:1px solid var(--border)}
.pub-item:last-child{margin-bottom:0}
.pub-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pub-right{display:flex;align-items:center;gap:10px}
.del-btn{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.3);color:var(--red);border-radius:6px;padding:4px 12px;font-size:11px;font-family:var(--font-mono);cursor:pointer;transition:all 0.2s}
.del-btn:hover{background:rgba(239,68,68,0.2)}

/* RESPONSIVE */
@media(max-width:900px){
  .search-input{max-width:100%;width:100%;min-width:0}
  .dash-header{flex-direction:column;align-items:stretch}
  .dash-right{width:100%;justify-content:space-between;gap:12px}
  .search-bar{flex:1;min-width:0}
}
@media(max-width:640px){
  #navbar{min-height:56px}
  :root,html[data-theme="dark"]{--nav-h:56px}
  html[data-theme="light"]{--nav-h:56px}
  .nav-logo{font-size:17px}
  .hero-btns{gap:8px;flex-direction:column;align-items:stretch;max-width:400px;margin-left:auto;margin-right:auto}
  .btn-primary,.btn-outline,.hero-btns button{width:100%;justify-content:center;min-height:44px}
  .chart-canvas-wrap{min-height:180px}
  .chart-canvas-wrap canvas{max-height:220px}
  #dashboard-page,#admin-page{padding:14px 10px}
  .chart-watchlist-grid{grid-template-columns:1fr}
  .table-card{padding:14px}
  .section{padding-left:16px;padding-right:16px}
  footer{flex-direction:column;text-align:center;padding:18px 16px}
  .index-grid{grid-template-columns:repeat(2,1fr)}
  .tip-grid{grid-template-columns:1fr}
}
@media(max-width:400px){
  .index-grid{grid-template-columns:1fr}
}
/* —— Light: elevated “product” UI —— */
html[data-theme="light"] #navbar{
  box-shadow:var(--shadow-nav);
  -webkit-backdrop-filter:blur(12px);
  backdrop-filter:blur(12px);
}
html[data-theme="light"] .theme-toggle,
html[data-theme="light"] .nav-burger{
  background:var(--bg1);
  box-shadow:var(--shadow-sm);
  border-color:var(--border);
}
html[data-theme="light"] .nav-link{
  background:var(--bg1);
  box-shadow:var(--shadow-sm);
  border-color:var(--border);
  color:var(--text1);
  font-weight:600;
}
html[data-theme="light"] .nav-link:hover,
html[data-theme="light"] .nav-link.active{
  box-shadow:0 0 0 1px color-mix(in srgb,var(--acc)30%,var(--border));
  background:color-mix(in srgb,var(--acc)6%,#ffffff);
}
html[data-theme="light"] .btn-primary{
  box-shadow:0 2px 6px -1px color-mix(in srgb,var(--acc)32%,transparent);
  border-radius:9px;
}
html[data-theme="light"] .btn-primary:hover{box-shadow:0 4px 14px -2px color-mix(in srgb,var(--acc)40%,transparent)}
html[data-theme="light"] .btn-outline{
  background:var(--bg1);
  box-shadow:var(--shadow-sm);
  border-radius:9px;
  color:var(--acc);
}
html[data-theme="light"] .ticker-card,
html[data-theme="light"] .feat-card,
html[data-theme="light"] .testi-card,
html[data-theme="light"] .tip-preview-card,
html[data-theme="light"] .auth-card,
html[data-theme="light"] .chart-card,
html[data-theme="light"] .wl-card,
html[data-theme="light"] .table-card,
html[data-theme="light"] .tips-card,
html[data-theme="light"] .idx-card,
html[data-theme="light"] .stat-card,
html[data-theme="light"] .post-form,
html[data-theme="light"] .published-list,
html[data-theme="light"] .demo-hint,
html[data-theme="light"] .search-bar,
html[data-theme="light"] .card{
  background:var(--bg1);
  box-shadow:var(--shadow-sm);
  border-color:#dfe3e8;
  border-radius:12px;
}
html[data-theme="light"] .table-card,
html[data-theme="light"] .tips-card,
html[data-theme="light"] .post-form{ border-radius:var(--radius-lg) }
html[data-theme="light"] .ticker-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:color-mix(in srgb,var(--acc)30%,#dfe3e8)}
html[data-theme="light"] .feat-card:hover{box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--acc)25%,#dfe3e8)}
html[data-theme="light"] .hiw-bg{background:var(--bg2)}
html[data-theme="light"] .feat-icon{
  background:color-mix(in srgb,var(--acc)8%,#ffffff);
  box-shadow:0 1px 0 color-mix(in srgb,var(--acc)20%,transparent);
}
html[data-theme="light"] .hero-sub{ color:var(--text2) }
html[data-theme="light"] .hero-h1 .hero-line1{ color:var(--text2) }
html[data-theme="light"] .hero-h1 .highlight{ color:var(--acc) }
html[data-theme="light"] .hero-ticker{ gap:clamp(10px,2.5vw,16px); width:100% }
html[data-theme="light"] .live-badge{
  border-color: color-mix(in srgb, var(--acc) 25%, #dfe3e8);
  font-weight: 600;
}
html[data-theme="light"] .section-h2{ color: var(--text1) }
html[data-theme="light"] #hero{
  padding-left: max(1.1rem, env(safe-area-inset-left, 0px));
  padding-right: max(1.1rem, env(safe-area-inset-right, 0px));
}
html[data-theme="light"] footer{
  background: var(--bg1);
  box-shadow: 0 -1px 0 #e4e7ec;
}
html[data-theme="light"] .cta-section{
  border-top:1px solid var(--border);
}
html[data-theme="light"] .wl-item{
  background: var(--bg2);
  box-shadow: none;
}
html[data-theme="light"] .wl-item:hover,
html[data-theme="light"] .wl-item.active{ background: var(--bg3) }
html[data-theme="light"] .tip-box,
html[data-theme="light"] .tip-price-box{ background: var(--bg2) }
html[data-theme="light"] .form-input:focus{ box-shadow: 0 0 0 3px color-mix(in srgb,var(--acc) 18%, transparent) }
/* Mobile: light — breathing room, no card crowding */
@media (max-width: 640px){
  html[data-theme="light"] .hero-btns{ max-width: min(100%, 420px) }
  html[data-theme="light"] .features-grid{ gap: 12px; margin-top: 32px; }
  html[data-theme="light"] .ticker-card{ min-height: 92px; }
  html[data-theme="light"] #nav-collapse.open{
    background: #ffffff;
    box-shadow: var(--shadow-md);
  }
}

/* —— Admin layout (sidebar) —— */
.admin-body{min-height:100vh;margin:0;background:var(--bg0)}
.admin-shell{display:flex;min-height:100vh}
.admin-aside{
  width:220px;flex-shrink:0;background:var(--bg1);
  border-right:1px solid var(--border);padding:20px 0;display:flex;flex-direction:column;
  position:sticky;top:0;align-self:flex-start;min-height:100vh;z-index:2
}
.admin-aside-brand{display:flex;align-items:center;gap:10px;padding:0 18px 20px;border-bottom:1px solid var(--border)}
.admin-aside-logo{font-size:1.4rem;color:var(--gold)}
.admin-aside-title{font-family:var(--font-ui);font-weight:700;font-size:15px}
.admin-aside-sub{font-size:10px;font-family:var(--font-mono);color:var(--text3);text-transform:uppercase;letter-spacing:0.06em}
.admin-nav{display:flex;flex-direction:column;gap:2px;padding:12px 10px;flex:1}
.admin-nav-link{
  display:block;padding:10px 12px;border-radius:8px;font-size:13px;font-weight:600;color:var(--text2);
  text-decoration:none;border:1px solid transparent
}
.admin-nav-link:hover{background:var(--bg2);color:var(--text1)}
.admin-nav-link.active{
  background:rgba(0,229,160,0.1);color:var(--acc);border-color:color-mix(in srgb,var(--acc)25%,transparent)
}
.admin-nav-link.muted{font-size:12px;font-weight:500;opacity:0.85}
.admin-aside-foot{padding:12px 10px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}
.admin-logout-btn{
  width:100%;text-align:left;padding:10px 12px;border-radius:8px;font-size:12px;
  background:transparent;border:1px solid var(--border);color:var(--red);cursor:pointer;font-family:inherit
}
.admin-logout-btn:hover{background:color-mix(in srgb,var(--red)8%,transparent)}
.admin-main{flex:1;min-width:0;display:flex;flex-direction:column}
.admin-topbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:16px 22px;border-bottom:1px solid var(--border);background:var(--bg0);
  position:sticky;top:0;z-index:1
}
.admin-topbar-title{font-family:var(--font-ui);font-weight:700;font-size:1.1rem}
.admin-topbar-meta{display:flex;align-items:center;gap:12px}
.admin-content{padding:20px 22px 40px;flex:1;max-width:1000px;width:100%;margin:0 auto}
.admin-page-inner{max-width:860px}
.admin-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:20px}
@media(max-width:600px){
  .admin-shell{flex-direction:column}
  .admin-aside{width:100%;min-height:0;position:relative;border-right:none;border-bottom:1px solid var(--border)}
  .admin-nav{flex-direction:row;flex-wrap:wrap}
}
.admin-kpi{
  background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:16px;
  box-shadow:var(--shadow-sm)
}
.admin-kpi-label{font-size:10px;font-family:var(--font-mono);color:var(--text3);letter-spacing:0.04em}
.admin-kpi-val{font-size:1.5rem;font-weight:700;font-family:var(--font-mono);margin-top:4px}
.admin-card{
  background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:18px;
  margin-bottom:16px;box-shadow:var(--shadow-sm)
}
.admin-card-title{font-weight:700;font-size:14px;margin-bottom:12px}
.admin-table{width:100%;border-collapse:collapse;font-size:12px}
.admin-table th,.admin-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}
.admin-table th{color:var(--text3);font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.04em}
.admin-table tr:last-child td{border-bottom:none}
.admin-quicklinks{display:flex;flex-wrap:wrap;gap:10px}
.admin-ql{
  display:inline-flex;align-items:center;padding:10px 16px;border-radius:10px;
  background:var(--bg2);border:1px solid var(--border);color:var(--acc);font-size:13px;font-weight:600;
  text-decoration:none
}
.admin-ql:hover{border-color:var(--acc)}
.admin-flash{
  background:var(--acc-muted);border:1px solid var(--acc);color:var(--text1);
  border-radius:8px;padding:10px 14px;font-size:13px;margin-bottom:16px
}
.form-err{color:var(--red);font-size:12px;margin:6px 0 0}
.form-input.is-invalid{border-color:var(--red)}

/* —— User account panel —— */
.panel-page{padding:24px max(16px,env(safe-area-inset-right)) 40px max(16px,env(safe-area-inset-left));max-width:720px;margin:0 auto}
.panel-header{margin-bottom:24px}
.panel-back{display:inline-block;font-size:12px;color:var(--text3);text-decoration:none;margin-bottom:8px}
.panel-back:hover{color:var(--acc)}
.panel-title{font-family:var(--font-ui);font-size:1.4rem;font-weight:700;margin:0 0 4px}
.panel-sub{color:var(--text3);font-size:13px;margin:0}
.panel-grid{display:grid;gap:20px}
@media(min-width:720px){.panel-grid{grid-template-columns:1fr 1fr}}
.panel-card{
  background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow-sm)
}
.panel-h2{font-size:15px;font-weight:700;margin:0 0 16px}
.panel-ok{
  background:var(--acc-muted);border:1px solid var(--acc);border-radius:8px;padding:8px 12px;
  font-size:12px;margin:0 0 14px
}
.form-hint a{text-decoration:underline}

/* —— Tips module (user /tips) —— */
.tips-module{
  padding:20px max(16px,env(safe-area-inset-right)) 40px max(16px,env(safe-area-inset-left));
  max-width:900px;margin:0 auto
}
.tips-module-h1{font-family:var(--font-ui);font-size:1.35rem;font-weight:700;margin:0 0 6px;letter-spacing:-0.02em}
.tips-module-sub{color:var(--text3);font-size:13px;margin:0 0 20px}
.tips-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.tips-filter{
  display:inline-flex;align-items:center;padding:8px 14px;border-radius:999px;font-size:12px;font-weight:600;
  text-decoration:none;border:1px solid var(--border);color:var(--text2);background:var(--bg1)
}
.tips-filter:hover{border-color:var(--acc);color:var(--acc)}
.tips-filter.active{background:rgba(0,229,160,0.12);border-color:var(--acc);color:var(--acc)}
.tips-empty{color:var(--text3);font-size:14px;padding:24px 0}
.tips-module-list{display:flex;flex-direction:column;gap:14px}
.tip-module-card{
  background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:16px 18px;
  box-shadow:var(--shadow-sm);transition:box-shadow 0.2s,border-color 0.2s
}
.tip-module-card:hover{box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--acc)25%,var(--border))}
.tip-module-title{font-size:15px;font-weight:700;margin:6px 0 0;font-family:var(--font-ui)}
.tip-read-more{font-size:12px;color:var(--acc);margin-top:8px;font-weight:600}
.tip-module-excerpt{margin-top:8px}
.tip-module-meta{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);font-size:11px;color:var(--text3)}
.tip-detail-h2{font-size:12px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.06em;color:var(--text3);margin:20px 0 8px}
.tip-detail-body{margin-top:8px}
.admin-mini-link{font-size:12px;font-weight:600;color:var(--acc);text-decoration:none}
.admin-mini-link:hover{text-decoration:underline}
.admin-mini-btn{
  font-size:11px;padding:6px 10px;border-radius:6px;border:1px solid var(--border);
  background:var(--bg2);color:var(--text1);cursor:pointer;font-family:inherit
}
.admin-mini-btn:hover{border-color:var(--acc);color:var(--acc)}
