/* ============================================================
   Airvana · 共享 shell 样式（设计 token + 登录门 + 布局 + 原子）
   会员台 / 管理员台各页 <link> 此文件，只写自己的业务样式。
   ============================================================ */
:root{
  --bg:#f5f6f9; --card:#ffffff; --card2:#fbfcfe;
  --ink:#171d2b; --sub:#5a6474; --faint:#98a0af;
  --line:#e9ebf1; --line2:#f1f3f7;
  --brand:#4b57d8; --brand-ink:#3742b3; --brand-soft:#eef0fd; --brand-2:#6d78e8;
  --gold:#a9761f; --gold-soft:#f7efdc;
  --ok:#0e9c86; --ok-soft:#e2f5f1; --warn:#b7791f; --warn-soft:#f8f1e3;
  --red:#c4503a; --red-soft:#fbecea;
  --ink-mk1:#3a3f52; --ink-mk2:#171d2b;      /* admin 深色 mark 渐变 */
  --sh:0 1px 2px rgba(23,29,43,.04),0 3px 8px rgba(23,29,43,.04);
  --sh-md:0 1px 3px rgba(23,29,43,.05),0 8px 24px rgba(23,29,43,.07);
  --sh-lg:0 2px 6px rgba(23,29,43,.06),0 18px 48px rgba(23,29,43,.12);
  --r:16px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg);color:var(--ink);
  font-family:"Inter","Noto Sans SC",system-ui,-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased;font-size:14px;line-height:1.55;letter-spacing:-.005em}
a{color:var(--brand);text-decoration:none}
.mono{font-family:"Space Mono",monospace}
svg{display:block}
input,select,textarea,button{font-family:inherit}
.hidden{display:none!important}

/* 页面业务内容容器：鉴权完成前隐藏，避免闪现 */
#page{display:none}

/* 启动态：有本地会话时先显示中性 spinner，验签期间不闪登录框 */
#av-boot{position:fixed;inset:0;display:grid;place-items:center;background:var(--bg);z-index:60}
#av-boot .ring{width:30px;height:30px;border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:avspin .7s linear infinite}
@keyframes avspin{to{transform:rotate(360deg)}}

/* ---------------- 登录门 ---------------- */
#av-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(70% 55% at 50% -12%,#e9ecfd,transparent 62%),var(--bg)}
.gcard{width:100%;max-width:410px;background:var(--card);border:1px solid var(--line);
  border-radius:22px;box-shadow:var(--sh-lg);padding:40px 36px 30px;text-align:center}
.gmk{width:48px;height:48px;border-radius:14px;color:#fff;display:grid;place-items:center;
  font-weight:800;font-size:23px;margin:0 auto 20px;
  background:linear-gradient(140deg,var(--brand-2),var(--brand));box-shadow:0 8px 22px rgba(75,87,216,.36)}
.gmk.adm{background:linear-gradient(140deg,var(--ink-mk1),var(--ink-mk2));box-shadow:0 8px 22px rgba(23,29,43,.28)}
.gcard h1{font-size:21px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}
.gcard .sub{color:var(--sub);font-size:13.5px;line-height:1.65;margin-bottom:24px}
.gbul{display:flex;flex-direction:column;gap:11px;margin-bottom:26px;text-align:left}
.gbul .b{display:flex;align-items:center;gap:12px;font-size:13px}
.gbul .b .i{width:32px;height:32px;border-radius:10px;background:var(--brand-soft);color:var(--brand);
  display:grid;place-items:center;flex:0 0 auto}
#av-tgbtn{min-height:46px;display:flex;justify-content:center}
.gmicro{margin-top:15px;font-size:12px;color:var(--faint)}
#av-demo{display:none;margin-top:16px;background:none;border:none;color:var(--faint);
  font-size:12px;cursor:pointer;text-decoration:underline}
.gmsg{margin-top:14px;font-size:12.5px;color:var(--red);display:none}
.gfoot{margin-top:20px;font-size:11px;color:var(--faint)}

