
/* ═══════════════════════════════════════════
   BRAND TOKENS — Young Laureates
   Navy · Gold · Warm White
═══════════════════════════════════════════ */
:root{
  /* Brand palette */
  --navy:#0d2240;
  --navy2:#122a50;
  --navy3:#1a3a68;
  --gold:#c9922a;
  --gold2:#e5aa3a;
  --gold-lt:#f5e0b0;
  --gold-glow:rgba(201,146,42,.15);
  --cream:#faf8f4;
  --warm-white:#ffffff;
  --slate:#4a5568;
  --muted:#718096;
  --faint:#a0aec0;

  /* Semantic */
  --green:#2d8c5f;--green-lt:rgba(45,140,95,.12);
  --red:#c0392b;--red-lt:rgba(192,57,43,.1);
  --blue:#2563eb;--blue-lt:rgba(37,99,235,.1);
  --purple:#7c3aed;

  /* Surfaces */
  --surface:#ffffff;
  --surface2:#f7f5f0;
  --border:#e2d9cc;
  --border2:#ede8e0;

  /* Admin dark surfaces */
  --adm-bg:#0a1628;
  --adm-surface:#0f2040;
  --adm-surface2:#162850;
  --adm-border:rgba(255,255,255,.1);
  --adm-text:#e8eef8;
  --adm-muted:rgba(232,238,248,.55);

  --r:12px;
  --shadow:0 2px 12px rgba(13,34,64,.08);
  --shadow-md:0 6px 24px rgba(13,34,64,.12);
  --shadow-lg:0 16px 48px rgba(13,34,64,.18);
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;font-family:'Inter',sans-serif;color:var(--navy);background:var(--cream);}
button{cursor:pointer;font-family:'Inter',sans-serif;}
input,select,textarea{font-family:'Inter',sans-serif;}
a{color:inherit;text-decoration:none;}
::-webkit-scrollbar{width:5px;}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;}

/* ── PAGE SYSTEM ── */
.pg{display:none!important;}
.pg.on{display:block!important;}
#pg-login.on{display:flex!important;}
#pg-student.on{display:flex!important;flex-direction:column;}

/* ════════════════════════════════════
   LOGIN
════════════════════════════════════ */
#pg-login{
  min-height:100vh;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy3) 60%,#1e4a8a 100%);
  align-items:center;justify-content:center;position:relative;overflow:hidden;
}
.login-bg-pattern{
  position:absolute;inset:0;opacity:.06;
  background-image:repeating-linear-gradient(45deg,#fff 0,#fff 1px,transparent 0,transparent 50%);
  background-size:20px 20px;
}
.login-deco{position:absolute;border-radius:50%;background:rgba(201,146,42,.08);}
.login-card{
  position:relative;z-index:10;width:100%;max-width:420px;
  background:var(--warm-white);border-radius:20px;
  padding:48px 44px;box-shadow:var(--shadow-lg);
  text-align:center;
}
.lc-brand{margin-bottom:32px;}
.lc-school{font-family:'Playfair Display',serif;font-size:1.65rem;color:var(--navy);font-weight:700;line-height:1.1;}
.lc-tagline{font-size:.78rem;color:var(--muted);margin-top:5px;letter-spacing:.5px;text-transform:uppercase;}
.lc-rule{width:48px;height:3px;background:var(--gold);border-radius:2px;margin:14px auto 0;}
.ltabs{display:flex;gap:6px;margin-bottom:24px;background:var(--surface2);border-radius:10px;padding:4px;}
.ltab{flex:1;padding:9px;border-radius:8px;border:none;background:transparent;color:var(--muted);font-weight:600;font-size:.85rem;transition:all .2s;}
.ltab.on{background:var(--warm-white);color:var(--navy);box-shadow:var(--shadow);}
.lform{text-align:left;}
.lbl{display:block;font-size:.68rem;font-weight:600;color:var(--slate);text-transform:uppercase;letter-spacing:.7px;margin-bottom:5px;}
.linput{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:11px 13px;color:var(--navy);font-size:.9rem;outline:none;margin-bottom:13px;transition:border-color .2s;}
.linput:focus{border-color:var(--gold);background:var(--warm-white);}
.lgo{
  width:100%;padding:13px;border-radius:10px;border:none;
  background:var(--navy);color:var(--warm-white);
  font-weight:700;font-size:.95rem;letter-spacing:.3px;
  box-shadow:0 4px 16px rgba(13,34,64,.25);transition:all .2s;
}
.lgo:hover{background:var(--navy3);transform:translateY(-1px);}
.lerr{color:var(--red);font-size:.78rem;margin-top:10px;min-height:16px;text-align:center;}

/* ════════════════════════════════════
   STUDENT — HEADER
════════════════════════════════════ */
#pg-student{min-height:100vh;background:var(--cream);}
.s-header{
  background:var(--navy);color:var(--warm-white);
  padding:0 24px;height:60px;
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;
  border-bottom:3px solid var(--gold);
  box-shadow:0 2px 16px rgba(13,34,64,.3);
}
.s-header-left{display:flex;align-items:center;gap:14px;}
.s-logo{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--gold2);font-weight:700;}
.s-sep{width:1px;height:22px;background:rgba(255,255,255,.15);}
.s-greeting{font-size:.88rem;font-weight:500;color:rgba(255,255,255,.85);}
.s-header-right{display:flex;align-items:center;gap:8px;}
.hbtn{padding:7px 14px;border-radius:8px;border:none;font-size:.78rem;font-weight:600;transition:all .2s;}
.hbtn-gold{background:var(--gold);color:var(--warm-white);}
.hbtn-gold:hover{background:var(--gold2);}
.hbtn-ghost{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.85);}
.hbtn-ghost:hover{background:rgba(255,255,255,.18);}
.notif-dot{display:inline-block;width:7px;height:7px;background:#e74c3c;border-radius:50%;margin-left:4px;vertical-align:middle;}

/* TABS */
.s-tabs{
  display:flex;gap:0;background:var(--warm-white);
  border-bottom:2px solid var(--border);padding:0 24px;flex-shrink:0;
}
.s-tab{
  padding:13px 20px;border:none;background:transparent;
  font-size:.84rem;font-weight:600;color:var(--muted);
  border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s;
}
.s-tab:hover{color:var(--navy);}
.s-tab.on{color:var(--navy);border-bottom-color:var(--gold);}

/* STUDENT BODY */
.s-body{flex:1;overflow:hidden;display:flex;min-height:0;}
.s-view{display:none;flex:1;overflow-y:auto;padding:22px 24px 40px;}
.s-view.on{display:block;}

/* ── DAILY DATE BAR ── */
.date-bar{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--warm-white);border:1px solid var(--border);border-radius:var(--r);
  padding:13px 18px;margin-bottom:16px;box-shadow:var(--shadow);
}
.date-bar-left{display:flex;align-items:center;gap:12px;}
.day-pill{background:var(--navy);color:var(--gold2);font-family:'Playfair Display',serif;font-size:1.3rem;padding:6px 18px;border-radius:8px;font-weight:600;}
.date-full{font-size:.83rem;color:var(--muted);}
.date-bar-right{display:flex;align-items:center;gap:8px;}
.prog-chip{display:flex;align-items:center;gap:7px;background:var(--green-lt);border:1px solid rgba(45,140,95,.22);border-radius:20px;padding:5px 12px;}
.prog-chip-n{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--green);}
.prog-chip-l{font-size:.68rem;font-weight:600;color:var(--green);}

