/* ============================================================
   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;}
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;}
.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);}
.nav-burger svg{width:26px; height:26px;}
.mobile-menu{display:none;}

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;}

/* 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-burger{display:block;}
  .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:264px; box-shadow:var(--sh-xl);}
  .sidebar.open{transform:none;}
  .app-burger{display:block;}
  .mobile-menu.open{display:block; position:fixed; inset:0; top:71px; background:#fff; z-index:480; padding:24px;}
  .mobile-menu.open a{display:block; font-size:18px; font-weight:700; padding:14px 0; border-bottom:1px solid var(--surface-high);}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr;}
  .metrics{grid-template-columns:1fr;}
  .section{padding:64px 0;}
  .content{padding:20px;}
  .topbar{padding:14px 18px;}
}

/* ============================================================
   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;}
}
