:root{
  --ink:#161d33; --terra:#c56b45; --sage:#7d9b6a; --cream:#f8f1e3; --gold:#e2a349;
  --line:#e4ddcf; --muted:#6b6555; --paper:#fffdf8; --bad:#b23b3b; --good:#4f7a3f;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Nunito Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);background:var(--cream);line-height:1.5}
a{color:var(--terra);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}
h1,h2,h3{font-family:Fraunces,Georgia,serif;font-weight:600;line-height:1.2;color:var(--ink)}
h1{font-size:1.7rem;margin:24px 0 6px}
h2{font-size:1.25rem;margin:26px 0 10px}

/* top bar + responsive nav */
.topbar{position:sticky;top:0;z-index:40;background:linear-gradient(180deg,#1b2340,#161d33);color:#fff;box-shadow:0 2px 14px rgba(22,29,51,.20)}
.topbar .bar{display:flex;align-items:center;gap:18px;min-height:60px}
.logo{color:#fff;font-family:Fraunces,serif;font-weight:600;font-size:1.14rem;white-space:nowrap;letter-spacing:.01em}
.logo span{color:var(--gold)}
.mainnav{display:flex;gap:4px;flex:1;flex-wrap:wrap;align-items:center}
.navlink{color:#c9d2e6;font-weight:700;font-size:.9rem;padding:8px 12px;border-radius:9px;transition:background .15s,color .15s}
.navlink:hover{color:#fff;background:rgba(255,255,255,.09);text-decoration:none}
.navlink.on{color:var(--ink);background:var(--gold)}
.navlink.out{margin-left:auto;color:#f0c9b6}
.navtoggle{display:none}
.hamb{display:none}
.navscrim{display:none}
@media(max-width:860px){
  .mainnav{position:fixed;top:0;right:0;height:100dvh;width:80%;max-width:310px;background:linear-gradient(180deg,#1b2340,#141a2e);
    flex-direction:column;align-items:stretch;gap:4px;padding:66px 16px 24px;flex-wrap:nowrap;overflow-y:auto;
    transform:translateX(106%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:-10px 0 34px rgba(0,0,0,.34);z-index:60}
  .navlink{font-size:1.06rem;padding:13px 14px}
  .navlink.out{margin:10px 0 0;border-top:1px solid rgba(255,255,255,.13);border-radius:0;padding-top:16px}
  .hamb{display:flex;position:fixed;bottom:22px;right:22px;z-index:70;width:58px;height:58px;border-radius:50%;
    background:var(--terra);box-shadow:0 8px 22px rgba(201,119,47,.5);flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer}
  .hamb span{width:25px;height:3px;background:#fff;border-radius:2px;transition:transform .3s,opacity .2s}
  .navscrim{position:fixed;inset:0;background:rgba(18,24,44,.55);z-index:50;opacity:0;pointer-events:none;transition:opacity .3s}
  body:has(.navtoggle:checked) .mainnav{transform:none}
  body:has(.navtoggle:checked) .navscrim{display:block;opacity:1;pointer-events:auto}
  body:has(.navtoggle:checked) .hamb{background:var(--ink)}
  body:has(.navtoggle:checked) .hamb span:nth-child(1){transform:translateY(9px) rotate(45deg)}
  body:has(.navtoggle:checked) .hamb span:nth-child(2){opacity:0}
  body:has(.navtoggle:checked) .hamb span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}
}

/* in-page sub navigation (child/family page) */
.subnav{position:sticky;top:0;z-index:30;display:flex;gap:6px;overflow-x:auto;padding:12px 0;margin:0 0 6px;
  background:var(--cream);-webkit-overflow-scrolling:touch}
.subnav a{white-space:nowrap;font-weight:700;font-size:.85rem;color:var(--muted);background:var(--paper);
  border:1px solid var(--line);padding:7px 13px;border-radius:20px;transition:all .15s}
.subnav a:hover{color:var(--ink);border-color:var(--terra);text-decoration:none}
html{scroll-behavior:smooth}
[id^="sec-"],[id^="child-"]{scroll-margin-top:90px}

/* ===== Admin left sidebar (desktop-first) ===== */
.sidebar{position:fixed;top:0;left:0;width:232px;height:100dvh;z-index:60;display:flex;flex-direction:column;
  background:linear-gradient(180deg,#1b2340,#141a2e);color:#fff;padding:18px 14px;overflow-y:auto;
  box-shadow:2px 0 18px rgba(22,29,51,.14)}
.slogo{display:block;color:#fff;font-family:Fraunces,serif;font-weight:600;font-size:1.16rem;line-height:1.1;padding:6px 10px 18px;letter-spacing:.01em}
.slogo .sub{display:block;color:var(--gold);font-size:.92rem}
.sidenav{display:flex;flex-direction:column;gap:3px}
.sidebar .navlink{display:block;color:#c9d2e6;font-weight:700;font-size:.94rem;padding:11px 13px;border-radius:9px;transition:background .15s,color .15s}
.sidebar .navlink:hover{color:#fff;background:rgba(255,255,255,.09);text-decoration:none}
.sidebar .navlink.on{color:var(--ink);background:var(--gold);box-shadow:0 2px 8px rgba(226,163,73,.35)}
.sidebar .navlink.out{margin-top:auto;color:#f0c9b6;border-top:1px solid rgba(255,255,255,.12);border-radius:0;padding-top:16px}
.mobilebar{display:none}
.appmain{margin-left:232px;padding:28px clamp(20px,3.4vw,44px) 40px;min-height:64vh}
.foot{margin-left:232px}
@media(max-width:860px){
  .sidebar{width:284px;transform:translateX(-108%);transition:transform .3s cubic-bezier(.4,0,.2,1);padding-top:60px}
  body:has(.navtoggle:checked) .sidebar{transform:none}
  .appmain{margin-left:0;padding:20px 16px 96px}
  .foot{margin-left:0}
  .mobilebar{display:flex;position:sticky;top:0;z-index:40;align-items:center;height:54px;padding:0 16px;
    background:linear-gradient(180deg,#1b2340,#161d33);box-shadow:0 2px 12px rgba(22,29,51,.2)}
  .slogo-sm{color:#fff;font-family:Fraunces,serif;font-weight:600;font-size:1.06rem}
  .slogo-sm span{color:var(--gold)}
  .subnav{top:54px}
}

/* cards + tables */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:16px 0}
.card{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:16px}
.card .big{font-size:2rem;font-family:Fraunces,serif;font-weight:600}
.card .lbl{color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.04em}
.cap{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0}
.capday{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:10px 14px;text-align:center;min-width:78px}
.capday b{display:block;font-family:Fraunces,serif;font-size:1.4rem}
.capday.full b{color:var(--bad)}
.capday small{color:var(--muted)}

table{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line);border-radius:12px;overflow:hidden}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);font-size:.94rem;vertical-align:top}
th{background:#efe8d9;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
tr:last-child td{border-bottom:none}

.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.78rem;font-weight:700}
.b-new{background:#e7eef7;color:#2a4a72}
.b-waitlist{background:#fdf0dd;color:#8a5a1e}
.b-offered{background:#efe6f7;color:#5a3a86}
.b-enrolled{background:#e3efdb;color:#3f6a2e}
.b-withdrawn{background:#eee;color:#777}

/* onboarding journey lanes */
.lanes{display:flex;gap:12px;flex-wrap:wrap;margin:6px 0 20px}
.jcard{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:10px;padding:12px 14px;min-width:210px;max-width:260px}
.jname{font-family:Fraunces,serif;font-weight:600;font-size:1.05rem}
.jsub{font-size:.82rem;margin-top:2px}
.jact{margin-top:10px}
.pill{display:inline-block;padding:1px 8px;border:1px solid var(--line);border-radius:20px;font-size:.78rem;margin:1px}
.paid{color:var(--good);font-weight:700}
.owing{color:var(--bad);font-weight:700}

/* forms + buttons */
.btn{display:inline-block;background:var(--terra);color:#fff;border:0;border-radius:9px;
  padding:9px 16px;font-weight:800;font-size:.92rem;cursor:pointer}
.btn:hover{background:#b5691f;text-decoration:none}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.sm{padding:5px 10px;font-size:.82rem}
.field{margin:10px 0}
label{display:block;font-weight:700;font-size:.9rem;margin-bottom:4px}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid #cfc7b6;border-radius:8px;
  font:inherit;background:#fff}
textarea{min-height:70px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.flash{background:#e3efdb;border:1px solid var(--sage);color:#3f6a2e;padding:10px 14px;border-radius:9px;margin:16px 0}
.err{background:#f7e0e0;border:1px solid var(--bad);color:var(--bad);padding:10px 14px;border-radius:9px;margin:12px 0}
.muted{color:var(--muted)}
.section{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:18px;margin:14px 0}
.inline{display:inline}

/* login / setup */
.authbox{max-width:420px;margin:60px auto;background:var(--paper);border:1px solid var(--line);
  border-radius:16px;padding:30px}
.authbox h1{margin-top:0;text-align:center}
.qr{text-align:center;margin:16px 0}
.secretcode{font-family:ui-monospace,Menlo,monospace;background:#efe8d9;
  padding:8px 12px;border-radius:8px;letter-spacing:2px;display:inline-block;word-break:break-all}
/* season planner grid */
.cal{width:100%;border-collapse:collapse;table-layout:fixed;background:var(--paper);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.cal th{background:#efe8d9;font-size:.78rem;padding:8px;text-align:center}
.cal td{border:1px solid var(--line);vertical-align:top;height:58px;padding:5px 6px;font-size:.78rem}
.cal .dnum{font-weight:700;font-size:.82rem}
.cal .dlbl{display:block;font-size:.68rem;line-height:1.15;margin-top:2px}
.d-open{background:#eaf3e2}
.d-holiday{background:#f7e0e0;color:#8a2b2b}
.d-closed{background:#eee;color:#777}
.d-maintenance{background:#fdf0dd;color:#8a5a1e}
.d-break{background:#e7eef7;color:#2a4a72}
.d-na{background:#faf8f3;color:#c9c1ad}
.legend{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.legend span{font-size:.75rem;padding:2px 9px;border-radius:20px}
@media(max-width:640px){.grid2{grid-template-columns:1fr}.cal td{height:auto}}

/* ---- polish pass ---- */
body{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.card,.section{box-shadow:0 1px 2px rgba(22,29,51,.05),0 4px 14px rgba(22,29,51,.05)}
.card{transition:transform .16s ease,box-shadow .16s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(22,29,51,.10)}
.section{border-radius:14px}
.btn{transition:transform .12s ease,background .15s,box-shadow .15s;box-shadow:0 1px 2px rgba(0,0,0,.10)}
.btn:hover{transform:translateY(-1px);box-shadow:0 3px 10px rgba(201,119,47,.28)}
.btn:active{transform:translateY(0)}
.btn.ghost:hover{box-shadow:0 2px 8px rgba(22,29,51,.10)}
h1{letter-spacing:-.015em}
.jcard{transition:transform .16s ease,box-shadow .16s ease}
.jcard:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(22,29,51,.12)}
.capday{transition:transform .16s ease}
.capday:hover{transform:translateY(-2px)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px rgba(201,119,47,.14)}
.flash{box-shadow:0 2px 10px rgba(79,122,63,.14)}

/* collapsible child cards on the family page */
details.childcard{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:12px;padding:0;margin:14px 0;overflow:hidden}
details.childcard>summary{list-style:none;cursor:pointer;padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:700}
details.childcard>summary::-webkit-details-marker{display:none}
details.childcard>summary::after{content:"▾";color:var(--muted);transition:transform .2s}
details.childcard[open]>summary::after{transform:rotate(180deg)}
details.childcard>summary h3{margin:0;font-size:1.1rem}
details.childcard .childbody{padding:0 18px 18px}

/* rich-text editor */
.rtbar{display:flex;gap:6px;margin-bottom:6px}
.rtedit{min-height:110px;border:1px solid #cfc7b6;border-radius:8px;padding:9px 11px;background:#fff;font:inherit;line-height:1.5}
.rtedit:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px rgba(201,119,47,.14)}
.rtedit ul{margin:6px 0 6px 22px}
.rtedit p{margin:0 0 8px}
.wsdesc ul{margin:8px 0 8px 22px}

/* KPI summary cards */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:4px 0 24px}
.kpi{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:15px 17px}
.kpi .n{font-family:Fraunces,serif;font-size:2rem;line-height:1;font-weight:600}
.kpi .l{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;margin-top:5px}
.kpi.good .n{color:var(--good)}
.kpi.bad .n{color:var(--bad)}

/* journey kanban board */
.board{display:grid;grid-template-columns:repeat(auto-fit,minmax(228px,1fr));gap:14px;align-items:start}
.col{background:#faf7ef;border:1px solid var(--line);border-radius:14px;padding:13px 12px}
.colhead{font-family:Fraunces,serif;font-weight:600;font-size:.98rem;display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:11px}
.colhead .cnt{background:var(--ink);color:#fff;font-family:'Nunito Sans',sans-serif;font-size:.72rem;font-weight:800;border-radius:20px;padding:2px 9px;min-width:22px;text-align:center}
.colhead small{display:block;color:var(--muted);font-weight:400;font-size:.72rem}
.col .jcard{max-width:none;min-width:0;width:100%;margin-bottom:10px;padding:12px 13px}
.col .jcard:last-child{margin-bottom:0}
.col .empty{color:var(--muted);font-size:.84rem;padding:2px}

/* CSS tabs (no JS): radio + labels */
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin:0 0 4px;border-bottom:2px solid var(--line);padding-bottom:0}
.tabs label{cursor:pointer;font-weight:700;font-size:.9rem;color:var(--muted);padding:9px 15px;border-radius:9px 9px 0 0;position:relative;top:2px;border:2px solid transparent;border-bottom:none}
.tabs label:hover{color:var(--ink)}
.tabpanel{display:none;padding-top:18px}
.tabinput{position:absolute;left:-9999px}
.ftabs:has(#ft-details:checked) .tp-details,
.ftabs:has(#ft-children:checked) .tp-children,
.ftabs:has(#ft-fees:checked) .tp-fees,
.ftabs:has(#ft-contacts:checked) .tp-contacts,
.ftabs:has(#ft-portal:checked) .tp-portal{display:block}
.ftabs:has(#ft-details:checked) label[for=ft-details],
.ftabs:has(#ft-children:checked) label[for=ft-children],
.ftabs:has(#ft-fees:checked) label[for=ft-fees],
.ftabs:has(#ft-contacts:checked) label[for=ft-contacts],
.ftabs:has(#ft-portal:checked) label[for=ft-portal]{color:var(--ink);background:var(--paper);border-color:var(--line);border-bottom:2px solid var(--paper)}

/* ---- mobile ---- */
@media(max-width:640px){
  .wrap{padding:0 14px}
  h1{font-size:1.42rem}
  h2{font-size:1.15rem}
  .cards{grid-template-columns:1fr 1fr;gap:10px}
  .card .big{font-size:1.7rem}
  table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  input,select,textarea{font-size:16px}
  .lanes{flex-direction:column}
  .jcard{max-width:none;min-width:0;width:100%}
  main.wrap{padding-bottom:96px}
  .subnav{top:56px}
}

/* unread-message badge + dashboard nudge */
.navbadge{float:right;min-width:20px;padding:1px 6px;border-radius:10px;background:#e2574b;color:#fff;font-size:.72rem;font-weight:800;line-height:1.5;text-align:center}
.navlink.on .navbadge{background:#b23b30}
.msgnudge{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:2px 0 18px;padding:12px 16px;background:#fff7ea;border:1px solid var(--gold);border-radius:12px;color:var(--ink);font-weight:600;text-decoration:none}
.msgnudge:hover{background:#fdf0d8;text-decoration:none}
.msgnudge strong{color:#b23b30;font-size:1.05em}
.msgnudge .go{font-weight:800;color:#b26a12;white-space:nowrap}

/* --- brand alignment with the public site (5 Jul 2026) --- */
.slogo{display:flex;align-items:flex-start;gap:10px}
.slogo .wm{display:flex;flex-direction:column;line-height:1.06;color:#fff;font-size:1.16rem}
.logo{display:flex;align-items:center;gap:9px}
.slogo-sm{display:flex;align-items:center;gap:8px}
.bmark{width:30px;height:30px;flex:0 0 30px}
.logo .bmark,.slogo-sm .bmark{width:26px;height:26px;flex:0 0 26px}
.foot{margin-left:0;background:#161d33;color:#c9cdd9;text-align:center;padding:20px 24px;font-size:.85rem;font-family:'Nunito Sans',system-ui,sans-serif}
.foot .wrap{max-width:1080px;margin:0 auto;padding:0}
.foot a{color:var(--gold)}
body:has(.sidebar) .foot{margin-left:232px}
@media(max-width:900px){body:has(.sidebar) .foot{margin-left:0}}
