@font-face{font-family:Paperlogy;font-style:normal;font-weight:400 800;font-display:swap;src:url(https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-4Regular.woff2)format("woff2")}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f5f7fb;--panel:#ffffffe0;--panel-strong:#fff;--text:#172033;--muted:#687386;--border:#dfe6f2;--primary:#3157ff;--primary-strong:#213ed8;--accent:#7c3aed;--success:#087f5b;--success-bg:#dcfce7;--warning:#946200;--warning-bg:#fef3c7;--danger:#b42318;--danger-bg:#fee4e2;--shadow:0 24px 80px #1c2b4c24;--radius-xl:28px;--radius-lg:20px;--radius-md:14px}*{box-sizing:border-box}html{background:var(--bg);min-width:0;overflow-x:hidden}body{min-width:0;color:var(--text);word-break:keep-all;overflow-wrap:break-word;line-break:strict;background:radial-gradient(circle at 0 0,#3157ff29,#0000 34rem),radial-gradient(circle at 100% 0,#7c3aed24,#0000 30rem),linear-gradient(#fbfcff 0%,#f5f7fb 44%,#edf2fb 100%);margin:0;font-family:Paperlogy,Apple SD Gothic Neo,Malgun Gothic,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}button,input,select{font:inherit}button{cursor:pointer}button:disabled,input:disabled,select:disabled{cursor:not-allowed}:focus-visible{outline-offset:3px;outline:3px solid #3157ff6b}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.app-shell{width:min(1180px,100%);margin:0 auto;padding:40px 20px 56px}.hero{grid-template-columns:minmax(200px,.34fr) minmax(0,.66fr);align-items:stretch;gap:16px;margin-bottom:18px;display:grid}.hero-card,.status-card,.panel{background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid #dfe6f2e0}.hero-card{border-radius:var(--radius-xl);background:linear-gradient(135deg,#fffffff5 0%,#f7faffeb 58%,#eef3ffe6 100%);padding:24px 30px 22px;position:relative;overflow:hidden}.hero-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#3157ff21,#0000 68%);border-radius:999px;width:210px;height:210px;position:absolute;bottom:-70px;right:-52px}.eyebrow{color:var(--primary-strong);letter-spacing:-.01em;margin:0 0 8px;font-weight:800}.hero h1{letter-spacing:-.06em;margin:0;font-size:clamp(2.18rem,3.4vw,3.42rem);line-height:1.02}.hero-title-line{display:inline}.hero-copy{max-width:700px;color:var(--muted);margin:12px 0 0;font-size:1rem;line-height:1.54}.hero-badges{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.hero-badges span{color:var(--primary-strong);background:#3157ff14;border:1px solid #3157ff29;border-radius:999px;padding:7px 11px;font-size:.86rem;font-weight:900}.status-card{border-radius:var(--radius-xl);place-items:center;min-width:0;padding:14px;display:grid}.school-logo{aspect-ratio:1;object-fit:contain;width:min(100%,180px);max-width:100%;height:auto;display:block}.tabs{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:20px 0;display:grid}.tab-button{border:1px solid var(--border);min-height:58px;color:var(--muted);background:#ffffffbd;border-radius:999px;font-weight:800;transition:transform .16s,background .16s,color .16s,box-shadow .16s}.tab-button[aria-selected=true]{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;box-shadow:0 18px 36px #3157ff38}.tab-button:hover:not(:disabled){transform:translateY(-1px)}.panel{border-radius:var(--radius-xl);padding:28px}.request-grid{grid-template-columns:minmax(0,.92fr) minmax(320px,1.08fr);align-items:stretch;gap:24px;display:grid}.request-side-panel{flex-direction:column;gap:18px;min-width:0;height:100%;display:flex}.form-card,.board-card,.receipt,.dashboard-card,.today-summary-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--panel-strong);padding:22px}.form-card h2,.board-card h2,.dashboard-card h2,.today-summary-card h2{letter-spacing:-.035em;margin:0 0 16px}.today-summary-card{min-width:0;margin-bottom:24px}.today-summary-header{justify-content:space-between;align-items:start;gap:14px;min-width:0;margin-bottom:16px;display:flex}.today-summary-kicker{color:var(--primary-strong);margin:0 0 6px;font-size:.88rem;font-weight:900}.today-date{color:var(--primary-strong);white-space:nowrap;background:#3157ff1a;border-radius:999px;flex:none;padding:8px 12px;font-size:.9rem;font-weight:900}.today-period-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;min-width:0;display:grid}.today-period-card{border:1px solid var(--border);border-radius:var(--radius-md);background:#fbfdff;min-width:0;padding:14px}.today-period-card h3{margin:0 0 10px;font-size:1rem}.today-reservation-list{gap:8px;min-width:0;margin:0;padding:0;list-style:none;display:grid}.today-reservation-line{color:#334155;overflow-wrap:break-word;flex-wrap:wrap;align-items:center;gap:4px 6px;min-width:0;font-size:.9rem;font-weight:800;display:flex}.field-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.field{gap:8px;min-width:0;display:grid}.field-full{grid-column:1/-1}label,.legend{color:#334155;font-size:.92rem;font-weight:800}input,select{border:1px solid var(--border);border-radius:var(--radius-md);width:100%;min-height:48px;color:var(--text);background:#fbfdff;padding:0 14px}.period-grid,.availability-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.period-toggle{border:1px solid var(--border);border-radius:var(--radius-md);color:#334155;background:#f8fafc;min-height:52px;font-weight:800}.period-toggle.selected{color:var(--primary-strong);background:#3157ff1a;border-color:#3157ffb8}.period-toggle.unavailable:not(.selected){color:#9aa4b2;background:#f1f5f9}.primary-button{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;border:0;width:100%;min-height:54px;margin-top:12px;font-weight:900;box-shadow:0 16px 32px #3157ff3d}.primary-button:disabled{opacity:.48;box-shadow:none}.availability-card{border:1px solid var(--border);border-radius:var(--radius-md);background:#fbfdff;gap:9px;padding:14px;display:grid}.availability-card strong{font-size:1.05rem}.badge,.status-badge{border-radius:999px;justify-content:center;align-items:center;width:fit-content;min-height:30px;padding:4px 10px;font-size:.84rem;font-weight:900;display:inline-flex}.today-reservation-line .status-badge{min-height:24px;padding:2px 8px;font-size:.76rem}.status-select-field{width:fit-content;min-width:112px;display:inline-flex}.status-select-field-compact{min-width:98px}.status-select{border-radius:999px;width:auto;min-width:112px;min-height:34px;padding:0 28px 0 10px;font-size:.84rem;font-weight:900;transition:background .16s,color .16s,border-color .16s}.status-select.status-confirmed{color:var(--success);background:var(--success-bg);border-color:#087f5b3d}.status-select.status-loaned{color:var(--warning);background:var(--warning-bg);border-color:#94620047}.status-select.status-returned{color:var(--danger);background:var(--danger-bg);border-color:#b4231838}.status-select-field-compact .status-select{min-width:98px;min-height:28px;padding-left:8px;font-size:.76rem}.status-select:disabled{opacity:.6}.badge.green,.status-confirmed{color:var(--success);background:var(--success-bg)}.badge.yellow,.status-loaned{color:var(--warning);background:var(--warning-bg)}.badge.red,.status-returned{color:var(--danger);background:var(--danger-bg)}.help-text,.empty-text,.error-text{color:var(--muted);line-height:1.6}.error-text{color:var(--danger);font-weight:800}.receipt{background:var(--panel-strong);margin-top:auto;padding:16px 18px;box-shadow:0 16px 36px #0f172a0d}.receipt h3{letter-spacing:-.025em;margin:0 0 10px;font-size:1rem}.receipt-summary{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin:0;display:grid}.receipt-item{min-width:0}.receipt-item dt{color:var(--muted);margin-bottom:3px;font-size:.78rem;font-weight:800}.receipt-item dd{color:var(--text);word-break:keep-all;margin:0;font-size:.9rem;font-weight:900;line-height:1.25}.reservation-meta{grid-template-columns:auto minmax(0,1fr);gap:8px 12px;margin:0;display:grid}.receipt dt,.reservation-meta dt{color:var(--muted);font-weight:800}.receipt dd,.reservation-meta dd{margin:0;font-weight:800}.dashboard-toolbar{justify-content:space-between;align-items:end;gap:14px;margin-bottom:18px;display:flex}.dashboard-heading{min-width:0}.dashboard-controls{flex:none;justify-content:flex-end;align-items:end;gap:10px;display:flex}.month-field{gap:6px;min-width:min(100%,154px);display:grid}.month-field select{white-space:nowrap;width:clamp(154px,16vw,184px);max-width:100%;min-height:42px;padding:0 34px 0 12px}.month-field option{white-space:nowrap}.refresh-button,.cancel-button{border:1px solid var(--border);border-radius:var(--radius-md);color:#334155;background:#fff;font-weight:900}.refresh-button{width:auto;min-width:92px;min-height:42px;padding:0 14px}.refresh-button:hover:not(:disabled),.cancel-button:hover:not(:disabled){color:var(--primary-strong);border-color:#3157ff73}.cancel-message{color:var(--success);margin:-4px 0 14px;font-weight:800}.calendar-weekdays{color:var(--muted);text-align:center;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-bottom:8px;font-size:.86rem;font-weight:900;display:grid}.calendar-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;min-width:0;display:grid}.calendar-day{border:1px solid var(--border);border-radius:var(--radius-md);background:#fbfdff;flex-direction:column;gap:10px;min-width:0;min-height:158px;padding:10px;display:flex}.calendar-day-has-reservation{background:#fff;border-color:#3157ff3d}.calendar-day[data-weekday="1"]{grid-column:1}.calendar-day[data-weekday="2"]{grid-column:2}.calendar-day[data-weekday="3"]{grid-column:3}.calendar-day[data-weekday="4"]{grid-column:4}.calendar-day[data-weekday="5"]{grid-column:5}.calendar-day-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.calendar-day-number{font-size:.98rem;font-weight:900}.calendar-count{color:var(--primary-strong);white-space:nowrap;background:#3157ff1a;border-radius:999px;flex:none;padding:3px 7px;font-size:.72rem;font-weight:900}.calendar-period-groups{gap:10px;min-width:0;display:grid}.calendar-period-group{gap:6px;min-width:0;display:grid}.calendar-period-title{color:var(--primary-strong);background:#3157ff14;border-radius:999px;justify-content:space-between;align-items:center;gap:8px;margin:0;padding:4px 8px;font-size:.76rem;font-weight:900;line-height:1.2;display:flex}.calendar-period-title span:last-child{color:var(--muted);flex:none;font-size:.7rem}.calendar-reservations{gap:8px;min-width:0;display:grid}.calendar-reservation-card{background:#f8fafc;border:1px solid #dfe6f2cc;border-radius:12px;gap:5px;min-width:0;padding:8px;display:grid}.calendar-reservation-primary,.calendar-reservation-secondary{overflow-wrap:break-word;flex-wrap:wrap;align-items:center;gap:4px;min-width:0;margin:0;line-height:1.35;display:flex}.calendar-reservation-primary{color:var(--text);font-size:.8rem;font-weight:900}.calendar-reservation-secondary{color:#334155;font-size:.78rem;font-weight:800}.reservation-actions.calendar-reservation-actions{flex-wrap:nowrap;grid-template-columns:minmax(0,1fr) 30px;justify-content:stretch;align-items:center;gap:3px;width:100%;min-width:0;max-width:100%;display:grid;overflow:hidden}.calendar-reservation-actions .status-select-field-compact{width:100%;min-width:0}.calendar-reservation-actions .status-select-field-compact .status-select{width:100%;min-width:0;padding-left:6px;padding-right:18px;font-size:.7rem}.calendar-reservation-actions .calendar-cancel-button{width:30px;min-width:0;padding:0;font-size:.66rem;overflow:hidden}.calendar-empty-text{margin:auto 0 0;font-size:.82rem}.dashboard-list{gap:12px;display:grid}.reservation-row{border:1px solid var(--border);border-radius:var(--radius-lg);background:#fbfdff;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:16px;padding:16px;display:grid}.reservation-lines{gap:6px;min-width:0;display:grid}.reservation-line{flex-wrap:wrap;align-items:center;gap:6px;min-width:0;margin:0;display:flex}.reservation-line-primary{letter-spacing:-.02em;font-weight:900}.reservation-line-secondary{color:#334155;font-weight:800}.dot{color:#9aa4b2}.reservation-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.cancel-button{min-height:34px;padding:0 10px;font-size:.82rem}.today-cancel-button{white-space:nowrap;border-radius:999px;min-height:28px;padding:0 8px;font-size:.76rem}.cancel-button:disabled{opacity:.45}@media (max-width:840px){.app-shell{padding:22px 14px 40px}.hero,.request-grid{grid-template-columns:1fr}.hero-card,.status-card,.panel{padding:18px}.school-logo{width:min(100%,132px)}.hero h1{letter-spacing:-.045em;overflow-wrap:break-word;font-size:clamp(2rem,8.6vw,2.55rem);line-height:1.05}.hero-title-line{display:block}.hero-copy{overflow-wrap:break-word;font-size:.96rem;line-height:1.5}.field-grid,.period-grid,.availability-grid,.today-period-grid,.tabs{grid-template-columns:1fr}.today-summary-header,.dashboard-toolbar,.reservation-row{grid-template-columns:1fr;display:grid}.calendar-weekdays{display:none}.calendar-grid{grid-template-columns:1fr}.calendar-day{min-height:0}.calendar-day-header{justify-content:flex-start}.calendar-day-number:after{content:"일"}.calendar-empty-text{margin:0}.dashboard-controls{grid-template-columns:minmax(0,1fr) auto;justify-content:start;width:100%;display:grid}.month-field,.month-field select{width:100%;min-width:0}.calendar-day[data-weekday]{grid-column:auto}.reservation-actions{justify-content:start}.receipt{margin-top:0}.receipt-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:420px){.app-shell{padding-left:12px;padding-right:12px}.hero-card,.status-card,.panel,.form-card,.board-card,.today-summary-card,.dashboard-card{border-radius:18px;padding:18px}.hero h1{font-size:2.08rem}.school-logo{width:min(100%,104px)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
