:root{--bg:#f4f7fb;--panel:#ffffff;--panel-2:#f8fafc;--text:#132033;--muted:#667085;--line:#d9e2ec;--primary:#155eef;--primary-dark:#0f46b7;--danger:#c62828;--danger-bg:#fff1f1;--ok:#0f7b45;--ok-bg:#ecfdf3;--warn:#a15c00;--warn-bg:#fff7e6;--shadow:0 14px 38px rgba(16,24,40,.08);--radius:16px;--radius-sm:10px}*{box-sizing:border-box}html{font-size:16px}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.45}.topbar{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;min-height:72px;padding:14px 28px;background:#0b1220;color:#fff;box-shadow:0 6px 22px rgba(0,0,0,.18)}.brand{display:flex;align-items:center;gap:12px;white-space:nowrap}.brand-mark{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#2563eb,#06b6d4);font-weight:800;letter-spacing:.03em}.mainnav{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.mainnav a{color:#dbe7ff;text-decoration:none;padding:9px 11px;border-radius:10px;font-weight:600;font-size:.94rem}.mainnav a:hover{background:rgba(255,255,255,.12);color:#fff}.user-pill{justify-self:end;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:999px;padding:8px 12px;font-size:.88rem;color:#dbe7ff}.page{max-width:1320px;margin:0 auto;padding:28px}.footer{max-width:1320px;margin:0 auto 28px;padding:0 28px;color:var(--muted);font-size:.9rem}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin-bottom:22px}.card .card{box-shadow:none;background:var(--panel-2);margin-bottom:0}.narrow{max-width:520px;margin-left:auto;margin-right:auto}.auth-shell{min-height:calc(100vh - 170px);display:grid;place-items:start center;padding-top:8vh}.section-title,.bar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px}.section-title h1,.bar h1,h1{margin:0;color:var(--text);line-height:1.15}.section-title p{margin:.35rem 0 0;color:var(--muted)}h2{margin:24px 0 12px}h3{margin:0 0 8px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px}.grid2,.form-grid.two{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:18px 22px}.form,.form.stack,form{display:block}.form.stack{display:grid;gap:16px}.form-card form,.form form{margin-top:8px}label{display:flex;flex-direction:column;gap:7px;color:#344054;font-weight:650;font-size:.93rem;margin:0}label span{display:block}input,select,textarea{width:100%;min-height:42px;padding:10px 12px;border:1px solid #cfd8e3;border-radius:10px;background:#fff;color:var(--text);font:inherit;outline:none;transition:border-color .15s,box-shadow .15s}textarea{min-height:104px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(21,94,239,.12)}input[type=checkbox]{width:auto;min-height:auto;margin-right:8px}.checkbox-row,.inline,label:has(input[type=checkbox]){display:flex;flex-direction:row;align-items:center;gap:8px;font-weight:600}.form-actions{display:flex;justify-content:flex-end;align-items:center;gap:12px;margin-top:22px}.form-actions.split{justify-content:space-between}.button,button{appearance:none;border:1px solid #c7d2df;border-radius:10px;background:#fff;color:#1f344d;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:9px 14px;font:inherit;font-weight:700;cursor:pointer;white-space:nowrap}button:hover,.button:hover{background:#f2f6fb}.button.primary,button.primary,.primary{background:var(--primary);border-color:var(--primary);color:#fff}.button.primary:hover,button.primary:hover,.primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.secondary{background:#eef4ff;border-color:#bfd0ff;color:#153e91}.danger{background:var(--danger-bg);border-color:#ffc8c8;color:var(--danger)}.small{min-height:34px;padding:6px 10px;font-size:.88rem;border-radius:8px}.actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.actions form{display:inline-flex;margin:0}.table-wrap{width:100%;overflow:auto;border:1px solid var(--line);border-radius:14px}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:13px 14px;text-align:left;border-bottom:1px solid var(--line);vertical-align:middle}th{background:#f8fafc;color:#475467;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}tr:last-child td{border-bottom:0}tbody tr:hover{background:#fbfdff}.data-table td:last-child{min-width:230px}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 9px;background:#eef2f7;color:#344054;font-weight:700;font-size:.78rem}.status-active{background:var(--ok-bg);color:var(--ok)}.status-pending{background:var(--warn-bg);color:var(--warn)}.status-disabled{background:#eef2f7;color:#667085}.notice,.alert,.ok,.error{border-radius:12px;padding:12px 14px;margin:14px 0;border:1px solid}.notice.ok,.ok{background:var(--ok-bg);color:var(--ok);border-color:#a6f4c5}.notice.error,.error,.alert{background:var(--danger-bg);color:var(--danger);border-color:#ffc8c8}.config,pre{background:#0b1220;color:#d6e4ff;padding:18px;border-radius:14px;overflow:auto;white-space:pre-wrap;font:13px/1.5 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace}.dashboard-stat p{font-size:2.2rem;font-weight:800;margin:8px 0 0;color:var(--primary)}@media(max-width:900px){.topbar{grid-template-columns:1fr;align-items:start}.user-pill{justify-self:start}.page{padding:18px}.grid2,.form-grid.two{grid-template-columns:1fr}.section-title,.bar{flex-direction:column;align-items:stretch}.form-actions,.form-actions.split{flex-direction:column-reverse;align-items:stretch}.button,button{width:100%}.actions{align-items:stretch}.actions .button,.actions button{width:auto}.data-table td:last-child{min-width:160px}}@media(max-width:560px){.topbar{padding:14px}.mainnav a{padding:8px}.card{padding:18px;border-radius:14px}th,td{padding:10px}.actions{flex-direction:column;align-items:flex-start}}

/* v4 Guided Wizard */
.wizard-hero{display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;background:linear-gradient(135deg,#ffffff,#eef4ff)}
.wizard-hero h1{margin:.35rem 0}.wizard-hero p{margin:0;color:var(--muted);max-width:760px}.button.big{min-height:48px;padding:12px 18px;font-size:1rem}.wizard-card{max-width:1180px;margin-left:auto;margin-right:auto}.wizard-progress{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:18px 0 24px}.wizard-progress span{display:grid;place-items:center;min-height:42px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--muted);font-weight:800}.wizard-progress span.active{background:var(--primary);border-color:var(--primary);color:#fff}.wizard-progress span.done{background:var(--ok-bg);border-color:#a6f4c5;color:var(--ok)}.subcard{background:var(--panel-2);border:1px solid var(--line);border-radius:14px;padding:20px;margin-bottom:16px}.subcard h2{margin-top:0}.choice-grid{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:16px}.choice-card{display:grid;grid-template-columns:auto 1fr;align-items:start;gap:10px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}.choice-card strong{display:block}.choice-card small,.hint,small{color:var(--muted);font-weight:500}.choice-card input{margin-top:4px}.hint{margin:.6rem 0 0}.alert ul{margin:.4rem 0 0;padding-left:1.2rem}.inline{display:inline-flex!important;flex-direction:row!important;align-items:center!important;gap:8px}.inline input{width:auto}@media(max-width:760px){.wizard-hero{grid-template-columns:1fr}.wizard-progress{grid-template-columns:1fr 1fr}.choice-grid{grid-template-columns:1fr}}

/* v5 Module Dashboard */
.module-hero{display:grid;grid-template-columns:1fr;gap:16px;background:linear-gradient(135deg,#ffffff,#edf7ff)}
.module-hero h1{margin:.35rem 0}.module-hero p{margin:0;color:var(--muted);max-width:860px}.module-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:22px;margin-bottom:22px}.module-card{display:grid;grid-template-columns:72px 1fr;gap:18px;align-items:start;min-height:260px;margin-bottom:0}.module-card h2{margin:10px 0 8px}.module-card p{color:var(--muted);margin:0 0 18px}.module-icon{display:grid;place-items:center;width:72px;height:72px;border-radius:18px;background:linear-gradient(135deg,#155eef,#06b6d4);color:#fff;font-weight:900;letter-spacing:.04em;box-shadow:0 12px 24px rgba(21,94,239,.22)}.module-icon.muted{background:#e9eef6;color:#526072;box-shadow:none}.module-body{display:flex;flex-direction:column;min-height:210px}.module-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:auto}.button.disabled{background:#eef2f7;border-color:#d9e2ec;color:#667085;cursor:not-allowed;pointer-events:auto}.module-active{border-color:#b8cdfd}.module-soon{box-shadow:none;background:#fbfdff}@media(max-width:640px){.module-grid{grid-template-columns:1fr}.module-card{grid-template-columns:1fr}.module-icon{width:58px;height:58px;border-radius:14px}.module-actions{flex-direction:column}.module-actions .button{width:100%}}