/* ---------------- 布局 ---------------- */
#av-app{display:none}
.layout{display:grid;grid-template-columns:238px 1fr;min-height:100vh}
.side{background:var(--card);border-right:1px solid var(--line);display:flex;flex-direction:column;
  padding:16px 14px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
.brand .mk{width:34px;height:34px;border-radius:10px;color:#fff;display:grid;place-items:center;
  font-weight:800;font-size:17px;background:linear-gradient(140deg,var(--brand-2),var(--brand));
  box-shadow:0 5px 14px rgba(75,87,216,.3)}
.brand.adm .mk{background:linear-gradient(140deg,var(--ink-mk1),var(--ink-mk2));box-shadow:0 5px 14px rgba(23,29,43,.24)}
.brand .tx b{font-size:15px;font-weight:700;display:block;line-height:1.1;letter-spacing:-.01em}
.brand .tx span{font-family:"Space Mono",monospace;font-size:8px;letter-spacing:.16em;color:var(--faint);text-transform:uppercase}
.navg{font-family:"Space Mono",monospace;font-size:8.5px;letter-spacing:.18em;color:var(--faint);
  text-transform:uppercase;padding:15px 10px 7px}
.navi{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:10px;color:var(--sub);
  font-size:13.5px;font-weight:500;cursor:pointer;transition:.14s;position:relative;text-decoration:none}
.navi:hover{background:var(--line2);color:var(--ink)}
.navi.on{background:var(--brand-soft);color:var(--brand-ink);font-weight:600}
.navi .lk{margin-left:auto;color:var(--faint);font-size:12px}
.navi.on .lk{color:var(--brand)}
.navi[data-locked] .lk{opacity:1}
.ucard{margin-top:auto;display:flex;align-items:center;gap:10px;padding:9px;border:1px solid var(--line);
  border-radius:13px;background:var(--card2)}
.ucard img{width:34px;height:34px;border-radius:10px;object-fit:cover;flex:0 0 auto;background:var(--line2)}
.ucard .nm{font-size:13px;font-weight:600;line-height:1.15}
.ucard .hd{font-family:"Space Mono",monospace;font-size:10px;color:var(--faint)}
.ucard .lo{margin-left:auto;color:var(--faint);cursor:pointer;padding:5px;border-radius:8px}
.ucard .lo:hover{color:var(--red);background:var(--line2)}

.main{min-width:0;display:flex;flex-direction:column}
.top{position:sticky;top:0;z-index:20;background:rgba(245,246,249,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;padding:15px 28px}
.top h2{font-size:16px;font-weight:700;letter-spacing:-.01em}
.top .crumb{color:var(--faint);font-size:13px}
.top .rt{margin-left:auto;display:flex;align-items:center;gap:9px}
.content{padding:26px 28px 72px;max-width:1040px;width:100%;margin:0 auto}

/* ---------------- chip / tier ---------------- */
.chip{font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.03em;padding:5px 11px;
  border-radius:20px;border:1px solid var(--line);color:var(--sub);background:var(--card);white-space:nowrap}
.chip.ok{background:var(--ok-soft);color:var(--ok);border-color:transparent}
.chip.warn{background:var(--warn-soft);color:var(--warn);border-color:transparent}
.chip.brand{background:var(--brand-soft);color:var(--brand-ink);border-color:transparent}
.tchip{display:inline-flex;align-items:center;gap:6px;font-family:"Space Mono",monospace;font-size:10px;
  font-weight:700;letter-spacing:.03em;padding:4px 10px 4px 6px;border-radius:20px;border:1px solid transparent}
.tchip .g{width:18px;height:18px;border-radius:6px;display:grid;place-items:center;font-size:11px;color:#fff}
.tier-S{background:#f3ecff;color:#6b3fd4} .tier-S .g{background:linear-gradient(140deg,#8b5cf6,#6b3fd4)}
.tier-A{background:var(--brand-soft);color:var(--brand-ink)} .tier-A .g{background:linear-gradient(140deg,var(--brand-2),var(--brand))}
.tier-B{background:var(--ok-soft);color:#0a6b5c} .tier-B .g{background:linear-gradient(140deg,#25b89b,var(--ok))}
.tier-C{background:var(--gold-soft);color:#8a5a12} .tier-C .g{background:linear-gradient(140deg,#c99a4a,var(--gold))}

/* ---------------- 按钮 ---------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:var(--brand);color:#fff;
  font-weight:600;font-size:13.5px;padding:10px 16px;border-radius:11px;border:none;cursor:pointer;transition:.15s;white-space:nowrap}
.btn:hover{background:var(--brand-ink)} .btn:active{transform:translateY(1px)}
.btn.block{width:100%}
.btn.ghost{background:var(--card);border:1px solid var(--line);color:var(--sub)}
.btn.ghost:hover{background:var(--line2);color:var(--ink)}
.btn.ok{background:var(--ok)} .btn.ok:hover{filter:brightness(.94)}
.btn.danger{background:var(--card);border:1px solid var(--line);color:var(--red)}
.btn.danger:hover{background:var(--red-soft)}
.btn.sm{padding:6px 12px;font-size:12px;border-radius:9px}
.btn:disabled{opacity:.5;cursor:default}

/* ---------------- 卡片 / 分节标题 ---------------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:20px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.h3{font-size:12.5px;font-weight:600;color:var(--sub);margin:28px 2px 13px;display:flex;align-items:center;gap:9px}
.h3::before{content:"";width:3px;height:13px;border-radius:3px;background:var(--brand);opacity:.55}
.h3 .more{margin-left:auto;color:var(--brand);font-size:12px;cursor:pointer;font-weight:500;text-decoration:none}
.h3.plain::before{display:none}
.foot{margin-top:34px;font-size:11px;color:var(--faint);text-align:center;line-height:1.6}

/* ---------------- demo 状态开关（localhost 预览）---------------- */
#av-demosw{position:fixed;bottom:14px;right:14px;z-index:99;background:#171d2b;border-radius:10px;padding:6px;
  display:none;gap:4px;font-size:11px;box-shadow:var(--sh-lg);align-items:center}
#av-demosw .lb{color:#8b93a3;padding:0 6px}
#av-demosw button{background:none;border:none;color:#9aa0ad;font-size:11px;padding:5px 9px;border-radius:7px;cursor:pointer}
#av-demosw button.on{background:var(--brand);color:#fff}

@media(max-width:860px){.grid2,.grid3{grid-template-columns:1fr}}
@media(max-width:620px){.layout{grid-template-columns:1fr}.side{display:none}.content{padding:20px 16px 60px}.top{padding:13px 16px}}
