/* ZLAO 代理端 — 白底黑字科技风, 与后台控制台同源 */
: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;
  --safe-top:env(safe-area-inset-top,0px); --safe-bot:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
.hidden{display:none!important}
input{font-family:var(--sans);font-size:16px} /* 16px 防 iOS 聚焦缩放 */
#particles{position:fixed;inset:0;z-index:0;pointer-events:none}

/* 品牌字 */
.ag-brand{font-family:var(--mono);font-weight:700;letter-spacing:.18em;font-size:28px;color:var(--ink)}
.ag-brand-sub{color:var(--ink-3);font-size:12.5px;letter-spacing:.06em;margin-top:5px;font-family:var(--mono)}

/* 按钮 — 主按钮黑底白字(同后台) */
.ag-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:46px;padding:0 18px;border:1px solid transparent;border-radius:11px;font-size:15px;font-weight:600;font-family:var(--sans);cursor:pointer;background:none;transition:.12s}
.ag-btn:active{transform:scale(.98)}
.ag-btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.ag-btn-lg{width:100%;height:52px;font-size:16px}
.ag-btn-ghost{background:#fff;border-color:var(--line);color:var(--ink-2)}

/* 登录 */
.ag-login{position:fixed;inset:0;z-index:10;display:grid;place-items:center;padding:24px;background:rgba(255,255,255,.72);backdrop-filter:blur(2px)}
.ag-login-box{width:100%;max-width:350px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:36px 26px;box-shadow:0 1px 2px rgba(10,10,11,.04),0 10px 36px -16px rgba(10,10,11,.14);text-align:center}
.ag-login-box .ag-brand{font-size:30px}
.ag-login-box .ag-brand-sub{margin-bottom:26px}
.ag-login-box input{width:100%;height:48px;padding:0 15px;border:1px solid var(--line);border-radius:11px;margin-bottom:12px;font-family:var(--mono);transition:.15s}
.ag-login-box input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.ag-login-box .ag-btn{width:100%;margin-top:6px}
.ag-err{color:var(--red);font-size:13px;min-height:18px;margin-top:12px}

/* App 布局 */
.ag-app{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;padding-bottom:calc(64px + var(--safe-bot))}
.ag-top{background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line);padding:calc(var(--safe-top) + 14px) 18px 16px}
.ag-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ag-hello{font-size:14px;color:var(--ink-2)}
.ag-hello b{color:var(--ink);font-weight:600}
.ag-logout{background:#fff;border:1px solid var(--line);color:var(--ink-2);font-size:13px;padding:7px 14px;border-radius:9px;cursor:pointer;font-family:var(--sans)}
.ag-logout:active{transform:scale(.98)}

/* 余额卡 — 白底, 黑色大数字 */
.ag-balance-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:0 1px 2px rgba(10,10,11,.03)}
.ag-bal-lab{font-size:11px;letter-spacing:.06em;color:var(--ink-3);font-family:var(--mono);text-transform:uppercase}
.ag-bal-val{font-size:40px;font-weight:700;font-family:var(--mono);letter-spacing:-.02em;margin:6px 0 14px;color:var(--ink)}
.ag-bal-meta{display:flex;gap:0;border-top:1px solid var(--line-2);padding-top:12px}
.ag-bal-meta>span{flex:1;display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--ink-3);font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em}
.ag-bal-meta>span+span{border-left:1px solid var(--line-2);padding-left:14px}
.ag-bal-meta b{font-family:var(--mono);font-weight:700;font-size:17px;color:var(--ink)}

/* 内容 */
.ag-main{flex:1;padding:16px 14px}
.ag-page{display:none;animation:fade .2s ease}
.ag-page.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
.ag-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:14px;box-shadow:0 1px 2px rgba(10,10,11,.03)}
.ag-card-title{font-size:14px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}

