/* ════════════════════════════════════════════════════════════════
   vine. dossier — 디자인 시스템 (v2 · 잉크 네이비 / 컬리 레이아웃)
   단일 source of truth. 페이지는 이 파일을 link. 갤러리: vine-system.html
   토큰 → base → 컴포넌트(Bay 순). 클래스는 갤러리 셀렉터와 1:1.
   ════════════════════════════════════════════════════════════════ */
:root{
  /* ── 단일 brand 노브 (네이비). 색 바꾸려면 여기만 ── */
  --pp:#1e3a5f; --pp-deep:#16293f; --pp-ink:#102236;
  --pp-soft:#eef2f7; --pp-line:#e1e8f0; --pp-tint:#6f8bab; --pp-bright:#2f5c8f;
  --accent2:#c0552f;                 /* 테라코타 = 긴급/마감 */
  --ok:#1e8f60; --ok-bg:#e7f5ee;
  /* ── 뉴트럴 (쿨틴트) ── */
  --ink:#26282b; --ink-2:#4c5056; --mut:#565b61; --faint:#6b7178; /* 시니어 대비 상향: ink-2≈8:1 · mut≈6.3:1 · faint=옛mut(AA 4.9:1) */
  --line:#edeff2; --line-2:#e0e4ea; --bg:#fcfdfe; --paper:#f9fafb; /* bg=네이비 미세틴트(순백 금지) */
  /* ── 스케일 ── */
  --s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:24px;--s-6:32px;--s-7:44px;
  --r-sm:6px;--r-md:12px;--r-lg:16px;--r-pill:999px;
  /* ── 타이포 스케일 (시니어 가독성. 글씨 키우려면 여기만) ── */
  --fs-2xs:12px;  /* 배지·미세라벨 = 시니어 바닥 */
  --fs-xs:13px;   /* 메타·캡션 */
  --fs-sm:14px;   /* 보조 라벨 */
  --fs-base:15.5px;/* 본문·버튼·탭 */
  --fs-md:17px;   /* 강조 본문·카드 타이틀 */
  --fs-lg:19px;   /* 소제목 */
  --fs-xl:22px;   /* 제목 */
  --fs-2xl:28px;  /* 큰 제목 */
  --fs-3xl:44px;  /* 히어로 숫자(세리프) */
  --num:'Fraunces',Georgia,serif;    /* 데이터 숫자 전용 세리프 */
  --sans:'Pretendard Variable',Pretendard,-apple-system,'Apple SD Gothic Neo',sans-serif;
  --ease:cubic-bezier(0.16,1,0.3,1); --dur:180ms;
  --tx:background-color,color,border-color,box-shadow,transform,opacity; /* transition 스코프(레이아웃 속성 제외) */
  --shadow:0 8px 22px rgba(20,40,70,0.10);
}
*{box-sizing:border-box;}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:var(--fs-base);line-height:1.65;letter-spacing:-0.003em;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-0.02em;}
svg.i{display:block;stroke:currentColor;stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.num{font-family:var(--num);font-weight:600;letter-spacing:-0.01em;}
a:focus-visible,button:focus-visible,input:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--pp);outline-offset:2px;border-radius:4px;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important;}}

