/* ==========================================================================
   探索 OpenClue · 设计系统 (桌面级专业 SaaS)
   品牌深蓝 · 平面设计 · 精致留白 · 柔和多层阴影
   ========================================================================== */
:root{
  /* 品牌色 */
  --brand:#2456C9; --brand-d:#1B3FA0; --brand-dd:#14264D; --brand-050:#EEF3FE; --brand-100:#DCE6FB;
  --accent:#0EA5A0; --gold:#C4881F; --gold-bg:#FBF3E2;
  --ok:#12A150; --ok-bg:#E9F9F0; --warn:#E5484D; --warn-bg:#FDECEC;
  /* 中性 */
  --bg:#F5F7FB; --bg-soft:#FAFBFE; --card:#FFFFFF;
  --line:#E7ECF4; --line-2:#EDF1F8;
  --ink:#131C33; --ink-2:#4A5670; --ink-3:#8A94A9; --ink-4:#AEB6C6;
  /* 阴影 */
  --sh-xs:0 1px 2px rgba(20,38,77,.05);
  --sh-sm:0 2px 6px rgba(20,38,77,.06);
  --sh-md:0 6px 20px rgba(20,38,77,.08);
  --sh-lg:0 16px 40px rgba(20,38,77,.12);
  --sh-brand:0 8px 24px rgba(36,86,201,.28);
  /* 圆角 */
  --r-sm:9px; --r-md:13px; --r-lg:18px; --r-xl:24px; --r-pill:999px;
  /* 间距 */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:24px; --sp-6:32px; --sp-7:48px;
  --nav-h:64px; --maxw:1120px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei","Segoe UI",Roboto,sans-serif;
  background:var(--bg); color:var(--ink); line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
::selection{background:var(--brand-100)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#D3DBE8;border-radius:8px;border:2px solid var(--bg)}

/* ---------- 顶部导航(桌面) ---------- */
.topbar{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.86);backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line)}
.topbar-in{max-width:var(--maxw);margin:0 auto;height:var(--nav-h);display:flex;align-items:center;gap:var(--sp-5);padding:0 var(--sp-5)}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;color:var(--brand-dd)}
.brand img{height:38px;width:auto;display:block}
.navlinks{display:flex;align-items:center;gap:4px;margin-left:var(--sp-4)}
.navlinks a{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:var(--r-sm);
  color:var(--ink-2);font-size:14.5px;font-weight:500;transition:.16s}
.navlinks a:hover{background:var(--brand-050);color:var(--brand)}
.navlinks a.active{background:var(--brand-050);color:var(--brand);font-weight:600}
.navlinks a .ic{width:18px;height:18px}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.userchip{display:flex;align-items:center;gap:8px;padding:6px 12px 6px 8px;border:1px solid var(--line);
  border-radius:var(--r-pill);font-size:13.5px;color:var(--ink-2);background:#fff}
.userchip .avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--accent));
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}

/* ---------- 移动底部 tab ---------- */
.botnav{display:none}
@media(max-width:760px){
  .navlinks{display:none}
  .botnav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:50;background:rgba(255,255,255,.94);
    backdrop-filter:blur(12px);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom)}
  .botnav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 0 7px;
    color:var(--ink-3);font-size:10.5px;font-weight:500}
  .botnav a .ic{width:22px;height:22px}
  .botnav a.active{color:var(--brand)}
  body{padding-bottom:64px}
}

