/* ============================================================
   Junney — Design System  (drop-in replacement for css/app.css)
   Pure CSS reskin. No JS changes required.
   Maps the new look onto existing class names + nav hrefs.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Rubik:wght@500;600;700;800&family=Heebo:wght@400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL,GRAD@20..48,300,0,0&display=block');

:root{
  /* ---- new core palette ---- */
  --bg:#F6F6F2; --surf:#FFFFFF; --surf2:#F0F0EA; --surf3:#FBFBF7;
  --ink:#16171B; --ink2:#3B3D44; --muted:#83857E; --line:#E7E7DF;
  --brand:#18281F; --brand-2:#1E2A22; --brand-ink:#FFFFFF;
  --accent:#BFEF3F; --accent-ink:#16171B;
  --bad:#C7402F; --bad-bg:#FBE9E5; --ok:#1F9D55; --ok-bg:#E6F5EC; --warn:#C18411; --warn-bg:#FAF0D8;

  /* ---- radii / shadow / type ---- */
  --r:18px; --r-sm:12px; --r-lg:22px;
  --sh:0 8px 24px rgba(20,40,22,.05); --sh-soft:0 8px 24px rgba(20,40,22,.05); --sh-hover:0 14px 32px rgba(20,40,22,.10);
  --font:'Heebo',system-ui,-apple-system,sans-serif; --font-display:'Rubik','Heebo',sans-serif;

  /* ---- back-compat aliases (old variable names used across page CSS) ---- */
  --g1:#16171B; --g2:#1E2A22; --g3:#2f8f4e; --g4:#82d09a; --g5:#eef3e6;
  --ink:#16171B; --ink2:#3B3D44; --text:#16171B; --border:#E7E7DF;
  --primary:#1E2A22; --green:#2f8f4e; --green-900:#16251b;
  --shadow:var(--sh); --shadow-soft:var(--sh); --shadow-sm:0 4px 12px rgba(20,40,22,.04);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;background:var(--bg);font-family:var(--font);color:var(--ink);font-size:15.5px;line-height:1.45}
