body{margin:0;font-family:Inter,Arial,sans-serif;background:#f5f6f8;color:#18202b}.hidden{display:none!important}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#111827,#334155)}.login-card{width:420px;background:white;border-radius:18px;padding:28px;box-shadow:0 22px 60px rgba(0,0,0,.25)}h1,h2,h3{margin-top:0}label{display:block;margin-top:14px;font-weight:700;font-size:13px}input,select{width:100%;box-sizing:border-box;padding:11px 12px;margin-top:6px;border:1px solid #d7dce3;border-radius:10px;background:#fff}button{border:0;border-radius:10px;background:#111827;color:white;padding:10px 14px;font-weight:700;cursor:pointer;margin-top:12px}button:hover{opacity:.9}.muted{color:#667085;font-size:13px}.msg{color:#b42318;font-size:13px}.dev-otp{background:#fff4d6;border:1px solid #f2c94c;border-radius:10px;padding:8px;color:#7a4b00}.app{display:flex;min-height:100vh}aside{width:245px;background:#111827;color:white;padding:22px;box-sizing:border-box}aside button{display:block;width:100%;background:#243044;text-align:left;margin:8px 0}main{flex:1;padding:24px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.panel{background:white;border:1px solid #e5e7eb;border-radius:16px;padding:18px;margin:14px 0;box-shadow:0 8px 26px rgba(15,23,42,.04)}pre{white-space:pre-wrap;background:#0b1220;color:#dbeafe;border-radius:12px;padding:12px;overflow:auto}.search-row{max-width:520px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:16px}.card{background:white;border:1px solid #e5e7eb;border-radius:16px;padding:16px;cursor:pointer}.card:hover{border-color:#111827}.danger-soft{border-color:#fecaca;background:#fffafa}canvas{background:white;border:1px solid #e5e7eb;border-radius:16px;padding:12px;margin-top:16px}

.form-grid{display:grid;grid-template-columns:repeat(5,minmax(130px,1fr));gap:12px;align-items:end}
.form-grid label{font-size:12px;color:#7c8798;display:flex;flex-direction:column;gap:6px}
.button-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.table-wrap{overflow:auto;max-height:420px;border:1px solid #e6eaf1;border-radius:12px;background:white}
table{border-collapse:collapse;width:100%;font-size:12px}
th,td{border-bottom:1px solid #edf0f5;padding:8px 10px;text-align:left;white-space:nowrap}
th{position:sticky;top:0;background:#f7f9fc;color:#495467}
.button-row.compact { gap: 8px; margin-top: 12px; }
button.secondary { background: #2f3a4a; }
.small { font-size: 12px; }
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;position:sticky;top:0;z-index:5;background:rgba(8,12,20,.92);backdrop-filter:blur(8px);padding:8px 0}.admin-badge{border:1px solid #334155;background:#0f172a;color:#e5e7eb;border-radius:999px;padding:8px 14px;cursor:pointer}.admin-badge:hover{background:#1e293b}.check-row{display:flex;gap:8px;align-items:center;margin:10px 0}.check-row input{width:auto!important}.login-card input{text-transform:none}.dev-otp{font-family:ui-monospace,Consolas,monospace;color:#facc15}.msg{white-space:pre-wrap}

.linklike{background:transparent;border:0;color:#2b5cff;text-decoration:underline;padding:6px 0;box-shadow:none}
.linklike:hover{background:transparent}
.reset-box{margin-top:12px;padding:12px;border:1px solid #dde3f0;border-radius:12px;background:#f8faff}
.small{font-size:12px}

/* v13 legal pages for Twilio A2P campaign review */
.legal-links a,.site-footer a{color:#2563eb;text-decoration:none;font-weight:700}.legal-links a:hover,.site-footer a:hover{text-decoration:underline}.site-footer{margin:30px 0 8px;color:#667085;font-size:13px}.legal-page{background:#0b1220;min-height:100vh;color:#18202b}.legal-container{max-width:920px;margin:0 auto;padding:34px 18px}.legal-card{background:#fff;border-radius:18px;padding:34px;box-shadow:0 24px 60px rgba(0,0,0,.22);line-height:1.62}.legal-card h1{font-size:34px;margin-bottom:4px}.legal-card h2{font-size:20px;margin-top:28px;margin-bottom:8px}.legal-card ul{padding-left:24px}.legal-card li{margin:8px 0}.legal-card a{color:#1d4ed8;font-weight:700}.back-link{display:inline-block;color:#dbeafe;text-decoration:none;font-weight:800;margin-bottom:16px}.back-link:hover{text-decoration:underline}@media(max-width:640px){.legal-card{padding:22px}.legal-card h1{font-size:28px}.legal-container{padding:22px 12px}}

.tiny{font-size:12px; margin-top:6px;}


/* v17: persistent password show/hide toggle. Hide browser-native reveal icons to avoid duplicate eyes. */
.password-wrap{position:relative;width:100%;margin-top:6px;}
.password-wrap input{margin-top:0;padding-right:76px;}
.password-wrap input::-ms-reveal,.password-wrap input::-ms-clear{display:none;}
.password-wrap input::-webkit-credentials-auto-fill-button,.password-wrap input::-webkit-caps-lock-indicator{visibility:hidden;display:none!important;pointer-events:none;}
.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);margin:0;padding:7px 10px;border:1px solid #cfd7e3;background:#fff;color:#111827;border-radius:10px;font-size:13px;font-weight:700;line-height:1;cursor:pointer;opacity:1;min-width:52px;text-align:center;}
.password-toggle:hover{background:#eef2f7;}
.password-toggle.is-showing{background:#eef2f7;border-color:#aeb8c8;}

/* ===== v25 user-friendly dashboards ===== */
.hero-panel{border:1px solid #e6eaf2; box-shadow:0 10px 30px rgba(15,23,42,.06)}
.status-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:14px}
.status-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:14px;box-shadow:0 4px 14px rgba(15,23,42,.05)}
.status-card.clickable{cursor:pointer;transition:transform .12s ease, box-shadow .12s ease}
.status-card.clickable:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,23,42,.10)}
.status-card-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.kv{display:flex;justify-content:space-between;gap:10px;padding:5px 0;border-top:1px solid #f1f5f9;font-size:13px}
.kv:first-of-type{border-top:0}
.kv span{color:#64748b}.kv b{font-weight:700;text-align:right;color:#111827}
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:800;white-space:nowrap;text-transform:uppercase;letter-spacing:.02em}
.badge.ok{background:#dcfce7;color:#166534}.badge.warn{background:#fef3c7;color:#92400e}.badge.bad{background:#fee2e2;color:#991b1b}
.two-col-wide{grid-template-columns:minmax(0,1.25fr) minmax(360px,.75fr)}
.compact-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}
.mini-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin:12px 0}
.mini-kpi{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:10px}
.mini-kpi span{display:block;color:#64748b;font-size:12px}.mini-kpi b{display:block;font-size:18px;margin-top:4px;color:#111827}
.friendly-table{max-height:560px;overflow:auto;background:#fff;border:1px solid #e5e7eb;border-radius:12px}
.small-table{max-height:260px;overflow:auto;background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-top:12px}
.data-table{border-collapse:separate;border-spacing:0;width:100%;font-size:13px;background:#fff}
.data-table th{position:sticky;top:0;background:#0f172a;color:#fff;text-align:left;padding:10px;border-right:1px solid rgba(255,255,255,.08);z-index:1}
.data-table td{padding:8px 10px;border-bottom:1px solid #e5e7eb;border-right:1px solid #f1f5f9;vertical-align:top;max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.data-table tr:hover td{background:#f8fafc}
.mini-btn{font-size:12px;padding:6px 9px;border-radius:9px}
.raw-details{margin-top:12px}.raw-details summary{cursor:pointer;color:#475569;font-weight:700}.raw-details pre{max-height:240px;overflow:auto}
.friendly-result{margin-top:14px}.result-card{border-radius:14px;border:1px solid #e5e7eb;padding:12px;background:#fff}.result-card h4{margin:0 0 8px 0}.result-ok{border-color:#bbf7d0;background:#f0fdf4}.result-warn{border-color:#fde68a;background:#fffbeb}
.notice{border:1px solid #dbeafe;background:#eff6ff;color:#1e40af;border-radius:12px;padding:10px;font-weight:700}.ok-notice{border-color:#bbf7d0;background:#f0fdf4;color:#166534}
.checklist p{margin:0 0 10px 0;line-height:1.4}
@media(max-width:1100px){.two-col-wide{grid-template-columns:1fr}.status-cards{grid-template-columns:1fr}}
.warn-notice{border-color:#fde68a;background:#fffbeb;color:#92400e}
.source-chip{display:inline-block;margin:2px 4px 2px 0;padding:3px 8px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:12px;font-weight:700}


/* ===== v29 Trading Desk ===== */
.trading-hero{background:linear-gradient(180deg,#ffffff,#f8fafc);}
.trading-toolbar{display:grid;grid-template-columns:minmax(320px,1fr) minmax(320px,.85fr);gap:18px;align-items:end}
.trading-controls{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:10px;align-items:end}
.trading-controls button{align-self:end;margin-top:0}
.trading-main-chart{height:520px!important;min-height:520px;background:#fff;border:1px solid #dbe3ef;border-radius:18px;padding:12px;margin-top:12px;box-shadow:0 10px 30px rgba(15,23,42,.06)}
.desk-head-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:14px;margin-top:12px}.desk-head-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:14px;box-shadow:0 6px 18px rgba(15,23,42,.05)}.desk-head-table{margin-top:10px;border:1px solid #eef2f7;border-radius:12px;overflow:auto;max-height:180px}.mini-head-table{font-size:11px;width:100%;border-collapse:collapse}.mini-head-table th{background:#f8fafc;color:#334155;position:static;padding:7px}.mini-head-table td{padding:7px;border-top:1px solid #eef2f7;white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}.empty-head{padding:18px;color:#64748b;background:#f8fafc;text-align:center}.badge.has{background:#dcfce7;color:#166534}
@media(max-width:1100px){.trading-toolbar{grid-template-columns:1fr}.trading-controls{grid-template-columns:1fr}.trading-main-chart{height:380px!important;min-height:380px}}
