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

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Sidebar */
  --surface:#FFFFFF;
  --sb-bg:#0B1628;--sb-bg2:#111F35;--sb-border:rgba(255,255,255,.07);
  --sb-text:#94A3C4;--sb-text-active:#F0F4FF;--sb-accent:#3B82F6;
  --sb-width:280px;
  /* Main */
  --main-bg:#F4F6FA;--surface:#FFFFFF;
  --color-text:#111827;--color-muted:#6B7280;--color-hint:#9CA3AF;
  --color-border:#E5E7EB;--color-border-md:#D1D5DB;
  --color-primary:#E0001A;
  --color-info:#3B82F6;--color-info-bg:#EFF6FF;
  --color-success:#16A34A;--color-success-bg:#F0FDF4;
  --color-danger:#DC2626;--color-danger-bg:#FEF2F2;
  --color-warning:#D97706;--color-warning-bg:#FFFBEB;
  --radius-sm:6px;--radius-md:10px;--radius-lg:14px;
  --font-sans:'DM Sans',system-ui,sans-serif;
  --font-mono:'DM Mono',monospace;
}

html,body{height:100%;font-family:var(--font-sans);font-size:15px;color:var(--color-text);background:var(--main-bg)}

/* Auth */
.auth-body{min-height:100vh;background:#081426;color:#F4F7FF}
.auth-shell{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:#081426}
.auth-hero{position:relative;display:flex;flex-direction:column;justify-content:space-between;min-height:100vh;padding:3.25rem 3.25rem;background:#10233D;border-right:1px solid rgba(148,163,184,.18);overflow:hidden}
.auth-hero::after{content:'';position:absolute;left:12%;bottom:-24%;width:520px;height:520px;background:radial-gradient(circle,rgba(59,130,246,.16),rgba(59,130,246,0) 68%);pointer-events:none}
.auth-logo{display:flex;align-items:center;position:relative;z-index:1}
.auth-logo__image{display:block;width:190px;max-width:52vw;height:auto;object-fit:contain}
.auth-logo__mark{width:46px;height:46px;border-radius:11px;background:#3B82F6;display:grid;place-items:center;box-shadow:0 14px 32px rgba(59,130,246,.25)}
.auth-logo__mark svg{width:22px;height:22px}
.auth-logo__text{font-size:21px;font-weight:700;letter-spacing:-.04em;color:#fff}
.auth-logo__text span,.auth-hero__content h1 span{color:#3B82F6}
.auth-hero__content{position:relative;z-index:1;max-width:610px;margin-top:6rem}
.auth-hero__content h1{font-size:44px;line-height:1.17;font-weight:700;letter-spacing:-.04em;color:#F3F7FF;margin-bottom:20px}
.auth-hero__content p{max-width:470px;font-size:17px;line-height:1.55;color:#9DBCF4}
.auth-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2rem;position:relative;z-index:1;max-width:500px}
.auth-stats strong{display:block;font-size:34px;line-height:1;font-weight:700;color:#3B82F6;letter-spacing:-.04em;margin-bottom:8px}
.auth-stats span{display:block;font-size:13px;color:#6F8BB9}
.auth-panel{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:3rem;background:#081426}
.auth-card{width:100%;max-width:420px}
.auth-card__header{margin-bottom:30px}
.auth-card__header h2{font-size:26px;line-height:1.15;font-weight:700;letter-spacing:-.04em;color:#fff;margin-bottom:10px}
.auth-card__header p{font-size:15px;color:#9DBCF4}
.auth-alert{padding:12px 16px;border-radius:8px;background:#2B1529;border:1px solid rgba(239,68,68,.42);color:#FFB4B4;font-size:14px;margin-bottom:22px}
.auth-alert--success{background:#102D26;border-color:rgba(34,197,94,.42);color:#A7F3D0}
.auth-form{display:grid;gap:20px}
.auth-field label{display:block;margin-bottom:7px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#9DBCF4}
.auth-form .auth-field input{width:100%;height:50px;border-radius:10px;border:1px solid transparent;background:#E8F0FC;color:#071426;font-size:15px;padding:0 18px;outline:none;transition:border-color .15s,box-shadow .15s,background .15s}
.auth-form .auth-field input:focus{border-color:#60A5FA;box-shadow:0 0 0 4px rgba(59,130,246,.32);background:#EEF5FF}
.auth-submit{height:52px;width:100%;border:none;border-radius:10px;background:#3B82F6;color:#fff;font-family:inherit;font-size:16px;font-weight:700;cursor:pointer;transition:background .15s,transform .15s,box-shadow .15s;margin-top:8px}
.auth-submit:hover{background:#2563EB;box-shadow:0 16px 34px rgba(37,99,235,.28)}
.auth-submit:active{transform:translateY(1px)}
.auth-links{margin-top:18px;text-align:center;font-size:13px}
.auth-links a{color:#9DBCF4;text-decoration:none}
.auth-links a:hover{color:#fff;text-decoration:underline}
.auth-shell--single{grid-template-columns:1fr}
.auth-logo--form{margin-bottom:32px;justify-content:center}
@media (max-width:900px){
  .auth-shell{grid-template-columns:1fr}
  .auth-hero{min-height:auto;padding:2rem 1.5rem 2.25rem;border-right:none;border-bottom:1px solid rgba(148,163,184,.18);gap:2.5rem}
  .auth-hero__content{margin-top:0}
  .auth-hero__content h1{font-size:38px}
  .auth-hero__content p{font-size:17px}
  .auth-stats{gap:1rem}
  .auth-stats strong{font-size:32px}
  .auth-panel{min-height:auto;padding:2.25rem 1.5rem 3rem}
}
@media (max-width:560px){
  .auth-logo__image{width:160px;max-width:70vw}
  .auth-logo__text{font-size:20px}
  .auth-hero__content h1{font-size:33px}
  .auth-stats{grid-template-columns:1fr}
}

/* ── Layout ───────────────────────────────────── */
.app-shell{display:flex;min-height:100vh}
.sidebar{width:var(--sb-width);background:var(--sb-bg);flex-shrink:0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:20;border-right:1px solid var(--sb-border)}
.main-area{margin-left:var(--sb-width);flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{background:#fff;border-bottom:1px solid var(--color-border);padding:0 1.75rem;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}
.page-content{padding:1.75rem;flex:1}
.topbar-main{display:flex;align-items:center;gap:12px;min-width:0}
.mobile-menu-btn,.sidebar-close{display:none;align-items:center;justify-content:center;border:1px solid transparent;background:transparent;color:inherit;cursor:pointer}
.mobile-menu-btn{width:38px;height:38px;border-radius:9px;color:var(--color-muted)}
.mobile-menu-btn:hover{background:#F3F4F6;color:var(--color-text)}
.sidebar-close{width:34px;height:34px;margin-left:auto;border-radius:8px;color:var(--sb-text-active)}
.sidebar-close:hover{background:rgba(255,255,255,.08)}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(3,7,18,.58);z-index:18}

/* ── Sidebar internals ────────────────────────── */
.sb-brand{padding:1.25rem 1rem;display:flex;align-items:center;border-bottom:1px solid var(--sb-border)}
.sb-brand-logo{display:block;width:150px;max-width:100%;height:auto;object-fit:contain}
.sb-brand-icon{width:34px;height:34px;background:var(--sb-accent);border-radius:8px;display:grid;place-items:center;flex-shrink:0}
.sb-brand-icon svg{width:18px;height:18px}
.sb-brand-name{font-size:14px;font-weight:600;color:#fff;letter-spacing:-.01em}
.sb-brand-ver{font-size:10px;color:rgba(255,255,255,.35);margin-left:6px}

.sb-section{padding:.75rem 0}
.sb-section-label{padding:0 1rem;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--sb-text);opacity:.6;margin-bottom:4px}
.sb-link{display:flex;align-items:center;gap:10px;padding:8px 1rem;font-size:13px;color:var(--sb-text);text-decoration:none;border-radius:0;transition:background .15s,color .15s;cursor:pointer;border:none;background:transparent;width:100%;text-align:left}
.sb-link:hover{background:rgba(255,255,255,.05);color:var(--sb-text-active)}
.sb-link.active{background:rgba(59,130,246,.15);color:var(--sb-text-active)}
.sb-link.active .sb-link-icon{color:var(--sb-accent)}
.sb-link-icon{width:18px;height:18px;flex-shrink:0;opacity:.7}
.sb-link.active .sb-link-icon{opacity:1}

.sb-tenant{margin:0 .75rem .75rem;background:var(--sb-bg2);border:1px solid var(--sb-border);border-radius:var(--radius-md);padding:10px 12px}
.sb-tenant-label{font-size:10px;font-weight:600;color:var(--sb-text);opacity:.6;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.sb-tenant select{width:100%;background:transparent;border:none;color:var(--sb-text-active);font-size:13px;font-family:inherit;outline:none;cursor:pointer}
.sb-tenant select option{background:var(--sb-bg2);color:#fff}

.sb-user{padding:1rem;border-top:1px solid var(--sb-border);display:flex;align-items:center;gap:10px;margin-top:auto}
.sb-avatar{width:32px;height:32px;border-radius:50%;background:var(--sb-accent);display:grid;place-items:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}
.sb-user-info{flex:1;min-width:0}
.sb-user-name{font-size:13px;font-weight:500;color:var(--sb-text-active);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-role{font-size:11px;color:var(--sb-text)}
.sb-logout{color:var(--sb-text);opacity:.6;cursor:pointer;background:none;border:none;padding:4px;border-radius:4px;transition:opacity .2s}
.sb-logout:hover{opacity:1}

/* ── Topbar ───────────────────────────────────── */
.topbar-title{font-size:16px;font-weight:600;letter-spacing:-.02em}
.topbar-actions{display:flex;align-items:center;gap:10px}

/* ── Page header ──────────────────────────────── */
.page-header{margin-bottom:1.5rem}
.page-title{font-size:22px;font-weight:700;letter-spacing:-.03em;margin-bottom:3px}
.page-sub{font-size:13px;color:var(--color-muted)}
.breadcrumb{font-size:12px;color:var(--color-muted);margin-bottom:.75rem;display:flex;align-items:center;gap:6px}
.breadcrumb a{color:var(--color-info);text-decoration:none}
.breadcrumb span{opacity:.4}

/* ── Cards ────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem}
.card-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem}
.card+.card,.card+.form-section{margin-top:1rem}
.card__subtitle{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted);margin-bottom:1rem}
.client-form-heading{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.client-form-heading .card__subtitle{margin-bottom:0}
.client-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.assign-client-form{margin:0}
.assign-client-select{min-width:190px;padding:6px 28px 6px 10px;font-size:12px;background-color:#fff}
.connection-result{padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin:-.25rem 0 1rem;border-left:3px solid}
.connection-result--loading{background:var(--color-info-bg);color:var(--color-info);border-color:var(--color-info)}
.connection-result--success{background:var(--color-success-bg);color:var(--color-success);border-color:var(--color-success)}
.connection-result--danger{background:var(--color-danger-bg);color:var(--color-danger);border-color:var(--color-danger)}
@media (max-width:720px){
  .client-form-heading{align-items:flex-start;flex-direction:column}
  .client-form-grid{grid-template-columns:1fr}
}

/* Metric cards */
.metric-card{background:var(--surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;position:relative;overflow:hidden}
.metric-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.metric-card--blue::before{background:var(--color-info)}
.metric-card--green::before{background:var(--color-success)}
.metric-card--red::before{background:var(--color-danger)}
.metric-card--yellow::before{background:var(--color-warning)}
.metric-label{font-size:12px;color:var(--color-muted);margin-bottom:6px}
.metric-value{font-size:32px;font-weight:700;letter-spacing:-.03em;line-height:1}
.metric-sub{font-size:12px;color:var(--color-muted);margin-top:6px}
.dashboard-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.75rem}
.dashboard-metrics--admin{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.dashboard-client-header{display:flex;align-items:center;gap:12px;margin-bottom:1.5rem}

/* Metric inline (jobs/detail, progress) */
.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-bottom:1.5rem}
.metric{background:var(--surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem;position:relative;overflow:hidden}
.metric::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-border)}
.metric--success::before{background:var(--color-success)}
.metric--danger::before{background:var(--color-danger)}
.metric--info::before{background:var(--color-info)}
.metric--neutral::before{background:var(--color-border-md)}
.metric__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);margin-bottom:6px}
.metric__value{font-size:28px;font-weight:700;letter-spacing:-.03em;line-height:1}

/* ── Forms ────────────────────────────────────── */
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:14px;font-weight:600;color:var(--color-muted);margin-bottom:5px;letter-spacing:.01em}
.field__hint{display:block;font-size:11px;color:var(--color-hint);margin-top:3px}
input[type="text"],input[type="url"],input[type="password"],input[type="email"],input[type="number"],select,textarea{
  width:100%;padding:9px 12px;font-size:13px;font-family:inherit;
  border:1px solid var(--color-border-md);border-radius:var(--radius-sm);
  background:#fff;color:var(--color-text);outline:none;transition:border-color .15s,box-shadow .15s
}
input:focus,select:focus,textarea:focus{border-color:var(--color-info);box-shadow:0 0 0 3px rgba(59,130,246,.1)}
.checkbox-label{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}

/* ── Buttons ──────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-family:inherit;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;border:1px solid transparent;transition:background .15s;text-decoration:none;white-space:nowrap}
.btn--primary{background:var(--color-primary);color:#fff}
.btn--primary:hover{background:#b50014}
.btn--blue{background:var(--color-info);color:#fff}
.btn--blue:hover{background:#2563EB}
.btn--ghost{background:transparent;border-color:var(--color-border-md);color:var(--color-text)}
.btn--ghost:hover{background:var(--main-bg)}
.btn--sm{padding:5px 11px;font-size:12px}
.btn--xs{padding:3px 8px;font-size:11px}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ── Badges ───────────────────────────────────── */
.badge{display:inline-flex;align-items:center;font-size:11px;font-weight:500;padding:2px 8px;border-radius:999px;white-space:nowrap}
.badge--success{background:var(--color-success-bg);color:var(--color-success)}
.badge--danger{background:var(--color-danger-bg);color:var(--color-danger)}
.badge--info{background:var(--color-info-bg);color:var(--color-info)}
.badge--warning{background:var(--color-warning-bg);color:var(--color-warning)}
.badge--neutral{background:#F3F4F6;color:var(--color-muted);border:1px solid var(--color-border)}
.badge--admin{background:#FEF3C7;color:#D97706}

/* ── Alerts ───────────────────────────────────── */
.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:1rem;border-left:3px solid}
.alert--success{background:var(--color-success-bg);color:var(--color-success);border-color:var(--color-success)}
.alert--danger{background:var(--color-danger-bg);color:var(--color-danger);border-color:var(--color-danger)}
.alert--info{background:var(--color-info-bg);color:var(--color-info);border-color:var(--color-info)}
.alert--warning{background:var(--color-warning-bg);color:var(--color-warning);border-color:var(--color-warning)}

/* ── Tables ───────────────────────────────────── */
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th{text-align:left;padding:9px 12px;font-size:11px;font-weight:600;color:var(--color-muted);border-bottom:1px solid var(--color-border);letter-spacing:.04em;text-transform:uppercase}
.table td{padding:10px 12px;border-bottom:1px solid var(--color-border);vertical-align:middle}
.table tbody tr:last-child td{border-bottom:none}
.table tbody tr:hover td{background:#FAFAFA}

/* ── File items ───────────────────────────────── */
.file-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:0.5px solid var(--color-border)}
.file-item:last-child{border-bottom:none}
.file-item__meta{flex:1;min-width:0}
.file-item__name{display:block;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.file-item__size{display:block;font-size:11px;color:var(--color-muted)}

/* ── Dropzone ─────────────────────────────────── */
.dropzone{border:1.5px dashed var(--color-border-md);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:border-color .2s,background .2s;padding:1.5rem}
.dropzone:hover,.dropzone--over{border-color:var(--color-info);background:var(--color-info-bg)}
.dropzone__icon{font-size:1.5rem;margin-bottom:6px}
.dropzone__text{font-size:13px;font-weight:500;margin-bottom:3px}
.dropzone__sub{font-size:11px;color:var(--color-muted)}

/* ── Progress bar ─────────────────────────────── */
.progress-bar{background:var(--color-border);border-radius:999px;overflow:hidden}
.progress-bar__fill{height:100%;background:var(--color-info);border-radius:999px;transition:width .2s ease}
.progress-bar__fill--done{background:var(--color-success)}
.progress-bar__fill--error{background:var(--color-danger)}

/* ── Nav row ──────────────────────────────────── */
.nav-row{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border)}

/* ── Misc ─────────────────────────────────────── */
code{font-family:var(--font-mono);font-size:12px;background:#F3F4F6;padding:1px 5px;border-radius:3px;border:1px solid var(--color-border)}
.text-muted{color:var(--color-muted)}
.text-sm{font-size:12px}
.tab{padding:5px 14px;border-radius:var(--radius-sm);border:1px solid var(--color-border-md);font-size:12px;cursor:pointer;color:var(--color-muted);background:transparent}
.tab.active{background:var(--color-info-bg);color:var(--color-info);border-color:var(--color-info)}

/* FTP browser */
.ftp-item{display:flex;align-items:center;gap:8px;padding:7px 12px;font-size:12px;cursor:pointer;border-bottom:.5px solid var(--color-border);transition:background .15s}
.ftp-item:hover{background:var(--main-bg)}
.ftp-item:last-child{border-bottom:none}
.ftp-item.is-dir{color:var(--color-info)}

/* Action buttons in tables */
.action-row{display:flex;gap:6px;justify-content:flex-end;align-items:center;flex-wrap:wrap}
.action-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px solid var(--color-border);background:#fff;color:var(--color-muted);cursor:pointer;transition:all .15s;text-decoration:none;font-family:inherit}
.action-btn:hover{background:var(--color-info-bg);border-color:var(--color-info);color:var(--color-info)}
.action-btn--primary{color:var(--color-info)}
.action-btn--success:hover{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}
.action-btn--warning:hover{background:var(--color-warning-bg);border-color:var(--color-warning);color:var(--color-warning)}
.action-btn--danger:hover{background:var(--color-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}
/* ── Topbar avatar + dropdown ─────────────────── */
.topbar-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-primary);display:grid;place-items:center;font-size:13px;font-weight:700;color:#fff;cursor:pointer;flex-shrink:0}
.user-avatar-btn{background:none;border:none;padding:0;cursor:pointer;border-radius:50%}
.user-dropdown{position:relative}
.user-dropdown-menu{display:none;position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:220px;box-shadow:0 8px 24px rgba(0,0,0,.10);z-index:100;overflow:hidden}
.user-dropdown-menu.open{display:block}
.user-dropdown-header{display:flex;align-items:center;gap:10px;padding:12px 14px}
.user-dropdown-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);display:grid;place-items:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}
.user-dropdown-name{font-size:13px;font-weight:600;color:var(--color-text)}
.user-dropdown-role{font-size:11px;color:var(--color-muted)}
.user-dropdown-divider{height:1px;background:var(--color-border);margin:0}
.user-dropdown-item{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:13px;color:var(--color-text);text-decoration:none;background:none;border:none;width:100%;cursor:pointer;font-family:inherit;transition:background .15s}
.user-dropdown-item:hover{background:var(--main-bg)}
.user-dropdown-item--danger{color:var(--color-danger)}
.user-dropdown-item--danger:hover{background:var(--color-danger-bg)}

/* Responsive app shell */
@media (max-width:980px){
  :root{--sb-width:270px}
  body.sidebar-open{overflow:hidden}
  .app-shell{display:block;min-height:100vh}
  .sidebar{width:var(--sb-width);transform:translateX(-100%);transition:transform .22s ease;z-index:30;box-shadow:18px 0 45px rgba(15,23,42,.24)}
  body.sidebar-open .sidebar{transform:translateX(0)}
  body.sidebar-open .mobile-overlay{display:block}
  .main-area{margin-left:0;min-width:0}
  .topbar{height:58px;padding:0 1rem}
  .page-content{padding:1.25rem}
  .mobile-menu-btn,.sidebar-close{display:inline-flex}
  .topbar-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .sb-brand{padding:1rem}
  .sb-user{padding:.9rem}
}

@media (max-width:760px){
  html,body{font-size:14px}
  .page-content{padding:1rem}
  .page-header{margin-bottom:1rem}
  .page-title{font-size:20px}
  .page-sub{font-size:12px}
  .dashboard-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin-bottom:1rem}
  .metric-card,.metric{padding:1rem}
  .metric-value{font-size:27px}
  .metric__value{font-size:25px}
  .card{padding:1rem;overflow-x:auto}
  .card-toolbar{align-items:flex-start;flex-direction:column}
  .dashboard-client-header{align-items:flex-start;flex-wrap:wrap}
  .dashboard-client-header .btn{margin-left:0!important;width:100%;justify-content:center}
  .table{min-width:720px}
  .table th,.table td{padding:8px 10px}
  .action-row{justify-content:flex-start}
  .nav-row{align-items:stretch;flex-direction:column-reverse;gap:.75rem}
  .nav-row .btn{justify-content:center;width:100%}
  .client-form-heading{align-items:stretch}
  .client-form-heading .btn{justify-content:center;width:100%}
  .assign-client-select{min-width:160px}
}

@media (max-width:520px){
  .topbar-actions{gap:6px}
  .topbar{padding:0 .75rem}
  .page-content{padding:.85rem}
  .dashboard-metrics{grid-template-columns:1fr}
  .metric-card{padding:1rem 1.1rem}
  .card{border-radius:12px}
  .btn{width:100%;justify-content:center}
  .btn--sm,.btn--xs{width:auto}
  .user-dropdown-menu{position:fixed;right:.75rem;left:.75rem;top:64px;min-width:0}
}

/* Comfort text sizing */
html,body{font-size:17px}
.sb-link,.field label,.btn,.alert,.dropzone__text,.table,.user-dropdown-item{font-size:15px}
.topbar-title,.page-sub,.connection-result{font-size:15px}
.page-title{font-size:24px}
.card__subtitle{font-size:16px}
.tab,.btn--sm,.assign-client-select,.text-sm,.dropzone__sub,.metric-label,.metric-sub,.field__hint{font-size:14px}
.btn--xs,.badge,.table th,.sb-section-label,.sb-user-role,.user-dropdown-role{font-size:13px}
.metric-value{font-size:34px}
.metric__label{font-size:13px}
.metric__value{font-size:30px}
input[type="text"],input[type="url"],input[type="password"],input[type="email"],input[type="number"],select,textarea{font-size:15px}
.sb-user-name,.user-dropdown-name{font-size:15px}
.sb-brand-name{font-size:16px}
.dropzone__icon{font-size:1.7rem!important}