/* ── DAILY READINESS STATUS ── */
.readiness-chip{
  display:inline-flex;align-items:center;gap:7px;
  border-radius:20px;padding:6px 12px;
  border:1.5px solid var(--border);
  background:var(--surface2);color:var(--navy);
  font-size:.72rem;font-weight:700;white-space:nowrap;
}
.readiness-chip .readiness-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(201,146,42,.12);}
.readiness-chip.ready{background:var(--green-lt);border-color:rgba(45,140,95,.28);color:var(--green);}
.readiness-chip.ready .readiness-dot{background:var(--green);box-shadow:0 0 0 3px rgba(45,140,95,.13);}
.readiness-chip.working{background:var(--gold-glow);border-color:rgba(201,146,42,.28);color:var(--gold);}
.readiness-chip.working .readiness-dot{background:var(--gold);}
.readiness-chip.not-ready{background:var(--red-lt);border-color:rgba(192,57,43,.24);color:var(--red);}
.readiness-chip.not-ready .readiness-dot{background:var(--red);box-shadow:0 0 0 3px rgba(192,57,43,.1);}
.readiness-note{font-size:.66rem;color:var(--muted);font-weight:600;margin-top:2px;text-align:right;}
.readiness-btns{display:inline-flex;gap:4px;flex-wrap:wrap;align-items:center;}
.readiness-btn{font-size:.66rem;font-weight:700;padding:4px 8px;border-radius:20px;border:1px solid var(--adm-border);background:rgba(255,255,255,.04);color:var(--adm-muted);cursor:pointer;transition:all .18s;}
.readiness-btn:hover{background:rgba(255,255,255,.09);color:var(--adm-text);}
.readiness-btn.on.ready{background:rgba(45,140,95,.16);border-color:rgba(45,140,95,.34);color:#4ade80;}
.readiness-btn.on.working{background:rgba(201,146,42,.16);border-color:rgba(201,146,42,.34);color:var(--gold2);}
.readiness-btn.on.not-ready{background:rgba(192,57,43,.16);border-color:rgba(192,57,43,.34);color:#f87171;}

/* ── ATTENDANCE TRACKING ── */
.att-card{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:12px;margin-top:8px;}
.att-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.att-stat{background:var(--warm-white);border:1px solid var(--border2);border-radius:9px;padding:10px;text-align:center;}
.att-stat-n{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:var(--navy);line-height:1;}
.att-stat-l{font-size:.63rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-top:4px;}
.att-status-chip{display:inline-flex;align-items:center;gap:5px;font-size:.68rem;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap;border:1px solid var(--border);background:var(--surface2);color:var(--muted);}
.att-status-chip.present{background:var(--green-lt);border-color:rgba(45,140,95,.28);color:var(--green);}
.att-status-chip.late{background:var(--gold-glow);border-color:rgba(201,146,42,.3);color:var(--gold);}
.att-status-chip.absent{background:var(--red-lt);border-color:rgba(192,57,43,.25);color:var(--red);}
.att-btns{display:flex;gap:5px;flex-wrap:wrap;}
.att-btn{font-size:.68rem;font-weight:700;padding:5px 9px;border-radius:20px;border:1px solid var(--adm-border);background:rgba(255,255,255,.04);color:var(--adm-muted);cursor:pointer;transition:all .18s;}
.att-btn:hover{background:rgba(255,255,255,.09);color:var(--adm-text);}
.att-btn.on.present{background:rgba(45,140,95,.16);border-color:rgba(45,140,95,.34);color:#4ade80;}
.att-btn.on.late{background:rgba(201,146,42,.16);border-color:rgba(201,146,42,.34);color:var(--gold2);}
.att-btn.on.absent{background:rgba(192,57,43,.16);border-color:rgba(192,57,43,.34);color:#f87171;}
.att-btn.clear{border-color:rgba(255,255,255,.18);color:var(--adm-muted);}
.att-btn.clear:hover{background:rgba(192,57,43,.10);border-color:rgba(192,57,43,.28);color:#fca5a5;}

@media(max-width:680px){.att-summary-grid{grid-template-columns:repeat(2,1fr);}}

/* ── COMPACT STUDENT APPS + ATTENDANCE CARD ── */
.student-tools-card{display:flex;flex-direction:column;gap:12px;}
.student-tools-section{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:12px;}
.student-tools-section .wc-hd{margin-bottom:8px;}
.student-tools-section .apps-big-btn{margin-bottom:6px;padding:9px 12px;font-size:.78rem;}
.student-tools-section .apps-note{font-size:.68rem;line-height:1.35;max-width:none;text-align:left;}
.student-tools-section .att-summary-grid{grid-template-columns:repeat(4,1fr);gap:6px;}
.student-tools-section .att-stat{padding:7px 5px;background:var(--warm-white);}
.student-tools-section .att-stat-n{font-size:1.05rem;}
.student-tools-section .att-stat-l{font-size:.56rem;}
.student-tools-section #att-today{font-size:.68rem;margin-top:7px;text-align:left;}
@media(max-width:680px){.student-tools-section .att-summary-grid{grid-template-columns:repeat(2,1fr);}}



/* ── SUBJECT CARDS ── */
.subjects-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:14px;margin-bottom:16px;
}
.subject-card{
  background:var(--warm-white);border:1px solid var(--border);
  border-radius:var(--r);box-shadow:var(--shadow);
  overflow:hidden;
}
.subject-card-hd{
  display:flex;align-items:center;gap:11px;padding:13px 16px;
  border-bottom:1px solid var(--border2);cursor:pointer;
  transition:background .18s;user-select:none;
}
.subject-card-hd:hover{background:var(--surface2);}
.subject-card-hd.open{background:var(--navy);color:var(--warm-white);}
.subj-color{width:5px;align-self:stretch;border-radius:3px;flex-shrink:0;}
.subj-icon{font-size:1.1rem;flex-shrink:0;}
.subj-title{font-size:.9rem;font-weight:700;flex:1;line-height:1.2;}
.subj-subtitle{font-size:.7rem;opacity:.6;margin-top:1px;}
.subj-badge{
  font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:20px;
  background:var(--gold-glow);color:var(--gold);border:1px solid rgba(201,146,42,.25);
  flex-shrink:0;
}
.subj-badge.done{background:var(--green-lt);color:var(--green);border-color:rgba(45,140,95,.25);}
.subj-arrow{font-size:.68rem;color:var(--faint);transition:transform .22s;flex-shrink:0;}
.subject-card-hd.open .subj-arrow{transform:rotate(90deg);}
.subject-card-hd.open .subj-badge{background:rgba(255,255,255,.15);color:var(--warm-white);border-color:rgba(255,255,255,.2);}
.subject-card-hd.open .subj-arrow{color:rgba(255,255,255,.5);}
.subject-body{display:none;padding:14px 16px;}
.subject-body.open{display:block;}
.task-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:9px 10px;border-radius:9px;margin-bottom:4px;
  background:var(--surface2);border:1px solid var(--border2);
  cursor:pointer;transition:all .18s;user-select:none;
}
.task-item:hover{background:#f0ece4;border-color:var(--border);}
.task-item.done{opacity:.5;}
.task-item.done .task-name{text-decoration:line-through;}
.task-cb{
  width:18px;height:18px;border-radius:5px;border:2px solid var(--border);
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font-size:11px;margin-top:1px;transition:all .2s;background:var(--warm-white);
}
.task-item.done .task-cb{background:var(--green);border-color:var(--green);color:var(--warm-white);}
.task-body{flex:1;}
.task-name{font-size:.83rem;font-weight:600;color:var(--navy);line-height:1.3;}
.task-meta{font-size:.69rem;color:var(--muted);margin-top:2px;}
.no-tasks{text-align:center;padding:22px;color:var(--faint);font-size:.82rem;}

/* ── ROW 2: PUZZLE + MESSAGES + BOOKS + APPS ── */
.bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:0;}
.widget-card{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:17px;}
.wc-hd{display:flex;align-items:center;gap:8px;margin-bottom:13px;}
.wc-title{font-family:'Playfair Display',serif;font-size:.98rem;color:var(--navy);font-weight:700;}
.wc-badge{font-size:.63rem;font-weight:700;padding:2px 7px;border-radius:20px;background:var(--gold-glow);color:var(--gold);border:1px solid rgba(201,146,42,.2);}

/* puzzle */
.pz-type{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--gold);margin-bottom:7px;}
.pz-q{font-size:.86rem;line-height:1.55;color:var(--navy);margin-bottom:11px;font-weight:500;}
.pz-opts{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:8px;}
.pz-opt{background:var(--surface2);border:2px solid var(--border);border-radius:9px;padding:8px;color:var(--navy);font-size:.8rem;font-weight:600;transition:all .18s;}
.pz-opt:hover:not(:disabled){background:var(--navy);color:var(--warm-white);border-color:var(--navy);}
.pz-opt.right{background:#d4edda;border-color:var(--green);color:var(--green);}
.pz-opt.wrong{background:#fde8e6;border-color:var(--red);color:var(--red);}
.pz-fb{font-size:.77rem;font-weight:700;min-height:14px;}
.pz-next{margin-top:7px;background:var(--navy);color:var(--gold2);border:none;border-radius:8px;padding:7px 14px;font-weight:700;font-size:.77rem;}

/* messages */
.msg-thread{display:flex;flex-direction:column;gap:7px;max-height:170px;overflow-y:auto;margin-bottom:10px;}
.msg-b{max-width:85%;padding:8px 11px;border-radius:11px;font-size:.8rem;line-height:1.44;}
.msg-b.from-admin{background:var(--navy);color:var(--warm-white);align-self:flex-start;border-bottom-left-radius:3px;}
.msg-b.from-student{background:var(--gold-lt);color:var(--navy);align-self:flex-end;border-bottom-right-radius:3px;}
.msg-who{font-size:.63rem;font-weight:700;margin-bottom:2px;opacity:.65;}
.msg-time{font-size:.6rem;opacity:.5;margin-top:2px;}
.msg-in{display:flex;gap:6px;}
.msg-inp{flex:1;background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:7px 10px;color:var(--navy);font-size:.8rem;outline:none;resize:none;min-height:34px;max-height:72px;transition:border-color .2s;}
.msg-inp:focus{border-color:var(--gold);}
.msg-snd{background:var(--navy);border:none;border-radius:9px;padding:7px 13px;color:var(--gold2);font-weight:700;font-size:.78rem;white-space:nowrap;}
.no-msgs{text-align:center;color:var(--faint);font-size:.79rem;padding:14px 0;}

/* books */
.bk-item{display:flex;align-items:flex-start;gap:9px;padding:8px 10px;border-radius:9px;background:var(--surface2);border:1px solid var(--border2);margin-bottom:4px;cursor:pointer;transition:all .18s;user-select:none;}
.bk-item:hover{background:#f0ece4;}
.bk-item.done{opacity:.45;}
.bk-item.done .bk-t{text-decoration:line-through;}
.bk-num{font-size:.75rem;font-weight:700;color:var(--gold);width:16px;flex-shrink:0;padding-top:2px;}
.bk-body{flex:1;}
.bk-t{font-size:.81rem;font-weight:600;color:var(--navy);}
.bk-a{font-size:.69rem;color:var(--muted);margin-top:1px;}
.bk-rnq{display:inline-flex;align-items:center;gap:3px;margin-top:4px;background:var(--gold-glow);border:1px solid rgba(201,146,42,.22);border-radius:5px;padding:2px 7px;font-size:.62rem;font-weight:700;color:var(--gold);}
.bk-ck{font-size:11px;color:var(--green);flex-shrink:0;padding-top:2px;}
.no-bk{text-align:center;color:var(--faint);font-size:.79rem;padding:14px 0;}

/* apps btn */
.apps-big-btn{
  width:100%;padding:11px 14px;border-radius:10px;border:none;
  background:var(--navy);color:var(--gold2);
  font-size:.84rem;font-weight:700;letter-spacing:.2px;
  box-shadow:var(--shadow);transition:all .2s;margin-bottom:8px;
  display:flex;align-items:center;justify-content:center;gap:7px;
}
.apps-card-compact{padding:14px!important;}
.apps-card-compact .wc-hd{margin-bottom:9px;}
.apps-card-compact .apps-note{font-size:.70rem;line-height:1.4;}
.apps-big-btn:hover{background:var(--navy3);transform:translateY(-1px);}
.apps-big-btn.hidden{display:none;}
.apps-note{font-size:.72rem;color:var(--muted);text-align:center;line-height:1.45;max-width:300px;margin:0 auto;}
/* keep apps card from stretching to match reading list */
.apps-card{align-self:start;}
.apps-card .apps-big-btn{padding:11px 14px;font-size:.84rem;margin-bottom:8px;}
.apps-card .widget-card{height:auto;}


/* ── ART JOURNAL: Morning SEL + Growth Mindset ── */
.student-message-stack{display:flex;flex-direction:column;gap:14px;}
.art-journal-card{background:linear-gradient(135deg,#ffffff 0%,#faf8f4 60%,#fff7e6 100%);border:1px solid rgba(201,146,42,.28);}
.art-journal-card.hidden{display:none!important;}
.aj-kicker{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--gold);margin-bottom:6px;}
.aj-prompt{font-family:'Playfair Display',serif;font-size:1rem;line-height:1.45;color:var(--navy);font-weight:700;margin-bottom:10px;}
.aj-note{font-size:.72rem;color:var(--muted);line-height:1.45;margin-bottom:12px;}
.aj-check{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:10px;background:var(--surface2);border:1px solid var(--border2);cursor:pointer;user-select:none;transition:all .18s;}
.aj-check:hover{background:#f0ece4;}
.aj-box{width:20px;height:20px;border-radius:6px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;background:var(--warm-white);font-size:12px;color:var(--warm-white);flex-shrink:0;}
.aj-check.done{background:var(--green-lt);border-color:rgba(45,140,95,.25);}
.aj-check.done .aj-box{background:var(--green);border-color:var(--green);}
.aj-check-text{font-size:.82rem;font-weight:800;color:var(--navy);}
.aj-complete-small{font-size:.68rem;color:var(--green);font-weight:700;margin-top:8px;display:none;}
.aj-complete-small.on{display:block;}
.aj-admin-row{display:grid;grid-template-columns:1fr 40px;gap:8px;align-items:start;margin-bottom:8px;}
.aj-admin-row textarea{width:100%;min-height:58px;background:rgba(0,0,0,.3);border:1.5px solid var(--adm-border);border-radius:8px;padding:8px 10px;color:var(--adm-text);font-size:.82rem;outline:none;resize:vertical;}
.aj-admin-row textarea:focus{border-color:var(--gold);}
.aj-admin-del{height:36px;border-radius:8px;border:1px solid rgba(192,57,43,.28);background:rgba(192,57,43,.12);color:#e74c3c;font-weight:800;}
.aj-preview-card{background:rgba(201,146,42,.08);border:1px solid rgba(201,146,42,.25);border-radius:12px;padding:13px;color:var(--adm-text);font-size:.84rem;line-height:1.5;}
.aj-status-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:999px;font-size:.68rem;font-weight:800;border:1px solid var(--adm-border);white-space:nowrap;}
.aj-status-chip.done{background:rgba(45,140,95,.15);border-color:rgba(45,140,95,.3);color:#4ade80;}
.aj-status-chip.pending{background:rgba(201,146,42,.15);border-color:rgba(201,146,42,.3);color:var(--gold2);}
.aj-status-chip.off{background:rgba(255,255,255,.05);border-color:var(--adm-border);color:var(--adm-muted);}
.aj-status-sub{font-size:.64rem;color:var(--adm-muted);margin-top:3px;line-height:1.25;}

@media(max-width:680px){.student-message-stack{gap:14px;}}

/* ════════════════════════════════════
   MASTERY DASHBOARD
════════════════════════════════════ */
.mastery-layout{display:grid;grid-template-columns:1fr 280px;gap:18px;align-items:start;}
.mastery-goals{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:20px;}
.mastery-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.mastery-title{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--navy);}
.mastery-prog-text{font-size:.76rem;color:var(--muted);}
.mastery-bar-wrap{margin-bottom:16px;}
.mastery-bar-track{height:10px;background:var(--surface2);border-radius:5px;overflow:hidden;border:1px solid var(--border);}
.mastery-bar-fill{height:100%;border-radius:5px;background:linear-gradient(90deg,var(--navy),var(--gold));transition:width 1.2s ease;}
.goal-item{
  display:flex;align-items:center;gap:11px;
  padding:10px 12px;border-radius:9px;
  border:1px solid var(--border2);background:var(--surface2);
  margin-bottom:5px;
}
.goal-item.done{background:#eafaf1;border-color:rgba(45,140,95,.2);}
.goal-num{font-family:'Playfair Display',serif;font-size:.85rem;color:var(--muted);width:22px;flex-shrink:0;text-align:right;}
.goal-icon{
  width:24px;height:24px;border-radius:50%;border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;
  background:var(--warm-white);
}
.goal-item.done .goal-icon{background:var(--green);border-color:var(--green);color:var(--warm-white);}
.goal-text{flex:1;font-size:.81rem;font-weight:600;color:var(--navy);}
.goal-item.done .goal-text{text-decoration:line-through;opacity:.5;}
.goal-cat{font-size:.63rem;padding:1px 7px;border-radius:20px;background:var(--gold-glow);color:var(--gold);border:1px solid rgba(201,146,42,.2);flex-shrink:0;}

/* mountain */
.mastery-mountain{
  background:var(--warm-white);border:1px solid var(--border);border-radius:var(--r);
  box-shadow:var(--shadow);padding:18px;text-align:center;
  position:sticky;top:22px;
}
.mm-title{font-family:'Playfair Display',serif;font-size:.95rem;color:var(--navy);margin-bottom:4px;}
.mm-sub{font-size:.7rem;color:var(--muted);margin-bottom:14px;}
.mm-wrap{position:relative;width:200px;margin:0 auto;}
.mm-svg{width:100%;display:block;}
.mm-stat{margin-top:14px;}
.mm-count{font-family:'Playfair Display',serif;font-size:2rem;color:var(--navy);}
.mm-label{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.mm-notice{
  margin-top:12px;padding:9px 12px;border-radius:9px;
  font-size:.72rem;font-weight:600;text-align:center;
}
.mm-notice.almost{background:#fff8e1;border:1px solid rgba(201,146,42,.3);color:var(--gold);}
.mm-notice.done{background:#eafaf1;border:1px solid rgba(45,140,95,.25);color:var(--green);}
.mm-admin-note{font-size:.68rem;color:var(--faint);margin-top:10px;line-height:1.5;}

@media(max-width:780px){.mastery-layout{grid-template-columns:1fr;}.mastery-mountain{position:static;}}
@media(max-width:680px){.bottom-grid{grid-template-columns:1fr;}.subjects-grid{grid-template-columns:1fr;}}

/* ════════════════════════════════════
   ADMIN PANEL
════════════════════════════════════ */
#pg-admin{min-height:100vh;background:var(--adm-bg);}
.adm-layout{display:flex;min-height:100vh;}

.adm-sb{
  width:230px;flex-shrink:0;background:var(--adm-surface);
  border-right:1px solid var(--adm-border);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;
}
.adm-sb-logo{padding:22px 18px 16px;border-bottom:1px solid var(--adm-border);}
.adm-sb-school{font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--gold2);font-weight:700;line-height:1.2;}
.adm-sb-role{font-size:.65rem;color:var(--adm-muted);margin-top:3px;text-transform:uppercase;letter-spacing:.8px;}
.adm-rule{width:30px;height:2px;background:var(--gold);border-radius:1px;margin-top:8px;}
.adm-nav{padding:14px 10px;flex:1;}
.adm-sec{font-size:.58rem;font-weight:700;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:1.3px;padding:0 8px;margin:14px 0 5px;}
/* Collapsible admin sidebar groups */
.adm-sec-toggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:10px 11px;margin:8px 0 3px;border:none;border-radius:9px;background:transparent;
  color:var(--adm-muted);font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.9px;
  cursor:pointer;transition:all .2s;text-align:left;
}
.adm-sec-toggle:hover{background:rgba(255,255,255,.06);color:var(--gold2);}
.adm-sec-toggle.open{background:rgba(201,146,42,.12);color:var(--gold2);}
.adm-sec-caret{font-size:.7rem;transition:transform .2s;}
.adm-sec-toggle.open .adm-sec-caret{transform:rotate(90deg);}
.adm-sec-items{display:none;padding-left:7px;margin-bottom:5px;}
.adm-sec-items.open{display:block;}
.adm-btn{
  display:flex;align-items:center;gap:9px;width:100%;padding:9px 11px;
  border-radius:9px;border:none;background:transparent;
  color:var(--adm-muted);font-size:.84rem;font-weight:500;
  transition:all .2s;margin-bottom:2px;text-align:left;
}
.adm-btn:hover{background:rgba(255,255,255,.07);color:var(--adm-text);}
.adm-btn.on{background:rgba(201,146,42,.15);color:var(--gold2);}
.adm-icon{font-size:.9rem;width:17px;text-align:center;}
.adm-ft{padding:13px;border-top:1px solid var(--adm-border);}
.adm-out{width:100%;background:rgba(192,57,43,.12);border:1px solid rgba(192,57,43,.25);border-radius:9px;padding:8px;color:#e74c3c;font-weight:700;font-size:.8rem;}

.adm-main{flex:1;padding:28px;overflow-y:auto;}
.adm-pg{display:none;}.adm-pg.on{display:block;}
.adm-title{font-family:'Playfair Display',serif;font-size:1.55rem;color:var(--adm-text);margin-bottom:4px;}
.adm-sub{font-size:.8rem;color:var(--adm-muted);margin-bottom:22px;}

/* admin cards */
.ac{background:var(--adm-surface);border:1px solid var(--adm-border);border-radius:14px;padding:20px;margin-bottom:14px;}
.ach{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--adm-muted);margin-bottom:14px;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin-bottom:16px;}
.stat-box{background:var(--adm-surface);border:1px solid var(--adm-border);border-radius:12px;padding:16px;}
.stat-n{font-family:'Playfair Display',serif;font-size:1.9rem;color:var(--gold2);}
.stat-l{font-size:.68rem;color:var(--adm-muted);font-weight:600;margin-top:2px;}

/* forms */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:11px;}
.fg.one{grid-template-columns:1fr;}
.af{display:flex;flex-direction:column;gap:4px;}
.af label{font-size:.66rem;font-weight:600;color:var(--adm-muted);text-transform:uppercase;letter-spacing:.5px;}
.af input,.af select,.af textarea{background:rgba(0,0,0,.3);border:1.5px solid var(--adm-border);border-radius:8px;padding:8px 10px;color:var(--adm-text);font-size:.85rem;outline:none;transition:border-color .2s;}
.af input:focus,.af select:focus,.af textarea:focus{border-color:var(--gold);}
.af select option{background:#0f2040;}
.ab{padding:9px 18px;border-radius:9px;border:none;font-weight:700;font-size:.83rem;transition:all .2s;}
.ab-navy{background:var(--gold);color:var(--navy);}.ab-navy:hover{background:var(--gold2);}
.ab-red{background:rgba(192,57,43,.12);border:1px solid rgba(192,57,43,.3);color:#e74c3c;}.ab-red:hover{background:rgba(192,57,43,.22);}
.ab-ghost{background:rgba(255,255,255,.07);border:1px solid var(--adm-border);color:var(--adm-muted);}.ab-ghost:hover{background:rgba(255,255,255,.12);color:var(--adm-text);}

/* tables */
.at{width:100%;border-collapse:collapse;font-size:.81rem;}
.at th{text-align:left;padding:8px 12px;font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--adm-muted);border-bottom:1px solid var(--adm-border);}
.at td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle;color:var(--adm-text);}
.at tr:hover td{background:rgba(255,255,255,.03);}
.bdg{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.65rem;font-weight:700;}
.bdg-b{background:rgba(37,99,235,.15);color:#60a5fa;}
.bdg-g{background:rgba(45,140,95,.15);color:#4ade80;}
.bdg-y{background:rgba(201,146,42,.15);color:var(--gold2);}
.bdg-r{background:rgba(231,76,60,.15);color:#e74c3c;}

/* day schedule editor */
.day-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap;}
.day-tab{padding:7px 16px;border-radius:20px;border:2px solid var(--adm-border);background:transparent;color:var(--adm-muted);font-weight:600;font-size:.79rem;transition:all .2s;}
.day-tab:hover{border-color:var(--gold);color:var(--gold);}
.day-tab.on{background:rgba(201,146,42,.15);border-color:var(--gold);color:var(--gold2);}
.grade-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap;}
.grade-tab{padding:5px 13px;border-radius:20px;border:2px solid var(--adm-border);background:transparent;color:var(--adm-muted);font-weight:600;font-size:.76rem;transition:all .2s;}
.grade-tab:hover,.grade-tab.on{border-color:var(--gold);color:var(--gold2);}
.grade-tab.on{background:rgba(201,146,42,.12);}

/* subject block editor */
.sbe{border:1px solid var(--adm-border);border-radius:11px;background:rgba(0,0,0,.15);margin-bottom:8px;overflow:hidden;}
.sbe-hd{display:flex;align-items:center;gap:9px;padding:10px 13px;border-bottom:1px solid var(--adm-border);}
.sbe-color{width:4px;align-self:stretch;border-radius:2px;flex-shrink:0;}
.sbe-name{flex:1;font-size:.85rem;font-weight:700;color:var(--adm-text);}
.sbe-del{background:none;border:none;color:var(--adm-muted);font-size:.95rem;padding:2px 4px;transition:color .2s;}
.sbe-del:hover{color:#e74c3c;}

/* ── Puzzle editor ── */
.pz-row{border:1px solid var(--adm-border);border-radius:10px;background:rgba(0,0,0,.15);margin-bottom:8px;padding:11px 13px;}
.pz-row-top{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.pz-row-top input{flex:1;background:rgba(0,0,0,.25);border:1.5px solid var(--adm-border);border-radius:7px;padding:6px 9px;color:var(--adm-text);font-size:.82rem;outline:none;}
.pz-row-top input:focus{border-color:var(--gold);}
.pz-row-top .pz-del{background:none;border:none;color:var(--adm-muted);font-size:1rem;cursor:pointer;padding:2px 5px;flex-shrink:0;}
.pz-row-top .pz-del:hover{color:#e74c3c;}
.pz-opts-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:7px;}
.pz-opts-grid input{background:rgba(0,0,0,.22);border:1.5px solid var(--adm-border);border-radius:7px;padding:5px 8px;color:var(--adm-text);font-size:.78rem;outline:none;}
.pz-opts-grid input:focus{border-color:var(--gold);}
.pz-opts-grid input.correct-opt{border-color:#2d8c5f;background:rgba(45,140,95,.12);}
.pz-row-meta{display:flex;align-items:center;gap:10px;font-size:.72rem;color:var(--adm-muted);}
.pz-row-meta label{display:flex;align-items:center;gap:4px;cursor:pointer;}
.pz-row-meta input[type=text]{width:80px;background:rgba(0,0,0,.22);border:1px solid var(--adm-border);border-radius:5px;padding:3px 7px;color:var(--adm-text);font-size:.72rem;outline:none;}
.pz-answer-note{font-size:.68rem;color:var(--gold2);margin-top:4px;}
.sbe-body{padding:12px;}
.task-row{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:8px;border:1px solid var(--adm-border);background:rgba(0,0,0,.18);margin-bottom:5px;}
.task-row input[type="text"]{flex:1;background:transparent;border:none;color:var(--adm-text);font-size:.81rem;outline:none;}
.task-row .ti{font-size:.72rem;color:var(--adm-muted);width:60px;background:rgba(0,0,0,.25);border:1px solid var(--adm-border);border-radius:5px;padding:3px 6px;outline:none;color:var(--adm-text);}
.task-row .td{background:none;border:none;color:var(--adm-muted);font-size:.9rem;cursor:pointer;transition:color .2s;padding:0;}
.task-row .td:hover{color:#e74c3c;}
.add-task-btn{display:flex;align-items:center;gap:6px;padding:6px 11px;border-radius:7px;border:1.5px dashed rgba(201,146,42,.3);background:transparent;color:var(--gold);font-weight:600;font-size:.75rem;margin-top:4px;transition:all .2s;}
.add-task-btn:hover{background:rgba(201,146,42,.08);}
.add-subj-btn{display:flex;align-items:center;gap:7px;padding:9px 15px;border-radius:9px;border:2px dashed rgba(201,146,42,.28);background:transparent;color:var(--gold);font-weight:700;font-size:.82rem;margin-top:6px;transition:all .2s;}
.add-subj-btn:hover{background:rgba(201,146,42,.08);}

/* mastery admin */
.mga-row{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:9px;border:1px solid var(--adm-border);background:rgba(0,0,0,.15);margin-bottom:5px;}
.mga-n{font-family:'Playfair Display',serif;font-size:.88rem;color:var(--adm-muted);width:24px;flex-shrink:0;}
.mga-text{flex:1;font-size:.81rem;font-weight:600;color:var(--adm-text);}
.mga-tog{padding:4px 12px;border-radius:20px;border:none;font-size:.7rem;font-weight:700;cursor:pointer;transition:all .2s;}
.mga-tog.done{background:rgba(45,140,95,.15);border:1px solid rgba(45,140,95,.3);color:#4ade80;}
.mga-tog.pend{background:rgba(255,255,255,.05);border:1px solid var(--adm-border);color:var(--adm-muted);}

/* student progress viewer */
.spv-hdr{display:flex;align-items:center;gap:11px;margin-bottom:14px;}
.spv-av{width:42px;height:42px;border-radius:50%;background:rgba(201,146,42,.15);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}

/* admin messages */
.adm-thread{display:flex;flex-direction:column;gap:8px;max-height:260px;overflow-y:auto;margin-bottom:11px;}
.adm-msg-input-row{display:flex;gap:8px;}
.adm-msg-input{flex:1;background:rgba(0,0,0,.3);border:1.5px solid var(--adm-border);border-radius:10px;padding:9px 12px;color:var(--adm-text);font-size:.82rem;outline:none;resize:none;max-height:80px;}
.adm-msg-input:focus{border-color:var(--gold);}
.adm-msg-send{background:var(--gold);border:none;border-radius:10px;padding:9px 15px;color:var(--navy);font-weight:700;font-size:.81rem;}

/* copy modal */
.modal-bg{position:fixed;inset:0;z-index:800;background:rgba(0,0,0,.6);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;}
.modal-bg.on{opacity:1;pointer-events:all;}
.modal{background:var(--adm-surface);border:1px solid var(--adm-border);border-radius:18px;padding:28px;width:100%;max-width:440px;box-shadow:0 30px 80px rgba(0,0,0,.5);}
.modal-title{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--adm-text);margin-bottom:5px;}
.modal-sub{font-size:.77rem;color:var(--adm-muted);margin-bottom:18px;}
.copy-list{display:flex;flex-direction:column;gap:5px;max-height:240px;overflow-y:auto;margin-bottom:16px;}
.copy-row{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:9px;border:1px solid var(--adm-border);background:rgba(0,0,0,.2);cursor:pointer;transition:all .18s;}
.copy-row:hover{background:rgba(255,255,255,.05);}
.copy-row.sel{background:rgba(201,146,42,.12);border-color:rgba(201,146,42,.35);}
.copy-chk{width:17px;height:17px;border-radius:4px;border:2px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;transition:all .18s;}
.copy-row.sel .copy-chk{background:var(--gold);border-color:var(--gold);color:var(--navy);}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;}

/* overlay celebration */
.overlay{position:fixed;inset:0;z-index:900;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.7);opacity:0;pointer-events:none;transition:opacity .3s;}
.overlay.on{opacity:1;pointer-events:all;}
.cel{background:var(--warm-white);border:3px solid var(--gold);border-radius:24px;padding:48px 52px;text-align:center;max-width:420px;animation:cpop .5s cubic-bezier(.175,.885,.32,1.275);}
@keyframes cpop{from{transform:scale(.5);}to{transform:scale(1);}}
.cel-ico{font-size:3.5rem;margin-bottom:12px;}
.cel-title{font-family:'Playfair Display',serif;font-size:2rem;color:var(--navy);}
.cel-sub{color:var(--muted);font-size:.87rem;margin:10px 0 22px;line-height:1.55;}
.cel-btn{background:var(--navy);color:var(--gold2);border:none;border-radius:12px;padding:12px 32px;font-weight:700;font-size:.95rem;}
.conf{position:fixed;width:9px;height:9px;pointer-events:none;z-index:901;border-radius:2px;animation:cfall var(--d) ease-in forwards;}
@keyframes cfall{0%{opacity:1;transform:translateY(-50px) rotate(0);}100%{opacity:0;transform:translateY(110vh) rotate(720deg);}}

/* ── ASSESSMENT TAB ── */
.assess-intro{background:var(--navy);color:var(--warm-white);border-radius:var(--r);padding:20px 24px;margin-bottom:18px;display:flex;align-items:flex-start;gap:16px;}
.assess-intro-icon{font-size:2rem;flex-shrink:0;margin-top:2px;}
.assess-intro-title{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--gold2);margin-bottom:4px;}
.assess-intro-sub{font-size:.8rem;color:rgba(255,255,255,.7);line-height:1.55;}
.assess-period-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px;}
@media(max-width:720px){.assess-period-grid{grid-template-columns:1fr;}}
.assess-period-card{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;}
.apc-header{padding:13px 16px;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:10px;}
.apc-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.apc-title{font-family:'Playfair Display',serif;font-size:.95rem;font-weight:700;color:var(--navy);}
.apc-sub{font-size:.68rem;color:var(--muted);margin-top:1px;}
.apc-body{padding:14px 16px;}
.score-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border2);}
.score-row:last-child{border-bottom:none;}
.score-area{display:flex;align-items:center;gap:8px;}
.score-area-icon{font-size:1rem;flex-shrink:0;}
.score-area-label{font-size:.82rem;font-weight:600;color:var(--navy);}
.score-area-sub{font-size:.68rem;color:var(--muted);margin-top:1px;}
.score-val-wrap{text-align:right;}
.score-val{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--navy);line-height:1;}
.score-val.empty{font-size:.8rem;color:var(--faint);font-family:'Inter',sans-serif;font-weight:400;}
.score-tag{display:inline-block;font-size:.62rem;font-weight:700;padding:1px 7px;border-radius:20px;margin-top:3px;}
.score-tag.above{background:#d4edda;color:var(--green);}
.score-tag.on{background:#fff8e1;color:var(--gold);}
.score-tag.below{background:#fde8e6;color:var(--red);}
.score-tag.none{display:none;}
/* growth arrows between periods */
.assess-growth-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px;}
.agr-card{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:14px 16px;}
.agr-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin-bottom:10px;}
.agr-item{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;}
.agr-label{font-size:.79rem;font-weight:600;color:var(--navy);}
.agr-delta{font-size:.85rem;font-weight:700;}
.agr-delta.pos{color:var(--green);}
.agr-delta.neg{color:var(--red);}
.agr-delta.neu{color:var(--muted);}
/* admin assessment form */
.assess-adm-period{border:1px solid var(--adm-border);border-radius:11px;background:rgba(0,0,0,.12);margin-bottom:10px;overflow:hidden;}
.aap-hd{display:flex;align-items:center;gap:9px;padding:11px 14px;border-bottom:1px solid var(--adm-border);}
.aap-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.aap-title{font-size:.87rem;font-weight:700;color:var(--adm-text);}
.aap-sub{font-size:.69rem;color:var(--adm-muted);margin-left:auto;}
.aap-body{padding:13px;}
.aap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.aap-field{display:flex;flex-direction:column;gap:4px;}
.aap-label{font-size:.64rem;font-weight:700;color:var(--adm-muted);text-transform:uppercase;letter-spacing:.5px;}
.aap-input{background:rgba(0,0,0,.3);border:1.5px solid var(--adm-border);border-radius:7px;padding:7px 10px;color:var(--adm-text);font-size:.86rem;outline:none;transition:border-color .2s;width:100%;}
.aap-input:focus{border-color:var(--gold);}


/* ─── Compact dropdowns for Parent History + Student Reading List ─── */
.reading-list-dropdown summary{list-style:none;cursor:pointer;user-select:none;margin-bottom:0;}
.reading-list-dropdown summary::-webkit-details-marker{display:none;}
.reading-list-dropdown .wc-title::after{content:' ▼';font-size:.7rem;color:var(--gold);font-family:Inter,sans-serif;}
.reading-list-dropdown[open] .wc-title::after{content:' ▲';}
.reading-list-dropdown #bk-list{margin-top:12px;max-height:360px;overflow-y:auto;padding-right:4px;}
.sp-scroll-history{max-height:220px;overflow-y:auto;padding-right:6px;margin-top:8px;}
.sp-compact-note-empty{color:var(--adm-muted);font-size:.75rem;}

/* ─── STUDENT PROGRESS TAB ─── */
.sp-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:14px;align-items:start;}
.sp-card{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:17px;margin-bottom:14px;}
.sp-card-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.sp-muted{font-size:.76rem;color:var(--muted);line-height:1.5;}
.sp-summary-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--border2);}
.sp-summary-row:last-child{border-bottom:none;}
.sp-summary-label{font-size:.84rem;font-weight:700;color:var(--navy);}
.sp-summary-bar{height:8px;background:var(--surface2);border:1px solid var(--border);border-radius:999px;overflow:hidden;margin-top:5px;}
.sp-summary-fill{height:100%;background:linear-gradient(90deg,var(--navy),var(--gold));border-radius:999px;}
.sp-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;border-radius:999px;background:var(--gold-glow);border:1px solid rgba(201,146,42,.22);color:var(--gold);font-size:.68rem;font-weight:800;white-space:nowrap;}
.sp-list{display:flex;flex-direction:column;gap:7px;}
.sp-list-item{padding:9px 11px;border-radius:9px;background:var(--surface2);border:1px solid var(--border2);font-size:.82rem;font-weight:600;color:var(--navy);line-height:1.35;}
.sp-list-item.growth{background:var(--gold-glow);border-color:rgba(201,146,42,.22);}
.sp-list-item.project{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;}
.sp-due{font-size:.68rem;color:var(--muted);font-weight:700;white-space:nowrap;}
.sp-note{background:var(--surface2);border-left:4px solid var(--gold);border-radius:10px;padding:12px 13px;font-size:.86rem;line-height:1.55;color:var(--navy);}
.sp-review-box{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;background:var(--green-lt);border:1px solid rgba(45,140,95,.22);border-radius:12px;padding:12px 14px;}
.sp-review-btn{background:var(--navy);color:var(--gold2);border:none;border-radius:9px;padding:9px 14px;font-weight:800;font-size:.8rem;}
.sp-admin-check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;}
.sp-admin-check{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border:1px solid var(--adm-border);border-radius:9px;background:rgba(0,0,0,.16);font-size:.8rem;color:var(--adm-text);line-height:1.35;cursor:pointer;}
.sp-admin-check input{margin-top:2px;accent-color:var(--gold);}
.sp-project-row{display:grid;grid-template-columns:1fr 145px 130px 34px;gap:8px;align-items:start;margin-bottom:8px;}
.sp-project-row input,.sp-project-row select{background:rgba(0,0,0,.3);border:1.5px solid var(--adm-border);border-radius:8px;padding:8px 10px;color:var(--adm-text);font-size:.82rem;outline:none;}
.sp-project-row input:focus,.sp-project-row select:focus{border-color:var(--gold);}
.sp-share-box{border:1px solid rgba(201,146,42,.25);background:rgba(201,146,42,.08);border-radius:12px;padding:13px;margin-top:12px;}
.sp-share-top{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px;}
.sp-share-title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--gold2);}
.sp-share-help{font-size:.74rem;color:var(--adm-muted);line-height:1.45;margin-bottom:10px;}
.sp-share-options{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px;}
.sp-share-options label{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--adm-text);}
.sp-share-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;max-height:150px;overflow-y:auto;padding:4px;}
.sp-share-student{display:flex;align-items:center;gap:7px;border:1px solid var(--adm-border);background:rgba(0,0,0,.18);border-radius:8px;padding:7px 9px;font-size:.78rem;color:var(--adm-text);}
.sp-share-student input,.sp-share-options input{accent-color:var(--gold);}
.sp-parent-note-box{background:var(--surface2);border:1px solid var(--border2);border-radius:12px;padding:12px;margin-top:12px;}
.sp-parent-note-box textarea{width:100%;min-height:78px;background:var(--warm-white);border:1.5px solid var(--border);border-radius:9px;padding:10px 12px;color:var(--navy);font-size:.84rem;outline:none;resize:vertical;}
.sp-parent-note-box textarea:focus{border-color:var(--gold);}
.sp-parent-note-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px;}
.sp-parent-note-send{background:var(--gold);color:var(--navy);border:none;border-radius:9px;padding:8px 13px;font-weight:800;font-size:.78rem;}
.sp-parent-note-send:hover{background:var(--gold2);}
.sp-parent-note-status{font-size:.72rem;color:var(--muted);font-weight:600;}
.overview-wait-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.65rem;font-weight:800;background:rgba(201,146,42,.15);color:var(--gold2);border:1px solid rgba(201,146,42,.25);margin-left:6px;}
.sp-snapshot-box{margin-top:8px;border:1px solid var(--adm-border);border-radius:10px;background:rgba(0,0,0,.18);padding:10px;font-size:.75rem;color:var(--adm-muted);line-height:1.45;}
.sp-snapshot-box summary{cursor:pointer;color:var(--gold2);font-weight:800;margin-bottom:6px;}
.sp-ack-note{font-size:.78rem;color:var(--adm-text);line-height:1.45;background:rgba(255,255,255,.05);border:1px solid var(--adm-border);border-radius:8px;padding:8px 10px;}
@media(max-width:850px){.sp-grid{grid-template-columns:1fr;}.sp-admin-check-grid{grid-template-columns:1fr;}.sp-project-row{grid-template-columns:1fr;}.sp-share-grid{grid-template-columns:1fr;}}