body{direction:rtl;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.hidden,.hidden *{}.hidden{display:none!important}
.muted{color:var(--muted);font-weight:600}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#dcdcd2;border-radius:8px;border:3px solid var(--bg)}
::-webkit-scrollbar-track{background:transparent}

/* ---- material-symbols icon helper (real text-node spans: <span class="mi">name</span>) ---- */
.mi{
  font-family:'Material Symbols Rounded';font-weight:normal;font-style:normal;line-height:1;
  -webkit-font-feature-settings:'liga';font-feature-settings:'liga';
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  direction:ltr;text-transform:none;letter-spacing:normal;white-space:nowrap;
  display:inline-block;flex:0 0 auto;vertical-align:middle;font-size:21px}

/* ====================== Buttons ====================== */
button,input,select,textarea{font-family:var(--font);font-size:15px}
button{border:0;cursor:pointer;border-radius:var(--r-sm);padding:11px 16px;font-weight:700;min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:.16s ease}
button:disabled{opacity:.5;cursor:not-allowed}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{opacity:.92;transform:translateY(-1px)}
.btn-secondary,.btn-muted{background:var(--surf);color:var(--ink2);border:1px solid var(--line)}
.btn-secondary:hover,.btn-muted:hover{border-color:#cfcfc4;background:var(--surf3)}
.btn-ghost{background:transparent;color:var(--ink2);border:1px solid transparent}
.btn-ghost:hover{background:var(--surf2)}
.btn-light{background:rgba(255,255,255,.16);color:#fff;border:1px solid rgba(255,255,255,.28)}
.btn-danger{background:var(--bad-bg);color:var(--bad);border:1px solid #eecdc7}
.btn-danger:hover{background:#f7ddd7}
.btn-sm{font-size:13px;padding:8px 12px;min-height:36px;border-radius:10px}
.btn-wide{width:100%}
.btn-accent{background:var(--accent);color:var(--accent-ink)}
.btn-accent:hover{filter:brightness(.97);transform:translateY(-1px)}
.btn-icon{width:40px;height:40px;min-height:40px;padding:0;border-radius:11px;background:var(--surf);color:var(--ink2);border:1px solid var(--line)}
.btn-icon:hover{background:var(--surf2)}

/* ====================== Inputs ====================== */
input,select,textarea{border:1px solid var(--line);background:#fff;border-radius:var(--r-sm);padding:11px 13px;color:var(--ink);width:100%;outline:none;transition:.18s;margin-bottom:12px;min-height:46px}
textarea{resize:vertical;min-height:90px}
input::placeholder{color:#a9aaa2}
input:focus,select:focus,textarea:focus{border-color:#9fd06a;box-shadow:0 0 0 3px rgba(150,209,86,.22)}
label{font-weight:700;color:var(--ink2);font-size:14px}

/* ====================== App shell ====================== */
.app-shell{display:grid;grid-template-columns:252px minmax(0,1fr);min-height:100vh;background:var(--bg)}
.sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;background:var(--surf);border-inline-end:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:16px}
.brand{display:flex;flex-direction:column;gap:10px;padding:6px 6px 16px;border-bottom:1px solid var(--line)}
.brand-title{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-size:19px;font-weight:700;letter-spacing:-.3px;color:var(--ink)}
.brand-title .brand-mi{width:32px;height:32px;border-radius:9px;background:var(--brand);color:var(--accent);font-size:20px}
.brand-sub{font-size:13px;color:var(--muted);font-weight:600;padding-inline-start:2px}

.nav{display:flex;flex-direction:column;gap:2px}
.nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--r-sm);color:var(--ink2);font-weight:600;font-size:14.5px}
.nav a .mi{color:var(--muted)}
.nav a:hover{background:var(--surf2)}
.nav a.active{background:var(--brand);color:#fff;font-weight:700}
.nav a.active .mi{color:var(--accent)}
.nav-task-link{justify-content:flex-start}
.nav-badge{margin-inline-start:auto;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:var(--warn-bg);color:var(--warn);font-size:11px;font-weight:800;display:inline-flex!important;align-items:center;justify-content:center}
.nav-badge.urgent{background:#fbe2c4;color:#9a4d00}
.nav a.active .nav-badge{background:rgba(255,255,255,.18);color:#fff}

.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:8px;padding-top:14px;border-top:1px solid var(--line)}
.version-badge{border:0;background:var(--surf2);color:var(--muted);border-radius:999px;padding:7px 12px;font-size:12px;font-weight:700;cursor:pointer;align-self:flex-start;min-height:auto}
.version-badge:hover{background:#e8e8df;color:var(--ink2)}
.tenant-new-link{display:block;text-align:center;font-weight:700;color:var(--brand);background:var(--surf2);border-radius:var(--r-sm);padding:9px 10px}
.tenant-new-link:hover{background:#e8e8df}

/* ---- studio switcher in brand ---- */
.tenant-switcher-label{display:block;font-size:11px;color:var(--muted);font-weight:700;margin-top:6px}
.tenant-switcher{width:100%;border:1px solid var(--line);border-radius:var(--r-sm);padding:9px;background:#fff;font-weight:700;min-height:auto;margin:0}
.tenant-current{font-size:11px;color:var(--muted);font-weight:700;margin-top:5px}

/* ====================== Main / topbar ====================== */
.main{min-width:0;padding:0}
.topbar,.app-topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 28px;background:rgba(246,246,242,.86);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);margin-bottom:0}
.page-title h1{margin:0;font-family:var(--font-display);font-size:21px;font-weight:700;letter-spacing:-.3px;color:var(--ink)}
.page-title p{margin:3px 0 0;color:var(--muted);font-size:13.5px}
.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
#pageActions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
#pageContent{padding:22px 28px 44px;display:flex;flex-direction:column;gap:18px}
.task-top-badge{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 13px;display:inline-flex;align-items:center;gap:7px;font-weight:700;color:var(--ink2);cursor:pointer;min-height:auto}
.task-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);display:inline-block}.task-dot.urgent{background:var(--warn)}

/* ====================== Cards ====================== */
.card{background:var(--surf);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:20px;margin:0;min-width:0}
.card h2,.card h3{margin-top:0;color:var(--ink);font-family:var(--font-display);letter-spacing:-.2px}
.card h2{font-size:19px}.card h3{font-size:16px}
.card.inner,.inner,.soft-card{box-shadow:none;background:var(--surf3)}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.section-head h2,.section-head h3{margin:0}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}

/* ---- hero card ---- */
.hero-card{display:flex;align-items:center;justify-content:space-between;gap:18px;background:var(--surf);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);padding:22px 24px;margin:0}
.hero-card h2{margin:0 0 4px;font-family:var(--font-display);font-size:25px;font-weight:700;letter-spacing:-.4px;color:var(--ink)}
.hero-card p{margin:0;color:var(--ink2);font-size:14.5px}
.hero-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.info-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:var(--surf2);font-size:13px;font-weight:700;color:var(--ink2)}

/* ====================== Stat / cockpit / dash cards ====================== */
.stat,.stat-card{background:var(--surf);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--sh)}
.stat-label{color:var(--muted);font-weight:600;font-size:13.5px}
.stat-value{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--ink);margin-top:5px;letter-spacing:-.3px}

.cockpit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin:0}
.dash-card{background:var(--surf);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--sh);position:relative;border-top:0;display:flex;flex-direction:column;gap:6px;transition:.16s ease}
.dash-card .dash-label{color:var(--muted);font-weight:600;font-size:13.5px}
.dash-card .dash-value{font-family:var(--font-display);font-size:27px;font-weight:700;color:var(--ink);letter-spacing:-.3px}
.dash-card .dash-sub{color:var(--muted);font-size:12.5px}
.dash-card.warn .dash-value{color:var(--warn)}
.dash-card.warn .dash-sub{color:var(--warn);font-weight:600}
.dash-card.bad .dash-value{color:var(--bad)}
.dash-card.bad .dash-sub{color:var(--bad);font-weight:600}
.dash-card.ok .dash-sub{color:var(--ok);font-weight:600}
.dash-card.clickable{cursor:pointer}
.dash-card.clickable::after{content:"\2190";position:absolute;left:16px;bottom:14px;color:#bcbdb2;font-weight:800;font-size:15px;opacity:0;transition:.16s}
.dash-card.clickable:hover{transform:translateY(-2px);box-shadow:var(--sh-hover);border-color:#d4d4c8}
.dash-card.clickable:hover::after{opacity:1}
.dash-card.clickable:focus{outline:3px solid rgba(150,209,86,.3);outline-offset:2px}

/* ---- dashboard workspace ---- */
.dashboard-workspace{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);gap:18px}
.today-list,.compact-list,.metric-list{display:flex;flex-direction:column;gap:9px}
.today-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:13px;padding:12px 14px;background:#fff;border-inline-start:3px solid var(--ok)}
.today-item small{display:block;color:var(--muted);margin-top:3px;font-weight:600}
.today-item strong{font-weight:700}
.today-item.risk{border-inline-start-color:var(--bad);background:#fffafa}
.today-item.almost{border-inline-start-color:var(--warn);background:#fffdf6}
.today-item.full{border-inline-start-color:var(--ok);background:#f7fff8}
.compact-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:13px;background:#fff}
.compact-item strong{font-weight:700;font-size:14.5px}
.compact-item small{color:var(--muted)}
.clickable-care,.clickable-row{cursor:pointer;transition:.14s}
.clickable-care:hover{background:var(--surf3);border-color:#d4d4c8}
.insights-placeholder,.insight-placeholder{min-height:160px;border:1px dashed #cfcfc2;border-radius:var(--r);background:linear-gradient(135deg,#fff,var(--surf3));display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--muted);gap:8px;padding:26px;font-weight:600}
.insight-placeholder strong{color:var(--ink);font-size:19px;font-family:var(--font-display)}
.empty,.empty-state{border:1px dashed #cfcfc2;border-radius:var(--r);background:var(--surf3);color:var(--muted);padding:30px;text-align:center}
.empty-state h3{margin:6px 0;color:var(--ink);font-family:var(--font-display)}.empty-state p{margin:0 0 16px}
.empty-icon{font-size:30px;line-height:1;margin-bottom:6px;opacity:.7}

/* ====================== Tables ====================== */
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--r);background:#fff;box-shadow:var(--sh);max-width:100%}
table{width:100%;border-collapse:collapse;text-align:right;white-space:nowrap;font-size:14px}
th,td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
th{background:var(--surf3);color:var(--muted);font-size:12.5px;font-weight:800;letter-spacing:.01em}
td{color:var(--ink2)}td strong{color:var(--ink);font-weight:700}
tr:last-child td{border-bottom:0}
tr.day-separator-row td{background:var(--surf2);font-family:var(--font-display);font-weight:800;color:var(--ink);font-size:13.5px;padding:9px 14px;border-bottom:1px solid var(--line)}
.clickable-row:hover td{background:var(--surf3)}
tr.lead-converted td{background:#f4f9f0}tr.lead-converted:hover td{background:#eef5e6}
tr.lead-archived td{background:var(--surf2);color:var(--muted)}tr.lead-archived strong{color:var(--ink2)}
.row-actions{display:inline-flex;gap:6px}
.icon-action{width:34px;height:34px;min-height:34px;padding:0;border-radius:10px;background:var(--surf2);color:var(--ink2);border:1px solid var(--line)}
.icon-action:hover{background:#e7e7dd}

/* ====================== Badges ====================== */
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 11px;font-size:12px;font-weight:700;line-height:1}
.badge-ok{background:var(--ok-bg);color:var(--ok)}
.badge-bad{background:var(--bad-bg);color:var(--bad)}
.badge-warn{background:var(--warn-bg);color:var(--warn)}
.badge-muted{background:var(--surf2);color:var(--ink2)}

/* ====================== Toolbar / filters / forms ====================== */
.toolbar,.toolbar-actions{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap}
.toolbar .filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.toolbar input,.toolbar select{margin:0;min-width:170px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.form-grid .full{grid-column:1/-1}

/* ====================== Tabs / segmented / pills ====================== */
.tabs-row{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}
.tab-btn{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 14px;cursor:pointer;font-weight:700;color:var(--ink2);min-height:auto}
.tab-btn:hover{background:var(--surf3)}
.tab-btn.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.segmented{display:flex;gap:5px;background:var(--surf2);padding:4px;border-radius:var(--r-sm)}
.segmented button{border:0;border-radius:9px;padding:8px 12px;background:transparent;font-weight:700;color:var(--muted);min-height:auto}
.segmented button.active{background:#fff;color:var(--ink);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.tag-muted{opacity:.75}

/* ---- metric / info grids ---- */
.metric-list>div,.info-grid>div{background:var(--surf3);border:1px solid var(--line);border-radius:13px;padding:13px}
.metric-list span,.info-grid span{display:block;color:var(--muted);font-size:13px}
.metric-list strong,.info-grid strong{display:block;margin-top:4px;font-weight:700}
.metric-list.three{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.info-grid .full{grid-column:1/-1}
.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px}
.summary-grid>div{background:var(--surf3);border:1px solid var(--line);border-radius:13px;padding:13px}
.summary-grid span{display:block;color:var(--muted);font-size:13px;margin-bottom:4px}
.summary-grid strong{font-size:20px;font-family:var(--font-display)}
.note-box{background:var(--surf3);border:1px solid var(--line);border-radius:13px;padding:14px;color:var(--ink2);font-weight:600}
.note-box strong{color:var(--ink)}
.note-box.warn{border-color:#ecd6a4;background:var(--warn-bg)}
.note-box.danger{border-color:#eecdc7;background:var(--bad-bg);color:var(--bad)}
.note-box.full{grid-column:1/-1}
.readonly-note,.readiness-note{background:var(--surf3);border:1px solid var(--line);border-radius:13px;padding:12px 14px;color:var(--ink2);font-weight:600;margin-bottom:12px}
.copy-box,.code,code{direction:ltr;text-align:left;background:var(--surf2);border:1px solid var(--line);border-radius:9px;padding:6px 9px;font-family:monospace;font-size:12.5px}
.copy-box{padding:12px;word-break:break-all;border-style:dashed}
.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px;margin-top:16px}
.quick-action{border:1px solid var(--line);background:#fff;border-radius:var(--r);padding:18px;text-align:right;cursor:pointer;box-shadow:var(--sh)}
.quick-action strong{display:block;font-size:17px;margin-bottom:6px;color:var(--ink);font-family:var(--font-display)}
.quick-action span{display:block;color:var(--muted);font-size:14px;line-height:1.45}
.quick-action:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--sh-hover)}

/* ====================== Settings layout ====================== */
.settings-layout{display:grid;grid-template-columns:248px minmax(0,1fr);gap:18px;align-items:start;min-width:0}
.settings-menu{display:flex;flex-direction:column;gap:6px;position:sticky;top:90px}
.settings-tab,.report-catalog button{border:1px solid var(--line);background:#fff;border-radius:var(--r-sm);padding:11px 13px;font-weight:700;cursor:pointer;color:var(--ink2);text-align:right;min-height:auto}
.settings-tab:hover,.report-catalog button:hover{background:var(--surf3)}
.settings-tab.active{background:var(--surf2);border-color:var(--brand);color:var(--ink)}
.report-catalog{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin:12px 0 18px}
.settings-panel{min-width:0}
.settings-readonly input:disabled,.settings-readonly select:disabled,.settings-readonly textarea:disabled{background:var(--surf3);color:var(--ink2);opacity:1;cursor:default}

/* ====================== Modal / toast / loading ====================== */
.modal-backdrop{position:fixed;inset:0;background:rgba(15,25,18,.5);display:none;align-items:center;justify-content:center;padding:18px;z-index:99}
.modal-backdrop.show{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);box-shadow:0 24px 70px rgba(0,0,0,.25);width:min(760px,100%);max-height:90vh;overflow:auto;padding:24px}
.wide-modal{max-width:1040px;width:min(1040px,96vw)}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px}
.modal-head h2{margin:0;font-family:var(--font-display)}
.center-card{max-width:760px;margin:48px auto;text-align:center}
.toast{position:fixed;bottom:24px;right:24px;background:var(--brand);color:#fff;padding:14px 18px;border-radius:var(--r-sm);box-shadow:var(--sh-hover);z-index:200;display:none;font-weight:700}
.toast.show{display:block}
.loading{position:fixed;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--brand));display:none;z-index:300}
.loading.show{display:block;animation:loading 1.4s infinite}
@keyframes loading{0%{transform:scaleX(0);transform-origin:right}50%{transform:scaleX(.8);transform-origin:right}51%{transform-origin:left}100%{transform:scaleX(0);transform-origin:left}}
.error{color:var(--bad);background:var(--bad-bg);border-radius:10px;padding:10px;margin:10px 0;display:none}

/* ====================== Support / readiness / version ====================== */
.support-mode-banner{background:linear-gradient(135deg,var(--brand),#2c4231);color:#fff;border-radius:var(--r);padding:12px 16px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:12px;box-shadow:var(--sh)}
.support-mode-banner .btn-light{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);color:#fff}
.payment-readiness-card{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;margin:0 0 16px;background:#fff;box-shadow:var(--sh);border-inline-start:3px solid var(--warn)}
.payment-readiness-card.ready{border-inline-start-color:var(--ok);background:linear-gradient(135deg,#fff,#f6fff8)}
.payment-readiness-card strong{display:block;color:var(--ink);font-size:16px}
.payment-readiness-card span{display:block;color:var(--muted);font-weight:600;margin-top:3px}
.readiness-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.readiness-item{display:grid;grid-template-columns:42px minmax(0,1fr) auto;gap:12px;align-items:center;border:1px solid var(--line);background:#fff;border-radius:var(--r-sm);padding:14px;color:inherit;box-shadow:var(--sh)}
.readiness-item:hover{border-color:#d4d4c8;background:var(--surf3)}
.readiness-icon{width:34px;height:34px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-weight:800;border:1px solid var(--line);background:var(--surf3)}
.readiness-icon.ok{background:var(--ok-bg);color:var(--ok);border-color:#bce8c9}
.readiness-icon.warn{background:var(--warn-bg);color:var(--warn);border-color:#ecd6a4}
.readiness-icon.bad{background:var(--bad-bg);color:var(--bad);border-color:#eecdc7}
.readiness-body strong{display:block;font-size:15px;margin-bottom:4px}
.readiness-body span{display:block;color:var(--muted);font-size:14px;line-height:1.45}
.version-info{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:14px}
.version-info div{background:var(--surf3);border:1px solid var(--line);border-radius:13px;padding:14px}
.version-info span{display:block;color:var(--muted);font-weight:600;font-size:13px}
.version-info strong{display:block;color:var(--ink);font-size:17px;margin-top:4px;font-family:var(--font-display)}
.smart-filter-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surf2);border:1px solid var(--line);color:var(--ink);border-radius:var(--r-sm);padding:12px 14px;margin:0 0 14px;font-weight:700}
.provider-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:999px;padding:5px 11px;background:#fff;font-weight:700;color:var(--ink2)}
.wizard-progress{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.wizard-progress span{background:var(--surf2);color:var(--muted);border-radius:999px;padding:7px 12px;font-weight:700;font-size:13px}
.wizard-progress span.active{background:var(--brand);color:#fff}
.wizard-note,.pending-plan-note{background:var(--surf3);border:1px solid var(--line);border-radius:13px;padding:14px 16px;margin-bottom:8px;color:var(--ink2)}
.wizard-note strong{display:block;font-size:16px;margin-bottom:4px;color:var(--ink)}

/* ====================== Integration card (Google Tasks etc.) ====================== */
.integration-card{border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;background:linear-gradient(180deg,#fff,var(--surf3));margin-bottom:16px}
.integration-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}
.integration-head strong{display:block;font-size:19px;color:var(--ink);font-family:var(--font-display)}
.integration-head span:not(.badge){display:block;color:var(--muted);margin-top:4px}
.info-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr));margin:12px 0}

/* ====================== Schedule / week board / agenda ====================== */
.week-controls,.client-week-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:10px 14px;box-shadow:var(--sh);margin:0 0 16px}
.week-title,.client-week-label{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:17px}
.week-board{display:grid;grid-template-columns:repeat(7,minmax(150px,1fr));gap:12px;align-items:start}
.day-column{background:var(--surf3);border:1px solid var(--line);border-radius:var(--r);padding:12px;min-height:170px}
.day-column h3{margin:0 0 10px;font-size:15px;color:var(--ink2);font-family:var(--font-display)}
.day-event{background:#fff;border:1px solid var(--line);border-radius:13px;padding:11px;margin-bottom:9px;box-shadow:var(--sh)}
.day-event strong{display:block;color:var(--ink);font-weight:700}
.day-event small{display:block;color:var(--muted);margin-top:4px;line-height:1.4}
.day-event.clickable{cursor:pointer}.day-event.clickable:hover{border-color:#d4d4c8}
.class-cancelled{opacity:.55;filter:grayscale(.25)}
tr.class-cancelled td,.day-event.class-cancelled{background:var(--surf2)!important;color:var(--muted)}
.class-past,.day-event.past-class,.agenda-class-card.past-class{opacity:.6;background:var(--surf3)}
.week-day-strip{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:9px;margin:14px 0 16px}
.week-day-button{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 10px;min-height:72px;color:var(--ink2);display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:right;min-height:72px}
.week-day-button .day-name{font-size:13px;color:var(--muted);font-weight:700}
.week-day-button .day-date{font-size:19px;color:var(--ink);font-weight:800;line-height:1;font-family:var(--font-display)}
.week-day-button .day-count{font-size:12px;color:var(--muted);font-weight:600}
.week-day-button.active{background:var(--brand);border-color:transparent;color:#fff}
.week-day-button.active .day-name,.week-day-button.active .day-date,.week-day-button.active .day-count{color:#fff}
.agenda-class-card{display:grid;grid-template-columns:84px 1fr auto;gap:14px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:13px;box-shadow:var(--sh);margin-bottom:9px}
.agenda-time{background:var(--surf2);border-radius:12px;padding:11px;text-align:center;font-weight:800;color:var(--ink);display:flex;flex-direction:column;gap:3px;font-family:var(--font-display)}
.agenda-time strong{font-size:21px;line-height:1}.agenda-time span{font-size:12px;color:var(--muted);font-weight:600}
.agenda-main strong{display:block;color:var(--ink);font-size:17px}.agenda-main small{display:block;color:var(--muted);font-weight:600;margin-top:4px}
.agenda-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.radio-card{display:grid!important;grid-template-columns:auto 1fr;gap:10px 12px;align-items:start;border:1px solid var(--line);border-radius:14px;padding:14px 16px!important;background:#fff;margin:0;cursor:pointer}
.radio-card input[type="radio"]{width:18px!important;height:18px!important;min-height:18px!important;margin:3px 0 0!important;padding:0!important;accent-color:var(--brand);box-shadow:none!important}
.radio-card .radio-copy{display:flex;flex-direction:column;gap:3px;line-height:1.35}
.radio-card strong{font-size:15px;color:var(--ink)}
.radio-card small{display:block;color:var(--muted);font-weight:600;font-size:13px}
.radio-card:has(input:checked){border-color:#bce2a0;background:#f7fbf0;box-shadow:0 0 0 3px rgba(150,209,86,.15)}
.check-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;margin-top:8px}
.check-grid label{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);background:#fff;font-weight:600}
.check-grid input{width:18px;height:18px;min-height:18px;margin:0;accent-color:var(--brand)}
.compact-check-grid{display:grid;grid-template-columns:repeat(7,minmax(60px,1fr));gap:6px;margin-top:8px}
.compact-check-grid label{min-height:38px;padding:6px 8px;border-radius:var(--r-sm);font-size:14px;justify-content:space-between;background:#fff;display:flex;align-items:center}
.recurring-weekday-grid{display:flex!important;flex-wrap:wrap;gap:8px}
.recurring-weekday-grid label,.weekday-pill{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:50px;min-height:38px;border:1px solid var(--line);border-radius:999px;background:#fff;padding:8px 12px;font-weight:700;cursor:pointer}
.recurring-weekday-grid input{width:auto;min-height:0;margin:0}
.medical-alert,.medical-alert-btn{display:inline-flex;align-items:center;justify-content:center;width:21px;height:21px;min-height:21px;border-radius:50%;background:var(--warn-bg);color:var(--warn);border:1px solid #e7c66a;font-weight:800;margin-inline-start:6px;font-size:13px;padding:0;cursor:pointer}
.attendance-row.has-medical-alert{border-color:#e7c66a;background:#fffdf4}

/* ====================== Login / tenant setup ====================== */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(circle at 70% 0%,rgba(197,237,79,.16),transparent 42%),var(--bg)}
.login-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:0 24px 60px rgba(20,40,22,.12);padding:34px;width:min(420px,100%);text-align:center}
.login-card h1{margin:0 0 8px;color:var(--ink);font-family:var(--font-display)}
.login-tabs{background:var(--surf2);border-radius:14px;padding:4px;display:flex;gap:4px;margin:18px 0}
.login-tab{flex:1;border:0;background:#fff;border-radius:11px;padding:10px;font-weight:700;color:var(--ink2);cursor:pointer;min-height:auto}
.login-tab:not(.active){background:transparent;color:var(--muted)}
.login-tab.active{box-shadow:0 1px 4px rgba(0,0,0,.08)}
.login-help{font-size:13px;color:var(--muted);line-height:1.5;margin:10px 0 0}
.tenant-setup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at 70% 0%,rgba(197,237,79,.16),transparent 42%),var(--bg)}
.tenant-setup-card{width:min(760px,100%);background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh)}
.tenant-logo{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--brand);margin-bottom:10px}.tenant-logo span{font-size:12px;color:var(--muted)}
.tenant-setup-card h1{margin:0 0 8px;font-size:28px;font-family:var(--font-display)}
.tenant-setup-form{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}
.tenant-setup-form label{font-weight:700;color:var(--ink2)}
.tenant-setup-form .note-box,.tenant-setup-form .error,.tenant-setup-form .btn-wide,.tenant-setup-form .check-row{grid-column:1/-1}
.small-check{display:flex!important;align-items:center;gap:8px;font-weight:700!important;color:var(--ink2)}.small-check input{width:18px!important;height:18px!important;min-height:18px!important;flex:0 0 auto;margin:0}

/* ====================== Client portal ====================== */
.client-body{background:var(--bg)}
.client-shell{min-height:100vh;padding:30px 18px;background:radial-gradient(circle at top right,rgba(197,237,79,.14),transparent 36%),var(--bg)}
.client-wrap{max-width:1120px;margin:0 auto}
.client-hero-pro{display:grid;grid-template-columns:1fr 230px;gap:18px;align-items:stretch;margin-bottom:18px}
.client-hero-copy{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);padding:30px}
.client-eyebrow{display:inline-flex;background:var(--surf2);color:var(--ink2);font-weight:700;border-radius:999px;padding:6px 12px;margin-bottom:12px}
.client-hero-copy h1{margin:0;color:var(--ink);font-size:34px;letter-spacing:-.5px;font-family:var(--font-display)}
.client-hero-copy p{margin:8px 0 0;color:var(--muted);font-size:17px}
.client-hero-panel{background:var(--brand);color:#fff;border-radius:var(--r-lg);box-shadow:var(--sh);padding:26px;display:flex;flex-direction:column;justify-content:center;gap:12px}
.client-hero-panel .badge{background:rgba(255,255,255,.16);color:#fff;align-self:flex-start;font-size:15px;padding:7px 13px}
.client-hero-panel .client-mini-label{opacity:.78;font-weight:700}
.client-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:18px}
.client-summary-compact{grid-column:1/-1;display:flex;gap:18px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);padding:18px 22px}
.client-summary-compact>div{flex:1;min-width:120px}
.client-summary-compact span{display:block;color:var(--muted);font-size:13px;font-weight:700}
.client-summary-compact strong{display:block;color:var(--ink);font-size:20px;font-family:var(--font-display);margin-top:3px}
.client-summary-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);padding:22px;min-height:116px;display:flex;flex-direction:column;justify-content:space-between}
.client-summary-card span{color:var(--muted);font-weight:700}
.client-summary-card strong{color:var(--ink);font-size:25px;line-height:1.1;font-family:var(--font-display)}
.client-card-pro{background:#fff;border:1px solid var(--line);box-shadow:var(--sh);border-radius:var(--r-lg);padding:24px}
.client-section-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}
.client-section-head h2{margin:0;color:var(--ink);font-size:26px;font-family:var(--font-display)}
.client-section-head p{margin:4px 0 0;color:var(--muted)}
.client-note{background:var(--warn-bg);color:var(--warn);font-weight:700;border-radius:14px;padding:12px 14px;margin-bottom:12px}
.client-week-strip{display:flex;gap:10px;overflow-x:auto;padding:2px 2px 14px;margin-bottom:8px}
.client-day-pill{flex:0 0 116px;background:#fff;border:1px solid var(--line);border-radius:18px;color:var(--ink2);padding:12px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:right;min-height:90px}
.client-day-pill span{font-size:13px;color:var(--muted);font-weight:800}
.client-day-pill strong{font-size:21px;color:var(--ink);font-family:var(--font-display)}
.client-day-pill small{font-size:12px;color:var(--muted);font-weight:700}
.client-day-pill.active{background:var(--brand);border-color:transparent;color:#fff}
.client-day-pill.active span,.client-day-pill.active strong,.client-day-pill.active small{color:#fff}
.client-day-pill.empty-day{opacity:.7}
.client-day-title{font-size:19px;font-weight:800;color:var(--ink);margin:8px 0 12px;font-family:var(--font-display)}
.client-class-list,.client-booking-list{display:grid;gap:11px}
.client-class-card-pro{display:grid;grid-template-columns:88px 1fr auto;gap:16px;align-items:center;border:1px solid var(--line);border-radius:var(--r);padding:16px;background:#fff}
.client-class-card-pro.booked{border-color:#bce2a0;background:linear-gradient(90deg,#f7fbf0,#fff)}
.client-time-box{background:var(--surf2);border-radius:14px;padding:13px;text-align:center;display:flex;flex-direction:column;gap:3px}
.client-time-box strong{font-size:22px;color:var(--ink);font-family:var(--font-display)}
.client-time-box span{font-size:13px;color:var(--muted);font-weight:700}
.client-class-title{font-weight:800;color:var(--ink);font-size:19px}
.client-class-meta{color:var(--muted);margin-top:5px;font-weight:600}
.client-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.client-booking-card{display:flex;justify-content:space-between;align-items:center;gap:14px;border:1px solid var(--line);border-radius:18px;background:#fff;padding:15px}
.client-booking-card strong{display:block;color:var(--ink);font-size:17px}
.client-booking-card span,.client-booking-card small{display:block;color:var(--muted);font-weight:600;margin-top:3px}
.client-error-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);padding:34px;text-align:center;max-width:520px;margin:60px auto}
.client-logo{font-size:34px;margin-bottom:8px}
.client-error-card h1{color:var(--ink);margin:0 0 8px;font-family:var(--font-display)}
.client-error-card p{color:var(--muted);margin:0}
.client-onboarding-backdrop{align-items:center;justify-content:center;overflow:auto;padding:18px}
.client-onboarding-modal{width:min(860px,94vw);max-height:88vh;overflow:auto;padding:24px;border-radius:var(--r-lg)}
.client-onboarding-form{display:grid;gap:14px}
.client-doc-text{white-space:pre-wrap;max-height:160px;overflow:auto;padding:14px;border-radius:14px;line-height:1.55;background:var(--surf3);border:1px solid var(--line)}
.client-consent-line{display:flex!important;align-items:center;gap:10px;margin:6px 0 2px;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:var(--surf3);font-weight:700}
.client-consent-line input[type="checkbox"]{width:18px!important;height:18px!important;min-width:18px!important;min-height:18px!important;accent-color:var(--brand);box-shadow:none;margin:0}

/* ====================== Desktop stable frame ====================== */
/* Lock scroll ONLY on app-shell pages so the sidebar stays fixed.
   Client/instructor/login pages (no .app-shell) scroll normally. */
@media(min-width:821px){
  .app-shell{height:100vh;overflow:hidden}
  .app-shell .main{height:100vh;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable}
  #supportModeMount:not(:empty){position:sticky;top:0;z-index:40}
}
/* belt-and-suspenders: if :has is supported, prevent body scroll behind the fixed shell */
@supports selector(body:has(.app-shell)){
  @media(min-width:821px){ body:has(.app-shell){overflow:hidden} }
}

/* ====================== Mobile ====================== */
@media(max-width:820px){
  html,body{overflow:auto;height:auto}
  .app-shell{display:block}
  .sidebar{position:sticky;top:0;z-index:40;height:auto;flex-direction:column;gap:10px;border-inline-end:0;border-bottom:1px solid var(--line);padding:10px 12px}
  .brand{flex-direction:row;align-items:center;gap:10px;padding:2px 2px 8px;border-bottom:1px solid var(--line)}
  .brand-sub,.sidebar-footer{display:none}
  #studioSwitcherMount{margin-inline-start:auto}
  .nav{flex-direction:row;overflow-x:auto;gap:7px;padding-bottom:2px;scrollbar-width:none}
  .nav::-webkit-scrollbar{display:none}
  .nav a{flex:0 0 auto;white-space:nowrap;padding:9px 13px;border:1px solid var(--line);font-size:13.5px}
  .nav a.active{border-color:var(--brand)}
  .nav-badge{margin-inline-start:6px}
  .main{height:auto;overflow:visible}
  .topbar,.app-topbar{padding:14px 16px}
  #pageContent{padding:16px}
  .cockpit-grid,.dashboard-workspace,.two-col,.grid-2,.grid-3,.grid-4,.form-grid,.metric-list.three,.info-grid,.settings-layout,.tenant-setup-form,.client-hero-pro,.client-summary-grid{grid-template-columns:1fr}
  .hero-card{flex-direction:column;align-items:stretch;gap:14px}
  .week-board{grid-template-columns:1fr}
  .week-day-strip{display:flex;overflow-x:auto}.week-day-button{flex:0 0 116px}
  .agenda-class-card,.client-class-card-pro{grid-template-columns:1fr}
  .compact-check-grid{grid-template-columns:repeat(2,minmax(120px,1fr))}
  table{font-size:13.5px}th,td{padding:10px}
  .page-title h1{font-size:19px}
}

/* ============================================================
   Additional page components (audited from all page JS)
   ============================================================ */
.action-row,.actions,.inline-actions,.compact-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.action-row button,.actions button{white-space:nowrap}
.input-with-button{display:flex;gap:8px;align-items:center}.input-with-button input{flex:1;margin:0}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.kpi{background:var(--surf3);border:1px solid var(--line);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:5px}
.kpi-label{color:var(--muted);font-weight:600;font-size:13px}
.kpi-value{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);letter-spacing:-.3px}
.timeline{display:grid;gap:10px}
.timeline-item{display:grid;grid-template-columns:84px 1fr auto;gap:14px;align-items:center;padding:13px;border:1px solid var(--line);border-radius:var(--r);background:#fff;box-shadow:var(--sh)}
.timeline-time{background:var(--surf2);border-radius:12px;padding:10px;text-align:center;font-weight:800;color:var(--ink);font-family:var(--font-display)}
.attendance-list{display:grid;gap:9px}
.attendance-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;border:1px solid var(--line);background:#fff;border-radius:14px;padding:12px 14px}
.attendance-meta{color:var(--muted);font-weight:600;font-size:13px}
.attendance-buttons{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}
.attendance-note-input{width:100%;min-height:64px;margin:0}
.health-card-list{display:grid;gap:10px;margin-top:12px}
.health-card-item{border:1px solid var(--line);border-radius:14px;padding:12px;background:var(--surf3)}
.health-card-item strong{display:block;color:var(--ink);margin-bottom:4px}
.health-card-item small{display:block;color:var(--muted);font-weight:600}
.health-doc-text{max-height:130px;overflow:auto}
.client-health-grid{display:grid;grid-template-columns:1fr;gap:12px}
/* ===== V29.5.2 help & support ===== */
.help-grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:18px;align-items:start}
.help-h{font-family:var(--font-display);font-size:18px;font-weight:800;margin:0 0 12px}
.help-faq{display:flex;flex-direction:column;gap:10px}
.help-faq-item{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff}
.help-faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;background:none;border:0;padding:14px 16px;font-family:inherit;font-size:15px;font-weight:700;color:var(--ink);cursor:pointer;text-align:right}
.help-faq-q:hover{background:var(--surf3)}
.help-faq-chev{color:var(--muted);transition:transform .18s ease}
.help-faq-item.open .help-faq-chev{transform:rotate(180deg)}
.help-faq-a{max-height:0;overflow:hidden;transition:max-height .22s ease}
.help-faq-item.open .help-faq-a{max-height:340px}
.help-faq-a p{margin:0;padding:0 16px 15px;color:var(--ink2);font-weight:600;line-height:1.6}
.help-side{display:flex;flex-direction:column;gap:18px}
.help-contact-icon{width:46px;height:46px;border-radius:13px;background:var(--brand);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.help-contact-icon .mi{font-size:26px}
.help-contact label{display:block;font-weight:700;font-size:13.5px;margin-top:12px}
.help-contact select,.help-contact textarea{width:100%;margin-top:6px}
.help-contact textarea{min-height:96px}
.help-contact .btn-wide{margin-top:14px;display:inline-flex;align-items:center;justify-content:center;gap:7px}
.help-mail{display:block;text-align:center;margin-top:12px;color:var(--muted);font-weight:700;text-decoration:none}
.help-mail:hover{color:var(--brand)}
.help-meta-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}
.help-meta-row:last-child{border-bottom:0}
.help-meta-row span{color:var(--muted);font-weight:600}
@media(max-width:820px){.help-grid{grid-template-columns:1fr}}
.smart-health-question{border:1px solid var(--line);border-radius:14px;padding:12px 14px;background:#fff;margin-bottom:10px}
.smart-detail{margin-top:8px}
.checkbox-line{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:var(--surf3);font-weight:600}
.checkbox-line input{width:18px;height:18px;min-height:18px;margin:0;accent-color:var(--brand)}
.ok-text{color:var(--ok);font-weight:700}
.bad-text{color:var(--bad);font-weight:700}
.instructor-day-section{display:grid;gap:10px;margin-bottom:18px}
.instructor-day-heading{font-size:17px;color:var(--ink);margin:4px 0 2px;font-weight:800;font-family:var(--font-display)}
.empty-instructor-day,.compact-empty,.empty-action{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;text-align:center;color:var(--muted);border:1px dashed #cfcfc2;border-radius:var(--r);background:var(--surf3)}
.empty-action span{color:var(--muted)}
.portal-compact-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--brand);color:#fff;border-radius:var(--r-lg);padding:22px 24px;margin-bottom:16px}
.portal-compact-hero h1,.portal-compact-hero h2{margin:0;font-family:var(--font-display)}
.portal-week-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px;box-shadow:var(--sh);margin-bottom:14px}
.instructor-week-timeline{display:grid;gap:10px}
.instructor-class-card{border:1px solid var(--line);border-radius:var(--r);padding:14px;background:#fff;box-shadow:var(--sh);margin-bottom:9px}
.instructor-class-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}
.instructor-class-head strong{font-family:var(--font-display);font-size:16px}
.instructor-health-backdrop{position:fixed;inset:0;background:rgba(15,25,18,.5);display:flex;align-items:center;justify-content:center;padding:18px;z-index:120}
.instructor-health-modal{background:#fff;border-radius:var(--r-lg);box-shadow:0 24px 70px rgba(0,0,0,.25);width:min(640px,100%);max-height:88vh;overflow:auto;padding:24px}
.product-price,.price-big{font-family:var(--font-display);font-weight:700;color:var(--ink)}
.price-big{font-size:28px;letter-spacing:-.3px}.product-price{font-size:18px}
.client-product-card{border:1px solid var(--line);border-radius:var(--r);padding:16px;background:#fff;box-shadow:var(--sh)}
.purchase-summary-card{border:1px solid var(--line);border-radius:var(--r);padding:16px;background:var(--surf3);margin:10px 0}
.purchase-summary-card strong{font-family:var(--font-display);font-size:17px}
.series-field{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.finance-row{cursor:pointer}.finance-row:hover td{background:var(--surf3)}.finance-row.locked{cursor:not-allowed;opacity:.85}.finance-row small{color:var(--muted);font-weight:600}
.inner-card{border:1px solid var(--line);border-radius:var(--r);padding:16px;background:#fff}.inner-card.full{width:100%;box-sizing:border-box}
.compact-week-nav{display:flex;align-items:center;justify-content:space-between}
.day-agenda{display:grid;gap:12px}
.class-edit-tabs{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 18px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.weekday-chip{display:inline-flex;align-items:center;justify-content:center;min-width:50px;min-height:38px;border:1px solid var(--line);border-radius:999px;background:#fff;padding:8px 12px;font-weight:700;cursor:pointer}
.weekday-chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.coupon-inline{display:flex;gap:8px;align-items:center;margin-top:10px;flex-wrap:wrap}.coupon-inline input{min-width:160px;margin:0}
.coupon-result{margin-top:6px}
.support-current{background:rgba(255,255,255,.16);color:#fff;border-radius:999px;padding:5px 11px;font-weight:700;font-size:12px}
.customer-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surf3);border:1px solid var(--line);border-radius:var(--r-sm);padding:14px;margin-bottom:12px}.customer-card-head small{display:block;color:var(--muted);margin-top:4px}
.tab-panel{min-height:200px}
.client-form-section{margin:0 0 18px}.client-form-section h3{margin:0 0 10px;font-family:var(--font-display)}
.client-policy-box{background:var(--surf3);border:1px solid var(--line);border-radius:14px;padding:16px;margin-top:16px;color:var(--ink2);line-height:1.7}
.client-class-main{min-width:0}
.client-status-source{color:var(--muted);font-weight:600;font-size:13px}
.settings-document-grid{display:grid;grid-template-columns:1fr;gap:18px}
.readiness-meta{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.readiness-meta small{color:var(--muted);font-weight:600}
.super-admin-shell{min-height:100vh;padding:24px;max-width:1200px;margin:0 auto}
.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px}
.metric-card{border:1px solid var(--line);border-radius:var(--r);padding:18px;background:#fff;box-shadow:var(--sh);text-align:right;cursor:pointer}
.metric-card:hover{transform:translateY(-1px);box-shadow:var(--sh-hover);border-color:#d4d4c8}
.metric-click,.clickable-dashboard{cursor:pointer}
.studio-admin-card{border:1px solid var(--line);border-radius:var(--r);padding:18px;background:#fff;box-shadow:var(--sh)}
@media(max-width:820px){
  .customers-mobile-cards table,.customers-mobile-cards thead,.customers-mobile-cards tbody,.customers-mobile-cards tr,.customers-mobile-cards td{display:block;width:100%;white-space:normal}
  .customers-mobile-cards thead{display:none}
  .customers-mobile-cards tr{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);margin-bottom:10px;padding:12px}
  .customers-mobile-cards td{border:0;padding:6px 0}
  .customers-mobile-cards td:before{content:attr(data-label);display:block;color:var(--muted);font-size:12px;font-weight:700}
  .instructor-week-timeline,.metrics-grid,.kpi-grid{grid-template-columns:1fr}
  .timeline-item,.attendance-row{grid-template-columns:1fr}
  .attendance-buttons{justify-content:stretch}.attendance-buttons button{flex:1}
  .portal-compact-hero{flex-direction:column;align-items:stretch}
}

/* ===== V29.5.2 portal mobile compaction ===== */
@media(max-width:560px){
  .client-shell{padding:14px 12px}
  .client-hero-pro,.client-hero-pro.portal-compact-hero{grid-template-columns:1fr;gap:10px;margin-bottom:12px}
  .client-hero-copy{padding:16px}
  .client-hero-copy h1{font-size:23px}
  .client-hero-panel{padding:14px;flex-direction:row;align-items:center;justify-content:space-between}
  .client-summary-grid{grid-template-columns:1fr;gap:0;margin-bottom:12px}
  .client-summary-compact{display:flex;gap:10px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh);padding:14px 16px}
  .client-summary-compact>div{flex:1;min-width:90px}
  .client-summary-compact span{display:block;color:var(--muted);font-size:12px;font-weight:700}
  .client-summary-compact strong{display:block;color:var(--ink);font-size:16px;font-family:var(--font-display)}
  .client-card-pro{padding:15px;border-radius:16px}
  .client-section-head h2{font-size:19px}
  .client-class-card-pro{grid-template-columns:60px 1fr;gap:11px;padding:12px}
  .client-class-card-pro .client-actions{grid-column:1/-1;justify-content:flex-start}
  .client-time-box{padding:8px}.client-time-box strong{font-size:17px}
  .client-class-title{font-size:16px}
  .client-day-pill{flex:0 0 88px;min-height:70px;padding:9px;border-radius:14px}
  .portal-compact-hero .client-hero-copy h1{font-size:20px}
  .portal-compact-hero .client-hero-copy p{font-size:13px}
  .instructor-class-card{padding:12px}
  .instructor-day-heading{font-size:16px}
  .attendance-buttons{flex-wrap:wrap;gap:6px}
  .attendance-buttons .btn-sm{flex:1;min-width:64px}
}

/* ===== V29.5.4 manager health review decision ===== */
.hr-status{margin-bottom:14px}
.health-review-summary{background:var(--surf3);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:16px}
.health-review-summary.calm{background:var(--ok-bg);border-color:#bfe3cd}
.hr-sum-head{font-weight:800;color:var(--ink);margin-bottom:4px}
.hr-sum-lead{color:var(--ink2);font-weight:600;margin-bottom:8px}
.health-review-summary.calm .hr-sum-lead{margin-bottom:0;color:var(--ok)}
.hr-sum-list{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.hr-sum-list li{display:flex;gap:8px;align-items:baseline;color:var(--ink2);flex-wrap:wrap}
.hr-sum-list li:before{content:"•";color:var(--warn);font-weight:800}
.hr-sum-q{font-weight:700;color:var(--ink)}
.hr-sum-d{color:var(--muted);font-weight:600}
.health-review-list{display:grid;gap:10px;margin:10px 0 0}
.hr-card{display:flex;justify-content:space-between;gap:14px;align-items:center;border:1px solid var(--line);border-radius:14px;padding:12px 14px;background:#fff}
.hr-card.is-block{border-color:#eecdc7;background:#fffaf9}
.hr-q{font-weight:800;color:var(--ink)}
.hr-a{color:var(--ink2);font-weight:600;margin-top:3px}
.hr-detail{color:var(--muted);font-weight:600;margin-top:3px;font-size:13.5px}
.hr-card-side{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex:0 0 auto}
.hr-side-label{color:var(--muted);font-size:12px;font-weight:700}
.hr-toggle{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:var(--surf2)}
.hr-seg{border:0;background:transparent;padding:6px 16px;font-weight:700;font-size:13px;cursor:pointer;color:var(--ink2);min-height:34px}
.hr-seg.sel-yes{background:var(--ok);color:#fff}
.hr-seg.sel-no{background:var(--ink2);color:#fff}
.hr-actions{display:flex;gap:8px;flex-wrap:wrap;margin:16px 0 4px}
.hr-docs{margin-top:14px;border-top:1px solid var(--line);padding-top:8px}
.hr-docs summary{cursor:pointer;font-weight:700;color:var(--ink2);padding:6px 0}
.hr-docs h4{margin-top:12px}
@media(max-width:560px){.hr-card{flex-direction:column;align-items:stretch}.hr-card-side{align-items:flex-start}}

/* ===== V29.5.4 instructor portal concise health ===== */
.instr-health-chips{display:grid;gap:10px;margin-top:8px}
.instr-health-chip{display:flex;gap:10px;align-items:flex-start;border:1px solid #e7c66a;background:#fffdf4;border-radius:14px;padding:12px 14px}
.instr-health-chip.note{border-color:var(--line);background:var(--surf3)}
.ihc-icon{font-size:18px;line-height:1.25;flex:0 0 auto}
.ihc-q{font-weight:800;color:var(--ink)}
.ihc-d{color:var(--ink2);font-weight:600;margin-top:2px;font-size:14px}
.ihc-sub{margin-top:-2px}

/* ===== V29.5.4 completed tasks muted state ===== */
tr.task-done{background:#f4f4f1}
tr.task-done td{color:#6f716d}
tr.task-done td strong{color:#555852}
tr.task-done td small{color:#9a9c96}
tr.task-done .badge{background:#e6ebe4;color:#3f5f48}

/* ============================================================
   V29.6 — Trust & Launch Readiness
   ============================================================ */

/* ---- 1+8. Auth guard: hide the app shell until auth is confirmed ---- */
.app-shell{visibility:hidden}
body.auth-ready .app-shell{visibility:visible}
.auth-gate{position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 70% 0%,rgba(191,239,63,.14),transparent 42%),rgba(246,246,242,.96)}
body.auth-ready .auth-gate{display:none}
.junney-loader{display:flex;flex-direction:column;align-items:center;gap:16px;background:#fff;padding:32px 46px;border-radius:24px;box-shadow:0 14px 40px rgba(20,40,22,.08);border:1px solid var(--line)}
.junney-loader-mark{width:60px;height:60px;display:block}
.junney-loader-dot{transform-box:fill-box;transform-origin:center;animation:junneyDotPulse 1.4s ease-in-out infinite}
.junney-loader p{margin:0;font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--ink2)}
@keyframes junneyDotPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}
@media (prefers-reduced-motion: reduce){.junney-loader-dot{animation:none}}

/* ---- 12. Accessibility: visible keyboard focus everywhere ---- */
:focus-visible{outline:3px solid #2f6df0;outline-offset:2px;border-radius:6px}
button:focus-visible,a:focus-visible,.login-tab:focus-visible,.client-day-pill:focus-visible,.hr-seg:focus-visible,summary:focus-visible{outline:3px solid #2f6df0;outline-offset:2px}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid #2f6df0;outline-offset:1px}
.skip-link{position:absolute;right:-9999px;top:0;background:var(--brand);color:#fff;padding:10px 16px;border-radius:0 0 10px 0;z-index:9999;font-weight:700}
.skip-link:focus{right:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
/* error text carries an icon + bold, never colour alone */
.error{color:var(--bad);background:var(--bad-bg);border:1px solid #eecdc7;border-radius:10px;padding:10px 12px;margin:10px 0;display:none;font-weight:700;text-align:right}
.error:not(:empty){display:block}
.error::before{content:"⚠ ";font-weight:800}
.error.is-success{color:var(--ok);background:var(--ok-bg);border-color:#bfe3cd}
.error.is-success::before{content:"✓ "}

/* ---- 13. Legal / footer links on login + standalone legal pages ---- */
.login-legal{margin-top:18px;font-size:13px;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.login-legal a{color:var(--ink2);font-weight:700;text-decoration:underline;text-underline-offset:3px}
.legal-page{max-width:760px;margin:0 auto;padding:40px 22px 64px}
.legal-page h1{font-family:var(--font-display);color:var(--ink);margin:0 0 6px}
.legal-page .legal-updated{color:var(--muted);font-weight:600;margin:0 0 24px}
.legal-page h2{font-family:var(--font-display);color:var(--ink);font-size:19px;margin:28px 0 8px}
.legal-page p,.legal-page li{color:var(--ink2);line-height:1.7}
.legal-page ul{padding-inline-start:22px}
.legal-page .legal-contact{background:var(--surf3);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-top:18px}
.legal-page .btn-primary{margin-top:26px}
.legal-back{display:inline-block;margin-bottom:20px;color:var(--ink2);font-weight:700}

/* ---- 4. Super Admin UX polish (visual only) ---- */
.super-admin-shell .metrics-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px}
.super-admin-shell .metric-card{padding:20px;border-radius:16px;display:flex;flex-direction:column;gap:5px}
.super-admin-shell .metric-card>span{color:var(--muted);font-size:13px;font-weight:600;letter-spacing:.1px}
.super-admin-shell .metric-card>strong{font-size:30px;font-weight:700;font-family:var(--font-display);color:var(--ink);line-height:1.05}
.super-admin-shell .metric-card>small{color:var(--muted);font-size:12.5px;font-weight:500}
.super-admin-shell .toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:8px}
.super-admin-shell .toolbar h2{margin:0;font-size:20px}
.super-admin-shell .toolbar-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.super-admin-shell .toolbar-actions input{min-width:240px}
.super-admin-shell table{width:100%;border-collapse:separate;border-spacing:0}
.super-admin-shell thead th{font-size:12.5px;font-weight:700;color:var(--muted);text-align:right;padding:10px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
.super-admin-shell tbody td{padding:14px;border-bottom:1px solid var(--surf2);vertical-align:middle;font-weight:500}
.super-admin-shell tbody tr:last-child td{border-bottom:0}
.super-admin-shell tbody td strong{font-weight:700}
.super-admin-shell tbody td small{color:var(--muted);font-weight:500}
.super-admin-shell .clickable-row{cursor:pointer;transition:background .14s ease}
.super-admin-shell .clickable-row:hover{background:var(--surf3)}
.super-admin-shell .soft-card h3,.super-admin-shell .soft-card h4{font-weight:700}
.super-admin-shell .soft-card p{font-weight:500;color:var(--ink2);margin:6px 0}
.super-admin-shell .soft-card p b{font-weight:700;color:var(--ink)}
.super-admin-shell .studio-admin-card .summary-grid strong{font-weight:700}

/* ---- 6. Client portal: today button + collapsible store ---- */
.client-today-btn{min-height:38px;padding:6px 16px;border-radius:999px}
.client-store-block{cursor:default}
.client-store-block>summary{list-style:none;cursor:pointer;display:flex;flex-direction:column;gap:2px;font-family:var(--font-display)}
.client-store-block>summary::-webkit-details-marker{display:none}
.client-store-block>summary>span{font-size:19px;font-weight:800;color:var(--ink)}
.client-store-block>summary>small{color:var(--muted);font-weight:600}
.client-store-block>summary::after{content:"▾";position:absolute;inset-inline-start:18px;margin-top:2px;color:var(--muted);font-size:14px}
.client-store-block{position:relative}
.client-store-block[open]>summary::after{content:"▴"}

/* ============================================================
   V29.7 — PWA install UX + iOS Safari white-screen fix
   ============================================================ */

/* ---- iOS Safari "blank until scroll" fix ----
   Root cause: min-height:100vh on full-page containers that carry a radial-gradient
   background. On iOS Safari the 100vh viewport (with the dynamic toolbar) is mis-measured
   and the gradient paint isn't flushed until a scroll/resize. We switch the full-height
   containers to the dynamic viewport unit (dvh) where supported, and give iOS a
   -webkit-fill-available fallback. Browsers without dvh keep their existing 100vh. */
html{min-height:100%}
body{min-height:100%}
@supports (min-height:100svh){
  .app-shell,.super-admin-shell,.login-page,.tenant-setup-page,.client-shell,.client-container,.auth-gate{min-height:100svh}
}
@supports (min-height:100dvh){
  .login-page,.tenant-setup-page,.client-shell,.client-container,.auth-gate{min-height:100dvh}
}
/* belt-and-braces for older iOS that understands neither dvh nor svh */
@supports (-webkit-touch-callout: none){
  .login-page,.tenant-setup-page,.client-shell,.client-container{min-height:-webkit-fill-available}
}
/* prevent horizontal jitter that can also trigger the repaint glitch on mobile */
html,body{overflow-x:hidden}

/* ---- PWA install panel (manager Help/Settings only) ---- */
.pwa-install-card .pwa-install-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.pwa-install-icon{width:44px;height:44px;border-radius:12px;background:var(--brand);color:var(--accent);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.pwa-install-icon .mi{font-size:24px}
.pwa-install-copy{flex:1;min-width:180px}
.pwa-install-copy strong{display:block;color:var(--ink);font-family:var(--font-display)}
.pwa-install-copy small{color:var(--muted);font-weight:600}
.pwa-installed-note{display:flex;align-items:center;gap:8px;color:var(--ok);font-weight:700}
.pwa-ios-steps{list-style:none;margin:14px 0 0;padding:0;display:grid;gap:10px}
.pwa-ios-steps li{display:flex;gap:10px;align-items:flex-start;color:var(--ink2);font-weight:600}
.pwa-ios-steps .pwa-step-num{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:var(--surf2);color:var(--ink);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:13px}
.pwa-share-glyph{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--surf2);color:var(--brand);font-weight:800}
/* ===== V30.0 Junney brand logo ===== */
.brand-logo{display:flex;align-items:center;width:100%;min-height:34px}
.brand-logo img{height:30px;width:auto;max-width:150px;display:block}
.auth-logo{height:46px;width:auto;margin:0 auto 12px;display:block}
@media(max-width:760px){.brand-logo img{height:27px;max-width:130px}.auth-logo{height:40px}}

/* ===== V30.1 client studio identity bar ===== */
.client-studio-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:1100px;margin:0 auto 14px;padding:12px 18px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh)}
.client-studio-bar .client-studio-mark{width:24px;height:24px;flex:0 0 auto}
.client-studio-name{font-family:var(--font-display);font-weight:800;font-size:17px;color:var(--ink)}
.client-studio-tag{color:var(--muted);font-weight:600;font-size:13px;margin-inline-start:auto}
