/* 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[type=checkbox]{height:20px;width:20px;padding:0;border-radius:5px;accent-color:var(--accent);flex:none}
/* 平台 logo(真·苹果/安卓图标) */
.plogo{display:inline-block;width:15px;height:15px;vertical-align:-3px;background-repeat:no-repeat;background-position:center;background-size:contain}
.plogo-ios{background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23333' d='M16.36 1.43c0 1.14-.42 2.2-1.13 3.02-.85.99-2.24 1.76-3.39 1.67-.14-1.1.45-2.27 1.13-3.02.79-.86 2.18-1.55 3.39-1.67zM20.6 17.07c-.62 1.42-.92 2.05-1.72 3.3-1.12 1.74-2.7 3.91-4.66 3.92-1.74.02-2.19-1.12-4.55-1.12-2.36 0-2.85 1.1-4.59 1.14-1.85.04-3.27-1.88-4.4-3.62C-1.34 16.5-1.6 10.9.86 7.9c1.2-1.5 3.06-2.45 5.04-2.45 1.97 0 3.21 1.13 4.85 1.13 1.59 0 2.56-1.13 4.85-1.13 1.73 0 3.56.94 4.86 2.57-4.27 2.34-3.58 8.43.14 9.05z'/></svg>")}
.plogo-and{background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%233DDC84' d='M17.6 9.48H6.4v7.6c0 .5.4.92.92.92h1.08v2.8a1.1 1.1 0 0 0 2.2 0v-2.8h2.8v2.8a1.1 1.1 0 0 0 2.2 0v-2.8h1.08c.5 0 .92-.42.92-.92v-7.6zM4.18 9.48a1.1 1.1 0 0 0-1.1 1.1v4.78a1.1 1.1 0 0 0 2.2 0v-4.78a1.1 1.1 0 0 0-1.1-1.1zm15.64 0a1.1 1.1 0 0 0-1.1 1.1v4.78a1.1 1.1 0 0 0 2.2 0v-4.78a1.1 1.1 0 0 0-1.1-1.1zM15.5 2.25l1.03-1.8a.22.22 0 0 0-.38-.22l-1.04 1.82A6.9 6.9 0 0 0 12 1.5c-1.13 0-2.2.2-3.1.55L7.86.23a.22.22 0 0 0-.38.22l1.03 1.8A5.6 5.6 0 0 0 6.4 6.9h11.2a5.6 5.6 0 0 0-2.1-4.65zM9.3 5.1a.62.62 0 1 1 0-1.24.62.62 0 0 1 0 1.24zm5.4 0a.62.62 0 1 1 0-1.24.62.62 0 0 1 0 1.24z'/></svg>")}
.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;cursor:pointer;white-space:nowrap;margin-left:10px}
.ag-code-pair{flex-direction:column;align-items:stretch;gap:8px}
.ag-pair-line{display:flex;align-items:center;gap:8px}
.ag-pair-tag{font-family:var(--sans);font-size:11px;font-weight:700;color:#fff;background:var(--accent);border-radius:5px;padding:2px 7px;flex:none}
.ag-pair-tag.udid{background:#11a36b}
.ag-pair-val{flex:1;word-break:break-all;font-size:14px}
.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}
.pill.accent{background:var(--accent-soft);color:var(--accent)}.pill.accent::before{background:var(--accent)}

/* 流水行 */
.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)}