/* ── FLOATING TIMER ── */
.timer-toggle-btn{
  display:flex;align-items:center;gap:6px;
  padding:7px 13px;border-radius:8px;border:1.5px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.1);color:var(--warm-white);
  font-size:.78rem;font-weight:600;transition:all .2s;
  white-space:nowrap;
}
.timer-toggle-btn:hover{background:rgba(255,255,255,.18);}
.timer-toggle-btn.running{border-color:var(--gold);color:var(--gold2);background:rgba(201,146,42,.15);}
.timer-toggle-btn .tbadge{
  font-family:'Playfair Display',serif;font-size:.85rem;font-weight:700;
  background:rgba(0,0,0,.25);border-radius:5px;padding:1px 6px;
  letter-spacing:.5px;min-width:52px;text-align:center;
}

.timer-panel{
  position:fixed;bottom:28px;right:24px;z-index:400;
  width:300px;
  background:var(--warm-white);
  border:1.5px solid var(--border);
  border-radius:16px;
  box-shadow:0 12px 40px rgba(13,34,64,.18),0 2px 8px rgba(13,34,64,.1);
  overflow:hidden;
  display:none;
  animation:timerIn .22s cubic-bezier(.175,.885,.32,1.275);
}
.timer-panel.open{display:block;}
@keyframes timerIn{from{opacity:0;transform:translateY(14px) scale(.96);}to{opacity:1;transform:none;}}

