/* ============================================================================
   Bombadil LMS — shared styles  (v2: unified component system)
   Identity: calm academic. Forest/moss greens on warm parchment, a serif
   display face (Fraunces) paired with a clean grotesque (Inter) for UI.
   No school references anywhere — this is Bombadil.
   ============================================================================ */
:root {
  --moss:        #4a6438;
  --moss-deep:   #2f4226;
  --moss-soft:   #e7efe2;
  --moss-tint:   #f1f5ec;
  --gold:        #c7a23b;
  --rust:        #9a4a2f;
  --parchment:   #ece4d0;
  --parchment-2: #e3dac3;
  --ink:         #2a2620;
  --ink-soft:    #6b6256;
  --line:        #d6ccb2;
  --line-soft:   #e6ddc9;
  --danger:      #a8432f;
  --danger-soft: #f7e6e1;
  --ok:          #3d6630;
  --warn:        #a06912;
  --card:        #fffefa;
  --radius:      14px;
  --radius-sm:   10px;
  --shadow-sm:   0 1px 2px rgba(47,66,38,.06);
  --shadow:      0 1px 2px rgba(47,66,38,.06), 0 6px 24px rgba(47,66,38,.08);
  --shadow-lg:   0 12px 40px rgba(47,66,38,.16);
  --ring:        0 0 0 3px rgba(74,100,56,.28);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(1100px 460px at 80% -8%, rgba(199,162,59,.07), transparent 60%),
    linear-gradient(180deg, #f0e9d8 0%, var(--parchment) 240px);
  background-attachment: fixed;
  min-height: 100vh;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

/* ---- Type scale ---- */
h1, h2, h3, h4, .display {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  letter-spacing: -0.012em;
  color: var(--moss-deep);
  line-height: 1.18;
}
h1 { font-size: clamp(1.6rem, 1.28rem + 1.2vw, 2.05rem); margin: 0 0 .35em; }
h2 { font-size: 1.34rem; margin: 0 0 .45em; }
h3 { font-size: 1.08rem; margin: 0 0 .4em; }
h4 { font-size: .95rem; margin: 0 0 .4em; }
.eyebrow { font-family: 'Inter', sans-serif; font-size: .7rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); }
p { margin: 0 0 1em; }
a { color: var(--moss); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- Buttons ---- */
.btn {
  font: inherit; font-weight: 600; line-height: 1.1;
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  border: 1px solid transparent; border-radius: var(--radius-sm);
  padding: 11px 18px;
  background: var(--moss); color: #fff;
  box-shadow: var(--shadow-sm);
  cursor: pointer; transition: background .15s, transform .06s, box-shadow .15s, border-color .15s;
  white-space: nowrap; text-decoration: none;
}
.btn:hover { background: var(--moss-deep); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(47,66,38,.18); text-decoration: none; }
.btn:active { transform: translateY(0); box-shadow: var(--shadow-sm); }
.btn:focus-visible { outline: none; box-shadow: var(--ring); }
.btn.secondary { background: var(--moss-soft); color: var(--moss-deep); box-shadow: none; }
.btn.secondary:hover { background: #d8e6d0; }
.btn.ghost { background: transparent; color: var(--moss); box-shadow: none; border-color: transparent; }
.btn.ghost:hover { background: var(--moss-soft); }
.btn.outline { background: #fff; color: var(--moss-deep); border-color: var(--line); box-shadow: none; }
.btn.outline:hover { background: var(--moss-tint); border-color: var(--moss); }
.btn.danger { background: var(--danger); }
.btn.danger:hover { background: #8a3526; }
.btn.small { padding: 7px 13px; font-size: .85rem; border-radius: 8px; gap: 5px; }
.btn.block { width: 100%; }
.btn:disabled { opacity: .5; cursor: not-allowed; transform: none; box-shadow: none; }

/* ---- Inputs ---- */
input, select, textarea {
  font: inherit; color: var(--ink);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  width: 100%;
  transition: border-color .15s, box-shadow .15s;
}
input::placeholder, textarea::placeholder { color: #a79e8c; }
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--moss);
  box-shadow: var(--ring);
}
label { font-size: .82rem; font-weight: 600; color: var(--ink-soft); display: block; margin-bottom: 6px; }
.field { margin-bottom: 14px; }
.field:last-child { margin-bottom: 0; }
.field label { margin-bottom: 5px; }
.hint { font-size: .8rem; color: var(--ink-soft); margin-top: 5px; }

/* ---- Cards ---- */
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 22px;
}
.card.pad-sm { padding: 16px; }
.card.hover { transition: transform .12s, box-shadow .12s, border-color .12s; }
.card.hover:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); border-color: var(--moss-soft); }

/* ---- Section header ---- */
.section-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 14px; flex-wrap: wrap; margin: 4px 0 16px; }
.section-head .sub { color: var(--ink-soft); font-size: .9rem; margin: 2px 0 0; }
.section-head h1, .section-head h2 { margin: 0; }

