:root{--bg:#f5f7ff;--panel:#fff;--line:#e3e8f6;--text:#111827;--muted:#6b7280;--brand:#4f46e5;--brand2:#7c3aed}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,Arial}
.app{display:grid;grid-template-columns:250px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#0f172a,#111827);color:#dbe7ff;padding:14px}
.logo{font-size:22px;font-weight:800;margin-bottom:6px}
.side-links{display:grid;gap:8px;margin:12px 0}
.side-links a{padding:9px 10px;border-radius:10px;text-decoration:none;color:#dbe7ff;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1)}
.side-links a.active{background:linear-gradient(135deg,var(--brand),var(--brand2));border-color:transparent}
.logout{display:inline-flex;margin-top:8px;padding:8px 10px;border-radius:10px;background:#1f2937;color:#fff;text-decoration:none}
.content{padding:14px;min-width:0}
.top{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
.card{margin-top:10px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px}
.muted{color:var(--muted)}
.btn{padding:10px 12px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;font-weight:700;cursor:pointer}
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:16px}
.login-card{width:min(420px,95vw)}
.login-form{display:grid;gap:8px}
input,select{padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff}
.err{background:#fff1f2;border:1px solid #fecdd3;color:#be123c;padding:10px;border-radius:10px}
@media(max-width:980px){.app{grid-template-columns:1fr}}

.ok-msg{background:#ecfdf3;border:1px solid #bbf7d0;color:#166534;padding:10px;border-radius:10px}
.section-head{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
.filter-row{display:grid;grid-template-columns:minmax(0,2fr) 180px auto auto;gap:8px;margin:10px 0}
.reset-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--text);text-decoration:none;font-weight:600}
.table-wrap{width:100%;overflow:auto;border:1px solid var(--line);border-radius:12px}
table{width:max-content;min-width:100%;border-collapse:collapse;background:#fff}
th,td{padding:10px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}
.badge{display:inline-block;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:700}
.badge.ok{background:#dcfce7;color:#166534}.badge.bad{background:#fee2e2;color:#991b1b}
.actions{display:flex;gap:6px;align-items:center}
.mini-btn{padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer}
.mini-btn.danger{background:#fff1f2;border-color:#fecdd3;color:#be123c}
.pagination{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:10px}
.modal{position:fixed;inset:0;background:#0007;display:none;align-items:center;justify-content:center;padding:12px;z-index:999}
.modal.show{display:flex}
.modal-box{width:min(900px,96vw);max-height:92vh;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
textarea{padding:10px;border:1px solid var(--line);border-radius:10px;min-height:90px}
@media(max-width:980px){.filter-row{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}}

.service-filter{grid-template-columns:minmax(0,2fr) 170px 170px auto auto}

.services-builder{display:grid;gap:8px;margin-top:8px}
.service-row{display:grid;grid-template-columns:repeat(4,minmax(130px,1fr));gap:8px;padding:10px;border:1px solid var(--line);border-radius:10px;background:#fafbff}
.service-row input,.service-row select{width:100%}
@media(max-width:980px){.service-row{grid-template-columns:1fr}}

.modal-box .form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-items:start}
.modal-box .form-grid > .services-builder,
.modal-box .form-grid > .section-actions{grid-column:1 / -1}
.services-builder{display:grid;gap:10px;margin-top:4px}
.service-row{display:grid;grid-template-columns:repeat(4,minmax(140px,1fr));gap:8px;padding:10px;border:1px solid var(--line);border-radius:10px;background:#fafbff}
.service-row .mini-btn.danger{justify-self:start}
.section-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.section-actions .btn{min-height:42px}
.section-actions .mini-btn{min-height:42px}
@media(max-width:1100px){.service-row{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){.modal-box .form-grid{grid-template-columns:1fr}.service-row{grid-template-columns:1fr}}
.fld{display:grid;gap:4px;align-content:start}
.fld>span{font-size:12px;color:var(--muted);font-weight:600}
.service-row{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:10px;padding:12px;border:1px solid var(--line);border-radius:12px;background:#fafbff}
.mail-box{grid-column:1 / -1;display:grid;gap:8px;padding:8px;border:1px dashed var(--line);border-radius:10px;background:#fff}
.mail-creds-list{display:grid;gap:8px}
.mail-cred-item{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:end}
@media(max-width:980px){.service-row{grid-template-columns:1fr}.mail-cred-item{grid-template-columns:1fr}}

.fld.full{grid-column:1 / -1}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-items:start}
@media(max-width:980px){.form-grid{grid-template-columns:1fr}}

.kpi-grid{display:grid;grid-template-columns:repeat(5,minmax(160px,1fr));gap:10px}
.kpi-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}
.kpi-card.wide{grid-column:span 2}
.kpi-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.kpi-value{font-size:26px;font-weight:800;margin-top:6px}
@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.kpi-card.wide{grid-column:span 3}}
@media(max-width:760px){.kpi-grid{grid-template-columns:1fr}.kpi-card.wide{grid-column:span 1}}
.client-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.client-card{border:1px solid var(--line);border-radius:12px;background:#fff;padding:12px;text-align:left;cursor:pointer;display:grid;gap:6px}
.client-card:hover{border-color:#c7d2fe;box-shadow:0 8px 22px rgba(79,70,229,.08)}
.cc-head{display:flex;justify-content:space-between;align-items:center;gap:8px}
.cc-name{font-size:16px;font-weight:800}
.cc-company{font-size:13px;color:var(--muted)}
.cc-meta{font-size:13px;color:#374151}
@media(max-width:1100px){.client-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){.client-cards{grid-template-columns:1fr}}
.client-card.healthy{border-left:5px solid #16a34a}
.client-card.expiring{border-left:5px solid #f59e0b;background:#fffaf0}
.client-card.expired{border-left:5px solid #dc2626;background:#fff5f5}
.client-card.inactive{border-left:5px solid #64748b;background:#f8fafc}

/* Button sizing + prevent stretch in grid forms */
.form-grid .btn,
.form-grid .mini-btn,
.filter-row .btn,
.filter-row .reset-btn,
.section-actions .btn,
.section-actions .mini-btn{align-self:center;height:40px;min-height:40px;line-height:1;padding-top:0;padding-bottom:0}
.form-grid .btn,
.form-grid .mini-btn{justify-self:start}
.filter-row .btn,
.filter-row .reset-btn{justify-self:start}

/* --- Fix: Reminders/Settings action layout --- */
.section-head > div[style*="display:flex"]{align-items:center}

/* Keep filter actions inline and non-stretched */
.filter-row{align-items:end}
.filter-row .btn,
.filter-row .reset-btn{height:40px;min-height:40px;align-self:end}

/* Reminders top action buttons */
.reminder-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.reminder-actions .btn{height:40px;min-height:40px}

/* Settings actions */
.settings-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;grid-column:1/-1}
.settings-actions .btn,.settings-actions .mini-btn{height:40px;min-height:40px}

/* revert overly aggressive global button stretch in forms */
.form-grid .btn,
.form-grid .mini-btn{align-self:auto;height:auto;min-height:40px}
