@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap);:root{--bg:#0e0f11;--surface:#16181c;--surface2:#1e2128;--border:#2a2d35;--border2:#363a45;--text:#f0f2f5;--muted:#7a8090;--accent:#4c8ef7;--accent-dim:#4c8ef71f;--green:#2ecc71;--green-dim:#2ecc711f;--amber:#f59e0b;--amber-dim:#f59e0b1f;--red:#ef4444;--red-dim:#ef44441f;--radius:12px;--radius-lg:16px;--nav-h:60px;--max-w:540px}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#0e0f11;background:var(--bg);color:#f0f2f5;color:var(--text);font-family:Space Grotesk,sans-serif;min-height:100vh}.loading-screen{align-items:center;color:#7a8090;color:var(--muted);display:flex;flex-direction:column;font-size:.9rem;gap:16px;height:100vh;justify-content:center}.spinner{animation:spin .7s linear infinite;border:2px solid #363a45;border-top-color:#4c8ef7;border:2px solid var(--border2);border-radius:50%;border-top-color:var(--accent);height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1 1;margin:0 auto;max-width:540px;max-width:var(--max-w);padding:16px 16px 80px;width:100%}.card{background:#16181c;background:var(--surface);border:1px solid #2a2d35;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);margin-bottom:12px;padding:16px}.card-sm{padding:12px 14px}.btn{align-items:center;background:#1e2128;background:var(--surface2);border:1px solid #363a45;border:1px solid var(--border2);border-radius:12px;border-radius:var(--radius);color:#f0f2f5;color:var(--text);cursor:pointer;display:inline-flex;font-family:Space Grotesk,sans-serif;font-size:.88rem;font-weight:600;gap:6px;justify-content:center;padding:11px 18px;transition:all .15s}.btn:hover{color:#4c8ef7;color:var(--accent)}.btn-primary,.btn:hover{border-color:#4c8ef7;border-color:var(--accent)}.btn-primary{background:#4c8ef7;background:var(--accent);color:#fff}.btn-primary:hover{color:#fff;opacity:.88}.btn-ghost{background:#0000;border-color:#0000;color:#7a8090;color:var(--muted)}.btn-ghost:hover{background:#1e2128;background:var(--surface2);border-color:#2a2d35;border-color:var(--border);color:#f0f2f5;color:var(--text)}.btn-full{width:100%}.btn:disabled{cursor:not-allowed;opacity:.4}.btn-sm{font-size:.82rem;padding:7px 12px}.form-group{margin-bottom:14px}.form-label{color:#7a8090;color:var(--muted);display:block;font-size:.78rem;font-weight:600;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.form-input,.form-select{background:#1e2128;background:var(--surface2);border:1px solid #363a45;border:1px solid var(--border2);border-radius:12px;border-radius:var(--radius);color:#f0f2f5;color:var(--text);font-family:Space Grotesk,sans-serif;font-size:.92rem;font-weight:500;outline:none;padding:10px 14px;transition:border-color .15s;width:100%}.form-input::placeholder{color:#7a8090;color:var(--muted)}.form-input:focus,.form-select:focus{border-color:#4c8ef7;border-color:var(--accent)}.section-title{color:#7a8090;color:var(--muted);font-size:.72rem;font-weight:700;letter-spacing:.08em;margin:20px 0 10px;text-transform:uppercase}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.75rem;font-weight:600;gap:4px;padding:3px 10px}.badge-green{background:#2ecc711f;background:var(--green-dim);color:#2ecc71;color:var(--green)}.badge-amber{background:#f59e0b1f;background:var(--amber-dim);color:#f59e0b;color:var(--amber)}.badge-red{background:#ef44441f;background:var(--red-dim);color:#ef4444;color:var(--red)}.badge-blue{background:#4c8ef71f;background:var(--accent-dim);color:#4c8ef7;color:var(--accent)}.badge-neutral{border:1px solid #2a2d35;border:1px solid var(--border);color:#7a8090;color:var(--muted)}.badge-neutral,.metric-card{background:#1e2128;background:var(--surface2)}.metric-card{border-radius:12px;border-radius:var(--radius);padding:12px 14px}.metric-label{color:#7a8090;color:var(--muted);font-size:.72rem;font-weight:600;letter-spacing:.05em;margin-bottom:5px;text-transform:uppercase}.metric-val{color:#f0f2f5;color:var(--text);font-size:1.5rem;font-weight:700}.metric-sub{color:#7a8090;color:var(--muted);font-size:.75rem;margin-top:2px}.toast{background:#1e2128;background:var(--surface2);border:1px solid #363a45;border:1px solid var(--border2);border-radius:999px;bottom:74px;box-shadow:0 8px 32px #0006;color:#f0f2f5;color:var(--text);font-size:.88rem;font-weight:600;left:50%;padding:10px 20px;position:fixed;transform:translateX(-50%) translateY(60px);transition:transform .3s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;z-index:999}.toast.show{transform:translateX(-50%) translateY(0)}.toast.ok{border-color:#2ecc71;border-color:var(--green);color:#2ecc71;color:var(--green)}.toast.err{border-color:#ef4444;border-color:var(--red);color:#ef4444;color:var(--red)}.modal-overlay{align-items:flex-end;background:#0009;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:200}.modal-box{animation:slideUp .25s ease;background:#16181c;background:var(--surface);border:1px solid #363a45;border:1px solid var(--border2);border-radius:16px 16px 12px 12px;border-radius:var(--radius-lg) var(--radius-lg) var(--radius) var(--radius);max-width:540px;max-width:var(--max-w);padding:24px 20px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}}.modal-title{font-size:1.1rem;font-weight:700;margin-bottom:16px}.grid-2{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.grid-3{grid-gap:8px;grid-template-columns:1fr 1fr 1fr}.grid-3,.grid-4{display:grid;gap:8px}.grid-4{grid-gap:8px;grid-template-columns:1fr 1fr 1fr 1fr}.progress-bar{background:#363a45;background:var(--border2);border-radius:2px;height:4px;overflow:hidden}.progress-fill{border-radius:2px;height:100%;transition:width .4s ease}.api-log,.mono{font-family:JetBrains Mono,monospace}.api-log{background:#0e0f11;background:var(--bg);border:1px solid #2a2d35;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);color:#7a8090;color:var(--muted);font-size:.75rem;line-height:1.9;margin-top:10px;max-height:110px;overflow-y:auto;padding:10px}.log-ok{color:#2ecc71;color:var(--green)}.log-err{color:#ef4444;color:var(--red)}.log-info{color:#4c8ef7;color:var(--accent)}.zone-row{align-items:center;display:flex;gap:8px;margin-bottom:6px}.zone-label{color:#7a8090;color:var(--muted);font-size:.75rem;font-weight:600;min-width:28px}.zone-bar-bg{background:#2a2d35;background:var(--border);border-radius:3px;flex:1 1;height:6px;overflow:hidden}.zone-bar-fill{border-radius:3px;height:100%;transition:width .5s ease}.zone-pct{color:#f0f2f5;color:var(--text);font-size:.75rem;font-weight:600;min-width:34px;text-align:right}.px-block{background:#1e2128;background:var(--surface2);border:1px solid #2a2d35;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);margin-bottom:10px;padding:14px 16px}.px-block-title{font-size:.95rem;font-weight:700;margin-bottom:8px}.px-meta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:8px}.px-meta-item{color:#7a8090;color:var(--muted);font-size:.82rem}.px-meta-item strong{color:#f0f2f5;color:var(--text);font-weight:600}.px-rationale{border-top:1px solid #2a2d35;border-top:1px solid var(--border);color:#7a8090;color:var(--muted);font-size:.8rem;line-height:1.65;margin-top:8px;padding-top:10px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#363a45;background:var(--border2);border-radius:999px}
/*# sourceMappingURL=main.af3ffa24.css.map*/