/* ---- Tabs (shared — was previously per-page only) ---- */
.tabs { display: flex; gap: 2px; flex-wrap: wrap; margin: 18px 0 18px; border-bottom: 2px solid var(--line); }
.tab {
  background: none; border: none; font: inherit; font-weight: 600;
  color: var(--ink-soft); padding: 10px 16px; cursor: pointer;
  border-bottom: 3px solid transparent; margin-bottom: -2px;
  border-radius: 8px 8px 0 0; transition: color .12s, background .12s, border-color .12s;
}
.tab:hover { color: var(--moss-deep); background: var(--moss-tint); }
.tab.active { color: var(--moss-deep); border-bottom-color: var(--moss); }
.tab:focus-visible { outline: none; box-shadow: var(--ring); }
/* pill-style sub-tabs */
.subtabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.subtab { font: inherit; font-weight: 600; font-size: .9rem; cursor: pointer; padding: 7px 14px; border-radius: 999px; border: 1px solid var(--line); background: #fff; color: var(--ink-soft); transition: all .12s; }
.subtab:hover { border-color: var(--moss); color: var(--moss-deep); }
.subtab.active { background: var(--moss); border-color: var(--moss); color: #fff; }

/* ---- Tables ---- */
.table-wrap { border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; background: var(--card); box-shadow: var(--shadow-sm); }
table { border-collapse: collapse; }
.table { width: 100%; border-collapse: collapse; font-size: .92rem; }
th { text-align: left; font-weight: 700; }
.table thead th, table.table th {
  background: var(--moss-tint); color: var(--moss-deep);
  font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  padding: 11px 14px; border-bottom: 1px solid var(--line); white-space: nowrap;
}
.table td, table.table td { padding: 11px 14px; border-bottom: 1px solid var(--line-soft); vertical-align: middle; }
.table tbody tr:last-child td { border-bottom: none; }
.table tbody tr { transition: background .1s; }
.table tbody tr:hover { background: var(--moss-tint); }
.table .num { text-align: right; font-variant-numeric: tabular-nums; }
.linkish { color: var(--moss); cursor: pointer; font-weight: 600; }
.linkish:hover { text-decoration: underline; }

/* ---- Chips / badges / pills ---- */
.chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: .78rem; font-weight: 600;
  padding: 3px 10px; border-radius: 999px;
  background: var(--moss-soft); color: var(--moss-deep);
}
.pill { display: inline-flex; align-items: center; gap: 5px; font-size: .74rem; font-weight: 700; padding: 2px 9px; border-radius: 999px; letter-spacing: .02em; }
.pill.green { background: var(--moss-soft); color: var(--moss-deep); }
.pill.gold  { background: #fbf2d8; color: #8a6a13; }
.pill.rust  { background: var(--danger-soft); color: var(--danger); }
.pill.grey  { background: var(--parchment-2); color: var(--ink-soft); }
.badge-A { background:#e7efe2; color:#2f4226; }
.badge-B { background:#eef3e9; color:#3d6630; }
.badge-C { background:#fdf6e6; color:#a06912; }
.badge-D { background:#f7ece1; color:#a0571f; }
.badge-F { background:#f7e6e1; color:#a8432f; }

/* ---- Avatar (initials) ---- */
.avatar { flex: 0 0 auto; display: inline-grid; place-items: center; width: 38px; height: 38px; border-radius: 999px; background: var(--moss-soft); color: var(--moss-deep); font-weight: 700; font-size: .82rem; letter-spacing: .01em; }
.avatar.sm { width: 30px; height: 30px; font-size: .72rem; }
.avatar.lg { width: 46px; height: 46px; font-size: .95rem; }
.avatar.rust { background: #f1ddd4; color: var(--rust); }
.avatar.gold { background: #fbf2d8; color: #8a6a13; }

/* ---- Empty states ---- */
.empty { margin: auto; color: var(--ink-soft); text-align: center; padding: 30px; }
.empty-state { display: grid; place-items: center; gap: 10px; text-align: center; padding: 44px 24px; color: var(--ink-soft); }
.empty-state .ico { width: 46px; height: 46px; color: var(--moss); opacity: .7; }
.empty-state h3 { color: var(--moss-deep); margin: 0; }
.empty-state p { margin: 0; max-width: 30ch; }

/* ---- Stats ---- */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; }
.stat { background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px; }
.stat .n { font-family: 'Fraunces', serif; font-size: 1.8rem; color: var(--moss-deep); line-height: 1; }
.stat .l { font-size: .78rem; color: var(--ink-soft); margin-top: 6px; }

/* ---- Layout primitives ---- */
.wrap { max-width: 1100px; margin: 0 auto; padding: 24px; }
.muted { color: var(--ink-soft); }
.row { display: flex; gap: 12px; align-items: center; }
.row.wrap-row { flex-wrap: wrap; }
.spread { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.grid { display: grid; gap: 16px; }
.grid.cols-2 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.grid.cols-3 { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
.divider { height: 1px; background: var(--line); border: none; margin: 18px 0; }
.stack > * + * { margin-top: 14px; }

/* ---- Modal (shared, robust — overlay scrolls so nothing is ever cut off) ---- */
.modal-bg {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(42,38,32,.5); backdrop-filter: blur(2px);
  display: none; padding: 24px; overflow-y: auto; overscroll-behavior: contain;
}
.modal-bg.show { display: flex; }
.modal {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  width: min(620px, 100%);
  margin: auto;                 /* centers when it fits, scrolls the overlay when it doesn't */
  padding: 26px;
  animation: modal-in .18s ease;
}
@keyframes modal-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.modal.wide { width: min(880px, 100%); }
.modal h2 { margin-top: 0; }
.modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; flex-wrap: wrap; }

/* ---- Top bar (portal shell) ---- */
.topbar {
  background: rgba(236,228,208,.92); color: var(--ink);
  padding: 16px 30px;
  display: flex; justify-content: space-between; align-items: center;
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 50; backdrop-filter: blur(6px);
}
.topbar .brand { display: flex; align-items: center; gap: 12px; }
.topbar .leaf-logo { width: 26px; height: 31px; color: var(--moss); flex: 0 0 26px; }
.topbar .wordmark { font-family: 'Fraunces', serif; font-size: 1.22rem; font-weight: 600; color: var(--moss-deep); letter-spacing: .22em; }
.topbar .role-label { font-family: Inter, sans-serif; font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); font-weight: 600; border-left: 1px solid var(--line); padding-left: 12px; margin-left: 2px; }
.topbar .row { display: flex; align-items: center; gap: 14px; }
.topbar .who { font-size: .85rem; color: var(--ink-soft); }
.topbar .btn.ghost { color: var(--moss); }
.topbar .btn.ghost:hover { background: var(--moss-soft); }
@media (max-width: 560px){ .topbar { padding: 12px 16px; } .topbar .wordmark { letter-spacing:.14em; font-size:1.05rem; } .topbar .role-label{ display:none; } }

/* ---- Stage 11: view-as banner ---- */
.viewas-banner{ position:sticky; top:0; z-index:1200; display:flex; justify-content:space-between; align-items:center; gap:12px;
  background:var(--rust); color:#fff; padding:9px 18px; font-size:.9rem; box-shadow:0 2px 8px rgba(0,0,0,.15); }
.viewas-banner .vr{ opacity:.85; text-transform:uppercase; font-size:.74rem; letter-spacing:.08em; }
.viewas-banner .btn{ background:#fff; color:var(--rust); }
.viewas-banner .btn:hover{ background:#f3ece0; }

/* ---- Toast ---- */
.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(8px);
  background: var(--moss-deep); color: #fff;
  padding: 12px 20px; border-radius: 10px; box-shadow: var(--shadow-lg);
  opacity: 0; pointer-events: none; transition: opacity .2s, transform .2s; z-index: 2000;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.error { background: var(--danger); }

/* ---- Scrollbars ---- */
* { scrollbar-width: thin; scrollbar-color: var(--line) transparent; }
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-thumb { background: var(--line); border-radius: 999px; border: 2px solid transparent; background-clip: padding-box; }
*::-webkit-scrollbar-thumb:hover { background: #c5b994; background-clip: padding-box; }

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
}

/* AP exam results panel (counselor + admin) */
.ap-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px; margin-top:8px; }
.ap-year-h { font-family:'Fraunces',serif; font-weight:600; color:var(--moss-deep); font-size:.95rem; margin-bottom:2px; }
.ap-tbl td, .ap-edit td, .ap-edit th { padding:4px 6px; font-size:.86rem; }
.ap-score { display:inline-block; min-width:22px; text-align:center; font-weight:700; border-radius:6px; padding:1px 6px; background:var(--parchment-2); }
.ap-score.good { background:var(--moss); color:#fff; }
.ap-score.ip { background:var(--parchment-2); color:var(--rust); font-weight:600; }
.ap-edit input, .ap-edit select { padding:4px 6px; }

/* Senior college-application profile (counselor) */
.cp-yes { background:var(--moss); color:#fff; border-radius:6px; padding:1px 8px; font-size:.76rem; font-weight:600; }
.cp-no { background:var(--parchment-2); color:var(--ink-soft); border-radius:6px; padding:1px 8px; font-size:.76rem; }
.cp-row { display:grid; grid-template-columns:200px 1fr; gap:12px; padding:5px 0; border-bottom:1px solid var(--line); }
.cp-row:last-child { border-bottom:none; }
.cp-l { color:var(--ink-soft); font-size:.84rem; }
.cp-v { white-space:pre-wrap; line-height:1.5; }
.cp-act { padding:8px 0; border-bottom:1px solid var(--line); }
.cp-act:last-child { border-bottom:none; }
.cp-act-h { font-weight:600; color:var(--moss-deep); }
.cp-essay { padding:8px 0; border-bottom:1px solid var(--line); }
.cp-essay:last-child { border-bottom:none; }
.cp-essay-q { font-family:'Fraunces',serif; color:var(--moss-deep); font-size:.95rem; margin-bottom:3px; }
.cp-rates { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:10px; }
.cp-rate { background:var(--parchment-2); border-radius:8px; padding:3px 10px; font-size:.84rem; }
.cp-f { margin-bottom:10px; }
.cp-f label { display:block; font-size:.8rem; color:var(--ink-soft); margin-bottom:3px; }
.cp-f input, .cp-f textarea, .cp-f select { width:100%; padding:6px 8px; }
.cp-2col, .cp-rate-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.cp-rate-grid { grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:10px; }
@media (max-width:720px){ .cp-2col, .cp-rate-grid { grid-template-columns:1fr; } .cp-row { grid-template-columns:1fr; gap:2px; } }
.cp-item { border:1px solid var(--line); border-radius:10px; padding:10px 12px; margin-bottom:10px; background:var(--parchment); }
.cp-item-h { display:flex; justify-content:space-between; align-items:center; font-weight:600; color:var(--moss-deep); margin-bottom:6px; }
table.cp-list { width:100%; border-collapse:collapse; }
table.cp-list td { padding:3px 4px; }
table.cp-list input { padding:5px 7px; }

/* College-list fit (senior profile) */
.cp-tier { display:inline-block; color:#fff; border-radius:5px; padding:1px 7px; font-size:.7rem; font-weight:700; letter-spacing:.02em; }
.cp-fit-head { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; margin:8px 0 4px; }
.cp-strength { font-family:'Fraunces',serif; color:var(--moss-deep); font-weight:600; }
.cp-balance { display:flex; gap:6px; }
.cp-grp { border-radius:6px; padding:2px 9px; font-size:.78rem; font-weight:600; }
.cp-grp.reach { background:#f1ddd4; color:#9a4a2f; } .cp-grp.target { background:#e2ecd9; color:#3f6d2f; }
.cp-grp.safety { background:#d8efe0; color:#2f7d4f; } .cp-grp.none { background:var(--parchment-2); color:var(--ink-soft); }
.cp-warn { margin:6px 0; font-size:.84rem; }
.cp-warn div { color:var(--rust); padding:2px 0; } .cp-warn div.ok { color:var(--moss-deep); }

/* Admit-rate tuning (admin) */
.ad-in { width:74px; padding:4px 6px; border:1px solid var(--line,#d9d2c5); border-radius:6px; font:inherit; }
.ad-in:focus { outline:2px solid var(--moss,#5c7a4a); outline-offset:0; }
.ad-badge { display:inline-block; background:var(--moss-deep,#3f5a32); color:#fff; border-radius:5px; padding:1px 7px; font-size:.66rem; font-weight:700; letter-spacing:.03em; vertical-align:middle; }

/* Security console (admin) */
.sec-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px; margin-bottom:14px; }
.sec-card { background:var(--card,#fff); border:1px solid var(--line,#e5ded1); border-radius:12px; padding:14px 16px; }
.sec-n { font-family:'Fraunces',serif; font-size:1.8rem; color:var(--moss-deep,#3f5a32); line-height:1; }
.sec-l { font-size:.78rem; color:var(--ink-soft,#7a7261); margin-top:6px; }
.sec-ev { display:inline-block; color:#fff; border-radius:5px; padding:1px 8px; font-size:.7rem; font-weight:700; white-space:nowrap; }

/* ============================================================================
   v3 streamline layer — skeletons, quick-link pills, folds, swipeable tabs
   ============================================================================ */
.skel{position:relative;overflow:hidden;background:var(--parchment-2);border-radius:8px;min-height:13px}
.skel::after{content:'';position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:skel 1.1s infinite}
@keyframes skel{100%{transform:translateX(100%)}}

/* compact quick-link pills (shared across portals) */
.quicklinks{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 2px}
.qcard{display:inline-flex;align-items:center;gap:6px;text-decoration:none;color:var(--ink-soft);border:1px solid var(--line);background:var(--card);border-radius:10px;padding:7px 11px;font-size:.84rem;font-weight:600;transition:border-color .12s,color .12s,transform .06s}
.qcard:hover{border-color:var(--moss);color:var(--moss-deep);text-decoration:none;transform:translateY(-1px)}

/* collapsible secondary content */
details.fold{margin-top:12px;border-top:1px solid var(--line-soft);padding-top:10px}
details.fold>summary{cursor:pointer;font-weight:600;color:var(--moss);font-size:.88rem;list-style:none;display:inline-flex;align-items:center;gap:6px}
details.fold>summary::-webkit-details-marker{display:none}
details.fold>summary::after{content:'▾';font-size:.7rem;transition:transform .15s}
details.fold[open]>summary::after{transform:rotate(180deg)}

/* tabs become a single swipeable row on small screens; tighter page padding */
@media (max-width:720px){
  .tabs{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .tabs::-webkit-scrollbar{display:none}
  .tab{white-space:nowrap;flex:0 0 auto}
  .wrap{padding:16px 14px}
}

/* ============================================================================
   v4 layer — Term Journey, Teacher Cockpit, Registration, mobile/tablet
   ============================================================================ */

/* ---- Term Journey ribbon (student Classroom week selector) ---- */
.journey{position:relative;margin:6px 0 14px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--card),var(--parchment-2));overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.journey svg{display:block}
.jy-path{fill:none;stroke:var(--line);stroke-width:2.5;stroke-dasharray:1 6;stroke-linecap:round}
.jy-path-done{fill:none;stroke:var(--moss);stroke-width:3;stroke-linecap:round;opacity:.55}
.jy-node{cursor:pointer}
.jy-node circle.c{fill:var(--card);stroke:var(--line);stroke-width:2}
.jy-node.has circle.c{stroke:var(--moss)}
.jy-node.past circle.c{fill:var(--moss);stroke:var(--moss)}
.jy-node.cur circle.c{fill:var(--gold);stroke:var(--gold)}
.jy-node.sel circle.ring{fill:none;stroke:var(--moss-deep);stroke-width:2;opacity:.9}
.jy-node text{font:600 10px Inter,system-ui,sans-serif;fill:var(--ink-soft);text-anchor:middle}
.jy-node.cur text,.jy-node.sel text{fill:var(--moss-deep)}
.jy-node circle.pulse{fill:none;stroke:var(--gold);stroke-width:2;opacity:0;transform-origin:center;animation:jypulse 2.2s ease-out infinite}
@keyframes jypulse{0%{opacity:.8;r:9}70%{opacity:0;r:17}100%{opacity:0;r:17}}
.jy-flag text{font:700 9.5px Inter,sans-serif;fill:var(--rust);text-anchor:middle}
.jy-legend{display:flex;gap:14px;align-items:center;font-size:.74rem;color:var(--ink-soft);padding:0 12px 8px}
.jy-legend i{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:5px;vertical-align:middle}

/* ---- Today / Up-next card ---- */
.today{border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:12px;background:var(--card);padding:12px 15px;margin:4px 0 12px}
.today .th{display:flex;justify-content:space-between;gap:10px;align-items:baseline;flex-wrap:wrap}
.today .tt{font-family:Fraunces,serif;font-weight:600;color:var(--moss-deep)}
.today .row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.tchip{font-size:.78rem;border:1px solid var(--line);background:var(--parchment-2);border-radius:999px;padding:4px 11px}
.tchip b{color:var(--moss-deep)}
.tchip.due{border-color:var(--rust);color:var(--rust);font-weight:600}

/* ---- Teacher Cockpit ---- */
.cockpit{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:12px;margin-top:10px}
.ckcard{border:1px solid var(--line);border-radius:14px;background:var(--card);padding:14px 15px;display:flex;flex-direction:column;gap:9px;transition:transform .08s,border-color .12s}
.ckcard:hover{transform:translateY(-2px);border-color:var(--moss)}
.ck-name{font-family:Fraunces,serif;font-weight:600;color:var(--moss-deep);font-size:1.03rem;line-height:1.25}
.ck-meta{display:flex;gap:6px;flex-wrap:wrap}
.mchip{font-size:.72rem;font-weight:600;color:var(--ink-soft);background:var(--parchment-2);border:1px solid var(--line);border-radius:999px;padding:2px 9px}
.ck-foot{display:flex;gap:8px;align-items:center;margin-top:auto;flex-wrap:wrap}
.alertchip{font-size:.74rem;font-weight:700;border-radius:999px;padding:3px 10px;background:var(--rust);color:#fff}
.alertchip.zero{background:var(--parchment-2);color:var(--ink-soft);font-weight:600;border:1px solid var(--line)}
.gradestrip{border:1px solid var(--rust);border-radius:12px;background:#fdf3ee;padding:11px 14px;display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:10px}
.gradestrip b{color:var(--rust)}

/* ---- Registration & invoice ---- */
.deptblock{margin:12px 0}
.depth{font-family:Fraunces,serif;font-weight:600;color:var(--moss-deep);margin:0 0 6px;font-size:.96rem}
.cpick{display:flex;gap:7px;flex-wrap:wrap}
.cchip{font-size:.82rem;border:1.5px solid var(--line);background:var(--card);border-radius:999px;padding:6px 13px;cursor:pointer;user-select:none;transition:all .1s}
.cchip.on{background:var(--moss);border-color:var(--moss);color:#fff;font-weight:600}
.cchip .hh{font-size:.66rem;opacity:.75;margin-left:4px}
.regstatus{border-radius:10px;padding:9px 13px;font-size:.86rem;font-weight:600;display:inline-flex;gap:8px;align-items:center;margin-bottom:10px}
.regstatus.pending{background:#fbf3df;color:#8a6410;border:1px solid #e3c878}
.regstatus.approved{background:var(--moss-soft);color:var(--moss-deep);border:1px solid var(--moss)}
.regstatus.declined{background:#fdeeee;color:var(--danger);border:1px solid var(--danger)}
table.inv{width:100%;border-collapse:collapse;font-size:.86rem}
table.inv th{text-align:left;font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft);padding:7px 9px;border-bottom:2px solid var(--line)}
table.inv td{padding:7px 9px;border-bottom:1px solid var(--line);vertical-align:top}
table.inv td.r{text-align:right;white-space:nowrap}
.bkt{font-size:.7rem;font-weight:700;border-radius:999px;padding:2px 9px;white-space:nowrap}
.bkt.school{background:var(--moss-soft);color:var(--moss-deep)}
.bkt.parent{background:#fbf3df;color:#8a6410}
.bkt.na{background:var(--parchment-2);color:var(--ink-soft)}
.bkt.tba{background:#eee9fa;color:#5b4a96}
.invtotal{display:flex;justify-content:flex-end;align-items:baseline;gap:12px;margin-top:10px;font-family:Fraunces,serif}
.invtotal .amt{font-size:1.5rem;font-weight:700;color:var(--moss-deep)}

/* ---- Bottom navigation (phones; pages opt in with body.bn-on) ---- */
.bottomnav{display:none}
@media (max-width:740px){
  body.bn-on{padding-bottom:calc(70px + env(safe-area-inset-bottom,0px))}
  body.bn-on .tabs{display:none}
  .bottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--card);border-top:1px solid var(--line);box-shadow:0 -4px 16px rgba(47,66,38,.08);padding:6px 4px calc(6px + env(safe-area-inset-bottom,0px))}
  .bn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;font:inherit;color:var(--ink-soft);text-decoration:none;font-size:.66rem;font-weight:600;padding:4px 2px;cursor:pointer;min-height:48px;justify-content:center}
  .bn .ic{font-size:1.25rem;line-height:1}
  .bn.active{color:var(--moss-deep)}
  .bn.active .ic{transform:translateY(-1px)}
}
.bnsheet{position:fixed;inset:0;z-index:95;display:none}
.bnsheet.show{display:block}
.bnsheet .bg{position:absolute;inset:0;background:rgba(35,30,22,.4)}
.bnsheet .panel{position:absolute;left:0;right:0;bottom:0;background:var(--card);border-radius:16px 16px 0 0;padding:14px 14px calc(18px + env(safe-area-inset-bottom,0px));box-shadow:0 -8px 30px rgba(0,0,0,.25)}
.bnsheet .panel a{display:flex;gap:12px;align-items:center;padding:13px 10px;border-radius:10px;text-decoration:none;color:var(--ink);font-weight:600}
.bnsheet .panel a:active{background:var(--parchment-2)}

/* ---- tablet & touch refinements ---- */
@media (max-width:980px){
  .cockpit{grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}
  .agrid{grid-template-columns:1fr 1fr}
}
@media (max-width:740px){
  .wrap{padding:14px 12px}
  h1{font-size:1.45rem}
  .quicklinks{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:4px}
  .quicklinks::-webkit-scrollbar{display:none}
  .qcard{flex:0 0 auto}
  .card{padding:14px}
  .agrid{grid-template-columns:1fr}
  table.sched th,table.sched td{padding:8px 6px;font-size:.84rem}
  .gtop{flex-wrap:wrap}
  .modal{width:min(560px,94vw);max-height:86vh;overflow:auto}
}
@media (pointer:coarse){
  .btn,.tab,.wk,.cchip,.bn{min-height:42px}
  .tab{padding:10px 14px}
  input,select,textarea{font-size:16px} /* prevents iOS zoom-on-focus */
}
