/* ============================================================
   YOUR CARE TRAINING — Platform stylesheet
   "Serene Care Identity" — built on brand tokens
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:ital,opsz,wght@0,6..12,300;0,6..12,400;0,6..12,600;0,6..12,700;0,6..12,800;0,6..12,900;1,6..12,400&display=swap');

:root {
  --periwinkle:#a5a6f6; --periwinkle-deep:#5557a0; --periwinkle-ink:#383881;
  --periwinkle-soft:#e1dfff; --periwinkle-wash:#e0e7ff;
  --teal:#2e6482; --teal-accent:#2dd4bf; --sky:#7db0d1; --sky-container:#a7dbfd;
  --sky-bg:#f0f9ff; --care-teal-ring:#0f766e;
  --surface:#f7f9fb; --surface-lowest:#ffffff; --surface-low:#f2f4f6;
  --surface-container:#eceef0; --surface-high:#e6e8ea; --surface-dim:#d8dadc;
  --ink:#191c1e; --ink-slate:#334155; --ink-variant:#464650; --ink-muted:#777682;
  --outline:#777682; --outline-variant:#c7c5d2; --field-bg:#f1f5f9;
  --success:#0d9488; --success-deep:#0a7a6f; --success-soft:#d1faf3; --error:#ba1a1a; --error-soft:#ffdad6;
  --warning:#b9770a; --warning-soft:#fdf0d5; --info:#2e6482;
  --font:'Nunito Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --r-sm:4px; --r-md:6px; --r-lg:8px; --r-xl:12px; --r-2xl:20px; --r-full:9999px;
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px; --s6:32px; --s8:48px; --s10:64px;
  --sh-xs:0 1px 2px rgba(85,87,160,.06);
  --sh-sm:0 4px 12px rgba(85,87,160,.08);
  --sh-md:0 8px 24px rgba(165,166,246,.15);
  --sh-lg:0 16px 40px rgba(85,87,160,.16);
  --sh-xl:0 28px 64px rgba(85,87,160,.20);
  --focus:0 0 0 4px rgba(165,166,246,.30);
  --maxw:1240px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
html,body{overflow-x:clip; max-width:100%;}
body{
  margin:0; font-family:var(--font); color:var(--ink-slate);
  background:var(--surface-lowest); line-height:1.6; -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit;}
::selection{background:var(--periwinkle-soft); color:var(--periwinkle-ink);}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px;}
.wrap-sm{max-width:880px; margin:0 auto; padding:0 24px;}
.section{padding:96px 0;}
.section-sm{padding:64px 0;}
.center{text-align:center;}
.eyebrow{font-size:13px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  color:var(--periwinkle-deep); margin:0 0 16px;}
.row{display:flex; gap:var(--s4);}
.row-between{display:flex; align-items:center; justify-content:space-between; gap:var(--s4);}
.col{display:flex; flex-direction:column;}
.muted{color:var(--ink-muted);}
.grid{display:grid; gap:24px;}
.hidden{display:none !important;}

/* ---------- Type ---------- */
h1,h2,h3,h4{color:var(--ink-slate); margin:0 0 .4em; font-weight:800; letter-spacing:-.02em; line-height:1.12;}
h1{font-size:clamp(34px,5vw,56px);}
h2{font-size:clamp(28px,3.6vw,42px);}
h3{font-size:clamp(20px,2.2vw,26px); letter-spacing:-.01em;}
h4{font-size:18px; letter-spacing:0;}
p{margin:0 0 1em;}
.lead{font-size:19px; color:var(--ink-variant); line-height:1.65;}
.accent{color:var(--periwinkle-deep);}
.display{font-weight:900;}

/* scribble underline accent */
.scribble{position:relative; display:inline-block; white-space:nowrap;}
.scribble::after{
  content:""; position:absolute; left:-4px; right:-4px; bottom:-7px; height:12px;
  background:no-repeat center/100% 100% url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 18' fill='none' preserveAspectRatio='none'%3E%3Cpath d='M4 11C46 6 96 4 150 6C198 8 250 10 296 5' stroke='%235557a0' stroke-width='5' stroke-linecap='round'/%3E%3Cpath d='M10 15C60 11 120 13 180 12C228 11 268 13 290 11' stroke='%235557a0' stroke-width='3' stroke-linecap='round' opacity='.55'/%3E%3C/svg%3E");
}
.scribble.sky::after{filter:hue-rotate(0);}

/* ---------- Buttons ---------- */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-weight:800; font-size:15.5px; border:none; border-radius:var(--r-full);
  padding:13px 24px; cursor:pointer; transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s;
  white-space:nowrap; line-height:1; text-decoration:none;}
