/* ZLAO License Console — 白底科技风 (Linear/Vercel 取向, 克制配色) */
:root{
  --bg:#ffffff;
  --panel:#ffffff;
  --ink:#0a0a0b;          /* 主文字 近黑 */
  --ink-2:#6b6f76;        /* 次文字 */
  --ink-3:#9aa0a6;        /* 更淡 */
  --line:#ececef;         /* 边框 */
  --line-2:#f4f4f6;       /* 更淡边框/底 */
  --accent:#2348ff;       /* 单一蓝色点缀(电光蓝) */
  --accent-soft:#eef1ff;
  --green:#11a36b; --green-soft:#e7f6ef;
  --red:#e5484d;   --red-soft:#fdecec;
  --gray:#8b9099;  --gray-soft:#f1f2f4;
  --mono:ui-monospace,"SF Mono","JetBrains Mono",Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif;
  --radius:10px;
  --shadow:0 1px 2px rgba(10,10,11,.04),0 6px 24px -12px rgba(10,10,11,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}
.hidden{display:none!important}
#particles{position:fixed;inset:0;z-index:0;pointer-events:none}

/* 品牌字 */
.brand-mark{font-family:var(--mono);font-weight:700;letter-spacing:.16em;font-size:26px;color:var(--ink)}
.brand-mark.sm{font-size:16px;letter-spacing:.14em}

/* ---- 登录 ---- */
.login{position:fixed;inset:0;z-index:10;display:grid;place-items:center;background:rgba(255,255,255,.7);backdrop-filter:blur(2px)}
.login-card{position:relative;width:340px;padding:38px 32px;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);text-align:center}
.login-card .brand-mark{margin-bottom:18px}
.login-title{font-size:17px;font-weight:600;letter-spacing:.01em}
.login-sub{color:var(--ink-3);font-size:12.5px;margin:4px 0 22px;font-family:var(--mono);letter-spacing:.04em}
.login-card input{width:100%;height:42px;padding:0 14px;border:1px solid var(--line);border-radius:9px;font-size:14px;font-family:var(--mono);transition:border-color .15s,box-shadow .15s}
.login-card input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.cap-row{display:flex;gap:10px;margin-top:12px}
.cap-row input{margin-top:0;flex:1}
.cap-img{width:130px;height:42px;border:1px solid var(--line);border-radius:9px;cursor:pointer;overflow:hidden;flex:none;display:grid;place-items:center;background:#fff}
.cap-img svg{display:block}
.login-card .btn{width:100%;margin-top:12px;height:42px}
.login-err{color:var(--red);font-size:12.5px;margin-top:12px;min-height:16px}

/* ---- 按钮 ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:34px;padding:0 15px;border-radius:8px;border:1px solid transparent;font-size:13px;font-weight:500;font-family:var(--sans);cursor:pointer;transition:.14s;white-space:nowrap;background:none}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-primary:hover{background:#23242a}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink-2)}
.btn-ghost:hover{border-color:#d8d9dd;color:var(--ink)}
.btn-sm{height:28px;padding:0 11px;font-size:12px}
.btn-danger{color:var(--red);border-color:var(--line)}
.btn-danger:hover{background:var(--red-soft);border-color:#f3c7c8}

/* ---- 顶栏 ---- */
.app{position:relative;z-index:1;min-height:100vh;display:flex}
.brand-tag{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--ink-3)}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px var(--green-soft);flex:none}

