@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600&family=Hanken+Grotesk:wght@400;500;600;700&display=swap";:root{--paper: #FBFAF7;--stage: #E9E6DE;--card: #FFFFFF;--side: #16201C;--ink: #1C1814;--ink-2: #46403A;--muted: #938A7E;--line: #EFEAE1;--amber: #F2A93C;--amber-deep: #965500;--amber-soft: #FCEFD7;--teal: #15A589;--teal-deep: #0B5746;--teal-soft: #E1F4EE;--coral: #F2643C;--coral-deep: #A83417;--coral-soft: #FCE7DF;--color-bg: var(--paper);--color-surface: var(--card);--color-text: var(--ink);--color-text-muted: var(--muted);--color-border: var(--line);--color-primary: var(--amber);--color-primary-ink: var(--amber-deep);--color-success: var(--teal);--color-danger: var(--coral);--font-display: "Fraunces", Georgia, serif;--font-sans: "Hanken Grotesk", system-ui, -apple-system, sans-serif;--r-sm: 11px;--r-md: 16px;--r-lg: 22px;--r-pill: 999px;--shadow: 0 10px 30px rgba(40, 30, 16, .08);--shadow-lg: 0 20px 50px rgba(40, 30, 16, .12);--sp-1: 8px;--sp-2: 12px;--sp-3: 16px;--sp-4: 24px}*{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased}#root{min-height:100vh}a{cursor:pointer;text-decoration:none}.muted{color:var(--muted)}.pad{padding:18px}.error{background:var(--coral-soft);color:var(--coral-deep);padding:10px 12px;border-radius:var(--r-sm);font-size:14px}.brand{display:flex;align-items:center;gap:10px}.brand .logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(145deg,var(--amber),#E8821C);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:600;font-size:20px}.brand b{font-family:var(--font-display);font-weight:600;font-size:19px}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(120% 60% at 80% -10%,#F3E7CF 0,transparent 55%),radial-gradient(120% 70% at -10% 110%,#DCEFE8 0,transparent 50%),var(--stage)}.auth-card{width:380px;max-width:100%;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.auth-card h1{font-family:var(--font-display);font-weight:600;font-size:24px;margin:18px 0 4px}.auth-card p{font-size:14px;margin-bottom:18px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field span{font-size:13px;font-weight:600;color:var(--ink-2)}.field input{height:44px;border:1px solid var(--line);border-radius:var(--r-sm);padding:0 13px;font:inherit;font-size:15px;background:var(--paper)}.field input:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-soft)}.btn-primary{height:46px;border:none;border-radius:var(--r-sm);background:var(--amber-deep);color:#fff;font:inherit;font-weight:600;font-size:15px;cursor:pointer;margin-top:6px}.btn-primary:disabled{opacity:.6;cursor:default}.shell{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--side);color:#cfd6d2;padding:18px 14px;display:flex;flex-direction:column}.sidebar .brand{padding:4px 8px 18px}.sidebar .brand b{color:#fff}.nav{display:flex;flex-direction:column;gap:2px}.nav .ni{padding:9px 12px;border-radius:10px;font-size:14px;font-weight:500;color:#b7bfba}.nav .ni:hover{background:#ffffff0d}.nav .ni.on{background:var(--amber);color:#3a2200;font-weight:600}.nav-group{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#ffffff59;font-weight:600;padding:12px 12px 5px}.me{margin-top:auto;display:flex;align-items:center;gap:10px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.me .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal-deep));color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}.me b{font-size:13px;color:#fff;display:block}.me span{font-size:11px;color:#ffffff80}.me .logout{margin-left:auto;background:#ffffff14;border:none;color:#cfd6d2;border-radius:8px;padding:6px 10px;font-size:12px;cursor:pointer}.main{flex:1;background:var(--paper);display:flex;flex-direction:column}.topbar{padding:18px 26px;border-bottom:1px solid var(--line)}.topbar h2{font-family:var(--font-display);font-weight:600;font-size:22px}.content{padding:24px 26px}.card-panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow);overflow:hidden}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--line)}.panel-head h3{font-size:15px;font-weight:700}.panel-head .count{background:var(--amber-soft);color:var(--amber-deep);font-size:12px;font-weight:700;padding:3px 10px;border-radius:var(--r-pill)}table.data{width:100%;border-collapse:collapse}table.data th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600;padding:11px 18px;border-bottom:1px solid var(--line)}table.data td{padding:12px 18px;font-size:14px;color:var(--ink-2);border-bottom:1px solid var(--line)}table.data tr:last-child td{border-bottom:none}table.data .strong{font-weight:600;color:var(--ink)}table.data .mono{font-family:var(--font-mono, monospace);font-size:13px;color:var(--muted)}.nav .ni.disabled{opacity:.45;cursor:default}.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:15px 16px;box-shadow:var(--shadow)}.kpi-label{font-size:12.5px;color:var(--muted);font-weight:600}.kpi-value{font-family:var(--font-display);font-weight:600;font-size:30px;margin-top:10px;line-height:1}.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}.genre{padding:18px}.gbar{height:14px;background:var(--amber-soft);border-radius:99px;overflow:hidden}.gbar .g{display:block;height:100%;background:var(--teal);border-radius:99px}.glabels{display:flex;justify-content:space-between;margin-top:8px;font-size:12.5px;color:var(--muted);font-weight:600}@media (max-width: 720px){.kpis{grid-template-columns:1fr 1fr}.split{grid-template-columns:1fr}}.toolbar{display:flex;gap:14px;margin-bottom:16px}.toolbar label{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--ink-2)}.toolbar select{height:38px;border:1px solid var(--line);border-radius:var(--r-sm);padding:0 10px;font:inherit;font-size:14px;background:var(--card);min-width:170px}.mini{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:6px 11px;font:inherit;font-size:12.5px;font-weight:600;color:var(--amber-deep);cursor:pointer}.mini:hover{border-color:var(--amber)}.mention{font-size:11px;font-weight:700;padding:3px 9px;border-radius:99px}.mention.m-good{background:var(--teal-soft);color:var(--teal-deep)}.mention.m-mid{background:var(--amber-soft);color:var(--amber-deep)}.mention.m-low{background:var(--coral-soft);color:var(--coral-deep)}.bulletin-doc{margin-top:18px;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-lg);overflow:hidden}.bd-band{height:6px;background:linear-gradient(90deg,var(--amber),var(--teal))}.bd-pad{padding:22px 26px 20px}.bd-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--ink);padding-bottom:14px}.bd-school{display:flex;gap:12px;align-items:center}.bd-logo{width:42px;height:42px;border-radius:11px;background:linear-gradient(145deg,var(--amber),#E8821C);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:22px}.bd-school b{font-family:var(--font-display);font-weight:600;font-size:16px;display:block}.bd-school span{font-size:11.5px;color:var(--muted)}.bd-doc{text-align:right}.bd-doc .t{font-family:var(--font-display);font-weight:600;font-size:15px}.bd-doc .p{font-size:12px;color:var(--amber-deep);font-weight:600}.bd-doc .y{font-size:11.5px;color:var(--muted)}.bd-who{display:flex;justify-content:space-between;align-items:center;margin:16px 0 12px;gap:14px}.bd-who b{font-family:var(--font-display);font-weight:600;font-size:20px}.bd-who .sub{font-size:12.5px;color:var(--ink-2);margin-top:2px}.bd-badges{display:flex;gap:9px}.bd-badge{text-align:center;border:1px solid var(--line);border-radius:11px;padding:8px 14px;min-width:70px}.bd-badge .v{font-family:var(--font-display);font-weight:600;font-size:18px}.bd-badge .k{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-top:3px;font-weight:600}.bd-badge.hl{background:var(--teal-deep);border-color:var(--teal-deep)}.bd-badge.hl .v,.bd-badge.hl .k{color:#fff}.bd-table{width:100%;border-collapse:collapse;margin-top:4px}.bd-table th{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600;text-align:center;padding:9px 6px;border-bottom:1.5px solid #D8D0C3}.bd-table th.l{text-align:left}.bd-table td{font-size:13px;padding:8px 6px;border-bottom:1px solid var(--line);text-align:center;color:var(--ink-2)}.bd-table td.l{text-align:left;font-weight:600;color:var(--ink)}.bd-table td.note{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--ink)}.bd-table tfoot td{border-top:2px solid var(--ink);font-weight:700}.bd-table tfoot td.note{color:var(--teal-deep)}.bd-foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px}.bd-mark{font-size:11px;color:var(--muted)}.ok-msg{background:var(--teal-soft);color:var(--teal-deep);padding:10px 12px;border-radius:var(--r-sm);font-size:14px;margin-bottom:12px}.btn-save{background:var(--amber-deep);color:#fff;border:none;border-radius:8px;padding:8px 16px;font:inherit;font-weight:600;font-size:13px;cursor:pointer}.btn-save:disabled{opacity:.6;cursor:default}.grade-in{width:96px;height:36px;border:1px solid var(--line);border-radius:8px;padding:0 10px;font:inherit;font-size:14px;text-align:center}.grade-in:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-soft)}.comm-item{padding:14px 18px;border-bottom:1px solid var(--line)}.comm-item:last-child{border-bottom:none}.comm-top{display:flex;align-items:center;gap:10px}.comm-top b{font-size:14.5px;font-weight:700}.sig-tag{font-size:10.5px;font-weight:700;background:var(--amber-soft);color:var(--amber-deep);padding:2px 8px;border-radius:99px}.comm-body{font-size:13px;color:var(--ink-2);margin:6px 0 8px;line-height:1.5}.comm-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--muted)}.comm-meta .signed{color:var(--teal-deep);font-weight:600}.comm-meta .done{color:var(--teal-deep);font-weight:700}.compose .field textarea{border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 12px;font:inherit;font-size:14px;background:var(--paper);resize:vertical}.compose .field textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-soft)}.check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2);margin-bottom:14px}.compose .btn-primary{width:100%}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.form-grid .field{margin-bottom:0}.form-grid select{height:44px;border:1px solid var(--line);border-radius:var(--r-sm);padding:0 10px;font:inherit;font-size:15px;background:var(--paper)}.form-actions{display:flex;justify-content:flex-end;gap:10px;padding:4px 18px 16px}.row-actions{display:flex;gap:8px}.mini.danger{color:var(--coral-deep)}.mini.danger:hover{border-color:var(--coral)}.btn-import{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer}.btn-import:hover{border-color:var(--amber)}@media (max-width: 720px){.form-grid{grid-template-columns:1fr}}.muted2{color:var(--muted);font-size:12.5px}.list-row{display:flex;align-items:center;gap:12px;padding:11px 18px;border-bottom:1px solid var(--line);cursor:pointer}.list-row:hover{background:var(--paper)}.list-row.on{background:var(--amber-soft)}.list-row>div:first-child{flex:1}.list-row b{font-size:14px}.inline-form{display:flex;gap:10px;padding:14px 18px;border-top:1px solid var(--line);flex-wrap:wrap;align-items:center}.inline-form input,.inline-form select{height:38px;border:1px solid var(--line);border-radius:8px;padding:0 10px;font:inherit;font-size:14px;background:var(--paper);flex:1;min-width:90px}