.btn:hover{transform:translateY(-2px);}
.btn:active{transform:translateY(0) scale(.98);}
.btn svg{width:18px; height:18px;}
.btn-primary{background:var(--periwinkle-deep); color:#fff; box-shadow:var(--sh-md);}
.btn-primary:hover{background:#4a4c91; box-shadow:var(--sh-lg);}
.btn-secondary{background:var(--teal); color:#fff; box-shadow:var(--sh-md);}
.btn-secondary:hover{background:#27566f;}
.btn-ghost{background:transparent; color:var(--periwinkle-deep); border:2px solid var(--periwinkle);}
.btn-ghost:hover{background:var(--periwinkle-soft);}
.btn-soft{background:var(--periwinkle-soft); color:var(--periwinkle-ink);}
.btn-soft:hover{background:#d6d3ff;}
.btn-white{background:#fff; color:var(--periwinkle-deep); box-shadow:var(--sh-sm);}
.btn-white:hover{box-shadow:var(--sh-md);}
.btn-lg{font-size:17px; padding:16px 30px;}
.btn-sm{font-size:13.5px; padding:9px 16px; gap:6px;}
.btn-sm svg{width:15px; height:15px;}
.btn-block{width:100%;}
.btn-danger{background:var(--error); color:#fff;}
.btn-danger:hover{background:#9c1414;}
.btn-icon{padding:10px; border-radius:var(--r-full);}
.btn:disabled{opacity:.5; cursor:not-allowed; transform:none;}

/* ---------- Cards ---------- */
.card{background:#fff; border-radius:var(--r-2xl); box-shadow:var(--sh-sm);
  border:1px solid rgba(199,197,210,.4); transition:transform .2s ease, box-shadow .25s ease;}
.card-pad{padding:28px;}
.card-hover:hover{transform:translateY(-4px); box-shadow:var(--sh-lg);}

/* ---------- Chips / badges ---------- */
.chip{display:inline-flex; align-items:center; gap:6px; font-weight:700; font-size:13px;
  border-radius:var(--r-full); padding:6px 13px; background:#fff; color:var(--ink-variant);
  border:1px solid var(--outline-variant); cursor:pointer; transition:all .15s ease; white-space:nowrap;}
.chip svg{width:15px; height:15px;}
.chip:hover{border-color:var(--periwinkle);}
.chip.active{background:var(--periwinkle-deep); color:#fff; border-color:var(--periwinkle-deep);}
.badge{display:inline-flex; align-items:center; gap:5px; font-weight:800; font-size:11.5px;
  letter-spacing:.03em; text-transform:uppercase; border-radius:var(--r-full); padding:4px 10px;}
.badge svg{width:13px; height:13px;}
.badge-peri{background:var(--periwinkle-soft); color:var(--periwinkle-ink);}
.badge-sky{background:#dcefff; color:var(--teal);}
.badge-success{background:var(--success-soft); color:var(--success);}
.badge-warning{background:var(--warning-soft); color:var(--warning);}
.badge-error{background:var(--error-soft); color:var(--on-error-container,#93000a);}
.badge-muted{background:var(--surface-high); color:var(--ink-variant);}
.badge-live{background:var(--success-soft); color:var(--success);}
.badge-draft{background:var(--surface-high); color:var(--ink-muted);}

/* ---------- Forms ---------- */
.field{display:flex; flex-direction:column; gap:7px; margin-bottom:18px;}
.field label{font-weight:700; font-size:13.5px; color:var(--ink-slate);}
.field .hint{font-size:12.5px; color:var(--ink-muted);}
.input, .select, textarea.input{
  font-family:var(--font); font-size:15px; color:var(--ink-slate);
  background:var(--field-bg); border:2px solid transparent; border-radius:var(--r-lg);
  padding:13px 15px; width:100%; transition:border-color .15s, box-shadow .15s, background .15s;}
.input::placeholder{color:var(--ink-muted);}
.input:focus, .select:focus, textarea.input:focus{
  outline:none; border-color:var(--periwinkle); background:#fff; box-shadow:var(--focus);}
.select{appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23777682' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 13px center; padding-right:40px;}
textarea.input{resize:vertical; min-height:110px; line-height:1.6;}
.input-icon{position:relative;}
.input-icon svg{position:absolute; left:14px; top:50%; transform:translateY(-50%); width:18px; height:18px; color:var(--ink-muted);}
.input-icon .input{padding-left:42px;}
/* address finder (UI.mountAddressFinder) */
.addr-find{position:relative;}
.addr-row{display:grid; grid-template-columns:1fr auto; gap:10px;}
.addr-results{margin-top:8px; border:1px solid var(--outline-variant); border-radius:var(--r-lg); overflow:hidden; background:#fff; box-shadow:var(--sh-sm); max-height:280px; overflow-y:auto;}
.addr-results .ar{padding:11px 15px; font-size:14px; cursor:pointer; border-bottom:1px solid var(--surface-high); display:flex; align-items:center; gap:10px; transition:background .12s;}
.addr-results .ar:last-child{border-bottom:none;}
.addr-results .ar:hover{background:var(--sky-bg);}
.addr-results .ar svg{width:16px; height:16px; color:var(--periwinkle-deep); flex-shrink:0;}
.addr-count{font-size:12px; color:var(--ink-muted); padding:8px 15px; background:var(--surface); font-weight:700; display:flex; align-items:center; gap:6px;}
.manual-link{font-size:12.5px; font-weight:700; color:var(--periwinkle-deep); cursor:pointer; margin-top:8px; display:inline-block;}
.checkbox{display:flex; align-items:flex-start; gap:10px; font-size:14px; color:var(--ink-variant); cursor:pointer;}
.checkbox input{margin-top:2px; width:18px; height:18px; accent-color:var(--periwinkle-deep); flex-shrink:0;}

/* ---------- Wavy section divider ---------- */
.wave{display:block; width:100%; height:auto; line-height:0;}

/* ---------- Stat block ---------- */
.stat{text-align:center;}
.stat .num{font-size:clamp(34px,4vw,46px); font-weight:300; color:var(--periwinkle-deep); line-height:1; letter-spacing:-.01em;}
.stat .scribble-bar{width:64px; height:7px; margin:14px auto 12px;
  background:no-repeat center/100% 100% url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 8' fill='none'%3E%3Cpath d='M3 4.5C30 2 60 2 90 4C103 5 110 5 117 3.5' stroke='%237db0d1' stroke-width='4' stroke-linecap='round'/%3E%3C/svg%3E");}
.stat .lbl{font-size:13.5px; font-weight:700; color:var(--ink-slate);}
.stat .sub{font-size:12.5px; color:var(--ink-muted);}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto; border-radius:var(--r-xl); border:1px solid var(--outline-variant); background:#fff;}
table.data{width:100%; border-collapse:collapse; font-size:14px; min-width:560px;}
table.data th{text-align:left; font-size:11.5px; font-weight:800; letter-spacing:.05em; text-transform:uppercase;
  color:var(--ink-muted); padding:14px 18px; border-bottom:1px solid var(--outline-variant); white-space:nowrap;}
table.data td{padding:15px 18px; border-bottom:1px solid var(--surface-high); color:var(--ink-slate); vertical-align:middle;}
table.data tr:last-child td{border-bottom:none;}
table.data tbody tr{transition:background .12s;}
table.data tbody tr:hover{background:var(--sky-bg);}
.t-strong{font-weight:700; color:var(--ink);}

/* ---------- Avatar ---------- */
.avatar{width:40px; height:40px; border-radius:var(--r-full); background:var(--periwinkle-soft); color:var(--periwinkle-ink);
  display:inline-flex; align-items:center; justify-content:center; font-weight:800; font-size:15px; flex-shrink:0; overflow:hidden;}
.avatar.sm{width:30px; height:30px; font-size:12px;}
.avatar.lg{width:64px; height:64px; font-size:24px;}

/* ---------- Progress ---------- */
.progress{height:8px; background:var(--surface-high); border-radius:var(--r-full); overflow:hidden;}
.progress > span{display:block; height:100%; background:linear-gradient(90deg,var(--periwinkle),var(--periwinkle-deep)); border-radius:var(--r-full); transition:width .6s ease;}

/* ---------- Toast ---------- */
#toast-host{position:fixed; bottom:24px; left:50%; transform:translateX(-50%); z-index:1000; display:flex; flex-direction:column; gap:10px; align-items:center;}
.toast{background:var(--ink); color:#fff; font-weight:600; font-size:14px; padding:13px 20px; border-radius:var(--r-full);
  box-shadow:var(--sh-lg); display:flex; align-items:center; gap:10px; animation:toastin .3s ease;}
.toast svg{width:18px; height:18px;}
.toast.success{background:var(--success);}
.toast.error{background:var(--error);}
@keyframes toastin{from{opacity:0; transform:translateY(12px);}to{opacity:1; transform:translateY(0);}}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed; inset:0; background:rgba(25,28,30,.45); backdrop-filter:blur(3px); z-index:900;
  display:flex; align-items:center; justify-content:center; padding:24px; animation:fade .2s ease;}
.modal{background:#fff; border-radius:var(--r-2xl); box-shadow:var(--sh-xl); max-width:520px; width:100%;
  max-height:90vh; overflow-y:auto; animation:modalin .28s cubic-bezier(.2,.8,.2,1);}
.modal-lg{max-width:760px;}
.modal-head{padding:24px 28px 0; display:flex; align-items:flex-start; justify-content:space-between;}
.modal-body{padding:18px 28px 28px;}
@keyframes modalin{from{opacity:0; transform:translateY(20px) scale(.97);}to{opacity:1; transform:none;}}
@keyframes fade{from{opacity:0;}to{opacity:1;}}

/* ---------- Reveal-on-scroll ----------
   Default = VISIBLE. JS adds .armed to below-the-fold elements only,
   then removes it (with transition) as they scroll in. Guarantees
   content is never stuck hidden (offscreen throttle / print / no-JS). */
.reveal{opacity:1; transform:none; transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1);}
.reveal.armed{opacity:0; transform:translateY(26px);}
@media (prefers-reduced-motion:reduce){.reveal.armed{opacity:1; transform:none;}}

/* ============================================================
   PUBLIC SITE NAV + FOOTER
   ============================================================ */
.nav{position:sticky; top:0; z-index:500; background:rgba(255,255,255,.82); backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(199,197,210,.35); transition:box-shadow .25s;}
.nav.scrolled{box-shadow:var(--sh-sm);}
.nav-inner{max-width:var(--maxw); margin:0 auto; padding:14px 24px; display:flex; align-items:center; gap:28px;}
.nav-logo{display:flex; align-items:center; gap:10px; flex-shrink:0;}
.nav-logo img{height:42px; width:auto;}
.nav-links{display:flex; align-items:center; gap:6px; margin-left:8px;}
.nav-links a{font-weight:700; font-size:14.5px; color:var(--ink-slate); padding:9px 14px; border-radius:var(--r-lg); transition:all .15s; position:relative;}
.nav-links a:hover{background:var(--surface-low); color:var(--periwinkle-deep);}
.nav-links a.active{color:var(--periwinkle-deep);}
.nav-spacer{flex:1;}
.nav-actions{display:flex; align-items:center; gap:10px;}
.nav-burger{display:none; background:none; border:none; cursor:pointer; padding:8px; color:var(--ink-slate); border-radius:var(--r-lg); -webkit-tap-highlight-color:transparent;}
.nav-burger svg{width:28px; height:28px;}

/* ---- Mobile slide-in menu (rendered at body level) ---- */
.mobile-menu{display:none;}
.mobile-menu.open{display:flex; flex-direction:column; position:fixed; inset:0; z-index:900;
  background:#fff; overflow-y:auto; -webkit-overflow-scrolling:touch; animation:mmIn .22s ease;}
@keyframes mmIn{from{opacity:0; transform:translateY(-8px);} to{opacity:1; transform:none;}}
.mobile-menu .mm-head{display:flex; align-items:center; justify-content:space-between; padding:14px 20px;
  border-bottom:1px solid var(--surface-high); position:sticky; top:0; background:#fff;}
.mobile-menu .mm-head .nav-logo img{height:40px;}
.mobile-menu .mm-close{width:46px; height:46px; border:none; border-radius:var(--r-full); background:var(--surface-low);
  display:flex; align-items:center; justify-content:center; cursor:pointer; color:var(--ink-slate); -webkit-tap-highlight-color:transparent;}
.mobile-menu .mm-links{display:flex; flex-direction:column; padding:14px 14px 4px; flex:1;}
.mobile-menu .mm-links a{display:flex; align-items:center; justify-content:space-between; gap:10px;
  font-size:19px; font-weight:800; color:var(--ink-slate); padding:17px 16px; border-radius:var(--r-xl);}
.mobile-menu .mm-links a svg{color:var(--ink-muted);}
.mobile-menu .mm-links a:active,.mobile-menu .mm-links a.active{background:var(--periwinkle-soft); color:var(--periwinkle-deep);}
.mobile-menu .mm-links a.active svg{color:var(--periwinkle-deep);}
.mobile-menu .mm-actions{display:flex; flex-direction:column; gap:12px; padding:18px 22px calc(28px + env(safe-area-inset-bottom));
  border-top:1px solid var(--surface-high);}
.mobile-menu .mm-actions .btn{width:100%; justify-content:center; padding:15px; font-size:16px;}
body.menu-open{overflow:hidden;}

footer.site-footer{background:linear-gradient(180deg,#fff, var(--sky-bg)); border-top:1px solid rgba(199,197,210,.4); padding:72px 0 28px; margin-top:0;}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1.4fr; gap:40px;}
.footer-col h4{font-size:15px; font-weight:800; color:var(--ink-slate); margin-bottom:16px;}
.footer-col a{display:block; color:var(--ink-variant); font-size:14px; padding:6px 0; transition:color .15s;}
.footer-col a:hover{color:var(--periwinkle-deep);}
.footer-bottom{border-top:1px solid var(--outline-variant); margin-top:48px; padding-top:24px;
  display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; font-size:13px; color:var(--ink-muted);}
.social{display:flex; gap:10px;}
.social a{width:38px; height:38px; border-radius:var(--r-full); background:#fff; box-shadow:var(--sh-xs);
  display:flex; align-items:center; justify-content:center; color:var(--periwinkle-deep); transition:all .18s;}
.social a:hover{background:var(--periwinkle-deep); color:#fff; transform:translateY(-2px);}
.social svg{width:18px; height:18px;}

/* ============================================================
   APP SHELL (portals / admin)
   ============================================================ */
.app{display:grid; grid-template-columns:264px 1fr; min-height:100vh; background:var(--surface);}
.sidebar{background:#fff; border-right:1px solid var(--outline-variant); padding:22px 16px; position:sticky; top:0; height:100vh; overflow-y:auto; display:flex; flex-direction:column;}
.sidebar-logo{display:flex; align-items:center; gap:9px; padding:6px 10px 22px;}
.sidebar-logo img{height:36px;}
.side-section{font-size:11px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-muted); padding:18px 12px 8px;}
.side-link{display:flex; align-items:center; gap:12px; padding:11px 13px; border-radius:var(--r-lg); color:var(--ink-slate);
  font-weight:700; font-size:14.5px; cursor:pointer; transition:all .14s; margin-bottom:2px;}
.side-link span{white-space:nowrap;}
.side-link svg{width:19px; height:19px; color:var(--ink-muted); transition:color .14s; flex-shrink:0;}
.side-link:hover{background:var(--surface-low);}
.side-link.active{background:var(--periwinkle-soft); color:var(--periwinkle-ink);}
.side-link.active svg{color:var(--periwinkle-deep);}
.side-badge{margin-left:auto; background:var(--periwinkle-deep); color:#fff; font-size:11px; font-weight:800; border-radius:var(--r-full); padding:2px 8px;}
.app-main{display:flex; flex-direction:column; min-width:0;}
.topbar{background:rgba(255,255,255,.85); backdrop-filter:blur(12px); border-bottom:1px solid var(--outline-variant);
  padding:16px 32px; display:flex; align-items:center; gap:18px; position:sticky; top:0; z-index:100;}
.topbar h1{font-size:22px; margin:0;}
.topbar-spacer{flex:1;}
.content{padding:32px; max-width:1280px; width:100%;}
.app-burger{display:none; background:none; border:none; cursor:pointer; color:var(--ink-slate); padding:6px;}
.app-burger svg{width:26px; height:26px;}

/* metric cards */
.metrics{display:grid; grid-template-columns:repeat(4,1fr); gap:20px;}
.metric{background:#fff; border-radius:var(--r-xl); padding:22px; border:1px solid var(--outline-variant); position:relative; overflow:hidden;}
.metric .mlabel{font-size:13px; font-weight:700; color:var(--ink-muted); display:flex; align-items:center; gap:8px;}
.metric .mlabel svg{width:17px; height:17px;}
.metric .mval{font-size:clamp(22px,2.2vw,30px); font-weight:800; color:var(--ink-slate); margin-top:10px; letter-spacing:-.02em; white-space:nowrap;}
.metric .mtrend{font-size:12.5px; font-weight:700; margin-top:6px; display:inline-flex; align-items:center; gap:4px;}
.mtrend.up{color:var(--success);} .mtrend.down{color:var(--error);}
.metric .micon{position:absolute; right:-8px; top:-8px; width:78px; height:78px; border-radius:var(--r-full); background:var(--periwinkle-soft); opacity:.45;}

/* clickable metric tiles */
a.metric-link{text-decoration:none; display:block; transition:transform .18s ease, box-shadow .2s ease, border-color .2s;}
a.metric-link:hover{transform:translateY(-3px); box-shadow:var(--sh-md); border-color:var(--periwinkle);}
a.metric-link .m-go{position:absolute; right:14px; bottom:14px; color:var(--ink-muted); opacity:0; transition:opacity .18s;}
a.metric-link:hover .m-go{opacity:1; color:var(--periwinkle-deep);}

/* ---------- Charts (Portal.charts) ---------- */
.ch{width:100%; height:auto; display:block;}
.ch-bar{transition:opacity .15s;} .ch-bar:hover{opacity:.82;}
.ch-legend{display:flex; gap:18px; flex-wrap:wrap; margin:0 0 6px; font-size:12.5px; font-weight:700; color:var(--ink-variant);}
.ch-legend i{display:inline-block; width:10px; height:10px; border-radius:3px; margin-right:6px;}
.hbars{display:flex; flex-direction:column; gap:14px;}
.hb{display:block; text-decoration:none;}
a.hb{border-radius:var(--r-lg); padding:6px 8px; margin:-6px -8px; transition:background .15s;}
a.hb:hover{background:var(--sky-bg);}
.hb-top{display:flex; justify-content:space-between; gap:12px; font-size:13.5px; margin-bottom:6px;}
.hb-label{font-weight:700; color:var(--ink-slate); min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.hb-val{font-weight:800; color:var(--ink); white-space:nowrap;}
.hb-val em{font-style:normal; font-weight:700; font-size:11.5px; color:var(--ink-muted);}
.hb-track{height:9px; background:var(--surface-high); border-radius:var(--r-full); overflow:hidden;}
.hb-track span{display:block; height:100%; border-radius:var(--r-full); background:linear-gradient(90deg,var(--periwinkle),var(--periwinkle-deep)); transition:width .8s cubic-bezier(.2,.8,.2,1);}
.donut-wrap{display:flex; gap:22px; align-items:center; flex-wrap:wrap;}
.donut-svg{position:relative; flex-shrink:0;}
.donut-centre{position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; pointer-events:none;}
.donut-centre .dc-v{font-size:26px; font-weight:800; color:var(--ink-slate); letter-spacing:-.02em;}
.donut-centre .dc-s{font-size:11px; font-weight:700; color:var(--ink-muted);}
.donut-key{display:flex; flex-direction:column; gap:8px; font-size:13px; font-weight:600; color:var(--ink-variant); min-width:0;}
.donut-key i{display:inline-block; width:10px; height:10px; border-radius:3px; margin-right:7px;}
.donut-key b{color:var(--ink);}

/* action centre rows (admin dashboard) */
.act-row{display:flex; align-items:center; gap:12px; padding:11px 12px; border-radius:var(--r-lg); text-decoration:none; transition:background .14s;}
.act-row:hover{background:var(--sky-bg);}
.act-row .ai{width:36px; height:36px; border-radius:var(--r-lg); display:flex; align-items:center; justify-content:center; flex-shrink:0;}
.act-row .at{font-weight:700; font-size:13.5px; color:var(--ink); line-height:1.3;}
.act-row .as{font-size:12px; color:var(--ink-muted);}
.act-row .an{margin-left:auto; flex-shrink:0; display:flex; align-items:center; gap:8px;}
.act-row .count{min-width:26px; height:26px; border-radius:var(--r-full); display:inline-flex; align-items:center; justify-content:center; font-size:12.5px; font-weight:800; padding:0 8px;}
.act-row .chev{color:var(--ink-muted); display:flex;}

/* ---------- Communications composer (Comms.composeModal) ---------- */
.cmp .cmp-count{font-size:12.5px; font-weight:700; color:var(--ink-variant); margin-top:9px; display:flex; align-items:center; gap:6px; min-height:18px;}
.cmp .cmp-count b{color:var(--periwinkle-deep);}
.cmp-results{margin-top:8px; border:1px solid var(--outline-variant); border-radius:var(--r-lg); background:#fff; box-shadow:var(--sh-md); overflow:hidden; max-height:264px; overflow-y:auto;}
.cmp-res{display:flex; align-items:center; gap:11px; width:100%; text-align:left; border:none; background:none; padding:10px 13px;
  cursor:pointer; font-family:var(--font); border-bottom:1px solid var(--surface-high); transition:background .12s;}
.cmp-res:last-child{border-bottom:none;}
.cmp-res:hover{background:var(--sky-bg);}
.cmp-res .ri{width:30px; height:30px; border-radius:var(--r-lg); background:var(--periwinkle-soft); color:var(--periwinkle-deep); display:flex; align-items:center; justify-content:center; flex-shrink:0;}
.cmp-res b{display:block; font-size:13.5px; color:var(--ink); font-weight:700;}
.cmp-res i{display:block; font-style:normal; font-size:11.5px; color:var(--ink-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.cmp-res .ra{margin-left:auto; color:var(--ink-muted); display:flex;}
.cmp-res.has .ra{color:var(--success);}
.cmp-chips{display:flex; flex-wrap:wrap; gap:7px; margin-top:10px;}
.cmp-chip{display:inline-flex; align-items:center; gap:7px; background:var(--periwinkle-soft); color:var(--periwinkle-ink);
  border-radius:var(--r-full); padding:6px 8px 6px 13px; font-size:12.5px; font-weight:800;}
.cmp-chip button{border:none; background:rgba(255,255,255,.55); color:var(--periwinkle-ink); width:18px; height:18px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .15s;}
.cmp-chip button:hover{background:#fff;}
.cmp-tags{display:flex; align-items:center; gap:7px; flex-wrap:wrap; margin-top:9px;}
.cmp-chans{display:flex; gap:10px;}
.cmp-chan{display:inline-flex; align-items:center; gap:8px; border:2px solid var(--outline-variant); background:#fff; border-radius:var(--r-full);
  padding:9px 18px; font-family:var(--font); font-size:13.5px; font-weight:800; color:var(--ink-muted); cursor:pointer; transition:all .15s;}
.cmp-chan .tick{display:none; width:18px; height:18px; border-radius:50%; background:var(--success); color:#fff; align-items:center; justify-content:center;}
.cmp-chan.active{border-color:var(--periwinkle-deep); color:var(--periwinkle-ink); background:var(--periwinkle-wash);}
.cmp-chan.active .tick{display:inline-flex;}
.cmp .chip.active{background:var(--periwinkle-deep); color:#fff; border-color:var(--periwinkle-deep);}
.cmp-prev{border:1px solid var(--outline-variant); border-radius:var(--r-lg); background:var(--sky-bg); padding:14px 16px; margin-top:2px;}
.cmp-prev .pv-head{font-size:11px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--teal); display:flex; align-items:center; gap:6px; margin-bottom:9px;}
.cmp-prev .pv-subj{font-weight:800; font-size:15px; color:var(--ink); margin-bottom:8px;}
.cmp-prev .pv-body{font-size:13.5px; color:var(--ink-slate); line-height:1.65;}

/* ---------- Org quick-book (OrgBook.quickBook) ---------- */
.qb-step{margin-bottom:16px;}
.qb-label{display:flex; align-items:center; gap:8px; font-size:12px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--periwinkle-deep); margin-bottom:9px;}
.qb-team{display:grid; grid-template-columns:1fr 1fr; gap:8px; max-height:218px; overflow-y:auto; padding:2px;}
.qb-member{display:flex; align-items:center; gap:10px; border:2px solid var(--outline-variant); border-radius:var(--r-lg); padding:9px 11px; cursor:pointer; transition:all .15s; background:#fff; position:relative;}
.qb-member input{position:absolute; opacity:0; pointer-events:none;}
.qb-member b{display:block; font-size:13px; color:var(--ink); font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.qb-member i{display:block; font-style:normal; font-size:11px; color:var(--ink-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.qb-member .qb-tick{margin-left:auto; width:20px; height:20px; border-radius:50%; background:var(--surface-high); color:#fff; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:background .15s;}
.qb-member.on{border-color:var(--periwinkle-deep); background:var(--periwinkle-wash);}
.qb-member.on .qb-tick{background:var(--success);}
.qb-dates{display:grid; grid-template-columns:1fr 1fr; gap:8px; max-height:240px; overflow-y:auto; padding:2px;}
.qb-date{border:2px solid var(--outline-variant); border-radius:var(--r-lg); background:#fff; padding:11px 13px; text-align:left; cursor:pointer; font-family:var(--font); transition:all .15s;}
.qb-date b{display:block; font-size:13.5px; color:var(--ink); font-weight:800;}
.qb-date i{display:block; font-style:normal; font-size:11.5px; color:var(--ink-muted); margin-top:2px;}
.qb-date .qb-seats{display:inline-block; margin-top:7px; font-size:10.5px; font-weight:800; padding:3px 9px; border-radius:var(--r-full); background:var(--success-soft); color:var(--success-deep);}
.qb-date .qb-seats.low{background:var(--warning-soft); color:var(--warning);}
.qb-date.on{border-color:var(--periwinkle-deep); background:var(--periwinkle-wash);}
.qb-date.full{opacity:.55; cursor:not-allowed;}
.qb-date.full .qb-seats{background:var(--surface-high); color:var(--ink-muted);}
.qb-summary{background:var(--sky-bg); border:1px solid var(--sky-container); border-radius:var(--r-lg); padding:13px 16px;}
.qb-sumrow{display:flex; justify-content:space-between; font-size:14px; font-weight:700; color:var(--ink-slate); margin-bottom:4px;}
.qb-sumrow b{font-size:17px; color:var(--periwinkle-deep);}
.qb-date .qb-seats.soon{background:var(--warning-soft); color:var(--warning); margin-left:5px;}
.qb-warn{display:flex; gap:9px; align-items:flex-start; margin-top:10px; padding:11px 14px; border-radius:var(--r-lg); background:var(--warning-soft); border:1px solid #f0d59a; color:#7a4d00; font-size:13px; font-weight:600; line-height:1.5;}
.qb-warn svg{flex-shrink:0; margin-top:2px;}
@media (max-width:600px){ .qb-team,.qb-dates{grid-template-columns:1fr;} }

/* ---------- In-app inbox (portal bell) ---------- */
.bell-wrap{position:relative;}
.bell-btn{background:var(--surface-low); border:none; cursor:pointer; position:relative; width:40px; height:40px; border-radius:var(--r-full);
  display:flex; align-items:center; justify-content:center; color:var(--ink-slate); transition:background .15s;}
.bell-btn:hover{background:var(--periwinkle-soft); color:var(--periwinkle-deep);}
.bell-count{position:absolute; top:-4px; right:-4px; min-width:18px; height:18px; border-radius:var(--r-full); background:var(--error);
  color:#fff; font-size:10.5px; font-weight:800; display:flex; align-items:center; justify-content:center; padding:0 5px; border:2px solid #fff;}
.bell-panel{position:absolute; right:0; top:50px; width:min(400px, calc(100vw - 40px)); background:#fff; border:1px solid var(--outline-variant);
  border-radius:var(--r-xl); box-shadow:var(--sh-xl); z-index:700; overflow:hidden; animation:modalin .25s cubic-bezier(.2,.8,.2,1);}
.bell-panel .bp-head{padding:14px 18px; border-bottom:1px solid var(--surface-high); font-weight:800; font-size:14px; color:var(--ink); display:flex; justify-content:space-between; align-items:center;}
.bell-panel .bp-list{max-height:420px; overflow-y:auto;}
.bp-msg{padding:14px 18px; border-bottom:1px solid var(--surface-high); cursor:pointer; transition:background .12s;}
.bp-msg:hover{background:var(--sky-bg);}
.bp-msg:last-child{border-bottom:none;}
.bp-msg .bm-top{display:flex; justify-content:space-between; gap:10px; align-items:flex-start;}
.bp-msg .bm-subj{font-weight:800; font-size:13.5px; color:var(--ink); line-height:1.35;}
.bp-msg.unread .bm-subj::before{content:""; display:inline-block; width:8px; height:8px; border-radius:50%; background:var(--periwinkle-deep); margin-right:7px; vertical-align:1px;}
.bp-msg .bm-date{font-size:11px; color:var(--ink-muted); font-weight:700; white-space:nowrap;}
.bp-msg .bm-body{font-size:12.5px; color:var(--ink-variant); line-height:1.55; margin-top:5px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;}
.bp-msg.open .bm-body{display:block; -webkit-line-clamp:unset;}
.bell-empty{padding:30px 18px; text-align:center; color:var(--ink-muted); font-size:13px;}

/* section card for portal pages */
.panel{background:#fff; border-radius:var(--r-xl); border:1px solid var(--outline-variant); overflow:hidden;}
.panel-head{padding:18px 22px; border-bottom:1px solid var(--surface-high); display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;}
.panel-head h3{margin:0; font-size:17px;}
.panel-body{padding:22px;}

/* tabs */
.tabs{display:flex; gap:4px; border-bottom:1px solid var(--outline-variant); margin-bottom:24px; overflow-x:auto;}
.tab{padding:12px 18px; font-weight:700; font-size:14.5px; color:var(--ink-muted); cursor:pointer; border-bottom:2px solid transparent; white-space:nowrap; transition:all .15s;}
.tab:hover{color:var(--ink-slate);}
.tab.active{color:var(--periwinkle-deep); border-bottom-color:var(--periwinkle-deep);}

/* empty state */
.empty{text-align:center; padding:56px 24px; color:var(--ink-muted);}
.empty svg{width:46px; height:46px; color:var(--outline-variant); margin-bottom:14px;}

/* segmented */
.seg{display:inline-flex; background:var(--surface-low); border-radius:var(--r-full); padding:4px; gap:2px;}
.seg button{border:none; background:none; font-weight:700; font-size:13.5px; color:var(--ink-muted); padding:8px 16px; border-radius:var(--r-full); cursor:pointer; transition:all .15s;}
.seg button.active{background:#fff; color:var(--periwinkle-deep); box-shadow:var(--sh-xs);}

/* ---------- Responsive ---------- */
@media (max-width:920px){
  .nav-links{display:none;}
  .nav-actions{display:none;}
  .nav-burger{display:block;}
  .nav-inner{padding:12px 18px; gap:12px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .metrics{grid-template-columns:repeat(2,1fr);}
  .app{grid-template-columns:1fr;}
  .sidebar{position:fixed; left:0; top:0; z-index:600; transform:translateX(-100%); transition:transform .25s; width:min(284px,86vw); box-shadow:var(--sh-xl);}
  .sidebar.open{transform:none;}
  .app-burger{display:block;}
  /* dim the content behind the open sidebar */
  body:has(.sidebar.open)::after{content:""; position:fixed; inset:0; background:rgba(22,22,45,.42); z-index:550; animation:fade .2s ease;}
  /* topbar tightening for mobile */
  .topbar{padding:13px 16px; gap:10px;}
  .topbar h1{font-size:19px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0;}
  .topbar .avatar{display:none;}   /* the user avatar already lives in the sidebar */
  .topbar > div:last-child{gap:10px !important;}
}
@media (max-width:600px){
  .wrap,.wrap-sm{padding:0 18px;}
  .footer-grid{grid-template-columns:1fr; gap:30px;}
  .footer-bottom{flex-direction:column; gap:14px; text-align:left;}
  .footer-bottom > div{text-align:left !important;}
  .metrics{grid-template-columns:1fr;}
  .section{padding:56px 0;}
  .section-sm{padding:36px 0;}
  .content{padding:18px;}
  .topbar{padding:13px 16px; gap:12px;}
  .topbar h1{font-size:19px;}
  .modal{padding:22px 20px; border-radius:20px 20px 0 0;}
  .modal-overlay{align-items:flex-end; padding:0;}
  .btn-lg{padding:14px 22px; font-size:15.5px;}
}

/* ============================================================
   LEGAL / POLICY PAGES
   ============================================================ */
.legal-hero{background:linear-gradient(180deg,var(--sky-bg),#fff); padding:56px 0 36px;}
.legal-meta{display:flex; gap:18px; flex-wrap:wrap; margin-top:16px; font-size:13.5px; color:var(--ink-muted); font-weight:600;}
.legal-meta span{display:inline-flex; align-items:center; gap:7px;}
.legal-meta svg{width:15px; height:15px; color:var(--periwinkle-deep);}
.legal-layout{display:grid; grid-template-columns:248px 1fr; gap:56px; align-items:start; padding:48px 0 96px;}
.legal-toc{position:sticky; top:90px;}
.legal-toc .toc-title{font-size:11.5px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:14px;}
.legal-toc a{display:block; font-size:13.5px; font-weight:600; color:var(--ink-variant); padding:7px 12px; border-left:2px solid var(--surface-high); transition:all .15s; line-height:1.4;}
.legal-toc a:hover{color:var(--periwinkle-deep); border-left-color:var(--periwinkle);}
.legal-toc a.active{color:var(--periwinkle-deep); border-left-color:var(--periwinkle-deep); background:var(--periwinkle-soft);}
.legal-body{max-width:760px; min-width:0;}
.legal-body h2{font-size:23px; margin:40px 0 14px; scroll-margin-top:90px;}
.legal-body h2:first-child{margin-top:0;}
.legal-body h3{font-size:17px; margin:24px 0 10px;}
.legal-body p, .legal-body li{font-size:15.5px; line-height:1.7; color:var(--ink-slate);}
.legal-body ul{padding-left:22px; margin:0 0 1em;}
.legal-body li{margin-bottom:7px;}
.legal-body strong{color:var(--ink); font-weight:700;}
.legal-body a{color:var(--periwinkle-deep); font-weight:700; text-decoration:underline; text-underline-offset:2px;}
.legal-body hr{border:none; border-top:1px solid var(--outline-variant); margin:32px 0;}
.legal-intro{background:var(--sky-bg); border-radius:var(--r-xl); padding:22px 24px; margin-bottom:8px; font-size:15px; color:var(--ink-slate);}
.legal-callout{background:var(--periwinkle-soft); border-radius:var(--r-xl); padding:20px 24px; margin:24px 0;}
.legal-callout strong{color:var(--periwinkle-ink);}
.legal-table-wrap{overflow-x:auto; border:1px solid var(--outline-variant); border-radius:var(--r-xl); margin:20px 0;}
table.legal-table{width:100%; border-collapse:collapse; font-size:13.5px; min-width:680px;}
table.legal-table th{text-align:left; background:var(--surface-low); font-size:11.5px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-variant); padding:12px 16px; border-bottom:1px solid var(--outline-variant);}
table.legal-table td{padding:13px 16px; border-bottom:1px solid var(--surface-high); color:var(--ink-slate); vertical-align:top; line-height:1.5;}
table.legal-table tr:last-child td{border-bottom:none;}
table.legal-table td:first-child{font-weight:700; color:var(--ink); white-space:nowrap;}
.legal-contact{background:#fff; border:1px solid var(--outline-variant); border-radius:var(--r-xl); padding:24px; margin-top:28px;}
.legal-related{display:flex; gap:12px; flex-wrap:wrap; margin-top:24px;}
.legal-related a{display:inline-flex; align-items:center; gap:8px; font-size:13.5px; font-weight:700; color:var(--periwinkle-deep); background:var(--periwinkle-soft); padding:10px 16px; border-radius:var(--r-full); text-decoration:none; transition:all .15s;}
.legal-related a:hover{background:#d6d3ff; transform:translateY(-1px);}
.legal-related svg{width:15px; height:15px;}
@media (max-width:900px){
  .legal-layout{grid-template-columns:1fr; gap:0; padding-top:28px;}
  .legal-toc{display:none;}
}
