:root{color:#17202a;font-synthesis:none;text-rendering:optimizelegibility;background:#f6f8f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,a{font:inherit}.app-shell{color:#17202a;grid-template-columns:280px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{color:#fff;background:#102a35;flex-direction:column;gap:28px;padding:24px 18px;display:flex}.brand{align-items:center;gap:12px;display:flex}.brand-mark{color:#062026;background:#2bb7a8;border-radius:8px;place-items:center;width:42px;height:42px;font-weight:800;display:grid}.brand strong,.brand span{display:block}.brand span{color:#ffffffad;margin-top:2px;font-size:13px}.notice-nav{gap:10px;display:grid}.main-nav{gap:8px;display:grid}.main-nav-button{color:#fff;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;align-items:center;gap:9px;min-height:40px;padding:0 12px;font-weight:800;display:flex}.main-nav-button.active{color:#062026;background:#2bb7a8}.notice-tab{text-align:left;color:#fff;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;padding:13px}.notice-tab.active{color:#102a35;background:#e8fbf7}.notice-tab span,.notice-tab strong,.notice-tab em{display:block}.notice-tab span,.notice-tab em{opacity:.72;font-size:12px;font-style:normal}.notice-tab strong{margin:5px 0;font-size:14px;line-height:1.35}.workspace{padding:28px;position:relative}.topbar{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:22px;display:flex}h1,h2,p{margin:0}.topbar h1{font-size:28px;line-height:1.2}.topbar p,.panel-head p,.empty{color:#667984;margin-top:7px;font-size:14px}.actions,.table-toolbar,.panel-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.primary-button,.secondary-button,.ghost-link,.icon-button,.confirm-button,.confirmed-button,.notion-button{cursor:pointer;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:40px;font-weight:700;text-decoration:none;display:inline-flex}.primary-button{color:#fff;background:#102a35;padding:0 16px}.secondary-button,.ghost-link,.icon-button{color:#102a35;background:#fff;border:1px solid #dce4e6;padding:0 12px}.icon-button{width:40px;padding:0}.icon-button:disabled{opacity:.45;cursor:not-allowed}.summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px;display:grid}.metric,.panel{background:#fff;border:1px solid #dde6e7;border-radius:8px}.metric{grid-template-columns:42px 1fr;align-items:center;column-gap:12px;padding:16px;display:grid}.metric-icon{color:#0f887e;background:#e8fbf7;border-radius:8px;grid-row:span 2;place-items:center;width:42px;height:42px;display:grid}.metric span{color:#667984;font-size:13px}.metric strong{font-size:22px}.content-grid{grid-template-columns:minmax(0,1fr) 360px;gap:16px;display:grid}.panel{padding:18px}.panel-head{margin-bottom:16px}.panel-head h2{font-size:19px}.panel-head.compact h2{font-size:17px}.notice-preview{color:#33444d;background:#f4fbfa;border-left:3px solid #2bb7a8;margin-bottom:18px;padding:14px 16px;line-height:1.55}.table-toolbar{margin-bottom:10px;padding-top:4px}.member-table,.link-list{gap:8px;display:grid}.member-row{border:1px solid #e6ecee;border-radius:8px;grid-template-columns:minmax(0,1fr) 86px 100px;align-items:center;gap:12px;min-height:56px;padding:10px 12px;display:grid}.member-row strong,.member-row span{display:block}.member-row span,.member-row time{color:#667984;font-size:13px}.status-chip{color:#8a5a00;background:#fff5d8;border-radius:999px;justify-self:start;padding:5px 10px;font-size:13px;font-weight:800}.status-chip.confirmed{color:#087669;background:#e4faf5}.link-row{border:1px solid #e6ecee;border-radius:8px;padding:10px}.link-row strong,.link-row span{display:block}.link-row span{overflow-wrap:anywhere;color:#667984;margin-top:4px;font-size:12px}.reminder-box{color:#fff;background:#102a35;border-radius:8px;margin-top:14px;padding:14px}.reminder-box p{color:#ffffffc2;margin-top:8px;font-size:13px;line-height:1.5}.toast{color:#fff;background:#102a35;border-radius:8px;max-width:440px;padding:12px 14px;position:fixed;bottom:24px;right:26px;box-shadow:0 18px 50px #102a353d}.confirm-screen{background:linear-gradient(#f6f8f8 0%,#e7f5f2 100%);place-items:center;min-height:100vh;padding:20px;display:grid}.confirm-card{background:#fff;border:1px solid #dce7e8;border-radius:8px;width:min(100%,440px);padding:22px;box-shadow:0 22px 70px #102a351f}.compact-brand{margin-bottom:28px}.confirm-card .brand span{color:#667984}.confirm-copy span{color:#0f887e;margin-bottom:10px;font-size:13px;font-weight:800;display:block}.confirm-copy h1{margin-bottom:12px;font-size:25px;line-height:1.25}.confirm-copy p{color:#526672;margin-bottom:20px;line-height:1.6}.notion-button{color:#102a35;background:#eef5f5;width:100%;margin-bottom:10px}.confirm-button,.confirmed-button{color:#fff;width:100%;min-height:52px;font-size:16px}.confirm-button{background:#0f887e}.confirmed-button{cursor:default;background:#102a35}.confirm-status{text-align:center;color:#526672;margin-top:14px;font-size:13px}.leave-grid{grid-template-columns:360px minmax(0,1fr);gap:16px;display:grid}.leave-form{gap:12px;display:grid}.leave-form label{color:#33444d;gap:6px;font-size:13px;font-weight:800;display:grid}.leave-form input,.leave-form select,.leave-form textarea{color:#17202a;width:100%;font:inherit;background:#fff;border:1px solid #dce4e6;border-radius:8px;padding:10px 11px;font-weight:500}.leave-form textarea{resize:vertical;min-height:84px}.leave-form .check-line{align-items:center;gap:8px;font-weight:700;display:flex}.leave-form .check-line input{width:16px;height:16px}.segmented{border:1px solid #dce4e6;border-radius:8px;display:inline-flex;overflow:hidden}.segmented button{color:#526672;cursor:pointer;background:#fff;border:0;border-right:1px solid #dce4e6;min-height:34px;padding:0 11px;font-weight:800}.segmented button:last-child{border-right:0}.segmented button.active{color:#fff;background:#102a35}.leave-list{gap:9px;display:grid}.leave-row{border:1px solid #e6ecee;border-radius:8px;grid-template-columns:minmax(0,1fr) 76px 132px;align-items:center;gap:12px;padding:12px;display:grid}.leave-row strong,.leave-row span{display:block}.leave-row span,.leave-row p{color:#667984;font-size:13px}.leave-row p{margin-top:5px;line-height:1.45}.row-actions{justify-content:flex-end;gap:7px;display:flex}.icon-button.approve{color:#087669;background:#e4faf5}.icon-button.reject{color:#b42318;background:#fff0ed}.leave-note{margin-top:16px}.teacher-shell{color:#17202a;background:#f6f8f8;min-height:100vh;padding:28px}.teacher-shell.calendar-first{gap:18px;display:grid}.teacher-topbar{justify-content:space-between;align-items:center;gap:16px;width:100%;max-width:1280px;margin:0 auto;display:flex}.teacher-topbar .brand span{color:#667984}.teacher-actions{align-items:center;gap:9px;display:flex}.text-action{color:#526672;cursor:pointer;background:0 0;border:0;align-items:center;gap:7px;min-height:40px;font-weight:800;display:inline-flex}.text-action.active{color:#087669}.admin-link.active{color:#fff;background:#102a35}.notice-calendar-layout{grid-template-columns:310px minmax(0,1fr);gap:16px;width:min(1280px,100%);margin:0 auto;display:grid}.notice-calendar-panel{align-self:start}.month-calendar-card{background:linear-gradient(#fff 0%,#f7fbfb 100%);border:1px solid #e1e9eb;border-radius:8px;margin-bottom:12px;padding:14px}.month-calendar-head{grid-template-columns:34px 1fr 34px;align-items:center;gap:8px;margin-bottom:12px;display:grid}.month-calendar-head strong{text-align:center;font-size:16px}.icon-button.mini{width:34px;min-height:34px}.weekday-row,.month-grid{grid-template-columns:repeat(7,minmax(0,1fr));display:grid}.weekday-row{margin-bottom:6px}.weekday-row span{color:#7a8a92;text-align:center;padding:5px 0;font-size:13px;font-weight:900}.month-grid{gap:3px}.month-day{aspect-ratio:1;color:#273740;cursor:pointer;background:0 0;border:0;border-radius:999px;place-items:center;min-width:0;font-weight:900;display:grid;position:relative}.month-day:hover{background:#eef5f5}.month-day.active{color:#fff;background:#102a35}.month-day.today:not(.active){color:#087669;outline:1px solid #9bded5}.month-day.empty-day{cursor:default}.month-day em{color:#062026;background:#2bb7a8;border-radius:999px;place-items:center;width:13px;height:13px;font-size:9px;font-style:normal;line-height:1;display:grid;position:absolute;bottom:2px;right:3px}.month-day.active em{color:#102a35;background:#fff}.date-jumper{grid-template-columns:40px minmax(0,1fr) 40px;gap:8px;margin-bottom:14px;display:grid}.compact-jumper{margin-bottom:12px}.date-jumper input{color:#17202a;min-height:40px;font:inherit;border:1px solid #dce4e6;border-radius:8px;padding:0 10px;font-weight:700}.selected-date-button{color:#102a35;cursor:pointer;background:#fff;border:1px solid #dce4e6;border-radius:8px;min-height:40px;font-weight:900}.calendar-date-list{gap:8px;max-height:calc(100vh - 210px);padding-right:3px;display:grid;overflow:auto}.calendar-date{color:#17202a;cursor:pointer;text-align:left;background:#fff;border:1px solid #e1e9eb;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;min-height:52px;padding:9px 11px;display:flex}.calendar-date.active{background:#e8fbf7;border-color:#2bb7a8}.calendar-date span{font-weight:800}.calendar-date strong{color:#087669;font-size:13px}.notice-reader{min-height:calc(100vh - 122px)}.reader-date{color:#0f887e;margin-bottom:7px;font-weight:900}.notice-reader h1{font-size:28px;line-height:1.2}.notice-choice-row{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.notice-choice{color:#526672;cursor:pointer;background:#fff;border:1px solid #dce4e6;border-radius:8px;min-height:34px;padding:0 11px;font-weight:800}.notice-choice.active{color:#fff;background:#102a35}.notion-page-body{color:#263841;border-top:1px solid #edf2f3;gap:10px;padding-top:18px;display:grid}.notice-heading{margin-top:8px;font-size:22px}.notice-subheading{margin-top:8px;font-size:18px}.notice-paragraph,.notice-list-item,.notice-todo,.notice-child-page{white-space:pre-wrap;line-height:1.7}.notice-todo{align-items:flex-start;gap:9px;display:flex}.notice-todo span{color:#087669;border:1px solid #aebdc2;border-radius:4px;flex:none;place-items:center;width:18px;height:18px;margin-top:4px;font-size:13px;font-weight:900;display:inline-grid}.notice-quote{color:#33444d;background:#f4fbfa;border-left:3px solid #2bb7a8;margin:4px 0;padding:10px 14px}.notice-divider{border:0;border-top:1px solid #dce4e6;width:100%}.board-grid,.leave-only-grid{width:min(980px,100%)}.board-summary,.leave-flow-card{align-content:start;gap:16px;display:grid}.board-summary p,.leave-flow-card p,.review-meta{color:#667984;line-height:1.55}.my-request-list{gap:10px;display:grid}.my-request-row{border:1px solid #dce4e6;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;display:grid}.my-request-row div{gap:3px;min-width:0;display:grid}.my-request-row strong,.my-request-row span{overflow-wrap:anywhere}.my-request-row span{color:#667984;font-size:13px}.my-request-row em{font-style:normal}.review-card{gap:12px;display:grid}.review-segment{width:100%}.review-segment button{flex:1}.review-textarea{resize:vertical;color:#17202a;min-height:90px;font:inherit;border:1px solid #dce4e6;border-radius:8px;padding:10px 11px}.teacher-hero{grid-template-columns:240px minmax(0,1fr) auto;align-items:center;gap:20px;max-width:1120px;margin:0 auto 18px;display:grid}.teacher-hero .brand span{color:#667984}.teacher-hero h1{font-size:30px;line-height:1.2}.teacher-hero p{color:#526672;margin-top:8px}.admin-link{color:#102a35;background:#fff;border:1px solid #dce4e6;border-radius:8px;justify-content:center;align-items:center;min-height:40px;padding:0 14px;font-weight:800;text-decoration:none;display:inline-flex}.teacher-grid{grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:16px;max-width:1120px;margin:0 auto;display:grid}.teacher-card{gap:12px;display:grid}.teacher-card label{color:#33444d;gap:6px;font-size:13px;font-weight:800;display:grid}.teacher-card input,.teacher-card select,.teacher-card textarea{color:#17202a;width:100%;font:inherit;background:#fff;border:1px solid #dce4e6;border-radius:8px;padding:10px 11px;font-weight:500}.teacher-card textarea{resize:vertical;min-height:88px}.teacher-card .check-line{align-items:center;gap:8px;font-weight:700;display:flex}.teacher-card .check-line input{width:16px;height:16px}.registration-done{color:#087669;background:#e8fbf7;border:1px solid #bfece5;border-radius:8px;padding:12px}.registration-done strong,.registration-done span{display:block}.registration-done span{margin-top:4px;font-size:13px}.teacher-process{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;max-width:1120px;margin:16px auto 0;display:grid}.teacher-notices{background:#fff;border:1px solid #dde6e7;border-radius:8px;max-width:1120px;margin:16px auto 0;padding:18px}.teacher-notice-list{gap:10px;display:grid}.teacher-notice-row{border:1px solid #e6ecee;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;min-height:92px;padding:13px;display:grid}.teacher-notice-row span,.teacher-notice-row strong,.teacher-notice-row p{display:block}.teacher-notice-row span{color:#0f887e;margin-bottom:5px;font-size:13px;font-weight:800}.teacher-notice-row strong{font-size:17px}.teacher-notice-row p{color:#667984;margin-top:6px;font-size:13px;line-height:1.45}.teacher-process div{color:#fff;background:#102a35;border-radius:8px;padding:14px}.teacher-process strong,.teacher-process span{display:block}.teacher-process span{color:#ffffffbd;margin-top:6px;font-size:13px}@media (width<=980px){.app-shell{grid-template-columns:1fr}.sidebar{padding:18px}.notice-nav{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.summary-grid,.content-grid,.leave-grid,.notice-calendar-layout,.teacher-hero,.teacher-grid,.teacher-process{grid-template-columns:1fr}}@media (width<=640px){.workspace{padding:18px}.topbar,.teacher-topbar,.panel-head,.table-toolbar{flex-direction:column;align-items:stretch}.teacher-actions{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;display:grid}.actions{width:100%}.primary-button{flex:1}.member-row,.leave-row,.teacher-notice-row{grid-template-columns:1fr}.row-actions{justify-content:flex-start}}