.timer-panel-hd{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--navy);padding:11px 15px;
  cursor:move;
  user-select:none;
  touch-action:none;
}
.timer-panel-title{font-family:'Playfair Display',serif;font-size:.9rem;color:var(--gold2);font-weight:700;}
.timer-close{background:none;border:none;color:rgba(255,255,255,.5);font-size:1.1rem;line-height:1;padding:0 2px;transition:color .2s;}
.timer-close:hover{color:var(--warm-white);}

.timer-display-wrap{
  padding:20px 18px 6px;text-align:center;
}
.timer-display{
  font-family:'Playfair Display',serif;
  font-size:3.2rem;font-weight:700;
  color:var(--navy);letter-spacing:2px;
  line-height:1;margin-bottom:4px;
  transition:color .3s;
}
.timer-display.warning{color:#c0392b;}
.timer-display.done{color:var(--green);}
.timer-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);}

/* preset chips */
.timer-presets{
  display:flex;gap:5px;flex-wrap:wrap;justify-content:center;
  padding:10px 14px 6px;
}
.timer-preset{
  padding:4px 10px;border-radius:20px;border:1.5px solid var(--border);
  background:var(--surface2);color:var(--navy);
  font-size:.72rem;font-weight:600;transition:all .18s;
}
.timer-preset:hover{background:var(--navy);color:var(--warm-white);border-color:var(--navy);}