/* ---- 侧边导航 ---- */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:228px;z-index:6;display:flex;flex-direction:column;background:rgba(255,255,255,.86);backdrop-filter:saturate(180%) blur(12px);border-right:1px solid var(--line)}
.side-brand{display:flex;flex-direction:column;gap:5px;padding:22px 22px 18px}
.side-nav{flex:1;display:flex;flex-direction:column;gap:3px;padding:8px 12px;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:11px;width:100%;height:40px;padding:0 13px;border:none;background:none;border-radius:9px;font-size:13.5px;font-weight:500;color:var(--ink-2);font-family:var(--sans);cursor:pointer;transition:.14s;text-align:left}
.nav-item svg{width:18px;height:18px;flex:none;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;opacity:.85}
.nav-item:hover{background:var(--line-2);color:var(--ink)}
.nav-item.active{background:var(--accent-soft);color:var(--accent)}
.nav-item.active svg{opacity:1}
.side-foot{padding:14px 16px;border-top:1px solid var(--line-2)}
.side-user{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.side-email{font-family:var(--mono);font-size:11.5px;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.side-acts{display:flex;flex-wrap:wrap;gap:6px}

/* ---- 内容区 ---- */
.content{flex:1;margin-left:228px;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:14px;height:64px;padding:0 30px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(10px)}
.page-title{display:flex;flex-direction:column;gap:2px}
.page-title h1{font-size:17px;font-weight:650;letter-spacing:-.01em}
.wrap{max-width:1000px;width:100%;margin:0 auto;padding:28px 30px 60px}
.view{display:none}
.view.active{display:block;animation:fade .2s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* 统计 */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:26px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.stat .k{font-size:11px;letter-spacing:.06em;color:var(--ink-3);font-family:var(--mono);text-transform:uppercase}
.stat .v{font-size:28px;font-weight:650;font-family:var(--mono);margin-top:8px;letter-spacing:-.02em}
.stat .v.accent{color:var(--accent)}
.stat .v.green{color:var(--green)} .stat .v.red{color:var(--red)} .stat .v.gray{color:var(--gray)}

/* 面板 */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:22px;overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 20px;border-bottom:1px solid var(--line-2)}
.panel-head h2{font-size:14px;font-weight:600}
.hint{color:var(--ink-3);font-size:12px}

/* 生成 */
.gen-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:14px;padding:18px 20px}
.gen-row label{display:flex;flex-direction:column;gap:6px;font-size:11px;letter-spacing:.04em;color:var(--ink-2);font-family:var(--mono);text-transform:uppercase}
.gen-row label.grow{flex:1;min-width:160px}
.gen-row input,.gen-row select,.gen-row textarea{height:38px;padding:0 12px;border:1px solid var(--line);border-radius:8px;font-size:13.5px;font-family:var(--mono);background:#fff;transition:.15s;color:var(--ink)}
.gen-row input:focus,.gen-row select:focus,.gen-row textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.gen-row input[type=number]{width:104px}
.gen-row select{cursor:pointer;min-width:150px}
.gen-row textarea{height:auto;min-height:42px;padding:10px 12px;font-family:var(--sans);resize:vertical;line-height:1.5}
.gen-result{padding:16px 20px;border-top:1px solid var(--line-2);background:var(--line-2)}
.gen-result .codes{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px;margin-top:10px}
.gen-result .codes span{font-family:var(--mono);font-size:13px;background:#fff;border:1px solid var(--line);border-radius:7px;padding:7px 10px;letter-spacing:.02em}

/* 过滤 */
.filters{display:flex;align-items:center;gap:12px}
.tabs{display:inline-flex;background:var(--gray-soft);border-radius:8px;padding:3px}
.tabs button{border:none;background:none;font-size:12.5px;color:var(--ink-2);padding:5px 12px;border-radius:6px;cursor:pointer;font-family:var(--sans);transition:.14s}
.tabs button.active{background:#fff;color:var(--ink);box-shadow:0 1px 2px rgba(10,10,11,.06)}
.search{height:32px;width:230px;padding:0 12px;border:1px solid var(--line);border-radius:8px;font-size:13px;font-family:var(--mono)}
.search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* 表格 */
.table-wrap{overflow-x:auto}
.grid{width:100%;border-collapse:collapse;font-size:13px}
.grid th{text-align:left;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);font-family:var(--mono);font-weight:500;padding:11px 20px;border-bottom:1px solid var(--line-2);background:#fcfcfd}
.grid td{padding:13px 20px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.grid tr:last-child td{border-bottom:none}
.grid tr:hover td{background:#fcfcfd}
.ta-r{text-align:right}
.c-code{font-family:var(--mono);font-weight:600;letter-spacing:.02em}
.c-dev{font-family:var(--mono);color:var(--ink-2);font-size:12px}
.c-exp{font-family:var(--mono);font-size:12.5px;color:var(--ink-2)}
.c-note{color:var(--ink-2)}
.row-actions{display:inline-flex;gap:6px;justify-content:flex-end}

/* 状态药丸 */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:3px 9px;border-radius:20px;font-family:var(--sans)}
.pill::before{content:"";width:6px;height:6px;border-radius:50%}
.pill.unused{background:var(--gray-soft);color:#5d626b}.pill.unused::before{background:var(--gray)}
.pill.active{background:var(--green-soft);color:#0c7a4e}.pill.active::before{background:var(--green)}
.pill.disabled{background:var(--red-soft);color:#b4282d}.pill.disabled::before{background:var(--red)}
.pill.expired{background:#fff3e6;color:#b5650a}.pill.expired::before{background:#e8890b}

.ondot{display:inline-block;width:8px;height:8px;border-radius:50%}
.ondot.on{background:var(--green);box-shadow:0 0 0 3px var(--green-soft)}
.ondot.off{background:#cdd0d5}
.empty{padding:48px;text-align:center;color:var(--ink-3);font-size:13px}

/* 弹层 */
.modal{position:fixed;inset:0;z-index:20;display:grid;place-items:center;background:rgba(10,10,11,.28);backdrop-filter:blur(2px)}
.modal-card{width:560px;max-width:92vw;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:22px}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.modal-head h3{font-size:15px}
.code-box{margin-top:12px;font-family:var(--mono);font-size:11.5px;line-height:1.6;background:var(--line-2);border:1px solid var(--line);border-radius:9px;padding:14px;word-break:break-all;white-space:pre-wrap;max-height:300px;overflow:auto}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;font-size:13px;padding:10px 16px;border-radius:9px;opacity:0;transition:.22s;z-index:30;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:860px){
  .app{flex-direction:column}
  .sidebar{position:sticky;width:100%;flex-direction:row;align-items:center;bottom:auto;border-right:none;border-bottom:1px solid var(--line);padding:0 8px;overflow-x:auto}
  .side-brand{display:none}
  .side-nav{flex-direction:row;padding:8px;gap:4px}
  .nav-item{width:auto;white-space:nowrap}
  .nav-item span{display:none}
  .nav-item{padding:0 12px}
  .side-foot{border-top:none;border-left:1px solid var(--line-2);padding:8px 12px;margin-left:auto}
  .side-user{display:none}
  .content{margin-left:0}
  .wrap{padding:20px 16px 48px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .filters{flex-direction:column;align-items:stretch}.search{width:100%}
}
