  :root{
    --bg:#0a0e1a; --bg2:#10162a; --card:#141a2e; --card2:#1a2240;
    --line:#232b45; --line2:#324067;
    --txt:#e8edf7; --mut:#a3b1cc; --dim:#7283a3;
    --acc:#4cc2ff; --acc-ink:#06283d;
    --ok:#3ddc97; --warn:#ffc24b; --danger:#ff6b6b;
  }
  /* 告知浏览器为深色主题:原生控件(下拉选项、时间/日期选择器)用深底浅字,避免深蓝底黑字 */
  :root{color-scheme:dark}
  *{box-sizing:border-box}
  select option{background:var(--bg2);color:var(--txt)}
  input::-webkit-calendar-picker-indicator{filter:invert(.75)}
  body{margin:0;font-family:-apple-system,system-ui,"PingFang SC","Microsoft YaHei",sans-serif;
    background:var(--bg);color:var(--txt);line-height:1.5}
  button{font-family:inherit}
  button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
    outline:2px solid var(--acc);outline-offset:2px}
  header{position:sticky;top:0;z-index:10;background:rgba(10,14,26,.92);backdrop-filter:blur(10px);
    border-bottom:1px solid var(--line);padding:13px 18px;display:flex;align-items:center;gap:10px}
  header h1{font-size:17px;margin:0;font-weight:700}
  .dot{width:8px;height:8px;border-radius:50%;background:var(--dim);flex-shrink:0}
  .dot.on{background:var(--ok);box-shadow:0 0 8px var(--ok)}
  .next-pill{margin-left:auto;font-size:11.5px;color:var(--mut);background:var(--bg2);
    border:1px solid var(--line);padding:4px 10px;border-radius:99px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:55%}
  .wrap{max-width:760px;margin:0 auto;padding:16px 16px 100px}
  .card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;margin-bottom:12px}
  .btn{border:0;border-radius:11px;padding:10px 16px;font-size:14px;cursor:pointer;font-weight:600;min-height:40px}
  .btn.sm{padding:8px 12px;font-size:13px;min-height:36px}
  .btn.primary{background:var(--acc);color:var(--acc-ink)}
  .btn.ghost{background:var(--bg2);color:var(--txt);border:1px solid var(--line)}
  .btn.danger{background:transparent;color:var(--danger);border:1px solid var(--danger)}
  .btn:active{transform:scale(.97)}
  .row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
  .muted{color:var(--mut)}
  .pill{font-size:11px;padding:1px 8px;border-radius:99px;background:var(--bg);border:1px solid var(--line);color:var(--mut);white-space:nowrap}
  .badge-next{font-size:11px;background:var(--acc);color:var(--acc-ink);padding:1px 8px;border-radius:99px;font-weight:700;white-space:nowrap}
  .empty{text-align:center;color:var(--mut);padding:48px 16px}
  .empty .big{font-size:46px;margin-bottom:10px}
  .hero{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#0c2b44,var(--card))}
  .tl-item{display:flex;margin-bottom:10px}
  .tl-time{width:52px;flex-shrink:0;text-align:right;padding:14px 10px 0 0;
    font-variant-numeric:tabular-nums;font-weight:700;font-size:13.5px;color:var(--mut)}
  .tl-rail{width:18px;flex-shrink:0;position:relative}
  .tl-rail:before{content:"";position:absolute;left:8px;top:0;bottom:-10px;width:2px;background:var(--line)}
  .tl-item:last-child .tl-rail:before{bottom:auto;height:26px}
  .tl-dot{position:absolute;left:3px;top:16px;width:12px;height:12px;border-radius:50%;
    background:var(--bg);border:2px solid var(--dim);z-index:1}
  .tl-item.done .tl-dot{background:var(--ok);border-color:var(--ok)}
  .tl-item.passed .tl-dot{background:var(--warn);border-color:var(--warn)}
  .tl-item.next .tl-dot{background:var(--acc);border-color:var(--acc);box-shadow:0 0 10px rgba(76,194,255,.7)}
  .tl-card{flex:1;margin-bottom:0}
  .tl-item.done .tl-card{opacity:.55}
  .tl-item.next .tl-card{border-color:var(--acc)}
  .ttl{font-weight:600;font-size:15px}
  .meta{color:var(--mut);font-size:12.5px;margin-top:3px}
  .note{color:var(--mut);font-size:12.5px;margin-top:5px;font-style:italic}
  .ico{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
  .switch{position:relative;width:44px;height:26px;flex-shrink:0;cursor:pointer}
  .switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer}
  .switch span{position:absolute;inset:0;background:var(--line);border-radius:99px;transition:.2s;pointer-events:none}
  .switch span:before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
  .switch input:checked+span{background:var(--ok)}
  .switch input:checked+span:before{transform:translateX(18px)}
  label{display:block;font-size:13px;color:var(--mut);margin:12px 0 5px}
  input,select,textarea{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--txt);
    border-radius:10px;padding:10px;font-size:14px;font-family:inherit}
  textarea{resize:vertical;min-height:60px}
  .grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
  .chips{display:flex;flex-wrap:wrap;gap:7px}
  .chip{padding:8px 13px;border-radius:10px;border:1px solid var(--line);background:var(--bg2);cursor:pointer;font-size:13px;min-height:36px}
  .chip.sel{background:var(--acc);color:var(--acc-ink);border-color:var(--acc);font-weight:600}
  .stat-num{font-size:26px;font-weight:800;font-variant-numeric:tabular-nums}
  .streak{font-size:28px;font-weight:800;color:var(--ok);font-variant-numeric:tabular-nums}
  .heat{display:grid;grid-template-columns:repeat(15,1fr);gap:4px;margin-top:10px}
  .heat div{aspect-ratio:1;border-radius:4px;background:var(--bg2)}
  .heat div.on{background:var(--ok)}
  .log-row{display:flex;gap:8px;justify-content:space-between;font-size:12.5px;color:var(--mut);
    padding:7px 0;border-bottom:1px dashed var(--line)}
  .log-row:last-child{border-bottom:0}
  .modal{position:fixed;inset:0;background:rgba(0,0,0,.65);display:none;align-items:flex-end;justify-content:center;z-index:50}
  .modal.show{display:flex}
  .sheet{background:var(--bg2);width:100%;max-width:760px;border-radius:20px 20px 0 0;padding:18px;
    max-height:90vh;overflow:auto;animation:up .2s}
  @keyframes up{from{transform:translateY(40px);opacity:.5}to{transform:translateY(0);opacity:1}}
  .sheet h3{margin:0 0 4px}
  .fab{position:fixed;right:18px;bottom:88px;width:58px;height:58px;border-radius:50%;background:var(--acc);
    color:var(--acc-ink);border:0;font-size:30px;cursor:pointer;box-shadow:0 8px 24px rgba(76,194,255,.4);z-index:20}
  .nav{position:fixed;left:0;right:0;bottom:0;z-index:30;background:rgba(13,18,34,.95);backdrop-filter:blur(12px);
    border-top:1px solid var(--line);display:flex;justify-content:center;gap:4px;
    padding:6px 8px calc(6px + env(safe-area-inset-bottom))}
  .nav button{flex:1;max-width:170px;display:flex;flex-direction:column;align-items:center;gap:3px;
    background:transparent;border:0;color:var(--dim);font-size:11px;padding:6px 4px;border-radius:12px;cursor:pointer;min-height:48px}
  .nav button.active{color:var(--acc)}
  .nav svg{width:22px;height:22px}
  .toast{position:fixed;left:50%;top:18px;transform:translateX(-50%);background:#0b1220;border:1px solid var(--line2);
    color:var(--txt);padding:10px 18px;border-radius:99px;z-index:99;opacity:0;transition:.25s;pointer-events:none;font-size:14px}
  .toast.show{opacity:1}
  .login{position:fixed;inset:0;background:var(--bg);z-index:60;display:none;align-items:center;justify-content:center;padding:24px}
  .login.show{display:flex}
  .login-card{width:100%;max-width:340px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:24px 22px}
  .hide{display:none!important}
  /* 添加弹窗的标签栏 */
  .sheet-tabs{margin:10px 0 14px;flex-wrap:nowrap}
  .sheet-tabs .chip{flex:1 1 0;min-width:0;text-align:center;min-height:40px}
  /* 设置页:可折叠分组 */
  details.card{padding:0}
  details.card>summary{cursor:pointer;list-style:none;padding:14px;font-weight:600;
    display:flex;align-items:center;gap:8px;min-height:48px;user-select:none}
  details.card>summary::-webkit-details-marker{display:none}
  details.card>summary:after{content:"▾";margin-left:auto;color:var(--dim);transition:transform .2s}
  details.card[open]>summary:after{transform:rotate(180deg)}
  details.card .d-body{padding:0 14px 14px}
  .sec-badge{margin-left:auto;margin-right:8px}
  details.card[open] .sec-badge{display:none}
  /* 特别提醒分层预览块 */
  .prev-block{white-space:pre-wrap;word-break:break-all;font-size:12px;line-height:1.6;color:var(--mut);
    background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:10px;max-height:220px;overflow:auto}
  /* 设置页:粘性保存栏 */
  .save-bar{position:sticky;bottom:calc(72px + env(safe-area-inset-bottom));z-index:5;display:flex;gap:10px;
    padding:10px;background:rgba(13,18,34,.92);backdrop-filter:blur(10px);
    border:1px solid var(--line2);border-radius:14px;margin-bottom:12px}

  /* ── Review 优化:交互反馈 + 移动端遮挡 ── */
  /* #1 FAB 遮挡:页面内容底部留白,最后一卡不被浮动按钮压住 */
  #view-today, #view-plans, #view-stats { padding-bottom: 96px; }
  /* #5#6 按钮 + 卡片 hover 反馈(仅有 hover 能力的设备,触屏不受影响) */
  @media (hover: hover) {
    .btn:hover { filter: brightness(1.12); }
    .card:hover { border-color: var(--line2); }
    .chip:hover { border-color: var(--line2); }
    /* #4 整卡可点击的卡片(today/plans 日程卡)hover 微高亮 */
    .card.clickable:hover { background: var(--card2); cursor: pointer; }
    /* #7 热力图格子 hover 高亮(配合原生 title 显示日期+状态) */
    .heat div:hover, .heat i:hover { outline: 2px solid var(--acc); outline-offset: 1px; }
  }
  /* #11 删除按钮已是 ghost 危险样式(transparent+border),无需改 */