/* custom time input */
.timer-custom-row{
  display:flex;align-items:center;gap:6px;
  padding:6px 14px 10px;justify-content:center;
}
.timer-adj{
  width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border);
  background:var(--surface2);color:var(--navy);font-size:1rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;transition:all .18s;
  flex-shrink:0;
}
.timer-adj:hover{background:var(--navy);color:var(--warm-white);border-color:var(--navy);}
.timer-custom-inp{
  width:68px;text-align:center;background:var(--surface2);
  border:1.5px solid var(--border);border-radius:8px;
  padding:5px 6px;font-size:.84rem;font-weight:600;color:var(--navy);
  outline:none;transition:border-color .2s;
}
.timer-custom-inp:focus{border-color:var(--gold);}
.timer-custom-label{font-size:.72rem;color:var(--muted);}

/* controls */
.timer-controls{
  display:flex;gap:8px;padding:0 14px 16px;justify-content:center;
}
.t-btn{
  flex:1;padding:10px;border-radius:10px;border:none;
  font-size:.82rem;font-weight:700;transition:all .2s;
}
.t-btn-start{background:var(--navy);color:var(--gold2);}
.t-btn-start:hover{background:var(--navy3);}
.t-btn-start.running{background:#e8f5e9;color:var(--green);border:1.5px solid rgba(45,140,95,.3);}
.t-btn-reset{background:var(--surface2);color:var(--slate);border:1.5px solid var(--border);}
.t-btn-reset:hover{background:#fde8e6;color:var(--red);border-color:rgba(192,57,43,.3);}

/* hide claude.ai preview attribution banner */
[class*="claude-"],[id*="claude-"],
div[style*="claude"],
.claude-disclaimer,
.artifact-footer,
#artifact-footer{display:none!important;height:0!important;overflow:hidden!important;}

.timer-sound-row{
  display:flex;align-items:center;gap:6px;
  padding:0 14px 10px;
}
.timer-sound-label{font-size:.68rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;}
.sound-opts{display:flex;gap:5px;flex:1;}
.sound-opt{
  flex:1;padding:5px 4px;border-radius:8px;
  border:1.5px solid var(--border);background:var(--surface2);
  color:var(--navy);font-size:.69rem;font-weight:600;
  transition:all .18s;text-align:center;line-height:1.3;
}
.sound-opt:hover{border-color:var(--navy);background:var(--navy);color:var(--warm-white);}
.sound-opt.on{background:var(--navy);color:var(--gold2);border-color:var(--navy);}
.sound-preview{
  background:none;border:none;color:var(--muted);
  font-size:.82rem;padding:0 2px;transition:color .18s;flex-shrink:0;
}
.sound-preview:hover{color:var(--navy);}


@keyframes timerFlash{0%,100%{background:var(--warm-white);}50%{background:#d4edda;}}
.timer-panel.flash{animation:timerFlash .5s ease 3;}


/* ─── Message popup overlay ─── */
.msg-popup{position:fixed;inset:0;z-index:950;background:rgba(13,34,64,.82);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;}
.msg-popup.on{opacity:1;pointer-events:all;}
.msg-popup-card{background:var(--warm-white);border-radius:20px;box-shadow:0 24px 72px rgba(13,34,64,.35);padding:36px 38px;max-width:460px;width:100%;text-align:center;}
.msg-popup-from{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--gold);margin-bottom:8px;}
.msg-popup-text{font-size:1rem;color:var(--navy);line-height:1.6;margin-bottom:20px;font-weight:500;}
.msg-popup-time{font-size:.72rem;color:var(--muted);margin-bottom:20px;}
.msg-popup-btn{background:var(--navy);color:var(--gold2);border:none;border-radius:11px;padding:11px 28px;font-weight:700;font-size:.9rem;}

/* ─── Per-student schedule ─── */
.st-sched-tabs{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px;}
.st-sched-tab{padding:5px 13px;border-radius:20px;border:2px solid var(--adm-border);background:transparent;color:var(--adm-muted);font-weight:600;font-size:.76rem;transition:all .2s;}
.st-sched-tab:hover,.st-sched-tab.on{border-color:var(--gold);color:var(--gold2);}
.st-sched-tab.on{background:rgba(201,146,42,.12);}
.sched-source-bar{display:flex;align-items:center;gap:8px;padding:9px 13px;background:rgba(201,146,42,.08);border:1px solid rgba(201,146,42,.22);border-radius:9px;margin-bottom:12px;font-size:.78rem;color:var(--gold2);}
.sched-source-bar button{margin-left:auto;padding:4px 11px;border-radius:7px;border:1px solid rgba(201,146,42,.35);background:rgba(201,146,42,.12);color:var(--gold2);font-size:.72rem;font-weight:700;cursor:pointer;}
.sched-source-bar button:hover{background:rgba(201,146,42,.22);}

/* ─── Book row with writing prompt ─── */
.bk-row-wrap{border:1px solid var(--adm-border);border-radius:10px;background:rgba(0,0,0,.12);margin-bottom:7px;overflow:hidden;}
.bk-row-main{display:flex;align-items:center;gap:8px;padding:9px 10px;}
.bk-prompt-row{padding:7px 10px 10px;border-top:1px solid var(--adm-border);background:rgba(0,0,0,.1);}
.bk-prompt-label{font-size:.64rem;font-weight:700;color:var(--gold2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;}
.bk-prompt-inp{width:100%;background:rgba(0,0,0,.28);border:1.5px solid var(--adm-border);border-radius:7px;padding:7px 9px;color:var(--adm-text);font-size:.8rem;outline:none;resize:vertical;min-height:52px;}
.bk-prompt-inp:focus{border-color:var(--gold);}

/* ─── Student book with prompt ─── */
.bk-completed-section{padding:10px 12px;background:var(--green-lt);border-top:1px solid rgba(45,140,95,.18);}
.bk-prompt-display{font-size:.82rem;color:var(--navy);line-height:1.5;margin-bottom:10px;font-style:italic;}
.bk-prompt-title{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--green);margin-bottom:4px;}
.bk-check-row{display:flex;align-items:center;gap:9px;cursor:pointer;user-select:none;padding:7px 10px;background:var(--warm-white);border-radius:8px;border:1px solid rgba(45,140,95,.2);}
.bk-check-row .task-cb{flex-shrink:0;}
.bk-check-label{font-size:.82rem;font-weight:600;color:var(--navy);}

/* ─── Reading list order note ─── */
.bk-order-note{display:flex;align-items:center;gap:8px;padding:8px 12px;background:rgba(201,146,42,.08);border:1px solid rgba(201,146,42,.2);border-radius:9px;margin-bottom:10px;font-size:.76rem;color:var(--gold);font-weight:600;}

/* ─── Reading progress tracking ─── */
.reading-status-chip{display:inline-flex;align-items:center;gap:5px;font-size:.64rem;font-weight:800;padding:3px 8px;border-radius:20px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);white-space:nowrap;}
.reading-status-chip.complete{background:var(--green-lt);border-color:rgba(45,140,95,.28);color:var(--green);}
.reading-status-chip.ready{background:var(--gold-glow);border-color:rgba(201,146,42,.3);color:var(--gold);}
.reading-status-chip.need{background:var(--red-lt);border-color:rgba(192,57,43,.22);color:var(--red);}
.reading-progress-panel{padding:11px 12px;background:var(--surface2);border-top:1px solid var(--border2);}
.reading-action-grid{display:grid;grid-template-columns:1fr;gap:7px;margin-top:8px;}
.reading-action-row{display:flex;align-items:center;gap:8px;background:var(--warm-white);border:1px solid var(--border2);border-radius:9px;padding:8px 10px;font-size:.8rem;font-weight:700;color:var(--navy);}
.reading-action-row.clickable{cursor:pointer;transition:all .18s;}
.reading-action-row.clickable:hover{border-color:var(--gold);box-shadow:var(--shadow);}
.reading-score-row{display:grid;grid-template-columns:1fr 96px 96px auto;gap:7px;align-items:center;margin-top:7px;}
.reading-score-row input{background:var(--warm-white);border:1.5px solid var(--border);border-radius:8px;padding:7px 8px;color:var(--navy);font-size:.78rem;outline:none;}
.reading-score-row input:focus{border-color:var(--gold);}
.reading-mini{font-size:.68rem;color:var(--muted);line-height:1.45;margin-top:5px;}
.bk-locked{font-size:.72rem;color:var(--muted);margin-top:6px;font-style:italic;background:var(--surface2);border:1px dashed var(--border);border-radius:8px;padding:8px 10px;}
.bk-quiz-note{display:inline-flex;align-items:center;gap:5px;margin:8px 0 4px;background:var(--gold-glow);border:1px solid rgba(201,146,42,.22);border-radius:8px;padding:7px 10px;font-size:.76rem;font-weight:800;color:var(--gold);}

.rp-card{border:1px solid var(--adm-border);background:rgba(0,0,0,.13);border-radius:12px;padding:13px;margin-bottom:9px;}
.rp-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px;}
.rp-title{font-size:.9rem;font-weight:800;color:var(--adm-text);}
.rp-sub{font-size:.7rem;color:var(--adm-muted);margin-top:2px;}
.rp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.rp-box{background:rgba(255,255,255,.045);border:1px solid var(--adm-border);border-radius:9px;padding:9px;}
.rp-label{font-size:.58rem;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--adm-muted);margin-bottom:4px;}
.rp-value{font-size:.78rem;font-weight:700;color:var(--adm-text);line-height:1.35;}
@media(max-width:760px){.reading-score-row{grid-template-columns:1fr 1fr;}.rp-grid{grid-template-columns:1fr 1fr;}}

