/* Staff Scheduler Frontend */
.ss-dashboard { font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif; max-width:900px; margin:0 auto; }
.ss-dashboard-header { padding:16px 0 8px; }
.ss-dashboard-header h2 { margin:0; font-size:24px; }

/* Tabs */
.ss-tabs { display:flex; gap:4px; border-bottom:2px solid #e5e7eb; margin-bottom:20px; }
.ss-tab-btn { background:none; border:none; padding:10px 18px; font-size:15px; cursor:pointer; color:#666; border-bottom:2px solid transparent; margin-bottom:-2px; }
.ss-tab-btn.active { color:#2271b1; border-bottom-color:#2271b1; font-weight:600; }
.ss-tab-content { display:none; }
.ss-tab-content.active { display:block; }

/* Week nav */
.ss-week-nav { display:flex; align-items:center; gap:12px; margin-bottom:16px; flex-wrap:wrap; }
.ss-btn { display:inline-block; padding:7px 14px; background:#e6f1fb; color:#185fa5; border-radius:5px; text-decoration:none; font-size:14px; border:1px solid #b5d4f4; cursor:pointer; font-family:inherit; transition:background .15s, border-color .15s; }
.ss-btn:hover { background:#b5d4f4; border-color:#85b7eb; color:#0c447c; }
.ss-btn-primary { background:#e6f1fb; color:#185fa5; border:1px solid #b5d4f4; }
.ss-btn-primary:hover { background:#b5d4f4; border-color:#85b7eb; color:#0c447c; }
.ss-btn-sm { padding:3px 8px; font-size:12px; }

/* My Schedule - week grid */
.ss-my-schedule { display:grid; grid-template-columns:repeat(7,1fr); gap:8px; }
.ss-day-block { border:1px solid #e5e7eb; border-radius:8px; overflow:hidden; }
.ss-day-block.ss-today { border-color:#2271b1; box-shadow:0 0 0 2px rgba(34,113,177,.2); }
.ss-day-header { background:#f3f4f6; padding:8px; text-align:center; }
.ss-day-name { display:block; font-weight:700; font-size:13px; }
.ss-day-date { display:block; font-size:11px; color:#666; }
.ss-day-shifts { padding:8px; min-height:60px; }
.ss-off { font-size:12px; color:#9ca3af; }
.ss-shift-block { background:var(--ss-shift-bg,#e6f1fb); color:var(--ss-shift-text,#185fa5); border:1px solid #b5d4f4; border-radius:5px; padding:6px 8px; margin-bottom:5px; font-size:13px; }
.ss-shift-times { font-weight:700; }
.ss-shift-role { font-size:11px; opacity:.85; }
.ss-shift-notes { font-size:11px; opacity:.75; margin-top:2px; }

/* Time-off form */
.ss-timeoff-form { background:#f9fafb; border:1px solid #e5e7eb; border-radius:8px; padding:20px; margin-bottom:24px; max-width:540px; }
.ss-timeoff-form h3 { margin-top:0; }
.ss-form-row { display:flex; gap:16px; margin-bottom:12px; flex-wrap:wrap; }
.ss-form-row label { flex:1; min-width:140px; font-size:14px; }
.ss-form-row input, .ss-form-row textarea { width:100%; padding:6px 8px; border:1px solid #d1d5db; border-radius:4px; font-size:14px; box-sizing:border-box; margin-top:4px; }

/* Requests list */
.ss-requests-list { display:flex; flex-direction:column; gap:10px; max-width:540px; }
.ss-request-item { border:1px solid #e5e7eb; border-radius:6px; padding:12px 14px; }
.ss-request-item.ss-status-approved { border-left:4px solid #22c55e; }
.ss-request-item.ss-status-denied   { border-left:4px solid #ef4444; }
.ss-request-item.ss-status-pending  { border-left:4px solid #f59e0b; }
.ss-req-dates { font-weight:600; margin-bottom:4px; }
.ss-req-reason { color:#555; font-size:13px; margin-bottom:6px; }
.ss-req-status { display:flex; align-items:center; gap:8px; }
.ss-badge { display:inline-block; padding:2px 8px; border-radius:12px; font-size:12px; font-weight:600; text-transform:uppercase; }
.ss-badge-pending  { background:#fef3c7; color:#92400e; }
.ss-badge-approved { background:#d1fae5; color:#065f46; }
.ss-badge-denied   { background:#fee2e2; color:#991b1b; }

/* View toggle */
.ss-view-toggle { display:flex; gap:4px; margin-bottom:16px; }
.ss-view-btn { display:inline-block; padding:6px 16px; border:1px solid #d1d5db; border-radius:5px; text-decoration:none; color:#555; font-size:14px; font-weight:500; }
.ss-view-btn.active { background:var(--ss-primary,#2271b1); color:#fff; border-color:var(--ss-primary,#2271b1); }
.ss-view-btn:hover { border-color:var(--ss-primary,#2271b1); color:var(--ss-primary,#2271b1); }
.ss-view-btn.active:hover { color:#fff; }

/* Month grid */
.ss-month-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:4px; }
.ss-month-day-hdr { text-align:center; font-size:12px; font-weight:700; color:#6b7280; padding:6px 0; }
.ss-month-cell { border:1px solid #e5e7eb; border-radius:5px; min-height:80px; padding:6px 7px; }
.ss-month-cell.ss-today { border-color:var(--ss-primary,#2271b1); background:var(--ss-today-bg,#fff8e6); }
.ss-month-empty { border:none; background:transparent; }
.ss-month-day-num { font-size:13px; font-weight:600; color:#374151; margin-bottom:4px; }
.ss-today-num { display:inline-block; background:var(--ss-primary,#2271b1); color:#fff; width:22px; height:22px; border-radius:50%; text-align:center; line-height:22px; }
.ss-month-shift { background:var(--ss-shift-bg,#2271b1); color:var(--ss-shift-text,#fff); border-radius:3px; padding:2px 5px; font-size:11px; font-weight:600; margin-bottom:3px; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; }
.ss-month-pos { font-weight:400; opacity:.85; }

@media(max-width:600px){
    .ss-month-grid { grid-template-columns:repeat(7,1fr); gap:2px; }
    .ss-month-cell { min-height:50px; padding:3px 4px; }
    .ss-month-shift { font-size:9px; padding:1px 3px; }
    .ss-month-day-num { font-size:11px; }
}
@media (max-width: 640px) {
    .ss-my-schedule { grid-template-columns:repeat(2,1fr); }
    .ss-week-nav { font-size:14px; }
}
@media (max-width: 400px) {
    .ss-my-schedule { grid-template-columns:1fr; }
}

/* ── Chat ──────────────────────────────────────────────────────────── */
.ss-chat-layout { display:flex; gap:0; border:1px solid #e5e7eb; border-radius:10px; overflow:hidden; height:520px; }
.ss-chat-sidebar { width:200px; flex-shrink:0; background:#f9fafb; border-right:1px solid #e5e7eb; overflow-y:auto; }
.ss-chat-sidebar-item { padding:10px 14px; cursor:pointer; font-size:14px; display:flex; align-items:center; gap:8px; border-bottom:1px solid #f0f0f0; }
.ss-chat-sidebar-item:hover, .ss-chat-sidebar-item.active { background:#eff6ff; color:var(--ss-primary,#2271b1); }
.ss-chat-sidebar-section { padding:8px 14px 4px; font-size:11px; font-weight:700; text-transform:uppercase; color:#9ca3af; letter-spacing:.05em; }
.ss-dm-avatar { width:24px; height:24px; border-radius:50%; background:var(--ss-primary,#2271b1); color:#fff; display:inline-flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; flex-shrink:0; }
.ss-chat-pane { flex:1; display:flex; flex-direction:column; min-width:0; }
.ss-chat-header { padding:12px 16px; font-weight:700; font-size:15px; border-bottom:1px solid #e5e7eb; background:#fff; }
.ss-chat-messages { flex:1; overflow-y:auto; padding:12px 16px; background:#fff; display:flex; flex-direction:column; gap:4px; }
.ss-chat-loading, .ss-chat-empty { color:#9ca3af; font-size:14px; text-align:center; padding:20px 0; }
.ss-chat-date-sep { text-align:center; font-size:11px; color:#9ca3af; margin:8px 0 4px; position:relative; }
.ss-chat-date-sep::before { content:''; position:absolute; top:50%; left:0; right:0; height:1px; background:#e5e7eb; z-index:0; }
.ss-chat-date-sep { background:transparent; }
.ss-msg { max-width:75%; margin-bottom:6px; }
.ss-msg-mine { align-self:flex-end; }
.ss-msg-meta { display:flex; align-items:center; gap:6px; margin-bottom:2px; font-size:11px; color:#9ca3af; }
.ss-msg-mine .ss-msg-meta { flex-direction:row-reverse; }
.ss-msg-name { font-weight:600; color:#374151; font-size:12px; }
.ss-msg-admin { background:#fef3c7; color:#92400e; padding:1px 5px; border-radius:3px; font-size:10px; font-weight:700; }
.ss-msg-time { font-size:11px; }
.ss-msg-delete { background:none; border:none; cursor:pointer; color:#d1d5db; font-size:12px; padding:0 2px; }
.ss-msg-delete:hover { color:#ef4444; }
.ss-msg-body { background:#f3f4f6; padding:8px 12px; border-radius:0 10px 10px 10px; font-size:14px; line-height:1.5; word-break:break-word; white-space:pre-wrap; }
.ss-msg-mine .ss-msg-body { background:var(--ss-primary,#2271b1); color:#fff; border-radius:10px 0 10px 10px; }
.ss-chat-input-row { display:flex; gap:8px; padding:10px 12px; border-top:1px solid #e5e7eb; background:#f9fafb; align-items:flex-end; }
.ss-chat-input-row textarea { flex:1; border:1px solid #d1d5db; border-radius:6px; padding:8px 10px; font-size:14px; resize:none; font-family:inherit; }
.ss-unread-badge { display:inline-block; background:#ef4444; color:#fff; border-radius:10px; font-size:11px; font-weight:700; padding:1px 6px; margin-left:4px; }

/* ── Availability ──────────────────────────────────────────────────── */
.ss-avail-layout { display:flex; gap:24px; flex-wrap:wrap; }
.ss-avail-section { flex:1; min-width:280px; background:#f9fafb; border:1px solid #e5e7eb; border-radius:8px; padding:20px; }
.ss-avail-section h3 { margin-top:0; }
.ss-dow-grid { display:flex; flex-direction:column; gap:8px; }
.ss-dow-item { display:flex; }
.ss-dow-label { display:flex; align-items:center; justify-content:space-between; width:100%; gap:12px; }
.ss-dow-label > span { font-size:14px; font-weight:500; width:90px; flex-shrink:0; }
.ss-dow-toggle { display:flex; border:1px solid #d1d5db; border-radius:5px; overflow:hidden; }
.ss-dow-btn { border:none; padding:5px 12px; font-size:12px; cursor:pointer; background:#fff; color:#555; font-weight:500; }
.ss-dow-btn.active { background:var(--ss-primary,#2271b1); color:#fff; }
.ss-dow-btn-off.active { background:#ef4444; color:#fff; }
.ss-blackout-form { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.ss-blackout-form input { padding:6px 8px; border:1px solid #d1d5db; border-radius:4px; font-size:14px; }
.ss-blackout-list { display:flex; flex-direction:column; gap:6px; }
.ss-bo-item { display:flex; align-items:center; gap:8px; background:#fff; border:1px solid #e5e7eb; border-radius:5px; padding:8px 10px; flex-wrap:wrap; }
.ss-bo-date { font-weight:600; font-size:13px; }
.ss-bo-note { color:#6b7280; font-size:12px; flex:1; }
.ss-bo-empty { color:#9ca3af; font-size:13px; }

/* Unavailable in week view */
.ss-day-unavail .ss-day-header { background:#fee2e2; }
.ss-unavail-label { font-size:11px; color:#ef4444; font-weight:600; }

/* Month view clickable + unavailable */
.ss-month-clickable { cursor:pointer; }
.ss-month-clickable:hover { background:#eff6ff; border-color:var(--ss-primary,#2271b1); }
.ss-month-unavail { background:#fef2f2; }
.ss-month-unavail-label { font-size:10px; color:#ef4444; font-weight:600; }
.ss-month-requested { background:#fef3c7 !important; color:#92400e !important; font-size:10px; }
.ss-month-hint { font-size:13px; color:#6b7280; margin-bottom:8px; }

/* Quick modal */
.ss-quick-modal { position:fixed; top:50%; left:50%; transform:translate(-50%,-50%); background:#fff; padding:24px; border-radius:10px; z-index:1000; width:320px; max-width:90vw; box-shadow:0 8px 32px rgba(0,0,0,.15); }
.ss-quick-modal h3 { margin-top:0; }

@media(max-width:600px){
    .ss-chat-layout { flex-direction:column; height:auto; }
    .ss-chat-sidebar { width:100%; height:auto; max-height:140px; display:flex; flex-wrap:wrap; border-right:none; border-bottom:1px solid #e5e7eb; }
    .ss-chat-sidebar-section { display:none; }
    .ss-chat-messages { height:300px; }
    .ss-avail-layout { flex-direction:column; }
}

/* ── Combined Time Off & Availability layout ───────────────────────── */
.ss-combined-layout { display:flex; gap:24px; flex-wrap:wrap; align-items:flex-start; }
.ss-combined-section { flex:1; min-width:280px; }
.ss-combined-section h3 { margin-top:0; padding-bottom:8px; border-bottom:2px solid #f0f0f0; }
.ss-combined-section h4 { margin-bottom:6px; font-size:14px; }
@media(max-width:640px){ .ss-combined-layout { flex-direction:column; } }

/* ── Time Off & Availability merged tab ─────────────────────────────── */
.ss-toa-layout { display:flex; gap:24px; flex-wrap:wrap; align-items:flex-start; }
.ss-toa-col { flex:1; min-width:280px; display:flex; flex-direction:column; gap:20px; }
.ss-toa-section { background:#f9fafb; border:1px solid #e5e7eb; border-radius:8px; padding:20px; }
.ss-toa-section h3 { margin-top:0; font-size:16px; }
.ss-muted { color:#6b7280; font-size:13px; margin:0 0 10px; }

@media(max-width:640px){
    .ss-toa-layout { flex-direction:column; }
}

/* ── List View ──────────────────────────────────────────────────────── */
.ss-list-view { padding:4px 0; }
.ss-list-heading { font-size:16px; margin:0 0 16px; color:#374151; }
.ss-list-empty { text-align:center; padding:48px 20px; color:#9ca3af; }
.ss-list-empty span { font-size:36px; display:block; margin-bottom:8px; }
.ss-list-month-group { margin-bottom:28px; }
.ss-list-month-hdr { font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:#9ca3af; margin:0 0 10px; padding-bottom:6px; border-bottom:1px solid #e5e7eb; }
.ss-list-item { display:flex; align-items:stretch; gap:14px; padding:12px 0; border-bottom:1px solid #f3f4f6; }
.ss-list-item.ss-list-today { background:#fffbeb; border-radius:8px; padding:12px; margin:-2px -12px; border-bottom:none; }
.ss-list-date-col { min-width:56px; text-align:center; }
.ss-list-dow { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:#6b7280; }
.ss-list-today .ss-list-dow { color:#f59e0b; }
.ss-list-date { font-size:20px; font-weight:700; color:#111827; line-height:1.1; margin-top:2px; }
.ss-list-today .ss-list-date { color:#d97706; }
.ss-list-bar { width:3px; border-radius:99px; background:var(--ss-primary,#2563eb); flex-shrink:0; }
.ss-list-today .ss-list-bar { background:#f59e0b; }
.ss-list-details { flex:1; }
.ss-list-times { font-size:15px; font-weight:600; color:#111827; }
.ss-list-dash { margin:0 4px; color:#9ca3af; }
.ss-list-duration { font-size:12px; font-weight:400; color:#6b7280; margin-left:6px; }
.ss-list-position { font-size:13px; color:var(--ss-primary,#2563eb); margin-top:3px; font-weight:500; }
.ss-list-notes { font-size:12px; color:#6b7280; margin-top:2px; }

/* ── SMS opt-in ─────────────────────────────────────────────────────── */
.ss-sms-optin-row { display:flex; align-items:center; gap:8px; cursor:pointer; font-weight:600; }
.ss-sms-optin-row input { width:16px; height:16px; cursor:pointer; }

/* ── Profile Page ───────────────────────────────────────────────────── */
.ss-profile { max-width:860px; margin:0 auto; padding:24px 16px; }
.ss-profile-header { display:flex; align-items:center; gap:18px; margin-bottom:28px; }
.ss-profile-avatar { width:64px; height:64px; border-radius:50%; background:var(--ss-primary,#2563eb); color:#fff; font-size:28px; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.ss-profile-title h2 { margin:0 0 2px; font-size:22px; }
.ss-profile-role { margin:0; font-size:13px; color:#6b7280; }

.ss-profile-notice { padding:10px 16px; border-radius:6px; margin-bottom:20px; font-size:14px; font-weight:500; }
.ss-profile-notice.success { background:#f0fdf4; border:1px solid #86efac; color:#166534; }
.ss-profile-notice.error   { background:#fef2f2; border:1px solid #fca5a5; color:#991b1b; }

.ss-profile-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:24px; }
.ss-profile-card { background:#fff; border:1px solid #e5e7eb; border-radius:10px; padding:22px; }
.ss-profile-card-full { grid-column:1/-1; }
.ss-card-title { margin:0 0 6px; font-size:15px; font-weight:700; }
.ss-card-desc { margin:0 0 16px; font-size:13px; color:#6b7280; line-height:1.5; }

.ss-field-group { margin-bottom:16px; }
.ss-field-label { display:block; font-size:13px; font-weight:600; color:#374151; margin-bottom:5px; }
.ss-field-input { width:100%; padding:8px 10px; border:1px solid #d1d5db; border-radius:6px; font-size:14px; box-sizing:border-box; }
.ss-field-input:focus { border-color:var(--ss-primary,#2563eb); outline:none; box-shadow:0 0 0 2px rgba(37,99,235,.15); }
.ss-field-hint { margin:4px 0 0; font-size:11px; color:#9ca3af; }

.ss-notify-list { display:flex; flex-direction:column; gap:0; }
.ss-notify-row { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 0; border-bottom:1px solid #f3f4f6; cursor:pointer; }
.ss-notify-row:last-child { border-bottom:none; }
.ss-notify-info { flex:1; }
.ss-notify-label { display:block; font-size:14px; font-weight:600; color:#111827; }
.ss-notify-desc  { display:block; font-size:12px; color:#6b7280; margin-top:2px; line-height:1.4; }
.ss-toggle-wrap  { flex-shrink:0; }

.ss-profile-save-row { display:flex; align-items:center; gap:16px; }
.ss-btn-lg { padding:12px 28px; font-size:15px; }

/* Toggle reuse for profile */
.ss-toggle { position:relative; display:inline-block; width:44px; height:24px; }
.ss-toggle input { opacity:0; width:0; height:0; }
.ss-toggle-slider { position:absolute; cursor:pointer; inset:0; background:#d1d5db; border-radius:24px; transition:.25s; }
.ss-toggle-slider:before { content:''; position:absolute; height:18px; width:18px; left:3px; bottom:3px; background:#fff; border-radius:50%; transition:.25s; }
.ss-toggle input:checked + .ss-toggle-slider { background:var(--ss-primary,#2563eb); }
.ss-toggle input:checked + .ss-toggle-slider:before { transform:translateX(20px); }

@media(max-width:600px){
    .ss-profile-grid { grid-template-columns:1fr; }
    .ss-profile-card-full { grid-column:auto; }
}

/* ── Chat tab live badge ────────────────────────────────────────────── */
.ss-tab-btn { position:relative; }
.ss-unread-badge { display:inline-flex; align-items:center; justify-content:center; min-width:18px; height:18px; padding:0 4px; border-radius:9px; background:#ef4444; color:#fff; font-size:11px; font-weight:700; margin-left:5px; line-height:1; vertical-align:middle; }

/* ── Profile avatar uploader ────────────────────────────────────────── */
.ss-profile-avatar-wrap { display:flex; flex-direction:column; align-items:center; gap:8px; }
.ss-profile-avatar { width:80px; height:80px; border-radius:50%; background:var(--ss-primary,#2563eb); color:#fff; font-size:34px; font-weight:700; display:flex; align-items:center; justify-content:center; overflow:hidden; flex-shrink:0; }
.ss-profile-avatar img { width:100%; height:100%; object-fit:cover; }
.ss-avatar-actions { display:flex; gap:6px; flex-wrap:wrap; justify-content:center; }
.ss-avatar-upload-label { cursor:pointer; }
.ss-btn-danger { background:#fee2e2; color:#dc2626; border:1px solid #fca5a5; }
.ss-btn-danger:hover { background:#fecaca; }

/* ── Dual email+SMS notification toggles ───────────────────────────── */
.ss-notify-header-row { display:grid; grid-template-columns:1fr 80px 80px; gap:8px; padding:0 0 6px; border-bottom:1px solid #e5e7eb; margin-bottom:4px; }
.ss-notify-header-label {}
.ss-notify-header-ch { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:#6b7280; text-align:center; }
.ss-notify-row-dual { display:grid; grid-template-columns:1fr auto; gap:8px; align-items:center; padding:12px 0; border-bottom:1px solid #f3f4f6; }
.ss-notify-row-dual:last-child { border-bottom:none; }
.ss-notify-toggles { display:flex; gap:10px; align-items:center; }
.ss-notify-sms-disabled { font-size:13px; color:#9ca3af; background:#f9fafb; border:1px solid #e5e7eb; border-radius:4px; padding:8px 10px; margin-bottom:12px; }
.ss-toggle-sms.ss-toggle-slider { background:#d1d5db; }
input:checked + .ss-toggle-sms { background:#16a34a !important; }

/* ── Open Sans font ─────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;500;600;700&display=swap');

.ss-dashboard, .ss-profile, .ss-chat-standalone, .ss-admin-panel {
    font-family: 'Open Sans', var(--ss-font, sans-serif);
}

/* ── Frontend Admin Panel ────────────────────────────────────────────── */
.ss-admin-panel { max-width:1200px; margin:0 auto; padding:24px 16px; }

.ss-panel-nav { position:sticky; top:0; z-index:100; background:#fff; border-bottom:2px solid var(--ss-primary,#2563eb); display:flex; gap:4px; flex-wrap:wrap; padding:8px 0; margin-bottom:32px; }
.ss-panel-nav a { padding:7px 14px; border-radius:6px 6px 0 0; text-decoration:none; font-size:13px; font-weight:600; color:#555; transition:.15s; }
.ss-panel-nav a:hover { background:var(--ss-primary,#2563eb); color:#fff; }

.ss-panel-section { background:#fff; border:1px solid #e5e7eb; border-radius:10px; padding:24px; margin-bottom:32px; scroll-margin-top:80px; }
.ss-panel-section h2 { margin:0 0 20px; font-size:18px; padding-bottom:12px; border-bottom:1px solid #f0f0f0; }
.ss-panel-section h3 { font-size:15px; margin:0 0 12px; }

.ss-panel-notice { padding:10px 16px; border-radius:6px; font-size:14px; font-weight:600; margin-bottom:16px; }
.ss-panel-notice-success { background:#f0fdf4; border:1px solid #86efac; color:#166534; }
.ss-panel-notice-error   { background:#fef2f2; border:1px solid #fca5a5; color:#991b1b; }

/* Schedule grid */
.ss-panel-section-header { display:flex; flex-wrap:wrap; align-items:center; gap:12px; margin-bottom:16px; }
.ss-panel-section-header h2 { margin:0; border:none; padding:0; flex:1; }
.ss-panel-week-nav { display:flex; align-items:center; gap:8px; }
.ss-panel-toolbar { display:flex; gap:8px; flex-wrap:wrap; }

.ss-fe-schedule-wrap { overflow-x:auto; }
.ss-fe-schedule-grid { display:grid; grid-template-columns:160px repeat(7, 1fr); min-width:700px; border:1px solid #e5e7eb; border-radius:8px; overflow:hidden; }
.ss-fe-grid-cell { border-right:1px solid #e5e7eb; border-bottom:1px solid #e5e7eb; padding:6px; min-height:70px; position:relative; }
.ss-fe-grid-cell:nth-child(8n) { border-right:none; }
.ss-fe-grid-header { background:#f9fafb; font-size:12px; font-weight:700; text-align:center; min-height:auto; padding:8px 4px; }
.ss-fe-today-hdr { background:#eff6ff; color:var(--ss-primary,#2563eb); }
.ss-fe-hdr-dow { display:block; text-transform:uppercase; letter-spacing:.05em; font-size:11px; }
.ss-fe-hdr-date { display:block; font-size:13px; }
.ss-fe-staff-col { font-size:13px; font-weight:600; background:#fafafa; display:flex; align-items:center; min-height:40px !important; }
.ss-fe-shift-cell { display:flex; flex-direction:column; gap:4px; }
.ss-fe-unavail { background:repeating-linear-gradient(45deg,#f9fafb,#f9fafb 4px,#f3f4f6 4px,#f3f4f6 8px); }
.ss-fe-unavail-label { font-size:10px; color:#9ca3af; text-align:center; margin:auto; }
.ss-fe-shift { background:var(--ss-shift-bg,#eff6ff); border:1px solid var(--ss-primary,#2563eb); border-radius:4px; padding:3px 6px; font-size:11px; position:relative; }
.ss-fe-shift:hover .ss-fe-shift-actions { opacity:1; }
.ss-fe-shift-time { display:block; font-weight:600; color:var(--ss-primary,#2563eb); }
.ss-fe-shift-pos { display:block; color:#555; font-size:10px; }
.ss-fe-shift-actions { position:absolute; top:2px; right:2px; display:flex; gap:2px; opacity:0; transition:.15s; }
.ss-fe-shift-actions button { background:none; border:none; cursor:pointer; padding:1px 3px; font-size:11px; line-height:1; }
.ss-fe-delete-shift { color:#dc2626; }
.ss-btn-add { background:none; border:1px dashed #d1d5db; border-radius:4px; color:#9ca3af; cursor:pointer; font-size:16px; padding:2px 6px; line-height:1; margin-top:auto; align-self:flex-start; transition:.15s; }
.ss-btn-add:hover { border-color:var(--ss-primary,#2563eb); color:var(--ss-primary,#2563eb); }

/* Tables */
.ss-fe-table { width:100%; border-collapse:collapse; font-size:13px; }
.ss-fe-table th { background:#f9fafb; padding:9px 12px; text-align:left; font-weight:600; border-bottom:2px solid #e5e7eb; }
.ss-fe-table td { padding:9px 12px; border-bottom:1px solid #f0f0f0; vertical-align:middle; }
.ss-fe-table tr:last-child td { border-bottom:none; }
.ss-fe-status-approved { background:#f0fdf4; }
.ss-fe-status-denied   { background:#fef2f2; }

/* Time off actions */
.ss-fe-to-actions { display:flex; gap:6px; }
.ss-btn-approve { background:#dcfce7; color:#166534; border:1px solid #86efac; }
.ss-btn-approve:hover { background:#bbf7d0; }
.ss-btn-deny    { background:#fee2e2; color:#991b1b; border:1px solid #fca5a5; }
.ss-btn-deny:hover { background:#fecaca; }

/* Add staff form */
.ss-fe-add-staff-form { background:#f9fafb; border:1px solid #e5e7eb; border-radius:8px; padding:16px; margin-bottom:20px; }
.ss-fe-form-row { display:flex; gap:10px; align-items:flex-end; flex-wrap:wrap; }
.ss-fe-form-row label { font-size:13px; font-weight:600; }
.ss-fe-form-row input { margin-top:4px; }

/* Reports */
.ss-range-preset { display:inline-block; padding:3px 10px; border:1px solid #d1d5db; border-radius:12px; text-decoration:none; color:#555; font-size:12px; margin-right:4px; }
.ss-range-preset:hover { background:var(--ss-primary,#2563eb); color:#fff; border-color:var(--ss-primary,#2563eb); }

/* Presets */
.ss-fe-presets-table input[type="time"] { padding:5px 8px; border:1px solid #d1d5db; border-radius:4px; font-size:13px; }
.ss-fe-preset-preview { font-weight:600; color:var(--ss-primary,#2563eb); }

/* Notification templates */
.ss-fe-tpl-block { border:1px solid #e5e7eb; border-radius:8px; padding:18px; margin-bottom:20px; }
.ss-fe-tpl-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.ss-fe-tpl-header h3 { margin:0; }
.ss-fe-tpl-actions { display:flex; gap:8px; }
.ss-fe-tpl-fields { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.ss-fe-tpl-col textarea, .ss-fe-tpl-col input[type="text"] { width:100%; box-sizing:border-box; font-family:monospace; font-size:13px; border:1px solid #d1d5db; border-radius:4px; padding:7px; margin-top:4px; }
.ss-fe-tpl-col textarea { resize:vertical; }
.ss-sms-char-count { font-size:12px; color:#6b7280; margin-top:4px; }

/* SMS section */
.ss-fe-sms-layout { display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.ss-fe-sms-table th { width:220px; padding:10px 0; font-size:14px; }

/* Shift modal */
.ss-fe-modal { position:fixed; inset:0; display:flex; align-items:center; justify-content:center; z-index:1000; }
.ss-fe-modal-inner { background:#fff; border-radius:10px; padding:24px; width:100%; max-width:420px; box-shadow:0 20px 60px rgba(0,0,0,.2); }
.ss-fe-modal-inner h3 { margin:0 0 16px; }
.ss-fe-modal-row { display:flex; gap:12px; margin-bottom:14px; flex-wrap:wrap; }
.ss-fe-modal-row label { flex:1; font-size:13px; font-weight:600; }
.ss-fe-modal-row input, .ss-fe-modal-row textarea { display:block; width:100%; margin-top:4px; padding:7px 9px; border:1px solid #d1d5db; border-radius:6px; font-size:14px; box-sizing:border-box; }
.ss-fe-modal-footer { display:flex; gap:10px; margin-top:18px; }

/* Print */
@media print {
    .ss-panel-nav, .ss-panel-toolbar, .ss-panel-week-nav, .ss-fe-shift-actions,
    .ss-fe-add-staff-form, .ss-fe-to-actions, .ss-fe-tpl-actions,
    button, .ss-btn { display:none !important; }
    .ss-panel-section { border:none; padding:0; margin-bottom:24px; }
}

/* Responsive */
@media(max-width:768px){
    .ss-fe-tpl-fields { grid-template-columns:1fr; }
    .ss-fe-sms-layout { grid-template-columns:1fr; }
    .ss-panel-nav { position:static; }
}

/* ════════════════════════════════════════════════════════════════════
   GLOBAL NAVIGATION
   Desktop: collapsible left sidebar (icon-only by default)
   Mobile (<768px): sticky bottom bar, icon-only
════════════════════════════════════════════════════════════════════ */

/* Body offset so content doesn't hide behind the sidebar */
body.ss-has-nav {
    padding-left: 72px;
    transition: padding-left .25s ease;
}
body.ss-nav-expanded {
    padding-left: 210px;
}

/* ── Sidebar (desktop) ───────────────────────────────────────────── */
.ss-global-nav {
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    width: 72px;
    background: #1a2744;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    z-index: 9000;
    transition: width .25s ease;
    overflow: hidden;
}
.ss-global-nav.ss-nav-expanded {
    width: 210px;
}

/* Toggle button */
.ss-nav-toggle {
    background: none;
    border: none;
    color: #6b88b8;
    padding: 18px 0;
    width: 100%;
    cursor: pointer;
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color .15s;
    flex-shrink: 0;
}
.ss-nav-toggle:hover { color: #fff; }

/* Nav list */
.ss-nav-list {
    list-style: none;
    margin: 0;
    padding: 8px 0;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.ss-nav-item { position: relative; }

.ss-nav-link {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 10px 14px;
    color: #6b88b8;
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
    transition: color .15s;
}
.ss-nav-link:hover { color: #fff; }
.ss-nav-link:hover .ss-nav-icon-wrap {
    background: rgba(147,197,253,.15);
}
.ss-nav-item.ss-nav-active .ss-nav-link {
    color: #fff;
}
.ss-nav-item.ss-nav-active .ss-nav-icon-wrap {
    background: rgba(99,160,255,.25);
    color: #93c5fd;
}

/* Icon wrapper — square surround, 2x size */
.ss-nav-icon-wrap {
    position: relative;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: rgba(255,255,255,.06);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 22px;
    color: #6b88b8;
    transition: background .15s, color .15s;
}
.ss-nav-item.ss-nav-active .ss-nav-icon-wrap i,
.ss-nav-link:hover .ss-nav-icon-wrap i {
    color: #93c5fd;
}

/* Label — hidden until expanded */
.ss-nav-label {
    opacity: 0;
    width: 0;
    overflow: hidden;
    transition: opacity .2s ease, width .25s ease;
    pointer-events: none;
    font-size: 13px;
    font-weight: 600;
    color: inherit;
}
.ss-global-nav.ss-nav-expanded .ss-nav-label {
    opacity: 1;
    width: auto;
    pointer-events: auto;
}

/* Unread badge on nav */
.ss-nav-badge {
    position: absolute;
    top: -5px;
    right: -5px;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    border-radius: 9px;
    background: #ef4444;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    border: 2px solid #1a2744;
}

/* Tooltip on icon-only mode */
.ss-global-nav:not(.ss-nav-expanded) .ss-nav-link:hover::after {
    content: attr(aria-label);
    position: absolute;
    left: 76px;
    top: 50%;
    transform: translateY(-50%);
    background: #1a2744;
    color: #fff;
    font-size: 12px;
    padding: 5px 10px;
    border-radius: 4px;
    white-space: nowrap;
    pointer-events: none;
    z-index: 9999;
    box-shadow: 0 2px 8px rgba(0,0,0,.3);
}


/* ── Mobile bottom bar (<768px) ──────────────────────────────────── */
@media (max-width: 767px) {
    body.ss-has-nav {
        padding-left: 0 !important;
        padding-bottom: 72px;
    }
    body.ss-nav-expanded { padding-left: 0 !important; }

    .ss-global-nav {
        position: fixed;
        top: auto;
        bottom: 0;
        left: 0;
        right: 0;
        height: 72px;
        width: 100% !important;
        flex-direction: row;
        align-items: stretch;
        border-top: 1px solid rgba(255,255,255,.1);
        border-right: none;
        overflow: visible;
        transition: none;
        padding: 0;
    }

    .ss-nav-toggle { display: none; }

    .ss-nav-list {
        flex-direction: row;
        flex: 1;
        gap: 0;
        padding: 0;
    }

    .ss-nav-item { flex: 1; }

    .ss-nav-link {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 0;
        padding: 10px 4px;
        text-align: center;
    }

    /* Icon box: keep square surround, slightly smaller on mobile */
    .ss-nav-icon-wrap {
        width: 40px;
        height: 40px;
        border-radius: 10px;
        font-size: 20px;
        background: transparent;
    }
    .ss-nav-link:hover .ss-nav-icon-wrap,
    .ss-nav-item.ss-nav-active .ss-nav-icon-wrap {
        background: rgba(99,160,255,.2);
    }

    /* Labels always hidden on mobile */
    .ss-nav-label { display: none !important; }

    /* Active indicator on mobile — top border on icon box */
    .ss-nav-item.ss-nav-active .ss-nav-link { color: #93c5fd; }

    /* Tooltip disabled on mobile */
    .ss-nav-link:hover::after { display: none; }

    .ss-dashboard, .ss-profile, .ss-chat-standalone, .ss-timeoff-page { padding-bottom: 16px; }
}

/* ── WordPress admin bar offset ──────────────────────────────────── */
.admin-bar .ss-global-nav {
    top: 32px;
    height: calc(100vh - 32px);
}
@media (max-width: 782px) {
    .admin-bar .ss-global-nav { top: 46px; }
}
@media (max-width: 767px) {
    .admin-bar .ss-global-nav { top: auto; bottom: 0; height: 64px; }
}

/* ── Calendar month view — black shift text for readability ─────── */
.ss-month-shift { color: #1a2744 !important; }
.ss-month-pos   { color: #185fa5; }

/* ── Shift list — ellipsis menu ─────────────────────────────────── */
.ss-list-actions { position:relative; margin-left:auto; flex-shrink:0; }
.ss-list-ellipsis { background:none; border:none; cursor:pointer; color:#9ca3af; padding:8px; font-size:16px; border-radius:6px; transition:.15s; }
.ss-list-ellipsis:hover { background:#f3f4f6; color:#374151; }
.ss-list-menu { position:absolute; right:0; top:100%; background:#fff; border:1px solid #e5e7eb; border-radius:8px; box-shadow:0 4px 16px rgba(0,0,0,.12); min-width:180px; z-index:100; overflow:hidden; }
.ss-list-menu-item { display:flex; align-items:center; gap:10px; width:100%; padding:11px 16px; background:none; border:none; font-size:14px; cursor:pointer; text-align:left; color:#374151; transition:background .1s; }
.ss-list-menu-item:hover { background:#f3f4f6; }
.ss-list-menu-item i { color:#6b7280; font-size:14px; }

/* Swap pending badge on list item */
.ss-list-swap-pending { background:#fffbeb; border-left-color:#f59e0b !important; }
.ss-list-swap-badge { display:inline-flex; align-items:center; gap:5px; font-size:12px; color:#92400e; background:#fef3c7; padding:2px 8px; border-radius:10px; margin-top:4px; }

/* View all button */
.ss-btn-view-all { display:block; width:100%; margin:12px 0; text-align:center; background:#f9fafb; border:1px dashed #d1d5db; color:#6b7280; }
.ss-btn-view-all:hover { background:#f3f4f6; border-color:#9ca3af; color:#374151; }

/* ── Swap sections ───────────────────────────────────────────────── */
.ss-swap-section { margin-top:28px; padding-top:20px; border-top:1px solid #e5e7eb; }
.ss-swap-section-title { font-size:15px; font-weight:700; margin:0 0 8px; color:#1e293b; display:flex; align-items:center; gap:8px; }
.ss-swap-section-desc { font-size:13px; color:#6b7280; margin:0 0 12px; }
.ss-swap-item { display:flex; align-items:center; gap:16px; padding:12px 16px; background:#fff; border:1px solid #e5e7eb; border-radius:8px; margin-bottom:8px; flex-wrap:wrap; }
.ss-swap-mine { border-left:3px solid #f59e0b; }
.ss-swap-unavail { background:#fff7ed; border-color:#fed7aa; }
.ss-swap-info { flex:1; }
.ss-swap-date { font-weight:700; font-size:14px; color:#1e293b; }
.ss-swap-time { font-size:13px; color:#185fa5; }
.ss-swap-pos  { font-size:12px; color:#6b7280; margin-top:2px; }
.ss-swap-from { font-size:12px; color:#6b7280; margin-top:4px; }
.ss-swap-status { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.ss-swap-unavail-note { font-size:12px; color:#b45309; display:flex; align-items:center; gap:4px; margin-top:4px; }

/* ── Channel sidebar items ───────────────────────────────────────── */
.ss-channel-item { display:flex; align-items:center; gap:8px; }
.ss-channel-readonly-badge { font-size:10px; background:#f3f4f6; color:#6b7280; padding:1px 6px; border-radius:8px; margin-left:auto; flex-shrink:0; }

/* ── Named preset chips in shift modal ──────────────────────────── */
.ss-preset-chips { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:14px; }
.ss-preset-chip { padding:5px 12px; background:#e6f1fb; border:1px solid #b5d4f4; border-radius:16px; font-size:12px; font-weight:600; color:#185fa5; cursor:pointer; transition:.15s; white-space:nowrap; }
.ss-preset-chip:hover { background:#b5d4f4; color:#0c447c; }
.ss-preset-chip.active { background:#185fa5; color:#fff; border-color:#185fa5; }

/* ── Admin presets template fixes ───────────────────────────────── */
.ss-named-preset-row { display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid #f0f0f0; flex-wrap:wrap; }

/* ════════════════════════════════════════════════════════════════════
   SHIFT SWAPS
════════════════════════════════════════════════════════════════════ */

/* Ellipsis button on list items */
.ss-list-item { position: relative; }
.ss-list-ellipsis-wrap { position: absolute; top: 12px; right: 12px; }
.ss-list-ellipsis { background: none; border: none; cursor: pointer; color: #94a3b8; font-size: 16px; padding: 4px 8px; border-radius: 4px; line-height: 1; }
.ss-list-ellipsis:hover { background: #f1f5f9; color: #1a2744; }

/* Ellipsis dropdown menu */
.ss-list-menu { position: absolute; right: 0; top: 32px; background: #fff; border: 1px solid #e2e8f0; border-radius: 8px; box-shadow: 0 4px 16px rgba(0,0,0,.1); z-index: 100; min-width: 180px; padding: 4px 0; }
.ss-list-menu-item { display: flex; align-items: center; gap: 8px; width: 100%; background: none; border: none; padding: 10px 14px; font-size: 13px; color: #334155; cursor: pointer; text-align: left; }
.ss-list-menu-item:hover { background: #f8fafc; color: #1a2744; }
.ss-list-menu-item i { width: 14px; color: #185fa5; }

/* Swap badge on list item */
.ss-list-swap-badge { display: flex; align-items: center; gap: 6px; font-size: 12px; color: #b45309; background: #fef3c7; border: 1px solid #fcd34d; border-radius: 4px; padding: 3px 8px; margin-top: 6px; }
.ss-list-swap-badge i { font-size: 11px; }
.ss-list-item-swap { border-left-color: #f59e0b !important; }

/* Swap requested badge on month cell */
.ss-month-shift-swap { border: 1px solid #fcd34d !important; background: #fef3c7 !important; }
.ss-month-swap-badge { font-size: 10px; color: #b45309; margin-left: 3px; }
.ss-month-shift-text { color: #1a2744; }

/* Month shift text — BLACK for readability */
.ss-month-shift { color: #1a2744 !important; }
.ss-month-shift span { color: #1a2744 !important; }

/* Available swaps section */
.ss-swap-section { margin-top: 28px; border-top: 2px solid #f1f5f9; padding-top: 20px; }
.ss-swap-section-title { font-size: 15px; font-weight: 700; color: #1a2744; margin: 0 0 14px; display: flex; align-items: center; gap: 8px; }
.ss-swap-section-title i { color: #185fa5; }
.ss-swap-item { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 16px; background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px; margin-bottom: 8px; flex-wrap: wrap; }
.ss-swap-item-info { flex: 1; }
.ss-swap-item-day { font-weight: 700; font-size: 14px; color: #1a2744; margin-bottom: 2px; }
.ss-swap-item-time { font-size: 13px; color: #475569; }
.ss-swap-item-pos, .ss-swap-item-who { font-size: 12px; color: #64748b; margin-top: 2px; }
.ss-swap-unavail-flag { color: #d97706; }

/* View all button */
.ss-view-all-wrap { text-align: center; margin: 16px 0; }

/* ════════════════════════════════════════════════════════════════════
   CHAT CHANNELS
════════════════════════════════════════════════════════════════════ */
.ss-channel-item { padding-left: 14px !important; }
.ss-channel-badge { font-size: 10px; background: #e2e8f0; color: #64748b; border-radius: 3px; padding: 1px 5px; margin-left: auto; }
.ss-chat-readonly-msg { padding: 10px 16px; font-size: 13px; color: #64748b; background: #f8fafc; border-top: 1px solid #e2e8f0; display: flex; align-items: center; gap: 6px; }

/* ════════════════════════════════════════════════════════════════════
   NAMED PRESET CHIPS
════════════════════════════════════════════════════════════════════ */
.ss-preset-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; padding-bottom: 14px; border-bottom: 1px solid #e5e7eb; }
.ss-preset-chip { padding: 5px 12px; background: #e6f1fb; border: 1px solid #b5d4f4; border-radius: 16px; color: #185fa5; font-size: 12px; font-weight: 600; cursor: pointer; transition: .15s; }
.ss-preset-chip:hover, .ss-preset-chip.active { background: #185fa5; border-color: #185fa5; color: #fff; }

/* ════════════════════════════════════════════════════════════════════
   LOGIN PAGE
════════════════════════════════════════════════════════════════════ */

.ss-login-wrap {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f0f4f8;
    padding: 24px 16px;
    font-family: 'Open Sans', sans-serif;
}

.ss-login-box {
    background: #fff;
    border-radius: 16px;
    border: 0.5px solid #e2e8f0;
    padding: 40px 36px;
    width: 100%;
    max-width: 400px;
}

/* Brand */
.ss-login-brand {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 28px;
}
.ss-login-brand-text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}
.ss-login-brand-just {
    font-size: 13px;
    font-weight: 400;
    color: #6b88b8;
    letter-spacing: .04em;
}
.ss-login-brand-schedule {
    font-size: 22px;
    font-weight: 700;
    color: #1a2744;
    letter-spacing: -.01em;
}

/* Title */
.ss-login-title {
    font-size: 20px;
    font-weight: 700;
    color: #1a2744;
    margin: 0 0 6px;
}
.ss-login-subtitle {
    font-size: 14px;
    color: #64748b;
    margin: 0 0 24px;
}

/* Alerts */
.ss-login-error, .ss-login-success {
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 18px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.ss-login-error   { background: #fef2f2; border: 1px solid #fca5a5; color: #991b1b; }
.ss-login-success { background: #f0fdf4; border: 1px solid #86efac; color: #166534; }

/* Form fields */
.ss-login-form { display: flex; flex-direction: column; gap: 16px; }
.ss-login-field { display: flex; flex-direction: column; gap: 6px; }
.ss-login-field label {
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.ss-login-forgot {
    font-size: 12px;
    font-weight: 400;
    color: #185fa5;
    text-decoration: none;
}
.ss-login-forgot:hover { text-decoration: underline; }

.ss-login-field input[type="text"],
.ss-login-field input[type="email"],
.ss-login-field input[type="password"] {
    padding: 10px 14px;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    font-size: 14px;
    font-family: inherit;
    color: #1a2744;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
    width: 100%;
    box-sizing: border-box;
}
.ss-login-field input:focus {
    border-color: #185fa5;
    box-shadow: 0 0 0 3px rgba(24,95,165,.12);
}

/* Password toggle */
.ss-login-password-wrap { position: relative; }
.ss-login-password-wrap input { padding-right: 42px; }
.ss-login-toggle-pw {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: #94a3b8;
    font-size: 15px;
    padding: 0;
    line-height: 1;
}
.ss-login-toggle-pw:hover { color: #185fa5; }

/* Remember */
.ss-login-remember { font-size: 13px; color: #64748b; }
.ss-login-remember label { display: flex; align-items: center; gap: 8px; cursor: pointer; }

/* Submit button */
.ss-login-btn {
    padding: 12px;
    background: #1a2744;
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: background .15s;
    margin-top: 4px;
}
.ss-login-btn:hover { background: #185fa5; }

/* Footer links */
.ss-login-switch {
    text-align: center;
    margin: 20px 0 0;
    font-size: 13px;
    color: #64748b;
}
.ss-login-switch a { color: #185fa5; text-decoration: none; }
.ss-login-switch a:hover { text-decoration: underline; }

/* Mobile */
@media (max-width: 480px) {
    .ss-login-box { padding: 28px 20px; }
}

/* Hide the global nav on the login page */
.ss-login-wrap ~ * .ss-global-nav,
body:has(.ss-login-wrap) .ss-global-nav { display: none !important; }
body:has(.ss-login-wrap) { padding-left: 0 !important; padding-bottom: 0 !important; }