/* 生成表单 */
.ag-gen{display:flex;flex-direction:column;gap:16px}
.ag-field{display:flex;flex-direction:column;gap:8px;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);font-weight:500;font-family:var(--mono)}
.ag-field input{height:46px;padding:0 14px;border:1px solid var(--line);border-radius:11px;font-family:var(--mono)}
.ag-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.ag-stepper{display:flex;align-items:center;border:1px solid var(--line);border-radius:11px;overflow:hidden;width:fit-content}
.ag-stepper button{width:52px;height:46px;border:none;background:var(--line-2);font-size:22px;color:var(--ink);cursor:pointer}
.ag-stepper button:active{background:var(--accent-soft)}
.ag-stepper input{width:78px;height:46px;border:none;text-align:center;font-size:18px;font-family:var(--mono);font-weight:600}
.ag-stepper input:focus{outline:none}
.ag-cost{font-size:14px;color:var(--ink-2);background:var(--line-2);border:1px solid var(--line);border-radius:10px;padding:12px 14px;text-align:center}
.ag-cost b{color:var(--ink);font-family:var(--mono);font-size:16px}

/* 生成结果 */
.ag-codes{display:flex;flex-direction:column;gap:8px}
.ag-code-item{display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:15px;font-weight:600;background:var(--line-2);border:1px solid var(--line);border-radius:9px;padding:11px 14px;letter-spacing:.03em}
.ag-code-item .cp{font-size:12px;color:var(--accent);font-family:var(--sans);font-weight:600}
.ag-chip{font-size:12.5px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:8px;padding:6px 12px;cursor:pointer;font-weight:500;font-family:var(--sans)}

/* 卡密 tabs */
.ag-tabs{display:flex;background:var(--gray-soft);border-radius:10px;padding:3px;margin-bottom:12px}
.ag-tabs button{flex:1;border:none;background:none;font-size:13px;color:var(--ink-2);padding:8px 4px;border-radius:8px;cursor:pointer;font-family:var(--sans);font-weight:500}
.ag-tabs button.active{background:#fff;color:var(--ink);box-shadow:0 1px 2px rgba(10,10,11,.06)}
.ag-search{width:100%;height:44px;padding:0 14px;border:1px solid var(--line);border-radius:11px;margin-bottom:12px;font-family:var(--mono)}
.ag-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* 列表 */
.ag-list{display:flex;flex-direction:column;gap:10px}
.ag-row{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:14px 16px;box-shadow:0 1px 2px rgba(10,10,11,.03)}
.ag-row-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.ag-row-code{font-family:var(--mono);font-size:15px;font-weight:600;letter-spacing:.02em}
.ag-row-sub{font-size:12px;color:var(--ink-3);margin-top:6px;display:flex;gap:12px;flex-wrap:wrap;font-family:var(--mono)}
.ag-row-acts{margin-top:12px;display:flex;gap:8px}
.ag-row-acts .ag-btn{height:38px;flex:1;font-size:13px;border-radius:9px}

/* 药丸 */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;padding:3px 9px;border-radius:20px}
.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}

/* 流水行 */
.ag-led{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--line);border-radius:13px;padding:14px 16px;box-shadow:0 1px 2px rgba(10,10,11,.03)}
.ag-led-l{display:flex;flex-direction:column;gap:5px}
.ag-led-ref{font-size:14px;font-weight:500}
.ag-led-time{font-size:12px;color:var(--ink-3);font-family:var(--mono)}
.ag-led-amt{font-family:var(--mono);font-weight:700;font-size:16px;color:var(--ink)}
.ag-led-amt.pos{color:var(--green)} .ag-led-amt.neg{color:var(--red)}
.ag-led-bal{font-size:11.5px;color:var(--ink-3);text-align:right;margin-top:3px;font-family:var(--mono)}

.ag-empty{text-align:center;color:var(--ink-3);font-size:14px;padding:50px 0}

/* 底部导航 */
.ag-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(12px);border-top:1px solid var(--line);padding-bottom:var(--safe-bot);z-index:10}
.ag-nav button{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 0 8px;border:none;background:none;color:var(--ink-3);font-size:11px;cursor:pointer;font-family:var(--sans)}
.ag-nav button svg{width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.ag-nav button.active{color:var(--ink)}

/* toast */
.ag-toast{position:fixed;left:50%;bottom:calc(80px + var(--safe-bot));transform:translateX(-50%) translateY(16px);background:var(--ink);color:#fff;font-size:14px;padding:12px 20px;border-radius:11px;opacity:0;transition:.22s;z-index:30;pointer-events:none;max-width:88vw;text-align:center}
.ag-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