.profile-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:var(--warm-white);border-radius:999px;padding:6px 10px;font-size:.78rem;font-weight:600;display:flex;align-items:center;gap:7px;}
.profile-btn:hover{background:rgba(255,255,255,.18);}
.user-avatar{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.14);overflow:hidden;border:1px solid rgba(255,255,255,.18);font-size:16px;vertical-align:middle;}
.user-avatar img{width:100%;height:100%;object-fit:cover;display:block;}
.avatar-mini{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;background:rgba(201,146,42,.12);border:1px solid rgba(201,146,42,.2);font-size:15px;vertical-align:middle;margin-right:7px;}
.avatar-mini img{width:100%;height:100%;object-fit:cover;display:block;}
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:700px){.profile-grid{grid-template-columns:1fr;}}
.theme-swatches{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-top:10px;}
.theme-card{border:1.5px solid var(--border);background:var(--warm-white);border-radius:14px;padding:10px 8px;display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;transition:all .18s;box-shadow:var(--shadow);}
.theme-card:hover{transform:translateY(-1px);border-color:var(--gold);}
.theme-card.on{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,146,42,.15), var(--shadow);}
.theme-card-label{font-size:.68rem;font-weight:700;color:var(--navy);text-align:center;line-height:1.15;}
.avatar-upload-note{font-size:.68rem;color:var(--muted);margin-top:6px;line-height:1.4;}
@media(max-width:640px){.theme-swatches{grid-template-columns:repeat(2,minmax(0,1fr));}}
.theme-swatch{width:34px;height:34px;border-radius:50%;border:2px solid var(--border);cursor:pointer;box-shadow:var(--shadow);}
.theme-swatch.on{outline:3px solid rgba(201,146,42,.25);border-color:var(--gold);}
.avatar-preview-big{width:76px;height:76px;border-radius:50%;overflow:hidden;border:3px solid var(--gold);display:flex;align-items:center;justify-content:center;background:var(--surface2);font-size:2rem;margin:0 auto 10px;}
.avatar-preview-big img{width:100%;height:100%;object-fit:cover;display:block;}