/* ── Bay 01 · Buttons ─────────────────────────────────── */
.btn{appearance:none;font:inherit;font-size:var(--fs-base);font-weight:600;border-radius:var(--r-sm);padding:10px 18px;border:1.5px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:var(--tx) var(--dur) var(--ease);}
.btn-primary{background:var(--pp);color:#fff;} .btn-primary:hover{background:var(--pp-deep);}
.btn-ghost{background:#fff;color:var(--pp);border-color:var(--pp);} .btn-ghost:hover{background:var(--pp-soft);}
.btn-text{background:none;color:var(--mut);padding:10px 6px;} .btn-text:hover{color:var(--pp);}

/* ── Bay 02 · Chips & Status ──────────────────────────── */
.chip{font-size:var(--fs-xs);font-weight:700;border-radius:var(--r-sm);padding:2px 8px;display:inline-block;}
.chip.ok{color:var(--ok);background:var(--ok-bg);}
.chip.warn{color:var(--accent2);background:#f9ece6;}
.chip.par{color:var(--pp);background:var(--pp-soft);}
.chip.none{color:var(--mut);background:#f1f0f3;}
.stat-dot{width:11px;height:11px;border-radius:50%;border:2px solid #fff;display:inline-block;}
.stat-dot.ok{background:var(--ok);} .stat-dot.warn{background:var(--accent2);}
.stat-dot.par{background:var(--pp-tint);} .stat-dot.none{background:#d2cfd8;}

/* ── Bay 03 · Tabs / Toggle ───────────────────────────── */
.tabs{display:flex;overflow-x:auto;border-bottom:1px solid var(--line);scrollbar-width:none;}
.tabs::-webkit-scrollbar{display:none;}
.tab{appearance:none;border:0;background:none;font:inherit;font-size:var(--fs-base);color:var(--mut);padding:12px 16px;white-space:nowrap;border-bottom:2.5px solid transparent;margin-bottom:-1px;cursor:pointer;}
.tab.on{color:var(--ink);font-weight:700;border-bottom-color:var(--pp);}
.toggle{display:inline-flex;background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r-pill);padding:3px;}
.toggle button{appearance:none;border:0;background:none;font:inherit;font-size:var(--fs-sm);font-weight:600;color:var(--mut);padding:6px 16px;border-radius:var(--r-pill);cursor:pointer;}
.toggle button.on{background:var(--pp);color:#fff;}

/* ── Bay 04 · Weight bar (지필:수행 시그니처) ───────────── */
/* 두 칸을 명확히 구분: 지필=밝은 슬레이트, 수행=잉크 네이비 + 흰 분리선. 라벨색 = 바 색. */
.wbar{display:flex;height:18px;border-radius:5px;overflow:hidden;background:#eceff3;}
.wbar .b-ji{background:#8c99ab;} .wbar .b-su{background:var(--pp);box-shadow:inset 2px 0 0 #fff;}
.wbar.empty{background:repeating-linear-gradient(135deg,#f2f4f7,#f2f4f7 6px,#e6eaef 6px,#e6eaef 7px);}
.barlab{font-size:var(--fs-xs);color:var(--ink-2);margin-top:8px;}
.barlab b{color:var(--ink);} .barlab .ji{color:#5f6c7e;font-weight:700;} .barlab .su{color:var(--pp);font-weight:700;}

/* ── Bay 05 · School icon (둥근) ───────────────────────── */
.school-ico{text-align:center;text-decoration:none;color:var(--ink);position:relative;display:inline-block;}
.school-ico .c{width:60px;height:60px;border-radius:50%;margin:0 auto 9px;display:grid;place-items:center;font-weight:700;font-size:var(--fs-lg);background:var(--paper);border:1px solid var(--line-2);transition:var(--tx) var(--dur) var(--ease);}
.school-ico:hover .c{border-color:var(--pp);color:var(--pp);transform:translateY(-2px);}
.school-ico .nm{font-size:var(--fs-xs);font-weight:500;}
.school-ico .stat-dot{position:absolute;top:-1px;left:50%;margin-left:11px;}

/* ── Bay 06 · Deadline card (마감) ─────────────────────── */
.dcard{border:1px solid var(--line-2);border-radius:var(--r-md);padding:18px;background:#fff;transition:var(--tx) var(--dur) var(--ease);cursor:pointer;}
.dcard:hover{border-color:var(--pp-line);box-shadow:var(--shadow);transform:translateY(-2px);}
.dcard .dtop{display:flex;align-items:baseline;gap:8px;}
.dcard .dd{font-family:var(--num);font-size:var(--fs-md);font-weight:600;color:var(--accent2);} .dcard .dd.soft{color:var(--pp);}
.dcard .date{font-size:var(--fs-xs);color:var(--mut);margin-left:auto;}
.dcard .sch{font-size:var(--fs-xs);color:var(--pp);font-weight:700;margin-top:14px;}
.dcard .subj{font-size:var(--fs-lg);font-weight:700;margin-top:4px;}
.dcard .kind{font-size:var(--fs-sm);color:var(--ink-2);margin-top:5px;}
.dcard .pct{display:inline-block;margin-top:14px;font-size:var(--fs-xs);font-weight:700;color:var(--pp);background:var(--pp-soft);border-radius:var(--r-sm);padding:4px 10px;}
.dcard .prov{font-size:var(--fs-xs);color:var(--mut);margin-top:14px;border-top:1px dashed var(--line-2);padding-top:9px;}

/* ── Bay 07 · Weight card (학교별 무게) ─────────────────── */
.wcard{border:1px solid var(--line-2);border-radius:var(--r-md);overflow:hidden;background:#fff;transition:var(--tx) var(--dur) var(--ease);cursor:pointer;}
.wcard:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.wcard .vis{background:var(--paper);border-bottom:1px solid var(--line);padding:22px;display:flex;align-items:baseline;justify-content:center;gap:7px;}
.wcard .vis .big{font-family:var(--num);font-size:var(--fs-3xl);font-weight:600;line-height:1;}
.wcard .vis .lb{font-size:var(--fs-sm);font-weight:600;color:var(--mut);}
.wcard .vis.empty{color:var(--mut);font-size:var(--fs-base);font-weight:500;}
.wcard .info{padding:16px 18px 18px;}
.wcard .nm{font-size:var(--fs-md);font-weight:700;display:flex;align-items:center;gap:8px;}
.wcard .loc{font-size:var(--fs-xs);color:var(--mut);margin-top:2px;}

/* ── Bay 08 · Modal / Overlay / Sheet ──────────────────── */
.overlay{position:fixed;inset:0;background:rgba(16,34,54,0.42);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:var(--tx) var(--dur) var(--ease);z-index:50;}
.overlay.open{opacity:1;visibility:visible;}
.modal{background:#fff;border-radius:var(--r-lg);max-width:440px;width:100%;padding:26px;transform:translateY(12px) scale(0.98);transition:var(--tx) var(--dur) var(--ease);box-shadow:0 24px 60px rgba(16,34,54,0.28);}
.overlay.open .modal{transform:none;}
.modal .mh{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.modal .mh .x{appearance:none;border:0;background:var(--paper);width:30px;height:30px;border-radius:50%;cursor:pointer;color:var(--mut);display:grid;place-items:center;flex:none;}
.modal .mh .x:hover{background:var(--line-2);color:var(--ink);}
.modal h3{font-size:var(--fs-xl);}
.modal .mkick{font-size:var(--fs-xs);color:var(--pp);font-weight:700;margin-bottom:6px;}
.modal .mrow{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:var(--fs-base);}
.modal .mrow span{color:var(--mut);} .modal .mrow b{font-weight:700;}
.modal .mprov{font-size:var(--fs-xs);color:var(--mut);margin-top:14px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 12px;}
.modal .mact{display:flex;gap:10px;margin-top:20px;}
.modal .mact .btn{flex:1;justify-content:center;}
/* 모바일 바텀시트 변형 */
.overlay.sheet{align-items:flex-end;padding:0;}
.overlay.sheet .modal{max-width:402px;border-radius:18px 18px 0 0;transform:translateY(100%);}
.overlay.sheet.open .modal{transform:none;}

/* ── Bay 09 · Toast ────────────────────────────────────── */
.toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);background:var(--pp-ink);color:#fff;font-size:var(--fs-sm);font-weight:600;padding:12px 20px;border-radius:var(--r-pill);opacity:0;visibility:hidden;transition:var(--tx) var(--dur) var(--ease);z-index:60;box-shadow:var(--shadow);}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%);}
.toast.ok{background:var(--ok);} .toast.warn{background:#d64545;} .toast.info{background:var(--pp);}
.modal .mfield{margin:14px 0 0;} .modal .mfield label{display:block;font-size:var(--fs-xs);font-weight:700;color:var(--ink-2);margin-bottom:5px;}
.modal .mfield input{width:100%;font:inherit;font-size:var(--fs-base);padding:10px 12px;border:1px solid var(--line-2);border-radius:var(--r-sm);box-sizing:border-box;}
.modal .mfield input:focus{outline:none;border-color:var(--pp);box-shadow:0 0 0 3px var(--pp-soft);}

/* ── Bay 10 · Note (정직성 배너) ───────────────────────── */
.note{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:16px 20px;font-size:var(--fs-xs);color:var(--ink-2);line-height:1.6;}
.note b{color:var(--pp);}

/* ── Bay 11 · Week grid (주간 일정 — 학사일정 ⨝ 평가계획) ── */
/* NEIS 학사일정을 주(週) 그리드로. 시험만 D-day(.dd) + 평가계획 연결. 색+아이콘 병행(색 단독 의미 금지). */
.weekgrid{border:1px solid var(--line-2);border-radius:var(--r-md);padding:18px;background:#fff;}
.wk-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:14px;}
.wk-nav{display:flex;align-items:center;gap:11px;}
.wk-arrow{appearance:none;border:1px solid var(--line-2);background:#fff;width:32px;height:32px;border-radius:var(--r-sm);cursor:pointer;color:var(--ink-2);display:grid;place-items:center;transition:var(--tx) var(--dur) var(--ease);}
.wk-arrow:hover:not(:disabled){border-color:var(--pp);color:var(--pp);}
.wk-arrow:disabled{opacity:.4;cursor:not-allowed;}
.wk-title{font-size:var(--fs-md);font-weight:700;} .wk-title b{color:var(--pp);}
.wk-title .rg{font-family:var(--num);font-weight:600;color:var(--ink-2);font-size:var(--fs-sm);margin-left:7px;}
.wk-title .tag{font-size:var(--fs-xs);font-weight:700;color:var(--accent2);background:#f9ece6;border-radius:var(--r-sm);padding:2px 8px;margin-left:8px;}
.wk-title .tag.now{color:var(--pp);background:var(--pp-soft);}
.wk-tools{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.wk-legend{display:flex;gap:13px;flex-wrap:wrap;font-size:var(--fs-xs);color:var(--mut);}
.wk-legend span{display:inline-flex;align-items:center;gap:4px;}
.wk-legend i{width:9px;height:9px;border-radius:2px;display:inline-block;}
.wk-days{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;}
.wk-day{border:1px solid var(--line-2);border-radius:8px;padding:9px 9px 10px;min-height:120px;display:flex;flex-direction:column;gap:6px;background:#fff;}
.wk-day.shade{background:var(--paper);}
.wk-day.today{border-color:var(--pp);box-shadow:inset 0 0 0 1px var(--pp);}
.wk-dh{display:flex;align-items:baseline;justify-content:space-between;}
.wk-dh .wd{font-size:var(--fs-xs);font-weight:700;color:var(--mut);}
.wk-dh .dnum{font-family:var(--num);font-size:var(--fs-lg);font-weight:600;color:var(--ink);}
.wk-day.sat .wd,.wk-day.sat .dnum{color:var(--pp-bright);}
.wk-day.sun .wd,.wk-day.sun .dnum{color:var(--accent2);}
.wk-day.today .wd{color:var(--pp);}
.wk-evs{display:flex;flex-direction:column;gap:4px;}
.wk-ev{display:flex;align-items:flex-start;gap:5px;font-size:var(--fs-sm);font-weight:600;line-height:1.4;padding:3px 6px;border-radius:5px;border-left:3px solid transparent;}
.wk-ev .i{width:13px;height:13px;flex:none;stroke-width:1.9;margin-top:1px;}
.wk-ev .nm{overflow-wrap:anywhere;word-break:keep-all;}  /* 칸이 좁아도 행사명 전체 노출(줄바꿈) */
.wk-ev.exam{color:var(--accent2);background:#f9ece6;border-color:var(--accent2);font-weight:700;}
.wk-ev.test{color:var(--pp);background:var(--pp-soft);border-color:var(--pp-bright);}
.wk-ev.event{color:var(--ok);background:var(--ok-bg);border-color:var(--ok);}
.wk-ev.holiday{color:#9d3b34;background:#f6ebe9;border-color:#c2796e;}
.wk-ev.off{color:var(--mut);background:transparent;border-color:var(--line-2);font-weight:500;}
/* 이 주 시험 ⨝ 평가계획 (v_deadlines 개념의 화면화) */
.wk-link{margin-top:16px;border:1px solid var(--pp-line);background:var(--pp-soft);border-radius:var(--r-md);padding:15px 18px;}
.wk-link-h{font-size:var(--fs-sm);font-weight:700;color:var(--pp);display:flex;align-items:center;gap:7px;margin-bottom:13px;}
.wk-link-h .dd{font-family:var(--num);color:var(--accent2);}
.wk-link-rows{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 24px;}
.wk-lr .top{display:flex;justify-content:space-between;align-items:baseline;font-size:var(--fs-sm);margin-bottom:6px;}
.wk-lr .top b{font-weight:700;} .wk-lr .top .pc{font-family:var(--num);font-size:var(--fs-xs);font-weight:600;color:var(--pp);}
.wk-lr .kd{font-size:var(--fs-xs);color:var(--ink-2);margin-top:6px;overflow-wrap:anywhere;}
.wk-link .none{font-size:var(--fs-xs);color:var(--mut);}
@media(max-width:760px){
  .wk-days{grid-template-columns:1fr;gap:6px;}
  .wk-day{flex-direction:row;align-items:flex-start;gap:13px;min-height:0;padding:11px 12px;}
  .wk-day.empty{display:none;}
  .wk-dh{flex-direction:column;align-items:center;width:34px;flex:none;gap:0;}
  .wk-evs{flex:1;}
  .wk-link-rows{grid-template-columns:1fr;}
}

/* ── Bay 12 · Month calendar (다학교 학사일정 + 학교 토글) ───── */
/* 색 = 학교(토글축) · 시험/학평 = 칩 질감+굵기 · 학교 머리글자 배지로 색 단독 의미 회피. */
/* 일정은 NEIS 전(全)학교 실데이터. 좌측 토글레일 + 우측 캘린더 비대칭(대시보드와 다른 리듬). */
.cal-layout{display:grid;grid-template-columns:236px 1fr;gap:28px;align-items:start;}
.cal-rail{position:sticky;top:18px;}
.cal-rail .rlab{font-size:var(--fs-xs);font-weight:700;letter-spacing:.06em;color:var(--mut);margin-bottom:11px;display:flex;justify-content:space-between;align-items:baseline;}
.cal-rail .rlab .all{font-weight:600;letter-spacing:0;color:var(--pp);cursor:pointer;font-size:var(--fs-xs);}
.sch-tg{display:flex;align-items:center;gap:10px;width:100%;padding:9px 11px;border:1px solid var(--line-2);border-radius:9px;background:#fff;cursor:pointer;text-align:left;font:inherit;transition:var(--tx) var(--dur) var(--ease);}
.sch-tg+.sch-tg{margin-top:7px;}
.sch-tg:hover{border-color:var(--pp-line);}
.sch-tg .sw{width:13px;height:13px;border-radius:4px;flex:none;background:var(--c);}
.sch-tg .nm{font-weight:600;font-size:var(--fs-sm);flex:1;color:var(--ink);}
.sch-tg .ct{font-family:var(--num);font-size:var(--fs-xs);color:var(--mut);}
.sch-tg[aria-pressed=false]{opacity:.5;background:var(--paper);}
.sch-tg[aria-pressed=false] .sw{background:transparent;box-shadow:inset 0 0 0 1.6px var(--c);}
.cal-railnote{font-size:var(--fs-xs);color:var(--mut);line-height:1.55;margin-top:14px;padding-top:13px;border-top:1px solid var(--line);}
.cal-railnote b{color:var(--pp);}

.cal{border:1px solid var(--line-2);border-radius:var(--r-md);background:#fff;overflow:hidden;}
.cal-head{display:flex;align-items:center;gap:14px;padding:15px 18px;border-bottom:1px solid var(--line);flex-wrap:wrap;}
.cal-nav{display:flex;align-items:center;gap:9px;}
.cal-arrow{appearance:none;border:1px solid var(--line-2);background:#fff;width:44px;height:44px;border-radius:var(--r-sm);cursor:pointer;color:var(--ink-2);display:grid;place-items:center;transition:var(--tx) var(--dur) var(--ease);}
.cal-arrow:hover:not(:disabled){border-color:var(--pp);color:var(--pp);} .cal-arrow:disabled{opacity:.4;cursor:not-allowed;}
.cal-mon{font-family:var(--num);font-size:var(--fs-xl);font-weight:600;letter-spacing:-.01em;min-width:96px;}
.cal-mon .yr{font-size:var(--fs-sm);color:var(--mut);font-weight:600;margin-left:7px;font-family:var(--sans);}
.cal-today{appearance:none;border:0;background:none;font:inherit;font-size:var(--fs-sm);font-weight:600;color:var(--pp);cursor:pointer;padding:6px;}
.cal-legend{margin-left:auto;display:flex;gap:15px;font-size:var(--fs-xs);color:var(--mut);align-items:center;}
.cal-legend .lg{display:inline-flex;align-items:center;gap:5px;}
.cal-legend .lg .e{width:13px;height:10px;border-radius:3px;background:color-mix(in srgb,var(--pp) 12%,#fff);border-left:3px solid var(--pp);}
.cal-legend .lg .t{width:13px;height:10px;border-radius:3px;border:1px dashed var(--pp-tint);}
/* 카테고리 토글 (표시 항목 — 시험/학평/행사/공휴/휴업). 색=학교 고정이라 타입은 칩 질감으로 구분 */
.cat-toggles{margin-left:auto;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.cat-toggles .cat-lab{font-size:var(--fs-xs);font-weight:700;color:var(--mut);margin-right:2px;}
.cat-pill{appearance:none;font:inherit;font-size:var(--fs-xs);font-weight:600;border:1px solid var(--line-2);background:#fff;color:var(--mut);border-radius:var(--r-pill);padding:5px 12px;cursor:pointer;transition:var(--tx) var(--dur) var(--ease);}
.cat-pill:hover{border-color:var(--pp);} .cat-pill[aria-pressed=true]{background:var(--pp);color:#fff;border-color:var(--pp);}
.cal-insight{padding:11px 18px;background:var(--pp-soft);border-bottom:1px solid var(--pp-line);font-size:var(--fs-xs);color:var(--pp);line-height:1.55;}
.cal-insight b{font-weight:700;} .cal-insight .num{font-family:var(--num);font-weight:600;}
.cal-insight .none{color:var(--accent2);}

.cal-wd{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--line);}
.cal-wd span{padding:9px 10px;font-size:var(--fs-xs);font-weight:700;color:var(--mut);}
.cal-wd span:nth-child(6){color:var(--pp-bright);} .cal-wd span:nth-child(7){color:var(--accent2);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);}
.cal-day{min-height:106px;padding:7px 8px 9px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:background var(--dur) var(--ease);}
.cal-day:nth-child(7n){border-right:0;}
.cal-day:hover{background:var(--paper);}
.cal-day .dn{font-family:var(--num);font-size:var(--fs-sm);font-weight:600;color:var(--ink-2);align-self:flex-start;}
.cal-day.sat .dn{color:var(--pp-bright);} .cal-day.sun .dn{color:var(--accent2);}
.cal-day.out{background:var(--paper);cursor:default;} .cal-day.out .dn{color:var(--faint);} .cal-day.out:hover{background:var(--paper);}
.cal-day.today .dn{color:#fff;background:var(--pp);min-width:21px;height:21px;padding:0 5px;border-radius:11px;display:grid;place-items:center;}
.cal-day.hol{background:#fcf6f4;} .cal-day.hol:hover{background:#faefeb;}
.cal-day .hn{font-size:var(--fs-xs);font-weight:600;color:var(--accent2);}
.cal-chips{display:flex;flex-direction:column;gap:3px;}
.cal-chip{--c:var(--pp);display:flex;align-items:flex-start;gap:5px;font-size:var(--fs-sm);line-height:1.4;border-radius:5px;padding:2px 5px 2px 3px;}
.cal-chip .ini{width:15px;height:15px;border-radius:4px;background:var(--c);color:#fff;font-size:var(--fs-2xs);font-weight:700;display:grid;place-items:center;flex:none;margin-top:0.5px;}
.cal-chip .nm{color:var(--ink-2);overflow-wrap:anywhere;word-break:keep-all;}
.cal-chip.exam{background:color-mix(in srgb,var(--c) 9%,#fff);} .cal-chip.exam .nm{color:var(--ink);font-weight:700;}
.cal-chip.event .ini{border-radius:50%;} .cal-chip.event .nm{color:var(--ink-2);font-weight:500;}  /* 행사 = 원형 배지로 시험·학평과 구분 */
.cal-day.offday{background:repeating-linear-gradient(135deg,#f7f8fa,#f7f8fa 6px,#eef1f4 6px,#eef1f4 7px);} .cal-day.offday:hover{background:repeating-linear-gradient(135deg,#f3f5f8,#f3f5f8 6px,#e8ecf1 6px,#e8ecf1 7px);}
.cal-day .offn{font-size:var(--fs-xs);font-weight:600;color:var(--mut);}
/* 일(日) 상세 모달 행 */
.cal-drow{display:flex;align-items:center;gap:9px;padding:9px 0;border-bottom:1px solid var(--line);}
.cal-drow .ini{width:18px;height:18px;border-radius:5px;background:var(--c);color:#fff;font-size:var(--fs-2xs);font-weight:700;display:grid;place-items:center;flex:none;}
.cal-drow .ds{font-size:var(--fs-sm);font-weight:600;flex:1;} .cal-drow .dk{font-size:var(--fs-xs);color:var(--mut);}

@media(max-width:880px){
  .cal-layout{grid-template-columns:1fr;gap:16px;}
  .cal-rail{position:static;}
  .cal-rail .toggles{display:flex;flex-wrap:wrap;gap:7px;} .sch-tg{width:auto;flex:1 1 30%;} .sch-tg+.sch-tg{margin-top:0;}
}
@media(max-width:560px){
  .cal-day{min-height:62px;padding:5px 5px 6px;}
  /* 좁은 폭: 색 배지 숨김(자리뺏음) → 좌측 색선으로 학교 구분, 이벤트명은 전부 노출(숨김 금지) */
  .cal-chip{padding:2px 5px;gap:4px;border-left:3px solid var(--c);border-radius:0 4px 4px 0;}
  .cal-chip .ini{display:none;}
  .cal-legend{display:none;}
}

/* ── Bay 13 · 수행평가 (과목 그룹 + 항목 행) ───────────────── */
/* 단일학교 깊이 — 과목별 지필:수행 무게(Bay 04 재사용) + 수행항목·배점. 실시일 없음(가짜금지) → "상시" 표기. */
.perf-bar{display:flex;gap:16px;align-items:baseline;flex-wrap:wrap;font-size:var(--fs-sm);color:var(--ink-2);margin-bottom:18px;}
.perf-bar b{font-family:var(--num);color:var(--pp);font-weight:600;}
.perf-bar .src{margin-left:auto;font-size:var(--fs-xs);color:var(--mut);}
.perf-list{display:flex;flex-direction:column;gap:13px;}
.perf-subj{border:1px solid var(--line-2);border-radius:var(--r-md);background:#fff;padding:15px 18px;transition:var(--tx) var(--dur) var(--ease);}
.perf-subj:hover{border-color:var(--pp-line);box-shadow:var(--shadow);}
.ps-h{display:flex;align-items:center;gap:9px;flex-wrap:wrap;}
.ps-h .nm{font-size:var(--fs-md);font-weight:700;}
.ps-rt{margin-left:auto;display:flex;align-items:center;gap:11px;}
.ps-rt .wbar{width:120px;flex:none;height:15px;}
.ps-rt .rtlab{font-size:var(--fs-xs);color:var(--ink-2);white-space:nowrap;} .ps-rt .rtlab .ji{color:#5f6c7e;font-weight:700;} .ps-rt .rtlab .su{color:var(--pp);font-weight:700;}
.ps-rt .rtlab.none{color:var(--mut);}
.perf-items{list-style:none;margin:13px 0 0;padding:0;}
.perf-item{display:flex;align-items:flex-start;gap:11px;padding:10px 0;border-top:1px solid var(--line);}
.perf-item .pct{font-family:var(--num);font-size:var(--fs-base);font-weight:600;color:var(--pp);background:var(--pp-soft);border-radius:var(--r-sm);padding:2px 0;flex:none;width:46px;text-align:center;}
.perf-item .pct.q{color:var(--mut);background:#f1f0f3;}
.perf-item .pn{font-size:var(--fs-base);flex:1;overflow-wrap:anywhere;line-height:1.45;}
.perf-item .when{font-size:var(--fs-xs);color:var(--mut);background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r-pill);padding:2px 10px;flex:none;white-space:nowrap;align-self:center;}
.ps-prov{font-size:var(--fs-xs);color:var(--mut);margin-top:11px;border-top:1px dashed var(--line-2);padding-top:9px;overflow-wrap:anywhere;}
.ps-note{font-size:var(--fs-xs);color:var(--accent2);margin-top:8px;}
@media(max-width:620px){
  .ps-rt{margin-left:0;width:100%;} .perf-item .when{display:none;}
}
/* 채점요소 펼침 (rubric — 항목 클릭 시 요소·배점 스택) */
.perf-item .rbtn{appearance:none;border:1px solid var(--line-2);background:#fff;font:inherit;font-size:var(--fs-xs);font-weight:600;color:var(--pp);border-radius:var(--r-pill);padding:2px 9px;cursor:pointer;flex:none;align-self:center;}
.perf-item .rbtn:hover{background:var(--pp-soft);}
.rubric{margin:8px 0 2px 57px;padding:10px 12px;background:var(--paper);border:1px solid var(--line);border-radius:8px;display:flex;flex-direction:column;gap:7px;}
.rubric .re{display:flex;align-items:center;gap:9px;font-size:var(--fs-xs);}
.rubric .re .nm{flex:1;overflow-wrap:anywhere;} .rubric .re .pt{font-family:var(--num);font-weight:600;color:var(--pp);flex:none;}
.rubric .re .track{height:7px;border-radius:4px;background:var(--pp-soft);width:90px;flex:none;overflow:hidden;}
.rubric .re .track i{display:block;height:100%;background:var(--pp);}

/* 과목 섹션 토글 (진도·성취수준·평가기준) */
.ps-more{margin-top:13px;border-top:1px dashed var(--line-2);padding-top:12px;}
.ps-secbtns{display:flex;gap:7px;flex-wrap:wrap;}
.ps-secbtn{appearance:none;border:1px solid var(--line-2);background:#fff;font:inherit;font-size:var(--fs-xs);font-weight:600;color:var(--ink-2);border-radius:var(--r-pill);padding:5px 13px;cursor:pointer;transition:var(--tx) var(--dur) var(--ease);}
.ps-secbtn:hover{border-color:var(--pp);} .ps-secbtn[aria-expanded=true]{background:var(--pp);color:#fff;border-color:var(--pp);}
.ps-sec{margin-top:14px;}
.ps-sec h4{font-size:var(--fs-sm);font-weight:700;color:var(--pp);margin-bottom:11px;display:flex;align-items:center;gap:7px;}
.ps-sec .seclab{font-size:var(--fs-xs);color:var(--mut);font-weight:500;}

/* ── Bay 14 · 진도 타임라인 (과목 주차별 단원·성취기준·평가유형) ── */
.tl-track{display:flex;gap:6px;margin-bottom:13px;}
.tl-track .tk{appearance:none;border:1px solid var(--line-2);background:#fff;font:inherit;font-size:var(--fs-xs);font-weight:600;color:var(--mut);border-radius:var(--r-pill);padding:3px 12px;cursor:pointer;}
.tl-track .tk.on{background:var(--pp-soft);color:var(--pp);border-color:var(--pp-line);}
.tl{position:relative;border-left:2px solid var(--line-2);margin-left:7px;}
.tl-row{position:relative;padding:9px 0 9px 20px;}
.tl-row + .tl-row{border-top:1px solid var(--line);}
.tl-row::before{content:"";position:absolute;left:-6px;top:14px;width:9px;height:9px;border-radius:50%;background:var(--pp-tint);border:2px solid #fff;box-shadow:0 0 0 1px var(--line-2);}
.tl-row.exam::before{background:var(--accent2);box-shadow:0 0 0 1px var(--accent2);}
.tl-row.perf::before{background:var(--pp);box-shadow:0 0 0 1px var(--pp);}
.tl-pd{font-size:var(--fs-xs);color:var(--mut);font-family:var(--num);}
.tl-pd .hr{margin-left:8px;color:var(--mut);}
.tl-unit{font-size:var(--fs-sm);font-weight:600;margin-top:2px;overflow-wrap:anywhere;}
.tl-meta{margin-top:5px;display:flex;flex-wrap:wrap;gap:5px;align-items:center;}
.tl-std{font-size:var(--fs-2xs);font-family:var(--num);color:var(--pp);background:var(--pp-soft);border-radius:4px;padding:1px 6px;}
.tl-ev{font-size:var(--fs-2xs);font-weight:700;border-radius:4px;padding:1px 7px;}
.tl-ev.exam{color:var(--accent2);background:#f9ece6;} .tl-ev.perf{color:var(--pp);background:var(--pp-soft);}

/* ── Bay 15 · 성취수준 사다리 (A~E desc·성취율) ───────────── */
.ladder{border:1px solid var(--line-2);border-radius:var(--r-md);overflow:hidden;}
.rung{display:flex;gap:13px;padding:11px 14px;align-items:baseline;}
.rung + .rung{border-top:1px solid var(--line);}
.rung .lv{font-family:var(--num);font-size:var(--fs-lg);font-weight:600;color:var(--pp);width:22px;flex:none;}
.rung .rt{font-size:var(--fs-xs);color:var(--mut);font-family:var(--num);width:104px;flex:none;}
.rung .ds{font-size:var(--fs-xs);color:var(--ink-2);line-height:1.5;overflow-wrap:anywhere;}
.rung[data-l="A"]{background:color-mix(in srgb,var(--pp) 9%,#fff);}
.rung[data-l="B"]{background:color-mix(in srgb,var(--pp) 5%,#fff);}
/* 평가기준 리스트 */
.crit-list{display:flex;flex-direction:column;gap:9px;}
.crit-row{font-size:var(--fs-xs);line-height:1.5;}
.crit-row .t{font-family:var(--num);font-size:var(--fs-xs);color:var(--pp);background:var(--pp-soft);border-radius:4px;padding:1px 7px;margin-right:7px;}
.crit-more{font-size:var(--fs-xs);color:var(--mut);margin-top:4px;}

/* ── 페이지 chrome (util · header · nav · phead · footer) · 전 페이지 공유 SoT ──
   폭은 페이지가 body{--canvas:NNNpx} 로 지정 (perf 1000 · 캘린더 1200 · 챙김 980). */
.wrap{max-width:var(--canvas,1100px);margin:0 auto;padding:0 24px;}
.util{border-bottom:1px solid var(--line);font-size:var(--fs-xs);color:var(--mut);}
.util .w{max-width:var(--canvas,1100px);margin:0 auto;padding:0 24px;display:flex;justify-content:flex-end;gap:18px;height:34px;align-items:center;}
.util a{color:var(--mut);text-decoration:none;} .util a:hover{color:var(--ink);}
.hdr .wrap{display:flex;align-items:center;gap:34px;padding:22px 24px;}
.logo{margin:0;font-weight:800;font-size:var(--fs-2xl);color:var(--ink);letter-spacing:-0.03em;white-space:nowrap;} .logo .pt{color:var(--pp);}
.search{flex:1;max-width:460px;position:relative;}
.search input{width:100%;height:44px;border:1.5px solid var(--pp);border-radius:8px;padding:0 42px 0 15px;font:inherit;font-size:var(--fs-base);outline:none;color:var(--ink);}
.search input::placeholder{color:var(--mut);}
.search .mag{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--pp);}
.hdr .icons{margin-left:auto;display:flex;gap:22px;align-items:center;}
.hdr .ib{text-align:center;font-size:var(--fs-xs);color:var(--ink-2);text-decoration:none;display:flex;flex-direction:column;align-items:center;gap:3px;min-height:44px;justify-content:center;}
.hdr .ib:hover{color:var(--pp);}
.nav{border-top:1px solid var(--line);border-bottom:1px solid var(--line-2);}
.nav .wrap{display:flex;align-items:center;height:50px;}
.nav .all{display:flex;align-items:center;gap:8px;font-weight:700;font-size:var(--fs-md);color:var(--ink);padding-right:24px;margin-right:6px;border-right:1px solid var(--line);white-space:nowrap;}
.nav a{font-size:var(--fs-md);color:var(--ink-2);text-decoration:none;padding:0 17px;font-weight:500;display:inline-flex;align-items:center;min-height:44px;white-space:nowrap;}
.nav a.on{color:var(--pp);font-weight:700;} .nav a:hover{color:var(--pp);}
.nav .right{margin-left:auto;font-size:var(--fs-xs);color:var(--mut);}
.phead{margin:30px 0 18px;}
.phead h2{font-size:var(--fs-2xl);font-weight:800;letter-spacing:-0.02em;}
.phead .sub{font-size:var(--fs-base);color:var(--mut);margin-top:7px;max-width:680px;line-height:1.55;}
.foot{margin:44px 0 56px;padding-top:22px;border-top:1px solid var(--line);font-size:var(--fs-xs);color:var(--mut);}
@media(max-width:880px){
  .hdr .wrap{flex-wrap:wrap;gap:14px;padding:14px 16px;} .search{order:3;max-width:none;flex-basis:100%;}
  .wrap,.util .w{padding:0 16px;}
  .nav .wrap{overflow-x:auto;} .nav .right{display:none;} .phead h2{font-size:var(--fs-xl);}
}

/* ── Bay 16 · Mobile tab bar (하단 내비 — 모바일에서 PC 가로 내비 대체) ── */
/* 데스크톱 숨김. ≤760px에서 .nav 숨기고 하단 탭바 표시 + body 하단 패딩. 전 페이지 공유. */
.mnav{display:none;}
@media(max-width:760px){
  .nav{display:none!important;}
  body{padding-bottom:70px;}
  .mnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:45;background:#fff;
        border-top:1px solid var(--line-2);padding:7px 4px calc(9px + env(safe-area-inset-bottom));
        box-shadow:0 -4px 18px rgba(20,40,70,.07);}
  .mnav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;text-decoration:none;
          color:var(--mut);font-size:var(--fs-xs);font-weight:600;min-height:44px;justify-content:center;}
  .mnav a .i{width:22px;height:22px;stroke:currentColor;stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round;}
  .mnav a.on{color:var(--pp);}
}

/* ── Bay 17 · Finder split (지도 기반 진입 — wawa 좌/우의 좌측을 지도로) ── */
/* 2-pane: 좌 지도, 우 솔리드 패널. 앱 진입 전 게이트웨이라 nav/탭바 없음. */
.finder{position:fixed;inset:0;display:grid;grid-template-columns:1fr 416px;}
.finder-map{position:relative;background:var(--pp-soft);}
.finder-map .leaflet-container{position:absolute;inset:0;font-family:var(--sans);background:#dfe6ee;}
.finder-panel{background:var(--paper);border-left:1px solid var(--line-2);display:flex;flex-direction:column;
              overflow-y:auto;box-shadow:-8px 0 30px rgba(20,40,70,.05);}
.fp-head{padding:22px 24px 16px;border-bottom:1px solid var(--line);}
.fp-brand{font-size:var(--fs-xl);font-weight:800;letter-spacing:-.03em;color:var(--ink);}
.fp-brand .dot{color:var(--pp);}
.fp-sub{font-size:var(--fs-sm);color:var(--mut);margin-top:5px;line-height:1.5;}
.fp-body{padding:18px 24px 28px;flex:1;}

/* ── Bay 18 · Region picker (캐스케이딩 + 브레드크럼) ── */
.rcrumb{display:flex;align-items:center;gap:5px;flex-wrap:wrap;font-size:var(--fs-xs);margin-bottom:16px;}
.rcrumb button{appearance:none;border:0;background:none;font:inherit;font-size:var(--fs-xs);color:var(--pp);
               font-weight:600;cursor:pointer;padding:2px 4px;border-radius:4px;}
.rcrumb button:hover{background:var(--pp-soft);}
.rcrumb .sep{color:var(--faint);}
.rcrumb .cur{color:var(--ink-2);font-weight:700;}
.rstep-h{font-size:var(--fs-xs);font-weight:700;letter-spacing:.04em;color:var(--mut);text-transform:uppercase;margin:0 0 10px;}
/* 지역 대시보드 진입 CTA (시·군·구 단계 상단) */
.fp-cta{display:flex;align-items:center;gap:10px;background:var(--pp);color:#fff;border-radius:var(--r-md);
        padding:13px 16px;text-decoration:none;margin:0 0 16px;transition:var(--tx) var(--dur) var(--ease);min-height:44px;}
.fp-cta:hover{background:var(--pp-deep);}
.fp-cta.off{background:#eef0f3;color:var(--mut);cursor:not-allowed;pointer-events:none;}
.fp-cta.off .cta-i{stroke:var(--faint);}
.fp-cta.off .cta-go{font-weight:600;opacity:.75;}
.fp-cta .cta-i{width:22px;height:22px;flex:none;stroke:#fff;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;opacity:.9;}
.fp-cta .cta-tx{flex:1;min-width:0;}
.fp-cta .cta-t{display:block;font-size:var(--fs-base);font-weight:700;letter-spacing:-.01em;}
.fp-cta .cta-m{display:block;font-size:var(--fs-xs);opacity:.82;margin-top:1px;font-variant-numeric:tabular-nums;}
.fp-cta .cta-go{flex:none;font-size:var(--fs-xs);font-weight:700;opacity:.95;}
.rpick-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
.rpick-grid button{appearance:none;text-align:left;background:#fff;border:1px solid var(--line-2);border-radius:var(--r-sm);
                   padding:11px 13px;cursor:pointer;font:inherit;transition:var(--tx) var(--dur) var(--ease);min-height:44px;}
.rpick-grid button:hover{border-color:var(--pp-tint);background:var(--pp-soft);}
.rpick-grid button[aria-pressed="true"]{border-color:var(--pp);background:var(--pp-soft);box-shadow:inset 0 0 0 1px var(--pp);}
.rpick-grid .rg-n{display:block;font-size:var(--fs-base);font-weight:700;color:var(--ink);}
.rpick-grid .rg-m{display:block;font-size:var(--fs-xs);color:var(--mut);margin-top:2px;font-variant-numeric:tabular-nums;}
.rpick-grid .rg-m b{color:var(--ok);font-weight:700;}
.rchips{display:flex;flex-wrap:wrap;gap:7px;}
.rchips button{appearance:none;background:#fff;border:1px solid var(--line-2);border-radius:var(--r-pill);
               padding:7px 14px;cursor:pointer;font:inherit;font-size:var(--fs-sm);font-weight:600;color:var(--ink-2);
               transition:var(--tx) var(--dur) var(--ease);min-height:38px;}
.rchips button:hover{border-color:var(--pp-tint);color:var(--pp);}
.rchips button[aria-pressed="true"]{background:var(--pp);border-color:var(--pp);color:#fff;}
.rchips button .c{font-variant-numeric:tabular-nums;opacity:.7;margin-left:5px;font-size:var(--fs-xs);}
/* 실데이터 보유 구 강조 — 색칠된 칩 + 점 */
.rchips button.has{border-color:var(--ok);background:var(--ok-bg);color:var(--ok);font-weight:700;}
.rchips button.has .c{color:var(--ok);opacity:.85;}
.rchips button.has:hover{border-color:var(--ok);background:#dcf0e6;}
.rchips .rdot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--ok);margin-right:6px;vertical-align:middle;}

/* ── Bay 19 · School list (필터 결과 · 양방향 hover · 티어 게이팅) ── */
.slist{display:flex;flex-direction:column;gap:7px;}
.srow{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line-2);border-radius:var(--r-md);
      padding:12px 14px;text-decoration:none;color:inherit;transition:var(--tx) var(--dur) var(--ease);min-height:56px;cursor:pointer;}
.srow:hover,.srow.hot{border-color:var(--pp-tint);box-shadow:var(--shadow);transform:translateY(-1px);}
.srow .tier{width:11px;height:11px;border-radius:50%;border:2px solid #fff;flex:none;
            box-shadow:0 0 0 1px var(--line-2);}
.srow .tier.full{background:var(--ok);box-shadow:0 0 0 1px var(--ok);}
.srow .tier.sched{background:var(--pp-bright);box-shadow:0 0 0 1px var(--pp-bright);}
.srow .tier.none{background:#cfd5dd;}
.srow .sinfo{flex:1;min-width:0;}
.srow .snm{font-size:var(--fs-base);font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.srow .smeta{font-size:var(--fs-xs);color:var(--mut);margin-top:1px;}
.srow .act{font-size:var(--fs-xs);font-weight:700;flex:none;padding:6px 12px;border-radius:var(--r-sm);white-space:nowrap;}
.srow .act.full{background:var(--ok-bg);color:var(--ok);}
.srow .act.sched{background:var(--pp-soft);color:var(--pp);}
.srow .act.none{background:#f1f0f3;color:var(--mut);}
.slist-empty{font-size:var(--fs-sm);color:var(--mut);text-align:center;padding:32px 0;}
.tier-legend{display:flex;gap:14px;flex-wrap:wrap;font-size:var(--fs-xs);color:var(--mut);margin-top:14px;padding-top:14px;border-top:1px solid var(--line);}
.tier-legend .it{display:flex;align-items:center;gap:6px;}
.tier-legend .d{width:9px;height:9px;border-radius:50%;}
.tier-legend .d.full{background:var(--ok);} .tier-legend .d.sched{background:var(--pp-bright);} .tier-legend .d.none{background:#cfd5dd;}

/* ── Bay 20 · Map skin (네이비 팝업 · 티어 마커 · 영역 라벨) ── */
/* 행정구역 라벨 (폴리곤 중앙 · 네이버/카카오식) — 배경없는 텍스트 라벨 */
.rlabel{background:none;border:0;box-shadow:none;padding:0;font-family:var(--sans);
        font-size:var(--fs-xs);font-weight:700;color:var(--pp-ink);white-space:nowrap;pointer-events:none;
        text-shadow:0 0 3px #fff,0 0 3px #fff,0 1px 2px #fff;}
.rlabel::before{display:none;}
.rlabel i{font-style:normal;font-family:var(--num);font-weight:600;color:var(--ok);margin-left:2px;}
.rlabel.none{color:var(--ink-2);} .rlabel.none i{color:var(--mut);}
.rlabel.sched i{color:var(--pp-bright);}
.mk{border-radius:50%;border:2px solid #fff;box-shadow:0 1px 5px rgba(20,40,70,.3);}
.mk.full{background:var(--ok);} .mk.sched{background:var(--pp-bright);} .mk.none{background:#9aa5b3;}
.mk.hot{outline:3px solid var(--pp);outline-offset:1px;z-index:1000;}
.mbubble{background:var(--pp);color:#fff;border-radius:var(--r-pill);border:2px solid #fff;
         box-shadow:0 2px 8px rgba(20,40,70,.3);display:flex;flex-direction:column;align-items:center;
         justify-content:center;font-family:var(--num);font-weight:600;line-height:1;cursor:pointer;}
.mbubble .bn{font-size:var(--fs-md);} .mbubble .bl{font-family:var(--sans);font-size:var(--fs-2xs);font-weight:600;opacity:.85;margin-top:1px;}
.mbubble:hover{background:var(--pp-deep);}
.leaflet-popup-content-wrapper{border-radius:var(--r-md);box-shadow:var(--shadow);}
.leaflet-popup-content{font-family:var(--sans);margin:13px 15px;}
.mpop-nm{font-size:var(--fs-base);font-weight:800;color:var(--ink);}
.mpop-meta{font-size:var(--fs-xs);color:var(--mut);margin-top:2px;}
.mpop-act{display:inline-block;margin-top:9px;font-size:var(--fs-xs);font-weight:700;text-decoration:none;
          padding:7px 14px;border-radius:var(--r-sm);background:var(--pp);color:#fff;}
.mpop-act.none{background:#f1f0f3;color:var(--mut);}

@media(max-width:760px){
  .finder{grid-template-columns:1fr;grid-template-rows:40vh 1fr;}
  .finder-panel{border-left:0;border-top:1px solid var(--line-2);border-radius:16px 16px 0 0;margin-top:-16px;z-index:5;box-shadow:0 -8px 30px rgba(20,40,70,.12);}
  .fp-head{padding:16px 18px 12px;} .fp-body{padding:14px 18px 24px;}
  .rpick-grid{grid-template-columns:repeat(2,1fr);}
}

/* ════════════════════════════════════════════════════════════════
   수행평가 챙김 워크플로 (Bay 21–26) — 학원쌤 도구. 밀도 높은 리스트 지향.
   상태: unaware 미인지 · aware 인지 · helping 도움중 · submitted 제출 · missing 미제출
   ════════════════════════════════════════════════════════════════ */

/* ── Bay 21 · 상태 토글 (5-state · 시그니처 인터랙션) ── */
.stog{display:inline-flex;gap:0;border:1px solid var(--line-2);border-radius:var(--r-pill);overflow:hidden;background:#fff;flex:none;}
.stog button{appearance:none;border:0;background:none;font:inherit;font-size:var(--fs-xs);font-weight:700;
             padding:8px 11px;cursor:pointer;color:var(--mut);white-space:nowrap;min-height:44px;transition:var(--tx) var(--dur) var(--ease);}
.stog button+button{border-left:1px solid var(--line);}
.stog button:hover{background:var(--paper);}
.stog button.on[data-s="unaware"]{background:#eceff3;color:var(--ink-2);}
.stog button.on[data-s="aware"]{background:var(--pp);color:#fff;}
.stog button.on[data-s="helping"]{background:var(--accent2);color:#fff;}
.stog button.on[data-s="submitted"]{background:var(--ok);color:#fff;}
.stog button.on[data-s="missing"]{background:#d64545;color:#fff;}
/* 작은 상태 점(요약 표시) */
.sdot{display:inline-block;width:9px;height:9px;border-radius:50%;vertical-align:middle;}
.sdot.unaware{background:#c2c9d2;} .sdot.aware{background:var(--pp);} .sdot.helping{background:var(--accent2);}
.sdot.submitted{background:var(--ok);} .sdot.missing{background:#d64545;}

/* ── Bay 22 · 수행평가 체크 행 (인터랙티브) ── */
.tcheck{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--line);background:#fff;}
.tcheck:hover{background:var(--paper);}
.tcheck .ti{flex:1;min-width:0;}
.tcheck .ti .nm{font-size:var(--fs-base);font-weight:600;color:var(--ink);overflow-wrap:anywhere;}
.tcheck .ti .mt{font-size:var(--fs-xs);color:var(--mut);margin-top:2px;}
.tcheck .tnote{appearance:none;border:1px solid var(--line-2);background:#fff;border-radius:var(--r-sm);
               font:inherit;font-size:var(--fs-xs);color:var(--mut);padding:5px 9px;cursor:pointer;flex:none;}
.tcheck .tnote.has{color:var(--pp);border-color:var(--pp-line);background:var(--pp-soft);}

/* ── Bay 23 · 쌤 워크리스트 ("이번 주 챙길 것") ── */
.wl-head{display:flex;align-items:baseline;gap:10px;margin:0 0 14px;}
.wl-head h2{font-size:var(--fs-lg);font-weight:800;letter-spacing:-.02em;}
.wl-head .cnt{font-family:var(--num);font-weight:600;color:var(--accent2);}
.wl-grp{margin-bottom:18px;border:1px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden;background:#fff;}
.wl-grp .hd{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 15px;
            background:var(--pp-soft);border-bottom:1px solid var(--pp-line);}
.wl-grp .hd .t{font-size:var(--fs-sm);font-weight:800;color:var(--pp-ink);}
.wl-grp .hd .t b{font-family:var(--num);}
.wl-grp .hd .bulk{font-size:var(--fs-xs);font-weight:700;color:var(--pp);background:#fff;border:1px solid var(--pp-line);
                  border-radius:var(--r-sm);padding:5px 11px;cursor:pointer;}
.wl-row{display:flex;align-items:center;gap:12px;padding:10px 15px;border-bottom:1px solid var(--line);}
.wl-row:last-child{border-bottom:0;}
.wl-row .who{flex:1;min-width:0;}
.wl-row .who .nm{font-size:var(--fs-base);font-weight:700;}
.wl-row .who .sb{font-size:var(--fs-xs);color:var(--mut);}
.wl-empty{text-align:center;color:var(--mut);padding:40px 0;font-size:var(--fs-base);}
.wl-empty b{color:var(--ok);}

/* ── Bay 24 · 학생 명부 ── */
.roster{display:flex;flex-direction:column;gap:7px;}
.rt-row{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line-2);border-radius:var(--r-md);
        padding:12px 15px;cursor:pointer;transition:var(--tx) var(--dur) var(--ease);min-height:56px;text-decoration:none;color:inherit;}
.rt-row:hover{border-color:var(--pp-tint);box-shadow:var(--shadow);transform:translateY(-1px);}
.rt-row .av{width:36px;height:36px;border-radius:50%;background:var(--pp-soft);color:var(--pp);font-weight:800;
            display:flex;align-items:center;justify-content:center;flex:none;font-size:var(--fs-base);}
.rt-row .info{flex:1;min-width:0;}
.rt-row .info .nm{font-size:var(--fs-base);font-weight:700;}
.rt-row .info .mt{font-size:var(--fs-xs);color:var(--mut);margin-top:1px;}
.rt-row .todo{font-family:var(--num);font-weight:600;font-size:var(--fs-xs);color:var(--accent2);background:#f9ece6;
              border-radius:var(--r-pill);padding:3px 10px;flex:none;}
.rt-row .todo.zero{color:var(--ok);background:var(--ok-bg);}

/* ── Bay 25 · 학생 등록 폼 ── */
.sform{display:flex;flex-direction:column;gap:14px;}
.sform label{font-size:var(--fs-xs);font-weight:700;color:var(--ink-2);display:block;margin-bottom:5px;}
.sform input,.sform select{width:100%;font:inherit;font-size:var(--fs-base);padding:10px 12px;border:1px solid var(--line-2);
                           border-radius:var(--r-sm);background:#fff;color:var(--ink);}
.sform input:focus,.sform select:focus{outline:none;border-color:var(--pp);box-shadow:0 0 0 3px var(--pp-soft);}
.sform .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.subjchips{display:flex;flex-wrap:wrap;gap:7px;}
.subjchips button{appearance:none;font:inherit;font-size:var(--fs-xs);font-weight:600;border:1px solid var(--line-2);
                  background:#fff;color:var(--ink-2);border-radius:var(--r-pill);padding:6px 13px;cursor:pointer;min-height:36px;}
.subjchips button[aria-pressed="true"]{background:var(--pp);border-color:var(--pp);color:#fff;}

/* ── Bay 26 · 반 cohort 헤더 ── */
.cohort-h{display:flex;align-items:center;gap:8px;font-size:var(--fs-sm);font-weight:700;color:var(--pp-ink);
          padding:8px 2px;}
.cohort-h .pin{font-size:var(--fs-xs);font-weight:700;color:var(--pp);background:var(--pp-soft);border-radius:var(--r-sm);padding:2px 8px;}

/* ── Bay 27 · 진도/시험범위 표 (학생 상세) ── */
.ptable{width:100%;border-collapse:collapse;background:#fff;font-size:var(--fs-sm);}
.ptable th{background:var(--pp-soft);color:var(--ink-2);font-weight:700;font-size:var(--fs-xs);text-align:left;
           padding:8px 11px;border-bottom:1px solid var(--pp-line);white-space:nowrap;}
.ptable td{padding:8px 11px;border-bottom:1px solid var(--line);vertical-align:top;}
.ptable .pd{font-family:var(--num);color:var(--ink-2);white-space:nowrap;width:74px;}
.ptable .un{color:var(--ink);overflow-wrap:anywhere;}
.ptable .std{display:inline-block;font-family:var(--num);font-size:var(--fs-sm);color:var(--pp);
             background:var(--pp-soft);border-radius:4px;padding:1px 6px;margin:1px 3px 1px 0;}
.ptable td.ev{white-space:nowrap;width:96px;}
.ptable .evx{display:inline-block;font-size:var(--fs-sm);font-weight:700;border-radius:4px;padding:2px 7px;}
.ptable .evx.ji{background:var(--pp);color:#fff;} .ptable .evx.su{background:var(--ok);color:#fff;}
/* 시험(평가유형 있는) 행 강조 = 시험범위 — 좌측 악센트 + 옅은 틴트 */
.ptable tr.exam td:first-child{box-shadow:inset 3px 0 0 var(--accent2);}
.ptable tr.exam td{background:#fdf7f4;}
.ptable tr.exam .un{font-weight:700;}
@media(max-width:560px){
  .ptable,.ptable tbody,.ptable tr,.ptable td{display:block;width:auto;}
  .ptable thead{display:none;}
  .ptable tr{border-bottom:1px solid var(--line);padding:9px 12px;}
  .ptable tr.exam{background:#fdf7f4;box-shadow:inset 3px 0 0 var(--accent2);}
  .ptable td{border:0;padding:1px 0;}
  .ptable td.pd{font-size:var(--fs-xs);color:var(--mut);}
  .ptable td.un{font-size:var(--fs-base);font-weight:600;color:var(--ink);margin:1px 0 3px;}
  .ptable td.ev:empty{display:none;}
}
