:root{--bg:#f5f7fb;--panel:#fff;--ink:#14213d;--muted:#64748b;--brand:#1f3b73;--brand2:#3157a4;--accent:#0ea5e9;--danger:#ef4444;--warning:#f59e0b;--success:#10b981;--line:#e2e8f0;--shadow:0 14px 40px rgba(15,23,42,.10);--radius:20px}*{box-sizing:border-box}body{margin:0;font-family:Heebo,system-ui,sans-serif;background:var(--bg);color:var(--ink)}a{text-decoration:none;color:inherit}.shell{display:flex;min-height:100vh;direction:rtl}.sidebar{width:245px;background:linear-gradient(180deg,#203b73,#294a91);color:white;padding:22px 16px;position:sticky;top:0;height:100vh;box-shadow:var(--shadow)}.brand{display:flex;gap:12px;align-items:center;margin-bottom:28px}.brand-mark{width:42px;height:42px;border-radius:15px;background:rgba(255,255,255,.16);display:grid;place-items:center;font-size:24px}.brand-mark.large{width:70px;height:70px;font-size:38px}.brand span{display:block;color:#cbd5e1;font-size:12px}.nav-item{display:flex;gap:12px;align-items:center;padding:12px 14px;border-radius:14px;margin:4px 0;color:#e5edf9}.nav-item:hover,.nav-item.active{background:white;color:#1f3b73}.logout-form{position:absolute;bottom:20px;right:16px;left:16px}.logout-form button{width:100%;padding:11px;border:0;border-radius:14px;background:rgba(255,255,255,.12);color:white}.main{flex:1;padding:24px 30px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;background:linear-gradient(90deg,#fff,#f8fbff);padding:18px 22px;border-radius:var(--radius);box-shadow:var(--shadow)}h1{font-size:24px;margin:0}.eyebrow{font-size:12px;color:var(--muted);font-weight:700}.top-actions{display:flex;gap:10px;align-items:center}.pill,.icon-pill,.user-chip{border:1px solid var(--line);background:#fff;padding:10px 14px;border-radius:999px}.card{background:var(--panel);border:1px solid #edf2f7;border-radius:var(--radius);padding:20px;margin-bottom:18px;box-shadow:var(--shadow)}.card.compact{padding:12px}.card.narrow{max-width:900px}.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.grid.two{display:grid;grid-template-columns:1.3fr .9fr;gap:18px}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}.kpi{background:#fff;border:1px solid #e8eef8;border-radius:18px;padding:18px;box-shadow:var(--shadow)}.kpi span{color:var(--muted);font-size:13px}.kpi strong{display:block;font-size:32px;margin-top:4px}.kpi.warning{border-color:#fde68a;background:#fffbeb}.kpi.danger{border-color:#fecaca;background:#fff1f2}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);background:#fff;border-radius:12px;padding:9px 14px;font-weight:700;color:#1e3a8a;cursor:pointer}.btn.primary,.primary{background:linear-gradient(135deg,#1f3b73,#2563eb);color:white;border:0}.btn.success{background:#10b981;color:#fff;border:0}.btn.danger{background:#fff1f2;color:#dc2626;border-color:#fecaca}.btn.whatsapp,.whatsapp{background:#ecfdf5;color:#059669}.btn.ghost{background:#f8fafc}.btn.small{padding:6px 10px;font-size:12px}.full{width:100%}.table{width:100%;border-collapse:separate;border-spacing:0 8px}.table th{text-align:right;color:#64748b;font-size:12px}.table td{background:#fff;border-top:1px solid #edf2f7;border-bottom:1px solid #edf2f7;padding:12px}.table tr td:first-child{border-radius:0 12px 12px 0}.table tr td:last-child{border-radius:12px 0 0 12px}.badge{display:inline-flex;padding:4px 9px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-size:12px}.badge.completed,.badge.paid,.badge.success{background:#dcfce7;color:#047857}.badge.cancelled,.badge.danger{background:#fee2e2;color:#b91c1c}.badge.warning,.badge.payment_required{background:#fef3c7;color:#92400e}.badge.info{background:#e0f2fe;color:#0369a1}.alert{padding:13px 16px;border-radius:14px;margin:12px 0}.alert.success{background:#ecfdf5;color:#047857}.alert.danger{background:#fef2f2;color:#b91c1c}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid .full{grid-column:1/-1}label{font-weight:700;color:#334155}input,select,textarea{width:100%;border:1px solid #dbe4ef;border-radius:12px;padding:10px;background:white;margin-top:6px;font-family:inherit}textarea{min-height:90px}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.toolbar input{max-width:260px}.notice-list{display:flex;flex-direction:column;gap:10px}.notice{border:1px solid #e2e8f0;border-radius:16px;padding:14px;background:#f8fafc}.notice.warning{background:#fffbeb;border-color:#fde68a}.notice.danger{background:#fff1f2;border-color:#fecaca}.notice.success{background:#ecfdf5;border-color:#bbf7d0}.task-row,.birthday{display:flex;justify-content:space-between;border-bottom:1px solid #edf2f7;padding:10px 0}.empty{color:#94a3b8;padding:18px}.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.profile-actions{display:flex;gap:10px;flex-wrap:wrap}.mini-dl{display:grid;grid-template-columns:130px 1fr;gap:8px}.mini-dl dt{color:#64748b}.tabs{display:flex;gap:8px;margin:18px 0}.tabs button{border:0;border-radius:999px;background:#e8eef8;padding:10px 16px}.tabs .active{background:#1f3b73;color:white}.color-dot{display:inline-block;width:16px;height:16px;border-radius:50%;vertical-align:middle}.inline{display:inline}.login-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top right,#5b7cbe,#172554 40%,#020617);padding:20px}.login-card{width:min(960px,100%);display:grid;grid-template-columns:1.1fr .9fr;background:white;border-radius:30px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.35)}.login-hero{background:linear-gradient(135deg,#1f3b73,#0ea5e9);color:white;padding:50px}.login-hero h1{font-size:38px;margin:20px 0 10px}.login-form{padding:50px;display:flex;flex-direction:column;gap:18px}.calendar-layout{display:grid;grid-template-columns:minmax(0,1fr) 0;position:relative}.calendar-scroll{overflow:auto;min-height:calc(100vh - 220px);min-width:980px;--slot-height:20px;--slot-minutes:5}.calendar-header{display:flex;position:sticky;top:0;z-index:10;background:#f8fafc;border-bottom:1px solid #dbe4ef}.calendar-body{display:flex;align-items:flex-start}.time-col{width:70px;flex-shrink:0}.time-col.header{height:var(--slot-height);min-height:var(--slot-height);border-bottom:1px solid #dbe4ef}.time-cell{height:var(--slot-height);min-height:var(--slot-height);color:#64748b;font-size:10px;border-bottom:1px solid #e2e8f0;padding:2px 4px;background:#fff;line-height:1.1;display:flex;align-items:flex-start;padding-top:3px}.worker-head{width:180px;flex-shrink:0;height:var(--slot-height);min-height:var(--slot-height);background:#f8fafc;border-bottom:1px solid #dbe4ef;border-left:1px solid #edf2f7;padding:8px;display:flex;align-items:center;gap:8px}.therapist-column{position:relative;width:180px;flex-shrink:0;border-left:1px solid #edf2f7}.appointments-layer{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:5}.avatar{width:34px;height:34px;border-radius:50%;background:#dbeafe;display:grid;place-items:center}.slot{height:var(--slot-height);min-height:var(--slot-height);border-bottom:1px solid #e2e8f0;border-right:1px solid #edf2f7;background:#f8fafc;cursor:pointer}.slot:hover{background:#e0f2fe}.appt-card{position:absolute;left:6px;right:6px;border-radius:10px;padding:5px 7px;box-shadow:0 8px 20px rgba(15,23,42,.16);font-size:12px;line-height:1.25;overflow:hidden;cursor:pointer;border-right:4px solid rgba(0,0,0,.18);z-index:6;display:flex;flex-direction:column;gap:1px;box-sizing:border-box;pointer-events:auto}.appt-card .appt-patient{font-weight:700;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:normal;display:block}.appt-card .appt-service{font-size:11px;opacity:.95;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.appt-card .appt-note{font-size:10px;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.appt-card .appt-time{font-size:10px;font-style:normal;opacity:.92;margin-top:auto;white-space:nowrap;display:block}.appt-card.appt-short{padding:4px 6px}.appt-card.appt-short .appt-service{font-size:10px;line-height:1.15}.appt-card.appt-short .appt-note{display:none}.appt-card.cancelled{opacity:.7;text-decoration:line-through}.appt-card.completed{filter:saturate(.8)}.appt-card.hold{border-style:dashed;border-right-color:#f59e0b}.appt-card.dragging{opacity:.6;cursor:grabbing}.appt-label{font-weight:700;font-size:10px;opacity:.85}.appt-note{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.calendar-tabs{display:flex;gap:8px;margin-top:10px}.calendar-tabs button{border:0;border-radius:999px;background:#e8eef8;padding:8px 14px;font-weight:700;cursor:pointer}.calendar-tabs button.active{background:#1f3b73;color:#fff}.available-slots-panel .slots-group{margin:16px 0}.slot-pills{display:flex;flex-wrap:wrap;gap:8px}.drawer-body{display:flex;flex-direction:column;gap:12px}.drawer{position:fixed;top:0;bottom:0;left:-430px;width:420px;background:white;z-index:40;box-shadow:-20px 0 60px rgba(15,23,42,.25);padding:24px;transition:.25s;overflow:auto}.drawer.open{left:0}.drawer-close{position:absolute;top:12px;left:12px;border:0;background:#f1f5f9;border-radius:50%;width:34px;height:34px}.drawer-actions{display:flex;gap:8px;flex-wrap:wrap}.drawer-form{display:flex;flex-direction:column}@media(max-width:1000px){.shell{display:block}.sidebar{position:relative;height:auto;width:auto}.main{padding:16px}.grid.two,.kpi-grid,.profile-grid,.login-card{grid-template-columns:1fr}.drawer{width:100%;left:-100%}}
.req{color:#dc2626;font-weight:700}.field-error{display:block;color:#dc2626;font-size:12px;margin-top:4px}
.doc-warning-banner{display:flex;align-items:center;gap:14px;background:#fff7ed;border:1px solid #fdba74;color:#9a3412}.doc-warning-banner .warn-icon{font-size:22px}.patient-tabs{flex-wrap:wrap}.details-dl{display:grid;grid-template-columns:160px 1fr;gap:10px 16px}.details-dl dt{color:#64748b}.age-preview{display:block;margin-top:6px;font-weight:600}.muted{color:#64748b;font-size:13px}.referral-fieldset{border:1px solid #e2e8f0;border-radius:14px;padding:14px;margin:0}.radio-row{display:flex;gap:18px;margin-top:8px}.radio-label{font-weight:500;display:flex;align-items:center;gap:6px}.radio-label input{width:auto;margin:0}.hint{color:#64748b;font-size:13px;margin:0 0 10px}.doc-upload-form{margin:18px 0;padding-top:18px;border-top:1px solid #edf2f7}.preview-thumb{max-width:180px;max-height:120px;margin-top:8px;border-radius:8px}.file-preview{padding:10px;background:#f8fafc;border-radius:12px}.doc-actions{display:flex;gap:6px;flex-wrap:wrap}.history-timeline{display:flex;flex-direction:column;gap:12px}.history-item{display:grid;grid-template-columns:110px 1fr;gap:12px;padding:12px;border:1px solid #edf2f7;border-radius:14px}.history-meta{color:#64748b;font-size:13px}.record-block{border:1px solid #edf2f7;border-radius:14px;padding:14px;margin-bottom:10px}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:50;display:grid;place-items:center;padding:20px}.modal{background:#fff;border-radius:18px;padding:20px;max-width:min(900px,95vw);max-height:90vh;overflow:auto;position:relative;width:100%}.preview-full{max-width:100%;max-height:70vh;display:block;margin:0 auto}.preview-iframe{width:100%;height:70vh;border:0}.incomplete-list{display:flex;flex-direction:column;gap:10px}.incomplete-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #edf2f7}.alert-inline.warning{color:#b45309;font-size:13px;display:block;margin-top:4px}.checkbox-inline{display:flex;align-items:center;gap:6px;font-weight:600}.checkbox-inline input{width:auto;margin:0}.upload-box{border:1px dashed #cbd5e1;border-radius:14px;padding:14px}.quick-doc-uploads{margin-bottom:16px}[x-cloak]{display:none!important}.row-inactive{opacity:.65}.series-block{border:1px solid #edf2f7;border-radius:14px;padding:16px;margin-bottom:14px}.series-appt-list{margin:8px 0 0;padding:0 20px 0 0}.series-appt-list li{margin:4px 0}
.task-alert-root{position:fixed;bottom:24px;left:24px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:min(420px,92vw)}
.task-alert-popup{background:#fff1f2;border:2px solid #ef4444;border-radius:16px;padding:16px 18px;box-shadow:0 20px 50px rgba(239,68,68,.35);animation:taskPop .35s ease}
.task-alert-popup.task-alert-urgent{background:#fee2e2;border-color:#b91c1c;box-shadow:0 24px 60px rgba(185,28,28,.45)}
.task-alert-popup strong{display:block;color:#b91c1c;font-size:16px;margin-bottom:6px}
.task-alert-time{color:#64748b;font-size:13px}
.task-alert-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.task-row.task-overdue,.row-overdue{background:#fff7ed}
.row-urgent td:first-child{border-right:3px solid #ef4444}
.task-list .task-overdue{border-color:#fecaca;background:#fffbeb;border-radius:12px;padding:8px;margin-bottom:6px}
@keyframes taskPop{from{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}
.quick-search-modal{max-width:520px;width:100%}
.quick-search-modal input[type=search]{width:100%;margin:12px 0}
.quick-search-results{list-style:none;margin:0;padding:0;max-height:320px;overflow:auto}
.quick-search-results li button{width:100%;text-align:right;padding:12px;border:0;background:#f8fafc;border-radius:12px;margin-bottom:8px;cursor:pointer}
.quick-search-results li button:hover{background:#e0f2fe}
.quick-search-results strong{display:block}
.dob-visible{font-family:inherit;letter-spacing:.02em}
.calendar-date-form{align-items:center;gap:10px;flex-wrap:wrap}
.calendar-date-picker-wrap{display:flex;align-items:center;min-width:auto}
.calendar-native-date{max-width:150px;font-size:13px}
.date-picker-input{direction:ltr;text-align:left}
.date-input-mask{direction:ltr;text-align:left;letter-spacing:.02em}
.date-input-bare .date-picker-input{width:100%}
.flatpickr-calendar{direction:ltr}
.patient-tabs button.active,.patient-tabs button.is-active{font-weight:700;background:#dbeafe;border-color:#2563eb;color:#1e3a8a}
.patient-tab-panel[hidden]{display:none!important}
.appt-card{position:absolute}
.appointment-status-icon{position:absolute;top:4px;inset-inline-end:4px;width:18px;height:18px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);line-height:1;z-index:2;pointer-events:none}
.appt-card .appt-patient,.appt-card .appt-service,.appt-card .appt-note{padding-inline-end:22px}
.status-scheduled{color:#16a34a}
.status-arrived{color:#f59e0b}
.status-completed{color:#16a34a}
.status-no-show{color:#dc2626}
.status-patient-cancelled{color:#111827}
.status-clinic-cancelled{color:#2563eb}
.appointment-status-panel{margin-top:8px}
.status-actions{gap:6px;margin-top:8px}
.status-btn.status-scheduled{border-color:#bbf7d0;color:#166534}
.status-btn.status-arrived{border-color:#fde68a;color:#b45309}
.status-btn.status-completed{border-color:#bbf7d0;color:#166534}
.status-btn.status-no-show{border-color:#fecaca;color:#b91c1c}
.status-btn.status-patient-cancelled{border-color:#d1d5db;color:#111827}
.status-btn.status-clinic-cancelled{border-color:#bfdbfe;color:#1d4ed8}
.drawer-modal{z-index:60}
.kpi.success{border-color:#bbf7d0;background:#ecfdf5}
.settings-tabs .tab-placeholder{padding:10px 14px;font-size:13px}
.settings-form-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:16px;margin-bottom:16px}
.settings-tab-panel{margin-top:12px}
.modal-backdrop[hidden]{display:none!important;visibility:hidden;pointer-events:none}
.modal-backdrop:not([hidden]){display:grid;place-items:center}
#patient-medical-record-modal[hidden]{display:none!important}
.notice-body{white-space:pre-line;margin:.35rem 0 .5rem;line-height:1.45}
.notice-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin:.35rem 0 .5rem}
.series-drawer-section{margin-top:.5rem;border:1px solid var(--line);background:#f8fafc}
.series-drawer-section h3{margin:0 0 .5rem;font-size:1rem}
.series-active-summary p{margin:.25rem 0;font-size:.9rem}
.series-active-summary .hint{color:var(--muted)}
.checkbox-inline{display:flex;align-items:center;gap:.5rem;font-weight:600}
.series-create-fields{background:#f8fafc;padding:1rem;border-radius:12px;border:1px solid var(--line)}
.series-block{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--line)}
.series-block:last-child{border-bottom:0}
.series-appt-list{margin:.5rem 0;padding-right:1.2rem}
.inline-form{display:inline}
.payment-modal{max-width:520px;width:min(96vw,520px)}
.payment-modal-patient{margin:0 0 12px;padding:0 16px}
.payment-modal-section{padding:0 16px 16px}
.payment-modal-section+.payment-modal-section{border-top:1px solid #e2e8f0;padding-top:16px}
.payment-section-title{margin:0 0 10px;font-size:15px;font-weight:600;color:#0f172a}
.payment-history-item{margin-bottom:8px}
.payment-history-meta{margin:4px 0 0;font-size:12px}
.payment-history-note{margin:6px 0 0;font-size:14px}
.follow-up-patients-table td{vertical-align:middle}
.follow-up-patients-table .toolbar-inline{flex-wrap:wrap;gap:6px}

/* Calendar only: off-hours stripes + time-axis labels */
.calendar-scroll .slot-off-hours{background-color:#f1f3f5;background-image:repeating-linear-gradient(135deg,transparent,transparent 8px,rgba(108,117,125,.18) 8px,rgba(108,117,125,.18) 10px)}
.calendar-scroll .slot-off-hours:hover{background-color:#eceef1}
.calendar-scroll .time-col{width:82px;flex-shrink:0}
.calendar-scroll .time-col.header{width:82px;min-width:82px}
.calendar-scroll .time-cell{font-size:12px;color:#475569;padding:0 10px;align-items:center;justify-content:center;padding-top:0;line-height:1.2;text-align:center;direction:ltr;unicode-bidi:isolate}
.calendar-scroll .appt-card,.calendar-scroll .appt-card.hold{pointer-events:auto}
.notice-toolbar{margin-top:.5rem;gap:.5rem}
.notice-toolbar .inline-form{display:inline}

/* Login page */
.login-body {
    min-height: 100vh;
    background: linear-gradient(145deg, #e8eef8 0%, #f5f7fb 45%, #eef4ff 100%);
}

.login-page {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
    direction: rtl;
}

.login-brand-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 40px;
    background: linear-gradient(160deg, #1a3568 0%, #254a8f 52%, #3157a4 100%);
    color: #fff;
    position: relative;
    overflow: hidden;
}

.login-brand-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.12) 0%, transparent 42%),
        radial-gradient(circle at 80% 70%, rgba(14, 165, 233, 0.18) 0%, transparent 45%);
    pointer-events: none;
}

.login-brand-inner {
    position: relative;
    z-index: 1;
    max-width: 420px;
}

.login-brand-mark {
    width: 72px;
    height: 72px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.22);
    display: grid;
    place-items: center;
    font-size: 36px;
    margin-bottom: 28px;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}

.login-brand-title {
    margin: 0 0 10px;
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 800;
    letter-spacing: 0.01em;
    line-height: 1.15;
}

.login-brand-tagline {
    margin: 0 0 28px;
    font-size: 1.05rem;
    color: rgba(255, 255, 255, 0.86);
    line-height: 1.6;
}

.login-brand-features {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 12px;
}

.login-brand-features li {
    position: relative;
    padding-right: 22px;
    font-size: 0.98rem;
    color: rgba(255, 255, 255, 0.92);
    line-height: 1.5;
}

.login-brand-features li::before {
    content: "✓";
    position: absolute;
    right: 0;
    top: 0;
    color: #7dd3fc;
    font-weight: 700;
}

.login-form-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 24px;
}

.login-form-card {
    width: min(100%, 420px);
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 24px;
    padding: 36px 32px 28px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.08);
}

.login-form-header {
    display: flex;
    gap: 14px;
    align-items: center;
    margin-bottom: 28px;
}

.login-form-mark {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: linear-gradient(145deg, #e8eef8, #dbeafe);
    color: var(--brand);
    display: grid;
    place-items: center;
    font-size: 22px;
    flex-shrink: 0;
}

.login-form-header h2 {
    margin: 0 0 4px;
    font-size: 1.45rem;
    font-weight: 700;
    color: var(--ink);
}

.login-form-header p {
    margin: 0;
    font-size: 0.92rem;
    color: var(--muted);
}

.login-form {
    display: grid;
    gap: 18px;
}

.login-field {
    display: grid;
    gap: 8px;
}

.login-field span {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--ink);
}

.login-field input {
    width: 100%;
    border: 1px solid #cbd5e1;
    border-radius: 14px;
    padding: 13px 15px;
    font: inherit;
    font-size: 1rem;
    background: #f8fafc;
    color: var(--ink);
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.login-field input::placeholder {
    color: #94a3b8;
}

.login-field input:focus {
    outline: none;
    border-color: var(--brand2);
    background: #fff;
    box-shadow: 0 0 0 4px rgba(49, 87, 164, 0.12);
}

.login-alert {
    margin: 0;
}

.login-submit {
    width: 100%;
    margin-top: 4px;
    padding: 14px 18px;
    border: none;
    border-radius: 14px;
    font: inherit;
    font-size: 1rem;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(145deg, var(--brand) 0%, var(--brand2) 100%);
    box-shadow: 0 10px 24px rgba(31, 59, 115, 0.28);
    cursor: pointer;
    transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.login-submit:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(31, 59, 115, 0.32);
}

.login-submit:active {
    transform: translateY(0);
}

.login-form-footer {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid var(--line);
    text-align: center;
    font-size: 0.85rem;
    color: var(--muted);
}

@media (max-width: 900px) {
    .login-page {
        grid-template-columns: 1fr;
    }

    .login-brand-panel {
        display: none;
    }

    .login-form-panel {
        padding: 24px 16px;
    }

    .login-form-card {
        padding: 28px 22px 22px;
    }
}

/* Initial assessment form */
.ia-form-page { display: grid; gap: 16px; margin-bottom: 80px; }
.ia-form-top h2 { margin: 0 0 6px; }
.ia-clinic-header { margin: 8px 0 0; font-size: 0.88rem; }
.ia-form-sections { display: grid; gap: 14px; }
.ia-section h3 { margin: 0 0 12px; color: var(--brand); font-size: 1.05rem; }
.ia-grid { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
.ia-treatment-card { border: 1px solid var(--line); border-radius: 14px; padding: 14px; margin-bottom: 12px; background: #f8fafc; }
.ia-form-actions { position: sticky; bottom: 12px; z-index: 20; box-shadow: var(--shadow); }
.ia-list-row { margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.ia-list-row:last-child { border-bottom: none; }
.ia-collapsible .ia-section-toggle,
.ia-section-toggle-row .ia-section-toggle.inline {
    display: flex; align-items: center; justify-content: space-between; width: 100%;
    background: none; border: none; padding: 0; cursor: pointer; text-align: right;
}
.ia-collapsible .ia-section-toggle h3,
.ia-section-toggle-row .ia-section-toggle h3 { margin: 0; flex: 1; }
.ia-section-toggle span { font-size: 1.2rem; color: var(--brand); width: 24px; text-align: center; }
.ia-section-body { margin-top: 12px; }
.ia-section-tools { margin-bottom: 12px; align-items: center; gap: 12px; }
.ia-accordion { padding: 0; overflow: hidden; }
.ia-accordion-head {
    display: flex; align-items: center; justify-content: space-between; width: 100%;
    padding: 12px 14px; background: #eef4fb; border: none; cursor: pointer; text-align: right;
}
.ia-accordion-body { padding: 14px; border-top: 1px solid var(--line); }
.ia-card-actions { margin-bottom: 10px; }