/* ─── PER-TASK TIMER (daily dashboard) ─── */
.task-timer-wrap{
  display:flex;align-items:center;gap:6px;margin-top:7px;
  padding:6px 10px;border-radius:8px;
  background:var(--surface2);border:1px solid var(--border2);
  user-select:none;
}
.task-timer-btn{
  width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);
  background:var(--warm-white);color:var(--navy);font-size:.72rem;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .18s;flex-shrink:0;padding:0;
}
.task-timer-btn:hover{background:var(--navy);color:var(--warm-white);border-color:var(--navy);}
.task-timer-btn.running{background:var(--gold);color:var(--warm-white);border-color:var(--gold);}
.task-timer-btn.done{background:var(--green);color:var(--warm-white);border-color:var(--green);}
.task-timer-display{
  font-family:'Playfair Display',serif;font-size:.95rem;font-weight:700;
  color:var(--navy);letter-spacing:.5px;min-width:46px;
}
.task-timer-display.running{color:var(--gold);}
.task-timer-display.done{color:var(--green);}
.task-timer-display.over{color:var(--red);}
.task-timer-goal{
  font-size:.67rem;font-weight:600;color:var(--muted);
  white-space:nowrap;margin-left:2px;
}
.task-timer-ring{
  position:relative;width:28px;height:28px;flex-shrink:0;
}
.task-timer-ring svg{transform:rotate(-90deg);}
.task-timer-ring-bg{fill:none;stroke:var(--border);stroke-width:3;}
.task-timer-ring-fill{fill:none;stroke:var(--gold);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .9s linear,stroke .3s;}
.task-timer-ring-fill.done{stroke:var(--green);}
.task-timer-ring-fill.over{stroke:var(--red);}
.task-item.done .task-timer-wrap{opacity:.5;pointer-events:none;}

