/* ============================================================================
   史蒂芬财经 · modern A-share watchlist app
   Dark fintech theme. Convention: 红涨 (red = up), 绿跌 (green = down).
   ========================================================================== */
:root {
  --bg:        #0b0e11;
  --bg-grad:   radial-gradient(1200px 600px at 50% -8%, #16202c 0%, #0b0e11 60%);
  --elev:      #11161c;
  --card:      #161b22;
  --card-2:    #1b212b;
  --line:      #242b35;
  --line-soft: #1c222b;
  --text:      #eaecef;
  --sub:       #8b95a5;
  --sub-2:     #5b6675;
  --up:        #f6465d;
  --up-soft:   rgba(246,70,93,.14);
  --down:      #1fc77d;
  --down-soft: rgba(31,199,125,.14);
  --flat:      #8b95a5;
  --gold:      #f0b90b;
  --blue:      #3b82f6;
  --blue-soft: rgba(59,130,246,.16);
  --shell-w:   460px;
  --tabbar-h:  62px;
  --appbar-h:  52px;
  --radius:    16px;
  --shadow:    0 8px 30px rgba(0,0,0,.45);
  --safe-bot:  env(safe-area-inset-bottom, 0px);
  --safe-top:  env(safe-area-inset-top, 0px);
  font-synthesis: none;
}
[data-theme="light"] {
  --bg:        #eef1f5;
  --bg-grad:   radial-gradient(1200px 600px at 50% -8%, #ffffff 0%, #eef1f5 60%);
  --elev:      #ffffff;
  --card:      #ffffff;
  --card-2:    #f4f6f9;
  --line:      #e3e7ee;
  --line-soft: #eceff4;
  --text:      #11161c;
  --sub:       #6b7686;
  --sub-2:     #98a2b3;
  --up:        #e0273a;
  --down:      #16a34a;
  --shadow:    0 8px 30px rgba(20,40,80,.12);
}

* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html, body { height:100%; }
body {
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",Roboto,Helvetica,Arial,sans-serif;
  background:#05070a;
  color:var(--text);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overscroll-behavior:none;
}
svg { width:22px; height:22px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
button { font-family:inherit; color:inherit; background:none; border:none; cursor:pointer; }
input { font-family:inherit; }
::-webkit-scrollbar { width:0; height:0; }

/* ---- app shell : phone frame on desktop, fullscreen on mobile ---- */
.app-shell {
  position:relative;
  width:100%;
  max-width:var(--shell-w);
  height:100dvh;
  margin:0 auto;
  background:var(--bg);
  background-image:var(--bg-grad);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
@media (min-width:520px){
  body { display:flex; align-items:center; justify-content:center;
         background:#05070a radial-gradient(900px 700px at 50% 0%, #11161d, #05070a); }
  .app-shell { height:min(920px, 96dvh); border-radius:30px;
               box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.04);
               overflow:hidden; }
}

/* ---- appbar ---- */
.appbar {
  height:calc(var(--appbar-h) + var(--safe-top)); flex:0 0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:var(--safe-top) 16px 0;
  background:linear-gradient(180deg, rgba(11,14,17,.92), rgba(11,14,17,.55));
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-soft);
  z-index:30;
}
.appbar-brand { display:flex; align-items:center; gap:9px; font-size:18px; font-weight:700; letter-spacing:.5px; }
.logo-dot { width:9px; height:9px; border-radius:3px; background:linear-gradient(135deg,var(--gold),var(--up)); box-shadow:0 0 12px rgba(240,185,11,.6); }
.appbar-actions { display:flex; gap:6px; }
.icon-btn { width:38px; height:38px; border-radius:11px; display:grid; place-items:center; color:var(--sub); }
.icon-btn:active { background:var(--card-2); color:var(--text); }

/* ---- view region ---- */
.view { flex:1 1 auto; overflow-y:auto; overflow-x:hidden; -webkit-overflow-scrolling:touch;
        padding-bottom:calc(var(--tabbar-h) + var(--safe-bot) + 14px);
        position:relative; z-index:2; background:var(--bg); will-change:transform; }
.view::-webkit-scrollbar { display:none; }

/* ---- 下拉刷新 ---- */
.ptr { position:absolute; left:0; right:0; top:calc(var(--appbar-h) + var(--safe-top)); height:54px; z-index:1;
  display:flex; align-items:center; justify-content:center; pointer-events:none; color:var(--gold); }
.ptr-ic { width:24px; height:24px; opacity:0; transition:opacity .15s; }
.ptr.ready .ptr-ic { color:var(--up); }
.ptr.spinning .ptr-ic { opacity:1 !important; transform:none !important; animation:ptr-spin .8s linear infinite; }
@keyframes ptr-spin { to { transform:rotate(360deg); } }

/* ---- tabbar ---- */
.tabbar {
  position:absolute; left:0; right:0; bottom:0;
  height:calc(var(--tabbar-h) + var(--safe-bot));
  padding-bottom:var(--safe-bot);
  display:flex; align-items:stretch;
  background:linear-gradient(180deg, rgba(13,17,22,.82), rgba(9,12,16,.97));
  backdrop-filter:blur(18px);
  border-top:1px solid var(--line);
  z-index:40;
}
.tab { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px;
       color:var(--sub-2); font-size:11px; font-weight:600; transition:color .18s; position:relative; }
.tab svg { width:23px; height:23px; stroke-width:1.9; }
.tab.active { color:var(--text); }
.tab.active svg { stroke:var(--gold); filter:drop-shadow(0 0 8px rgba(240,185,11,.35)); }

/* ---- generic blocks ---- */
.section { padding:14px 14px 4px; }
.card { background:var(--card); border:1px solid var(--line-soft); border-radius:var(--radius); }
.card-pad { padding:16px; }
.row-between { display:flex; align-items:center; justify-content:space-between; }
.muted { color:var(--sub); }
.tiny { font-size:11px; }
.mono { font-variant-numeric:tabular-nums; font-feature-settings:"tnum"; }
.up   { color:var(--up)   !important; }
.down { color:var(--down) !important; }
.flat { color:var(--flat) !important; }
.gold { color:var(--gold) !important; }
.bg-up   { background:var(--up); }
.bg-down { background:var(--down); }
.hide { display:none !important; }
.skeleton { background:linear-gradient(90deg,var(--card) 25%,var(--card-2) 37%,var(--card) 63%);
            background-size:400% 100%; animation:sk 1.3s ease infinite; border-radius:8px; }
@keyframes sk { 0%{background-position:100% 0} 100%{background-position:0 0} }
.empty { text-align:center; color:var(--sub); padding:48px 20px; font-size:14px; }
.empty svg { width:40px; height:40px; stroke:var(--sub-2); margin-bottom:10px; }

/* pills / chips */
.pill { display:inline-flex; align-items:center; justify-content:center; min-width:64px; padding:5px 8px;
        border-radius:9px; font-weight:700; font-size:14px; color:#fff; }
.chip-row { display:flex; gap:8px; overflow-x:auto; padding:2px; }
.chip-row::-webkit-scrollbar { display:none; }
.chip { flex:0 0 auto; padding:7px 14px; border-radius:999px; background:var(--card); border:1px solid var(--line);
        color:var(--sub); font-size:13px; font-weight:600; white-space:nowrap; transition:.15s; }
.chip.active { background:var(--gold); border-color:var(--gold); color:#1a1a1a; }

/* segmented control */
.segment { display:flex; background:var(--card-2); border-radius:12px; padding:4px; gap:4px; }
.segment button { flex:1; padding:9px 0; border-radius:9px; font-size:13px; font-weight:700; color:var(--sub); }
.segment button.active { background:var(--card); color:var(--text); box-shadow:0 2px 8px rgba(0,0,0,.3); }

/* ---- watchlist summary header ---- */
.market-strip { margin:14px 14px 0; padding:16px; border-radius:var(--radius);
  background:linear-gradient(135deg, #1a2330, #141a22);
  border:1px solid var(--line); position:relative; overflow:hidden; }
.market-strip::after { content:""; position:absolute; right:-30px; top:-30px; width:140px; height:140px;
  background:radial-gradient(circle, rgba(240,185,11,.14), transparent 70%); }
.ms-top { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--sub); }
.ms-dot { width:7px; height:7px; border-radius:50%; background:var(--down); box-shadow:0 0 8px var(--down); }
.ms-dot.open { background:var(--up); box-shadow:0 0 8px var(--up); animation:pulse 1.4s infinite; }
@keyframes pulse { 50%{opacity:.4} }
.ms-breadth { display:flex; gap:18px; margin-top:12px; }
.ms-cell .n { font-size:24px; font-weight:800; }
.ms-cell .l { font-size:11px; color:var(--sub); margin-top:1px; }
.breadth-bar { display:flex; height:7px; border-radius:6px; overflow:hidden; margin-top:14px; background:var(--card-2); }
.breadth-bar i { display:block; height:100%; }

/* ---- list rows ---- */
.list { padding:8px 8px 0; }
.list-head { display:flex; align-items:center; justify-content:space-between; padding:6px 10px 8px; color:var(--sub); font-size:12px; }
.list-head .sort { display:flex; gap:6px; align-items:center; }
.stock-row { display:flex; align-items:center; gap:12px; padding:12px 12px; border-radius:14px;
             transition:background .12s; }
.stock-row:active { background:var(--card-2); }
.stock-row + .stock-row { border-top:1px solid var(--line-soft); }
.sr-main { flex:1 1 auto; min-width:0; }
.sr-name { font-size:15.5px; font-weight:650; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sr-code { font-size:11.5px; color:var(--sub-2); margin-top:2px; letter-spacing:.3px; }
.sr-spark { width:68px; height:34px; flex:0 0 auto; }
/* stroke:none 覆盖全局 svg{stroke:currentColor;stroke-width:2}，避免填充块描白边 */
.sr-spark-svg { width:100%; height:100%; display:block; stroke:none; }
.sr-spark-svg polygon { stroke:none; }
.sr-right { text-align:right; flex:0 0 auto; min-width:96px; }
.sr-price { font-size:16px; font-weight:700; }
.sr-chg { margin-top:5px; }
.chg-tag { display:inline-block; min-width:62px; text-align:center; padding:3px 7px; border-radius:8px;
           font-size:12.5px; font-weight:700; color:#fff; }
.row-del { flex:0 0 auto; padding:8px 14px; border-radius:10px; background:var(--up-soft);
           color:var(--up); border:1px solid var(--up); font-size:14px; font-weight:700; white-space:nowrap; }
.row-del:active { background:var(--up); color:#fff; }
.sr-edit { flex:0 0 auto; display:flex; gap:8px; align-items:center; }
.row-group { flex:0 0 auto; padding:8px 12px; border-radius:10px; background:var(--card-2); border:1px solid var(--line);
             color:var(--sub); font-size:13px; font-weight:700; white-space:nowrap; max-width:104px; overflow:hidden; text-overflow:ellipsis; }
.row-group.on { color:var(--gold); border-color:var(--gold); }

/* ---- 自选分组 ---- */
.wg-tabs-wrap { padding:10px 12px 0; }
.wg-tabs { display:flex; gap:7px; overflow-x:auto; padding:0 2px 2px; }
.wg-tabs::-webkit-scrollbar { display:none; }
.wg-tab { flex:0 0 auto; display:flex; align-items:center; gap:5px; padding:6px 13px; border-radius:999px;
  background:var(--card); border:1px solid var(--line); color:var(--sub); font-size:13px; font-weight:600; white-space:nowrap; }
.wg-tab.active { background:var(--gold); border-color:var(--gold); color:#1a1a1a; }
.wg-tab .wg-n { font-size:11px; opacity:.7; font-variant-numeric:tabular-nums; }
.wg-manage { flex:0 0 auto; padding:6px 12px; border-radius:999px; background:transparent;
  border:1px dashed var(--line); color:var(--sub); font-size:12px; font-weight:600; white-space:nowrap; }

.sheet > .btn { width:100%; }
.sheet-title { font-size:16px; font-weight:700; margin-bottom:12px; }
.wg-mlist, .wg-plist { display:flex; flex-direction:column; gap:8px; max-height:46vh; overflow-y:auto; }
.wg-mrow { display:flex; gap:8px; align-items:center; }
.wg-rn, .wg-new { flex:1 1 auto; min-width:0; padding:10px 12px; border-radius:10px; background:var(--card-2);
  border:1px solid var(--line); color:var(--text); font-size:14px; outline:none; }
.wg-mbtn { flex:0 0 auto; padding:8px 12px; border-radius:9px; background:var(--card-2); color:var(--sub); font-size:13px; font-weight:700; }
.wg-mbtn.danger { color:var(--down); }
.wg-newrow { display:flex; gap:8px; align-items:center; margin-top:12px; }
.wg-addbtn { flex:0 0 auto; width:auto; padding:10px 16px; }
.wg-popt { display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border-radius:11px;
  background:var(--card-2); color:var(--text); font-size:15px; font-weight:600; }
.wg-popt.active { box-shadow:inset 0 0 0 1.5px var(--gold); }
.wg-ck { color:var(--gold); font-weight:800; }

/* ---- 长按操作菜单 ---- */
.stock-row, .rank-row { -webkit-touch-callout:none; user-select:none; }
.lp-press { transform:scale(.975); filter:brightness(1.12); transition:transform .12s ease, filter .12s ease; }
.sheet.actions .as-head { padding:2px 2px 12px; border-bottom:1px solid var(--line-soft); margin-bottom:10px; }
.as-name { font-size:16px; font-weight:700; }
.as-code { font-size:12px; color:var(--sub); margin-top:1px; font-variant-numeric:tabular-nums; }
.as-list { display:flex; flex-direction:column; gap:8px; }
.as-item { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:14px 16px; border-radius:12px;
  background:var(--card-2); color:var(--text); font-size:15px; font-weight:650; text-align:left; }
.as-item .as-lbl { flex:1 1 auto; }
.as-item .as-sub { font-size:12px; color:var(--sub); font-weight:500; white-space:nowrap; }
.as-item.primary { background:var(--gold); color:#1a1a1a; }
.as-item.danger { color:var(--down); }
.as-item:active { filter:brightness(1.1); }
.as-cancel { width:100%; margin-top:10px; }

/* ---- 详情页分组 pill ---- */
.hero-group { display:inline-flex; align-items:center; gap:6px; margin-top:12px; padding:7px 14px; border-radius:999px;
  background:var(--card-2); border:1px solid var(--line); color:var(--gold); font-size:13px; font-weight:700; }
.hero-group:active { background:var(--card); }
.fav-btn { flex:0 0 auto; width:34px; height:34px; margin-left:6px; padding:0; display:flex;
           align-items:center; justify-content:center; background:transparent; border:none;
           border-radius:50%; cursor:pointer; -webkit-tap-highlight-color:transparent; }
.fav-btn svg { width:20px; height:20px; stroke:var(--sub); fill:none; stroke-width:1.8; }
.fav-btn:active { background:var(--card-2); }

/* ---- markets ---- */
/* 指数卡片：一页三个，整页滑动翻页（scroll-snap），下方圆点指示页码 */
.idx-pager { display:flex; overflow-x:auto; scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch; padding-top:12px; }
.idx-pager::-webkit-scrollbar { display:none; }
.idx-page { flex:0 0 100%; scroll-snap-align:start; display:grid; grid-template-columns:repeat(3,1fr);
  gap:8px; padding:0 14px; box-sizing:border-box; }
.idx-card { background:linear-gradient(150deg,var(--card-2),var(--card)); border:1px solid var(--line);
  border-radius:12px; padding:10px; min-width:0; }
.idx-card:active { background:var(--card-2); }
.idx-card .nm { font-size:11px; color:var(--sub); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.idx-card .vl { font-size:17px; font-weight:800; margin-top:4px; letter-spacing:-.4px; white-space:nowrap; }
.idx-card .dl { font-size:10.5px; font-weight:700; margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.idx-dots { display:flex; justify-content:center; gap:6px; padding:9px 0 2px; }
.idx-dots i { width:6px; height:6px; border-radius:50%; background:var(--line); transition:.2s; }
.idx-dots i.on { background:var(--gold); width:16px; border-radius:3px; }
.sec-title { padding:16px 16px 4px; font-size:14px; font-weight:700; }
.stat-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.stat-box { background:var(--card); border:1px solid var(--line-soft); border-radius:14px; padding:13px 14px; }
.stat-box .v { font-size:21px; font-weight:800; }
.stat-box .k { font-size:11.5px; color:var(--sub); margin-top:2px; }
.chart-card { margin:14px; border-radius:var(--radius); background:var(--card); border:1px solid var(--line-soft); padding:14px 8px 6px; }
.chart-title { padding:0 8px 8px; font-size:13px; font-weight:700; color:var(--sub); }
.echart { width:100%; }
.rank-tabs { display:flex; gap:18px; padding:4px 16px 0; }
.rank-tabs button { padding:8px 0; font-size:14px; font-weight:700; color:var(--sub); border-bottom:2px solid transparent; }
.rank-tabs button.active { color:var(--text); border-bottom-color:var(--gold); }
.rank-row { display:flex; align-items:center; gap:12px; padding:11px 16px; }
.rank-row + .rank-row { border-top:1px solid var(--line-soft); }
.rank-no { width:22px; text-align:center; font-weight:800; font-size:13px; color:var(--sub-2); }
.rank-no.top { color:var(--gold); }

/* ---- analysis ---- */
.kv-row { display:flex; align-items:center; justify-content:space-between; padding:13px 16px; }
.kv-row + .kv-row { border-top:1px solid var(--line-soft); }
.analysis-bar { position:relative; height:30px; border-radius:7px; background:var(--card-2); overflow:hidden; flex:1; }
.analysis-bar i { position:absolute; top:0; bottom:0; opacity:.28; }
.analysis-bar span { position:absolute; inset:0; display:flex; align-items:center; padding:0 10px; font-size:12.5px; }

/* ---- detail overlay ---- */
.detail, .search-overlay {
  position:absolute; inset:0; z-index:60; background:var(--bg); background-image:var(--bg-grad);
  display:flex; flex-direction:column;
  opacity:0; visibility:hidden; transform:translateY(14px); pointer-events:none;
  transition:opacity .2s ease, transform .24s cubic-bezier(.32,.72,0,1);
}
.detail.open, .search-overlay.open { opacity:1; visibility:visible; transform:translateY(0); pointer-events:auto; }
.detail-head { height:calc(var(--appbar-h) + var(--safe-top)); flex:0 0 auto; display:flex; align-items:center; gap:8px;
  padding:var(--safe-top) 8px 0;
  border-bottom:1px solid var(--line-soft); background:rgba(11,14,17,.7); backdrop-filter:blur(10px); }
.detail-head .ttl { flex:1; min-width:0; }
.detail-head .ttl .n { font-size:16px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.detail-head .ttl .c { font-size:11px; color:var(--sub-2); }
.detail-body { flex:1; overflow-y:auto; padding-bottom:30px; }
.detail-body::-webkit-scrollbar { display:none; }

.hero { padding:18px 18px 8px; }
.hero .px { font-size:38px; font-weight:800; line-height:1.05; letter-spacing:-.5px; }
.hero .chg { display:flex; gap:12px; margin-top:6px; font-size:15px; font-weight:700; }
.hero-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:8px 6px; margin-top:16px; }
.hero-grid .c .k { font-size:10.5px; color:var(--sub); }
.hero-grid .c .v { font-size:13px; font-weight:650; margin-top:1px; }

.chart-tabs { display:flex; gap:6px; padding:6px 14px 0; }
.chart-tabs button { padding:7px 14px; font-size:13px; font-weight:700; color:var(--sub); border-radius:9px; }
.chart-tabs button.active { background:var(--card-2); color:var(--text); }

/* ---- 估值 (9 卡 + 多指标叠加 + 历史可比) ---- */
.val-header { padding:8px 14px 14px; }
.val-loading { padding:24px 14px; }
.val-overall { display:flex; align-items:center; gap:9px; margin-bottom:10px; }
.vo-badge { padding:5px 11px; border-radius:9px; color:#fff; font-size:14px; font-weight:800; letter-spacing:1px; }
.val-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:7px; }
.vcard { padding:9px 9px 8px; border-radius:11px; background:var(--card); border:1px solid var(--line-soft); }
.vcard-k { font-size:11px; color:var(--sub); white-space:nowrap; }
.vcard-v { margin-top:2px; }
.vcard-n { font-size:19px; font-weight:800; font-variant-numeric:tabular-nums; }
.vcard-u { font-size:11px; color:var(--sub-2); }
.vcard-s { font-size:11px; font-weight:700; margin-top:1px; }
.vcard-s.muted { color:var(--sub-2); font-weight:600; }
.val-sec { margin:15px 0 7px; }
.val-picker { display:flex; flex-wrap:wrap; gap:7px; }
.vpick { display:inline-flex; align-items:center; gap:6px; padding:6px 11px; border-radius:999px;
  background:var(--card); border:1px solid var(--line); color:var(--sub); font-size:12px; font-weight:600; transition:.15s; }
.vpick.active { background:var(--card-2); font-weight:700; }
.vp-dot { width:8px; height:8px; border-radius:50%; }
.val-ctrl { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:11px; flex-wrap:wrap; }
.val-seg { display:flex; background:var(--card-2); border-radius:10px; padding:3px; gap:3px; }
.vseg { padding:6px 12px; border-radius:8px; font-size:12px; font-weight:700; color:var(--sub); }
.vseg.active { background:var(--card); color:var(--text); box-shadow:0 2px 8px rgba(0,0,0,.3); }
.val-range { display:flex; gap:7px; }
.vrng { flex:0 0 auto; padding:6px 13px; border-radius:9px; background:var(--card-2); color:var(--sub); font-size:12px; font-weight:700; }
.vrng.active { background:var(--gold); color:#1a1a1a; }
.val-chart { margin-top:6px; }
.val-cmp { display:grid; grid-template-columns:repeat(2,1fr); gap:8px; }
.vcmp { padding:10px 12px; border-radius:11px; background:var(--card); border:1px solid var(--line-soft); }
.vcmp-h { font-size:12px; font-weight:700; }
.vcmp-d { font-size:15px; font-weight:750; margin-top:3px; font-variant-numeric:tabular-nums; }
.vcmp-v { font-size:12px; color:var(--sub); font-weight:600; }
.range-row { padding:8px 14px 0; }
.ma-legend { display:flex; flex-wrap:wrap; gap:6px 14px; padding:8px 16px 2px; font-size:11.5px;
  font-weight:700; font-variant-numeric:tabular-nums; min-height:18px; }
.ma-legend .ma-item { white-space:nowrap; }

.stats-table { margin:8px 14px; border-radius:14px; border:1px solid var(--line-soft); overflow:hidden; }
.stats-table .r { display:flex; }
.stats-table .r > div { flex:1; padding:12px 14px; }
.stats-table .r > div:first-child { border-right:1px solid var(--line-soft); }
.stats-table .r + .r { border-top:1px solid var(--line-soft); }
.stats-table .k { font-size:11px; color:var(--sub); }
.stats-table .v { font-size:15px; font-weight:700; margin-top:2px; }

.sub-title { padding:18px 16px 8px; font-size:14px; font-weight:700; }
.peak-row { display:flex; align-items:center; gap:12px; padding:11px 16px; }
.peak-row + .peak-row { border-top:1px solid var(--line-soft); }

.action-bar { display:flex; gap:10px; padding:14px; flex:0 0 auto;
  border-top:1px solid var(--line); background:var(--elev);
  padding-bottom:calc(14px + var(--safe-bot)); }
.btn { flex:1; padding:13px; border-radius:13px; font-size:15px; font-weight:700; text-align:center; }
.btn-primary { background:var(--gold); color:#1a1a1a; }
.btn-ghost { background:var(--card-2); color:var(--text); border:1px solid var(--line); }
.btn-up { background:var(--up); color:#fff; }
.btn-down { background:var(--down); color:#fff; }

/* ---- search ---- */
.search-head { display:flex; align-items:center; gap:10px; padding:calc(10px + var(--safe-top)) 14px 10px;
  border-bottom:1px solid var(--line-soft); }
.search-input-wrap { flex:1; display:flex; align-items:center; gap:8px; background:var(--card-2);
  border:1px solid var(--line); border-radius:12px; padding:0 12px; height:40px; }
.search-input-wrap .si { width:18px; height:18px; stroke:var(--sub); }
.search-input-wrap input { flex:1; background:none; border:none; outline:none; color:var(--text); font-size:15px; }
.text-btn { color:var(--gold); font-size:15px; font-weight:600; padding:6px; }
.search-results { flex:1; overflow-y:auto; padding:6px 8px; }

/* ---- me / settings ---- */
.me-head { padding:20px 18px 8px; }
.me-head .h { font-size:22px; font-weight:800; }
.group { margin:14px; border-radius:var(--radius); background:var(--card); border:1px solid var(--line-soft); overflow:hidden; }
.group-title { padding:14px 16px 6px; font-size:12px; font-weight:700; color:var(--sub); letter-spacing:.5px; }
.me-row { display:flex; align-items:center; gap:12px; padding:14px 16px; }
.me-row + .me-row { border-top:1px solid var(--line-soft); }
.me-row .ico { width:34px; height:34px; border-radius:10px; display:grid; place-items:center; background:var(--card-2); }
.me-row .ico svg { width:18px; height:18px; stroke:var(--gold); }
.me-row .lbl { flex:1; }
.me-row .lbl .t { font-size:15px; font-weight:600; }
.me-row .lbl .s { font-size:12px; color:var(--sub); margin-top:1px; }
.me-row .chev { color:var(--sub-2); }

/* switch */
.switch { width:44px; height:26px; border-radius:999px; background:var(--card-2); border:1px solid var(--line);
  position:relative; flex:0 0 auto; transition:.2s; }
.switch::after { content:""; position:absolute; top:2px; left:2px; width:20px; height:20px; border-radius:50%;
  background:var(--sub); transition:.2s; }
.switch.on { background:var(--down-soft); border-color:var(--down); }
.switch.on::after { left:20px; background:var(--down); }
.switch.up.on { background:var(--up-soft); border-color:var(--up); }
.switch.up.on::after { background:var(--up); }

/* ---- modal ---- */
.modal { position:absolute; inset:0; z-index:80; display:flex; align-items:flex-end; justify-content:center;
  visibility:hidden; }
.modal.open { visibility:visible; }
.modal-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.55); opacity:0; transition:.2s; }
.modal.open .modal-backdrop { opacity:1; }
.modal-card { position:relative; width:100%; max-width:var(--shell-w); background:var(--elev);
  border-radius:22px 22px 0 0; padding:18px 18px calc(18px + var(--safe-bot)); transform:translateY(100%);
  transition:transform .28s cubic-bezier(.32,.72,0,1); max-height:88%; overflow-y:auto; }
.modal.open .modal-card { transform:translateY(0); }
.modal-title { font-size:17px; font-weight:800; margin-bottom:14px; }
.field { margin-bottom:13px; }
.field label { display:block; font-size:12px; color:var(--sub); margin-bottom:6px; }
.field input, .field select { width:100%; height:46px; background:var(--card-2); border:1px solid var(--line);
  border-radius:12px; padding:0 14px; color:var(--text); font-size:15px; outline:none; }
.field input:focus, .field select:focus { border-color:var(--gold); }
.seg2 { display:flex; gap:8px; }
.seg2 button { flex:1; height:46px; border-radius:12px; border:1px solid var(--line); background:var(--card-2);
  font-weight:700; color:var(--sub); }
.seg2 button.active.up { background:var(--up-soft); border-color:var(--up); color:var(--up); }
.seg2 button.active.down { background:var(--down-soft); border-color:var(--down); color:var(--down); }

/* ---- toast ---- */
.toast { position:absolute; left:50%; bottom:calc(var(--tabbar-h) + 30px); transform:translate(-50%,20px);
  background:rgba(20,26,33,.96); border:1px solid var(--line); color:var(--text); padding:11px 18px;
  border-radius:12px; font-size:14px; font-weight:600; z-index:120; opacity:0; pointer-events:none;
  transition:.24s; box-shadow:var(--shadow); white-space:nowrap; }
.toast.show { opacity:1; transform:translate(-50%,0); }

/* loaders */
.spin { width:26px; height:26px; border-radius:50%; border:3px solid var(--line); border-top-color:var(--gold);
  animation:rot .7s linear infinite; margin:40px auto; }
@keyframes rot { to{ transform:rotate(360deg) } }

/* fade-in for view content */
.fade-in { animation:fade .28s ease; }
@keyframes fade { from{ opacity:0; transform:translateY(6px) } to{ opacity:1; transform:none } }

/* ---- auth gate (login / register) ---- */
.authgate { position:fixed; inset:0; z-index:9999; display:flex; align-items:center; justify-content:center;
            background:var(--bg); padding:24px; }
.auth-card { width:100%; max-width:340px; background:var(--card); border:1px solid var(--line);
             border-radius:18px; padding:28px 22px; box-shadow:0 12px 40px rgba(0,0,0,.35);
             display:flex; flex-direction:column; }
.auth-logo { font-size:40px; text-align:center; }
.auth-title { font-size:22px; font-weight:800; text-align:center; margin-top:6px; color:var(--text); }
.auth-sub { font-size:13px; color:var(--sub); text-align:center; margin:4px 0 18px; }
.auth-input { width:100%; height:46px; border:1px solid var(--line); background:var(--card-2);
              color:var(--text); border-radius:12px; padding:0 14px; font-size:15px; margin-bottom:12px;
              outline:none; box-sizing:border-box; }
.auth-input:focus { border-color:var(--gold); }
.auth-btn { width:100%; height:46px; border:none; border-radius:12px; background:var(--gold); color:#1a1d21;
            font-size:16px; font-weight:800; cursor:pointer; margin-top:4px; }
.auth-btn:active { filter:brightness(.94); }
.auth-btn:disabled { opacity:.6; }
.auth-err { color:var(--down); font-size:13px; min-height:18px; text-align:center; margin:2px 0; }
.auth-toggle { color:var(--gold); font-size:13px; text-align:center; margin-top:14px; cursor:pointer; }
.auth-code-row { display:flex; gap:8px; align-items:stretch; margin-bottom:12px; }
.auth-code-btn { flex:0 0 auto; height:46px; padding:0 14px; border-radius:12px; background:var(--card-2);
                 border:1px solid var(--line); color:var(--gold); font-size:13px; font-weight:700; white-space:nowrap; }
.auth-code-btn:disabled { opacity:.6; color:var(--sub); }
.sr-tag { display:inline-block; margin-left:6px; padding:1px 6px; border-radius:6px; background:var(--card-2);
          color:var(--gold); font-size:10px; font-weight:700; vertical-align:middle; }
.btn.btn-watched { color:var(--gold); border-color:var(--gold); }
