:root{--blue:#0094e2;--orange:#d87200;--teal:#008489;--bg:#f6f7f9;--paper:#fff;--text:#1f2937;--muted:#6b7280;--border:#e6e8ee;--bad:#b91c1c;--ok:#047857}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font:14px/1.45 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif}aside{position:fixed;inset:0 auto 0 0;width:220px;background:#fff;border-right:1px solid var(--border);padding:18px 14px}aside .brand{font-weight:900;color:var(--orange);font-size:18px;margin:4px 8px 22px}nav{display:grid;gap:4px}nav a{padding:10px 12px;border-radius:8px;color:#374151;text-decoration:none;font-weight:700}nav a:hover,nav a.active{background:#e8f6fd;color:var(--orange)}main{margin-left:220px;min-height:100vh}header{height:58px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:0 18px;position:sticky;top:0;z-index:2}header button{display:none}header span{display:block;color:var(--muted);font-size:12px}.logout{margin-left:auto;color:var(--orange);font-weight:800;text-decoration:none}.flash{margin:18px 24px 0;padding:12px 14px;border-radius:8px;border:1px solid #bfdbfe;background:#eff6ff;color:#1e40af;font-weight:700}.flash.bad{background:#fef2f2;border-color:#fecaca;color:var(--bad)}section{margin:18px 24px}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.stats div{background:#fff;border:1px solid var(--border);border-radius:8px;padding:16px}.stats b{font-size:26px;color:var(--orange);display:block}.stats span,.muted{color:var(--muted);font-weight:700}.panel{background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}.panel h2{margin:0;padding:13px 16px;background:#d9eefb;border-left:4px solid var(--orange);font-size:14px;color:var(--orange)}.panel-head{display:flex;align-items:center;justify-content:space-between;background:#d9eefb;border-left:4px solid var(--orange);padding-right:16px}.panel-head h2{background:transparent;border-left:0}.btn-link{display:inline-block;color:var(--orange);font-weight:900;text-decoration:none}.btn-link:hover{text-decoration:underline}form{padding:16px}.form-grid,.filters{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;align-items:end}.template{display:grid;grid-template-columns:1fr 180px;gap:12px}.template label:nth-last-of-type(1){grid-column:1/-1}.wide{grid-column:1/-1}label{display:grid;gap:6px;font-weight:800;color:#334155;font-size:12px;text-transform:uppercase}label span,.hint{color:var(--muted);font-size:12px;text-transform:none;font-weight:500}input,select,textarea{width:100%;border:1px solid #cbd5e1;border-radius:6px;padding:9px 10px;background:#fff;color:#111827;font:inherit}textarea{resize:vertical}button{border:0;background:var(--orange);color:#fff;border-radius:6px;padding:10px 14px;font-weight:900;cursor:pointer}button.secondary{background:#0f766e}button.danger{background:#b91c1c}.inline{padding-top:0}.mini{padding:0}.mini button{padding:7px 10px;font-size:12px}.table{padding:0 16px 16px;overflow:auto}table{border-collapse:collapse;width:100%;font-size:13px}th,td{border-bottom:1px solid var(--border);padding:10px;text-align:left;vertical-align:top}th{color:#92400e;font-size:12px}.empty{text-align:center;color:var(--muted);padding:24px}.preview-text{max-width:420px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge{display:inline-block;padding:3px 7px;border-radius:5px;background:#2563eb;color:#fff;font-size:11px;font-weight:900}.badge.ok{background:#059669}.badge.warn{background:#d97706}.pager{display:flex;gap:12px;align-items:center;justify-content:flex-end;padding:0 16px 16px}.pager a{color:var(--orange);font-weight:900;text-decoration:none}.check{grid-column:1/-1;display:flex;align-items:center;gap:8px;text-transform:none;font-size:13px}.check input{width:auto}.login{display:grid;place-items:center;min-height:100vh;background:linear-gradient(135deg,#e8f6fd,#fff 44%,#fff3e5)}.login-card{width:min(420px,92vw);background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 18px 50px rgba(15,23,42,.12);padding:24px}.login-card h1{margin:0;color:var(--orange)}.login-card p{margin:4px 0 18px;color:var(--muted)}.login-card button{width:100%;margin-top:8px}@media(max-width:900px){aside{transform:translateX(-100%);transition:.2s}.nav-open aside{transform:none;z-index:5}main{margin-left:0}header button{display:inline-block;background:#e8f6fd;color:var(--orange);padding:8px 10px}.grid,.form-grid,.filters,.template{grid-template-columns:1fr}section{margin:14px}.flash{margin:14px}}
.actions{display:flex;gap:10px;align-items:center}.preview-box{padding:16px}.email-preview{width:100%;height:520px;border:1px solid var(--border);border-radius:8px;background:#fff}.sms-preview{max-width:360px;border:1px solid var(--border);border-radius:12px;background:#f8fafc;padding:14px;white-space:pre-wrap;line-height:1.5}.template .actions+label.check{margin-top:-4px}
.row-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.small-link{display:inline-block;background:#e8f6fd;color:var(--orange);font-weight:900;text-decoration:none;border-radius:6px;padding:7px 10px}.small-link:hover{text-decoration:underline}
.custom-fields{border:1px solid var(--border);border-radius:8px;padding:12px;background:#fbfdff}.custom-fields h3{margin:0 0 6px;color:var(--orange);font-size:13px}.custom-row{display:grid;grid-template-columns:220px minmax(220px,1fr) 120px;gap:10px;align-items:end;margin-top:10px}.custom-list{padding:0 16px 10px}.custom-list span{display:inline-block;margin:3px 5px 0 0;padding:3px 7px;border-radius:999px;background:#eef6fb;color:#92400e;font-weight:800}@media(max-width:900px){.custom-row{grid-template-columns:1fr}.custom-row .hint{display:none}}
.quick-send-form{grid-template-columns:minmax(260px,1fr) 180px}.quick-send-form label:first-of-type{grid-column:2;grid-row:1}.quick-send-form label:nth-of-type(2){grid-column:1;grid-row:1}@media(max-width:900px){.quick-send-form{grid-template-columns:1fr}.quick-send-form label:first-of-type,.quick-send-form label:nth-of-type(2){grid-column:auto;grid-row:auto}}
.panel-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.contacts-main{margin-top:18px}.row-actions{display:flex;gap:8px;align-items:center}.small-link{display:inline-block;background:#e8f6fd;color:var(--orange);font-weight:900;text-decoration:none;border-radius:6px;padding:7px 10px}.modal-overlay{display:none;position:fixed;inset:0;z-index:50;background:rgba(15,23,42,.48);padding:24px;overflow:auto}.modal-overlay:target,.modal-overlay.modal-open{display:flex;align-items:flex-start;justify-content:center}.modal-card{width:min(720px,96vw);background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 20px 60px rgba(15,23,42,.22);margin:auto 0;overflow:hidden}.modal-wide{width:min(980px,96vw)}.modal-head{display:flex;justify-content:space-between;align-items:center;gap:12px;background:#d9eefb;border-left:4px solid var(--orange);padding:13px 16px}.modal-head h2{margin:0;color:var(--orange);font-size:14px}.modal-close{color:var(--orange);font-weight:900;text-decoration:none}.modal-form{padding:16px}.modal-form button{align-self:end}@media(max-width:900px){.panel-actions{width:100%;justify-content:flex-start}.modal-overlay{padding:12px}.row-actions{flex-direction:column;align-items:flex-start}.modal-card{margin:0}}
.modal-head-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}

.server-table-tools{display:grid;grid-template-columns:minmax(260px,1fr) 140px;gap:12px;align-items:end;padding:16px}.server-table th[data-order]{cursor:pointer;user-select:none;white-space:nowrap}.server-table th.sorted-asc::after{content:' ?';color:var(--orange)}.server-table th.sorted-desc::after{content:' ?';color:var(--orange)}.server-table .row-actions .small-link{white-space:nowrap}.pager button[disabled]{opacity:.45;cursor:not-allowed}@media(max-width:900px){.server-table-tools{grid-template-columns:1fr}}

/* Address book modals */
.modal-overlay:target,
.modal-overlay.modal-open{align-items:flex-start;justify-content:center;padding:32px 18px}
.modal-card{margin:0 auto;max-height:calc(100vh - 64px);display:flex;flex-direction:column}
.modal-card .table{overflow:auto;max-height:calc(100vh - 260px)}
.modal-xl{width:min(1120px,calc(100vw - 48px))}
.modal-wide{width:min(980px,calc(100vw - 48px))}
.modal-card table{min-width:860px}
#view-contacts .modal-card table{min-width:1040px}
#view-contacts .modal-head{position:sticky;top:0;z-index:2}
#view-contacts .server-table-tools{position:sticky;top:47px;z-index:2;background:#fff;border-bottom:1px solid var(--border)}
#view-contacts .row-actions{flex-wrap:nowrap;gap:6px}
#view-contacts .row-actions button{padding:7px 9px;font-size:12px;white-space:nowrap}
#view-contacts th,#view-contacts td{white-space:nowrap}
#view-contacts td:first-child{white-space:normal;min-width:170px}
#view-contacts .pager{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--border);padding-top:12px}
@media(max-width:900px){.modal-overlay:target,.modal-overlay.modal-open{padding:10px}.modal-xl,.modal-wide{width:100%}.modal-card{max-height:calc(100vh - 20px)}.modal-card .table{max-height:calc(100vh - 250px)}}
/* Templates page sizing */
.templates-panel{max-width:1280px}
.template-form{grid-template-columns:minmax(260px,1fr) 180px;align-items:end}
.template-form .template-subject,.template-form .template-message,.template-form .hint,.template-form .template-submit{grid-column:1/-1}
.template-form textarea{min-height:170px}
.template-submit{display:flex;justify-content:flex-start}.template-submit button{width:min(260px,100%)}
.templates-table-wrap{max-height:360px;overflow:auto}.templates-table{min-width:980px;table-layout:fixed}.templates-table th:nth-child(1),.templates-table td:nth-child(1){width:260px}.templates-table th:nth-child(2),.templates-table td:nth-child(2){width:90px}.templates-table th:nth-child(3),.templates-table td:nth-child(3){width:260px}.templates-table th:nth-child(5),.templates-table td:nth-child(5){width:170px}.template-message-cell{white-space:normal;line-height:1.35;max-width:520px;word-break:break-word}.templates-table thead th{position:sticky;top:0;background:#fff;z-index:1}
@media(max-width:900px){.template-form{grid-template-columns:1fr}.template-submit button{width:100%}.templates-table-wrap{max-height:none}}
/* Template management modals */
.templates-main .templates-table{min-width:1120px;table-layout:fixed}.templates-main .templates-table th:nth-child(1),.templates-main .templates-table td:nth-child(1){width:220px}.templates-main .templates-table th:nth-child(2),.templates-main .templates-table td:nth-child(2){width:90px}.templates-main .templates-table th:nth-child(3),.templates-main .templates-table td:nth-child(3){width:240px}.templates-main .templates-table th:nth-child(5),.templates-main .templates-table td:nth-child(5){width:170px}.templates-main .templates-table th:nth-child(6),.templates-main .templates-table td:nth-child(6){width:210px}.template-modal .template-form{grid-template-columns:minmax(260px,1fr) 180px}.template-view{padding:16px}.template-view dl{display:grid;grid-template-columns:110px 1fr;gap:8px 14px;margin:0 0 16px}.template-view dt{font-weight:900;color:#92400e}.template-view dd{margin:0}.template-view pre{white-space:pre-wrap;word-break:break-word;border:1px solid var(--border);border-radius:8px;background:#fbfdff;padding:14px;min-height:180px;font:inherit}
/* Campaign management */
.campaigns-main .campaigns-table{min-width:1280px;table-layout:fixed}.campaigns-main .quick-table{min-width:1080px;table-layout:fixed}.campaigns-table th:nth-child(1),.campaigns-table td:nth-child(1){width:260px}.campaigns-table th:nth-child(7),.campaigns-table td:nth-child(7){width:170px}.campaigns-table th:nth-child(10),.campaigns-table td:nth-child(10){width:180px}.quick-table th:nth-child(6),.quick-table td:nth-child(6){width:280px}.progress{height:8px;background:#e5e7eb;border-radius:999px;overflow:hidden;display:flex;margin-bottom:4px}.progress-sent{background:#059669;height:100%}.progress-failed{background:#b91c1c;height:100%}.campaign-modal .quick-send-form{grid-template-columns:minmax(260px,1fr) 180px}.campaign-modal .template{grid-template-columns:minmax(260px,1fr) 220px}.campaign-modal textarea{min-height:130px}
@media(max-width:900px){.campaign-modal .quick-send-form,.campaign-modal .template{grid-template-columns:1fr}}
/* Contact modal filtering and bulk selection */
#view-contacts .contacts-tools{grid-template-columns:minmax(260px,1fr) 170px 120px}
#view-contacts .bulk-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:0 16px 12px;background:#fff;border-bottom:1px solid var(--border)}
#view-contacts .bulk-actions span{font-weight:900;color:var(--muted);margin-right:auto}
#view-contacts .bulk-actions button{padding:8px 10px;font-size:12px}
#view-contacts .bulk-actions button[disabled]{opacity:.45;cursor:not-allowed}
#view-contacts th.check-col,#view-contacts td.check-col{width:42px;min-width:42px;max-width:42px;text-align:center;white-space:nowrap}
#view-contacts .check-col input{width:auto;margin:0}
#view-contacts .modal-card table{min-width:1120px}
#view-contacts td:nth-child(2){white-space:normal;min-width:170px}
@media(max-width:900px){#view-contacts .contacts-tools{grid-template-columns:1fr}#view-contacts .bulk-actions{align-items:flex-start}#view-contacts .bulk-actions span{width:100%;margin-right:0}}
/* Send preview */
.preview-split{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:16px;align-items:start}
.preview-split .email-preview{height:560px}
@media(max-width:900px){.preview-split{grid-template-columns:1fr}.preview-split .sms-preview{max-width:none}}