/* ─── STUDENT BUILDS SCHEDULE ─── */
.ms-task-card{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:16px 18px;margin-bottom:10px;display:flex;align-items:flex-start;gap:14px;position:relative;}
.ms-task-card.running{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,146,42,.12),var(--shadow);}
.ms-task-card.done{opacity:.6;}
.ms-task-card.done .ms-task-name{text-decoration:line-through;}
.ms-cat-pill{font-size:.62rem;font-weight:700;padding:2px 8px;border-radius:20px;background:var(--gold-glow);color:var(--gold);border:1px solid rgba(201,146,42,.22);flex-shrink:0;margin-top:2px;white-space:nowrap;}
.ms-cat-pill.math{background:var(--blue-lt);color:var(--blue);border-color:rgba(37,99,235,.22);}
.ms-cat-pill.ela{background:var(--green-lt);color:var(--green);border-color:rgba(45,140,95,.22);}
.ms-task-name{font-size:.9rem;font-weight:700;color:var(--navy);line-height:1.3;margin-bottom:2px;}
.ms-task-meta{font-size:.72rem;color:var(--muted);}
.ms-task-timer{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;color:var(--navy);min-width:62px;text-align:right;flex-shrink:0;}
.ms-task-timer.running{color:var(--gold);}
.ms-task-timer.done{color:var(--green);}
.ms-btn-row{display:flex;gap:7px;margin-top:10px;flex-wrap:wrap;}
.ms-btn{padding:7px 14px;border-radius:9px;border:none;font-size:.77rem;font-weight:700;cursor:pointer;transition:all .2s;}
.ms-btn-start{background:var(--navy);color:var(--gold2);}
.ms-btn-start:hover{background:var(--navy3);}
.ms-btn-start.running{background:#e8f5e9;color:var(--green);border:1.5px solid rgba(45,140,95,.3);}
.ms-btn-done{background:var(--green);color:#fff;}
.ms-btn-done:hover{background:#236b49;}
.ms-btn-del{background:var(--surface2);color:var(--red);border:1.5px solid rgba(192,57,43,.18);}
.ms-btn-del:hover{background:#fde8e6;}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(12px);background:var(--navy);border:1px solid var(--gold);border-radius:10px;padding:9px 20px;font-size:.83rem;font-weight:600;color:var(--warm-white);opacity:0;transition:all .3s;z-index:500;pointer-events:none;white-space:nowrap;}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0);}
.toast.ok{border-color:var(--green);color:#4ade80;}
.toast.err{border-color:var(--red);color:#f87171;}

/* ── MOVEMENT TRACKING MODAL ── */
.mt-modal-bg{position:fixed;inset:0;background:rgba(13,34,64,.55);z-index:800;display:none;align-items:center;justify-content:center;backdrop-filter:blur(3px);}
.mt-modal-bg.on{display:flex;}
.mt-modal{background:var(--warm-white);border-radius:16px;padding:28px 28px 24px;max-width:400px;width:94%;box-shadow:0 20px 60px rgba(13,34,64,.25);border:1px solid var(--border);}
.mt-modal-title{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--navy);font-weight:700;margin-bottom:6px;}
.mt-modal-sub{font-size:.78rem;color:var(--muted);margin-bottom:18px;line-height:1.5;}
.mt-modal-label{font-size:.68rem;font-weight:700;color:var(--slate);text-transform:uppercase;letter-spacing:.6px;margin-bottom:5px;display:block;}
.mt-modal-inp{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:10px 13px;color:var(--navy);font-size:.95rem;outline:none;margin-bottom:16px;font-family:'Inter',sans-serif;transition:border-color .2s;}
.mt-modal-inp:focus{border-color:var(--gold);}
.mt-modal-hint{font-size:.72rem;color:var(--muted);margin-top:-12px;margin-bottom:14px;line-height:1.4;}
.mt-modal-actions{display:flex;gap:8px;justify-content:flex-end;}


.grade-letter-main{font-weight:800;line-height:1;color:inherit;}
.grade-gpa{line-height:1.15;white-space:nowrap;}
.rc-table .grade-letter-main{font-size:.88rem;color:#0d2240;}
.rc-table .grade-gpa{font-size:.62rem;color:#718096;}

/* ── PROGRESS STATUS BADGE ── */
.prog-status{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap;}
.prog-status.progress{background:#d4edda;color:#1a6e44;border:1px solid rgba(45,140,95,.3);}
.prog-status.low{background:#fff3cd;color:#856404;border:1px solid rgba(201,146,42,.3);}
.prog-status.none{background:#fde8e6;color:#9a2421;border:1px solid rgba(192,57,43,.3);}

/* ── MS TASK CARD EXTENDED ── */
.ms-value-display{font-size:.72rem;color:var(--muted);margin-top:4px;display:flex;gap:10px;flex-wrap:wrap;}
.ms-value-chip{background:var(--surface2);border:1px solid var(--border2);border-radius:6px;padding:2px 8px;font-size:.69rem;font-weight:600;color:var(--navy);}

/* ── ADMIN CURRICULUM SETTINGS ── */
.curr-section{margin-bottom:18px;}
.curr-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;background:var(--adm-surface2);border:1px solid var(--adm-border);margin-bottom:5px;}
.curr-item.inactive{opacity:.5;}
.curr-item-name{flex:1;font-size:.84rem;font-weight:600;color:var(--adm-text);}
.curr-item-type{font-size:.68rem;color:var(--adm-muted);padding:2px 7px;border-radius:5px;background:rgba(201,146,42,.12);color:var(--gold2);}
.curr-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;}
.curr-toggle{font-size:.7rem;padding:4px 9px;border-radius:6px;border:1px solid var(--adm-border);background:transparent;color:var(--adm-muted);cursor:pointer;font-weight:600;transition:all .18s;}
.curr-toggle:hover{background:rgba(255,255,255,.08);}
.curr-toggle.active{color:#4ade80;border-color:rgba(74,222,128,.3);}
.curr-edit-btn{font-size:.7rem;padding:4px 9px;border-radius:6px;border:1px solid var(--adm-border);background:transparent;color:var(--adm-muted);cursor:pointer;font-weight:600;transition:all .18s;}
.curr-edit-btn:hover{background:rgba(255,255,255,.08);color:var(--gold2);}

/* ── PRESENCE INDICATOR ── */
.presence-dot{
  display:inline-block;width:9px;height:9px;border-radius:50%;flex-shrink:0;
  vertical-align:middle;margin-right:5px;
}
.presence-dot.online{
  background:#22c55e;
  box-shadow:0 0 0 3px rgba(34,197,94,.2);
  animation:presence-pulse 2s ease-in-out infinite;
}
.presence-dot.offline{ background:var(--adm-muted); opacity:.45; }
.presence-chip{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.71rem;font-weight:700;padding:3px 8px;border-radius:20px;
  white-space:nowrap;
}
.presence-chip.online{
  background:rgba(34,197,94,.12);color:#22c55e;
  border:1px solid rgba(34,197,94,.3);
}
.presence-chip.offline{
  background:rgba(255,255,255,.04);color:var(--adm-muted);
  border:1px solid var(--adm-border);
}
@keyframes presence-pulse{
  0%,100%{box-shadow:0 0 0 3px rgba(34,197,94,.2);}
  50%{box-shadow:0 0 0 5px rgba(34,197,94,.06);}
}


/* ════════════════════════════════════
   WEIGHTED GRADEBOOK + REPORT CARDS
════════════════════════════════════ */
.grade-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-bottom:18px;}
.grade-card{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;}
.grade-card-hd{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;background:var(--navy);color:var(--warm-white);border-bottom:3px solid var(--gold);}
.grade-class{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--gold2);}
.grade-final{text-align:right;}
.grade-percent{font-family:'Playfair Display',serif;font-size:1.65rem;font-weight:700;line-height:1;color:var(--warm-white);}
.grade-letter{font-size:.72rem;font-weight:800;letter-spacing:.8px;color:var(--gold2);margin-top:2px;}
.grade-body{padding:14px 16px;}
.grade-term-pill{display:inline-flex;border-radius:20px;background:var(--gold-glow);border:1px solid rgba(201,146,42,.22);color:var(--gold);font-size:.68rem;font-weight:800;padding:3px 9px;margin-bottom:10px;}
.grade-breakdown{display:flex;flex-direction:column;gap:6px;margin:8px 0 12px;}
.grade-break-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;font-size:.78rem;padding:7px 8px;background:var(--surface2);border:1px solid var(--border2);border-radius:8px;}
.grade-break-row strong{color:var(--navy);font-weight:700;}
.grade-break-row span{color:var(--muted);font-weight:700;}
.grade-note{font-size:.79rem;color:var(--slate);line-height:1.55;background:var(--surface2);border-left:3px solid var(--gold);border-radius:8px;padding:9px 10px;}
.grade-empty{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:28px;text-align:center;color:var(--muted);font-size:.86rem;}
.grade-term-select{background:var(--warm-white);border:1.5px solid var(--border);border-radius:9px;padding:8px 11px;color:var(--navy);font-weight:700;outline:none;}
.gb-layout{display:grid;grid-template-columns:minmax(300px,430px) 1fr;gap:14px;align-items:start;}
@media(max-width:980px){.gb-layout{grid-template-columns:1fr;}}
.gb-cat-row{display:grid;grid-template-columns:1.2fr .7fr .7fr 34px;gap:8px;align-items:end;margin-bottom:8px;}
.gb-cat-row input,.gb-cat-row select{background:rgba(0,0,0,.3);border:1.5px solid var(--adm-border);border-radius:8px;padding:8px 10px;color:var(--adm-text);font-size:.82rem;outline:none;width:100%;}
.gb-cat-row input:focus,.gb-cat-row select:focus{border-color:var(--gold);}
.gb-cat-row select option{background:#0f2040;}
.gb-del{height:35px;border-radius:8px;border:1px solid rgba(192,57,43,.25);background:rgba(192,57,43,.12);color:#f87171;font-weight:800;}
.gb-del:hover{background:rgba(192,57,43,.22);}
.gb-calc-box{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:12px 0;}
@media(max-width:850px){.gb-calc-box{grid-template-columns:repeat(2,1fr);}}
.gb-calc-stat{background:rgba(255,255,255,.05);border:1px solid var(--adm-border);border-radius:10px;padding:10px;text-align:center;}
.gb-calc-n{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--gold2);}
.gb-calc-l{font-size:.62rem;color:var(--adm-muted);font-weight:800;text-transform:uppercase;letter-spacing:.7px;margin-top:2px;}
.gb-warn{display:none;background:rgba(192,57,43,.12);border:1px solid rgba(192,57,43,.25);color:#fca5a5;border-radius:9px;padding:8px 10px;font-size:.76rem;font-weight:700;margin:8px 0;}
.gb-ok{display:none;background:rgba(45,140,95,.12);border:1px solid rgba(45,140,95,.25);color:#4ade80;border-radius:9px;padding:8px 10px;font-size:.76rem;font-weight:700;margin:8px 0;}
.gb-record{background:rgba(0,0,0,.14);border:1px solid var(--adm-border);border-radius:12px;padding:13px;margin-bottom:9px;}
.gb-record-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px;}
.gb-record-title{font-weight:800;color:var(--adm-text);font-size:.9rem;}
.gb-record-meta{font-size:.7rem;color:var(--adm-muted);margin-top:2px;}
.gb-record-score{text-align:right;font-family:'Playfair Display',serif;font-size:1.45rem;color:var(--gold2);font-weight:700;line-height:1;}
.gb-small-table{width:100%;border-collapse:collapse;margin-top:8px;font-size:.75rem;}
.gb-small-table td{border-top:1px solid rgba(255,255,255,.06);padding:6px 4px;color:var(--adm-muted);}
.gb-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px;}
.report-card-print{background:#fff;color:#0d2240;border-radius:16px;padding:28px;box-shadow:var(--shadow-md);border:1px solid var(--border);max-width:900px;margin:14px auto;}
.rc-head{display:flex;justify-content:space-between;gap:16px;border-bottom:3px solid var(--gold);padding-bottom:14px;margin-bottom:16px;}
.rc-school{font-family:'Playfair Display',serif;font-size:1.45rem;font-weight:700;color:var(--navy);}
.rc-sub{font-size:.76rem;color:var(--muted);margin-top:3px;}
.rc-title{text-align:right;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--gold);font-size:.8rem;}
.rc-info{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px;}
.rc-info div{background:#faf8f4;border:1px solid #e2d9cc;border-radius:9px;padding:8px 10px;font-size:.78rem;}
.rc-info strong{display:block;font-size:.62rem;text-transform:uppercase;letter-spacing:.6px;color:#718096;margin-bottom:2px;}
.rc-table{width:100%;border-collapse:collapse;font-size:.82rem;margin-bottom:14px;}
.rc-table th{background:#0d2240;color:#fff;text-align:left;padding:9px;border:1px solid #0d2240;font-size:.68rem;text-transform:uppercase;letter-spacing:.6px;}
.rc-table td{padding:9px;border:1px solid #e2d9cc;vertical-align:top;}
.rc-break{font-size:.72rem;color:#4a5568;line-height:1.45;margin-top:3px;}
.rc-comments{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px;}
.rc-box{border:1px solid #e2d9cc;border-radius:10px;padding:11px;background:#faf8f4;min-height:80px;}
.rc-box h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;color:#c9922a;margin-bottom:6px;}
.rc-box p{font-size:.8rem;line-height:1.55;color:#0d2240;white-space:pre-wrap;}
.rc-sign{display:flex;justify-content:space-between;gap:20px;margin-top:28px;font-size:.78rem;color:#4a5568;}
.rc-sign span{display:block;border-top:1px solid #0d2240;padding-top:6px;min-width:220px;}
@media print{
  body *{visibility:hidden!important;}
  #report-print-area,#report-print-area *{visibility:visible!important;}
  #report-print-area{position:absolute;left:0;top:0;width:100%;}
  .report-card-print{box-shadow:none;border:none;border-radius:0;max-width:none;margin:0;padding:18px;}
  .adm-sb,.adm-title,.adm-sub,.ac:not(.print-keep),button{display:none!important;}
}


/* Reading completion lock/unlock fixes */
.reading-action-row .task-cb.done{background:var(--green);border-color:var(--green);color:var(--warm-white);}
.reading-action-row .task-cb{width:18px;height:18px;border-radius:5px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;background:var(--warm-white);}

/* v5 course weight source-of-truth updates */
.course-map-row.selected-course-row td{background:rgba(201,146,42,.10)!important;}

/* Reading List admin reorder controls */
.bk-row-wrap.dragging{opacity:.55;border-color:var(--gold);}
.bk-drag-handle,.bk-move-btn{border:1px solid var(--adm-border);background:rgba(201,146,42,.1);color:var(--gold2);border-radius:7px;min-width:26px;height:28px;display:inline-flex;align-items:center;justify-content:center;font-weight:900;cursor:pointer;line-height:1;}
.bk-drag-handle{cursor:grab;font-size:.9rem;}
.bk-drag-handle:active{cursor:grabbing;}
.bk-move-btn{font-size:.78rem;}
.bk-drag-handle:hover,.bk-move-btn:hover{background:rgba(201,146,42,.22);border-color:rgba(201,146,42,.45);}

.readiness-select{background:rgba(255,255,255,.06);border:1px solid var(--adm-border,#2d3748);color:var(--adm-text,#fff);border-radius:999px;padding:6px 10px;font-weight:800;font-size:.72rem;min-width:145px;}
.readiness-select option{color:#111;background:#fff;}