/* ---------- 布局 ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:var(--sp-6) var(--sp-5)}
.container.narrow{max-width:720px}
.page-head{margin-bottom:var(--sp-5)}
.page-head h1{font-size:26px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.page-head p{color:var(--ink-3);font-size:14.5px;margin-top:6px}
.grid{display:grid;gap:var(--sp-4)}
@media(min-width:761px){.grid.cols-2{grid-template-columns:1fr 1fr}.grid.side{grid-template-columns:320px 1fr}}

/* ---------- 卡片 ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--sp-5);box-shadow:var(--sh-xs)}
.card.pad-lg{padding:var(--sp-6)}
.card.hover{transition:.18s}
.card.hover:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-color:var(--brand-100)}
.card-title{display:flex;align-items:center;gap:9px;font-size:16px;font-weight:650;margin-bottom:4px}
.card-title .ic{width:19px;height:19px;color:var(--brand)}
.card-sub{color:var(--ink-3);font-size:13.5px;margin-bottom:var(--sp-4)}
.divider{height:1px;background:var(--line-2);margin:var(--sp-4) 0}

/* ---------- 按钮 ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border:1px solid transparent;
  border-radius:var(--r-sm);font-size:14.5px;font-weight:600;cursor:pointer;transition:.16s;font-family:inherit;white-space:nowrap}
.btn .ic{width:18px;height:18px}
.btn.primary{background:var(--brand);color:#fff;box-shadow:var(--sh-brand)}
.btn.primary:hover{background:var(--brand-d)}
.btn.primary:active{transform:translateY(1px)}
.btn.ghost{background:#fff;color:var(--brand);border-color:var(--brand-100)}
.btn.ghost:hover{background:var(--brand-050);border-color:var(--brand)}
.btn.subtle{background:var(--bg);color:var(--ink-2);border-color:var(--line)}
.btn.subtle:hover{background:#EEF1F7}
.btn.block{width:100%}
.btn.lg{padding:14px 26px;font-size:15.5px}
.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}

/* ---------- 表单 ---------- */
.field{margin-bottom:var(--sp-4)}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:7px}
.field .tip{font-weight:400;color:var(--ink-3);margin-left:6px}
.input,textarea,select{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  font-size:15px;font-family:inherit;color:var(--ink);background:var(--bg-soft);transition:.15s}
.input:focus,textarea:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 4px var(--brand-050)}
textarea{min-height:92px;resize:vertical;line-height:1.6}
.input[readonly]{background:#F1F4F9;color:var(--gold);font-family:ui-monospace,monospace}
.input-group{display:flex;gap:10px}.input-group .input{flex:1}

/* ---------- chip / 徽章 / tier ---------- */
.chip{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;margin:3px;border:1.5px solid var(--line);
  border-radius:var(--r-pill);background:#fff;font-size:13.5px;color:var(--ink-2);cursor:pointer;transition:.15s}
.chip:hover{border-color:var(--brand);color:var(--brand)}
.chip.sel{background:var(--brand);color:#fff;border-color:var(--brand)}
.chip.q.sel{background:var(--gold);border-color:var(--gold)}
.tag{display:inline-block;background:var(--brand-050);color:var(--brand);padding:4px 12px;border-radius:var(--r-pill);font-size:12.5px;margin:3px 4px 3px 0;font-weight:500}
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--r-pill);font-size:11.5px;font-weight:600}
.badge.ok{background:var(--ok-bg);color:var(--ok)} .badge.gold{background:var(--gold-bg);color:var(--gold)}
.tier{font-size:11px;padding:3px 10px;border-radius:var(--r-pill);font-weight:700}
.tier.金{background:#FBF0D2;color:#A9781A}.tier.银{background:#EAEDF2;color:#5B6577}.tier.铜{background:#F6E0CC;color:#B96A2E}
.tier.铁{background:#E1E7FB;color:#3F4EBF}.tier.铅{background:#EEF0F4;color:#727B8C}

/* ---------- 步骤条 ---------- */
.steps{display:flex;gap:10px;margin-bottom:var(--sp-5)}
.step{flex:1;display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--r-md);
  background:#fff;border:1.5px solid var(--line);font-size:14px;color:var(--ink-3);transition:.18s}
.step .n{width:24px;height:24px;border-radius:50%;background:var(--bg);color:var(--ink-3);
  display:flex;align-items:center;justify-content:center;font-size:12.5px;font-weight:700;flex-shrink:0}
.step.active{border-color:var(--brand);color:var(--brand);font-weight:600;box-shadow:var(--sh-sm)}
.step.active .n{background:var(--brand);color:#fff}
.step.done{border-color:var(--ok);color:var(--ok)}
.step.done .n{background:var(--ok);color:#fff}
@media(max-width:760px){.steps{gap:6px}.step{flex-direction:column;text-align:center;gap:5px;padding:10px 6px;font-size:12px}}

/* ---------- 状态 / 反馈 ---------- */
.empty{text-align:center;padding:var(--sp-7) var(--sp-4);color:var(--ink-3)}
.empty .ic{width:44px;height:44px;color:var(--ink-4);margin-bottom:var(--sp-3)}
.empty h3{font-size:16px;color:var(--ink-2);font-weight:600;margin-bottom:6px}
.spinner{width:22px;height:22px;border:2.5px solid var(--brand-100);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite;display:inline-block;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}
.loading{color:var(--ink-3);text-align:center;padding:var(--sp-5);font-size:14px}
.note{padding:14px 16px;border-radius:var(--r-md);font-size:14px;display:flex;gap:10px;align-items:flex-start}
.note.ok{background:var(--ok-bg);color:#0B7A3B}.note.brand{background:var(--brand-050);color:var(--brand-d)}
.note .ic{width:19px;height:19px;flex-shrink:0;margin-top:1px}
.msg{font-size:13px;margin-top:8px;min-height:18px}.msg.ok{color:var(--ok)}.msg.err{color:var(--warn)}
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(10px);background:var(--ink);color:#fff;
  padding:12px 22px;border-radius:var(--r-pill);font-size:14px;font-weight:500;opacity:0;pointer-events:none;
  transition:.3s;z-index:100;box-shadow:var(--sh-lg)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- 图标基类 ---------- */
.ic{display:inline-block;width:20px;height:20px;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;
  stroke-linejoin:round;fill:none;vertical-align:middle;flex-shrink:0}

/* ========== 手写标语 + 齿轮 + 用户名 ========== */
.brand .slogan{height:30px;width:auto;margin-left:10px}
@media(max-width:560px){.brand .slogan{height:24px;margin-left:6px}}
.gear{width:40px;height:40px;border-radius:var(--r-pill);border:1px solid var(--line);background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-2);transition:.15s}
.gear:hover{background:var(--brand-050);color:var(--brand);border-color:var(--brand-100)}
.gear .ic{width:20px;height:20px}
.uname{font-size:14px;color:var(--ink);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;padding:4px 6px;border-radius:var(--r-pill)}
.uname:hover{background:var(--bg)}
.uname .avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.uname.guest .avatar{background:var(--ink-4)}

/* ========== 设置抽屉 ========== */
.drawer-mask{position:fixed;inset:0;background:rgba(20,38,77,.38);opacity:0;pointer-events:none;transition:.25s;z-index:60}
.drawer-mask.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;bottom:0;width:352px;max-width:88vw;background:#fff;box-shadow:var(--sh-lg);transform:translateX(100%);transition:.28s cubic-bezier(.4,0,.2,1);z-index:61;display:flex;flex-direction:column}
.drawer.open{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-size:17px;font-weight:700}
.drawer-close{width:34px;height:34px;border:none;background:var(--bg);border-radius:var(--r-pill);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-2)}
.drawer-close:hover{background:#EAEEF5}
.drawer-close .ic{width:18px;height:18px}
.drawer-body{padding:12px;overflow-y:auto;flex:1}
.drawer-user{display:flex;align-items:center;gap:12px;padding:14px 14px 18px}
.drawer-user .avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}
.drawer-user .who b{font-size:15px}.drawer-user .who div{font-size:12.5px;color:var(--ink-3)}
.drawer-sec{font-size:12px;color:var(--ink-4);font-weight:600;padding:14px 12px 6px;letter-spacing:.02em}
.drawer-item{display:flex;align-items:center;gap:13px;padding:13px 14px;border-radius:var(--r-md);cursor:pointer;color:var(--ink);font-size:15px;transition:.14s;width:100%;border:none;background:none;text-align:left;font-family:inherit}
.drawer-item:hover{background:var(--brand-050)}
.drawer-item .ic{width:20px;height:20px;color:var(--brand);flex-shrink:0}
.drawer-item .chev{margin-left:auto;color:var(--ink-4);width:18px;height:18px}
.drawer-item.danger{color:var(--warn)}.drawer-item.danger .ic{color:var(--warn)}

/* ========== onboarding 引导清单 ========== */
.tasklist{display:flex;flex-direction:column;gap:12px}
.taski{display:flex;align-items:center;gap:14px;padding:16px 18px;border:1.5px solid var(--line);border-radius:var(--r-md);background:#fff;transition:.15s;cursor:pointer}
.taski:hover{border-color:var(--brand-100);box-shadow:var(--sh-sm)}
.taski.done{border-color:#CDEBD8;background:var(--ok-bg);cursor:default}
.taski .badge-n{width:30px;height:30px;border-radius:50%;background:var(--bg);color:var(--ink-3);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}
.taski.done .badge-n{background:var(--ok);color:#fff}
.taski.done .badge-n .ic{width:16px;height:16px;color:#fff}
.taski .tt{flex:1}.taski .tt b{font-size:15px}.taski .tt div{font-size:13px;color:var(--ink-3);margin-top:2px}
.taski .go{color:var(--brand);font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.taski.done .go{color:var(--ok)}
.taski .go .ic{width:16px;height:16px}

/* ========== ➕ 虚位空状态 ========== */
.add-slot{display:flex;align-items:center;justify-content:center;gap:10px;padding:30px;border:2px dashed var(--line);border-radius:var(--r-lg);color:var(--ink-3);cursor:pointer;transition:.15s;font-size:15px;font-weight:500;background:var(--bg-soft)}
.add-slot:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-050)}
.add-slot .ic{width:22px;height:22px}
