:root{color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;font-family:Avenir Next,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:#fff;min-width:320px}button,input,select,textarea{font:inherit}a{color:inherit}.login-page,.app-shell,.splash-screen{min-height:100vh}.splash-screen,.login-page{background:radial-gradient(circle at 0 0,#155e752e,#0000 32%),radial-gradient(circle at 100% 100%,#92400e29,#0000 28%),linear-gradient(140deg,#faf7f2 0%,#f5efe5 100%);grid-template-columns:1.2fr .8fr;display:grid}.splash-screen{grid-template-columns:1fr;place-items:center}.splash-card,.login-card,.panel.card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffd6;border:1px solid #0f172a14;box-shadow:0 18px 50px #0f172a14}.login-hero,.login-panel{align-items:center;padding:4rem 4.5rem;display:flex}.login-hero{color:#17313a}.login-hero h1{letter-spacing:-.06em;max-width:11ch;margin:.5rem 0 1rem;font-size:clamp(2.8rem,5vw,4.6rem);line-height:.98}.login-hero p{max-width:56ch;font-size:1.05rem}.hero-grid{gap:1rem;margin-top:2.5rem;display:grid}.hero-grid div{background:#ffffff8c;border:1px solid #155e751f;border-radius:1rem;padding:1.2rem 1.3rem}.hero-grid strong,.resource-list strong,.about-box strong{font-size:1.05rem;display:block}.hero-grid span,.resource-list span,.topbar-user span{color:#5b6475}.login-panel{justify-content:center}.login-card,.splash-card{border-radius:1.6rem;width:min(100%,34rem);padding:2rem}.login-head h2,.splash-card h1,.brand h1,.workspace-header h2,.section-head h3{margin:.3rem 0 .5rem}.captcha-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.captcha-box{background:#fffdf8;border:1px solid #0f172a14;border-radius:.95rem;place-items:center;min-width:7.5rem;min-height:3rem;display:grid;overflow:hidden}.app-shell{background:radial-gradient(circle at 8% 12%,#3b82f614,#0000 26rem),linear-gradient(#f7fbff 0%,#fff 18rem);flex-direction:column;display:flex}.topbar{z-index:30;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#f7fbffdb;padding:1.2rem 1.5rem .9rem;position:sticky;top:0}.topbar-inner{background:#fff;border:1px solid #94a3b82e;border-radius:1.15rem;justify-content:space-between;align-items:center;gap:1rem;width:min(100%,1500px);margin:0 auto;padding:.85rem .95rem;display:flex;box-shadow:0 18px 45px #1e40af17}.topbar-main{flex:1;align-items:center;gap:2.2rem;min-width:0;display:flex}.brand{min-width:14rem}.topbar-brand{border-right:1px solid #94a3b838;align-items:center;gap:.7rem;padding:0 1.35rem 0 .55rem;display:flex}.brand-mark{background:linear-gradient(90deg,#ffffffbf 1px,#0000 1px) 0 0/.55rem .55rem,linear-gradient(#ffffffbf 1px,#0000 1px) 0 0/.55rem .55rem,linear-gradient(135deg,#38bdf8,#2563eb) 0 0/100% 100%;border-radius:.38rem;width:1.45rem;height:1.45rem;box-shadow:0 8px 18px #2563eb3d}.topbar-brand h1,.topbar-user p{white-space:nowrap;color:#1f5f83;margin:0;font-size:1.05rem;line-height:1.1}.topbar-actions{align-items:center;gap:.75rem;display:flex}.topbar-user{text-align:right;gap:.1rem;min-width:6.5rem;display:grid}.topbar-user span{font-size:.78rem}.eyebrow{color:#64748b;text-transform:uppercase;letter-spacing:.18em;margin:0;font-size:.75rem}.top-nav{background:0 0;border:none;flex-wrap:wrap;align-items:center;gap:1.85rem;width:100%;min-width:0;max-width:100%;padding:0;display:flex;overflow:visible}.nav-item,.ghost-button,.primary-button,.danger-link,.ghost-link{cursor:pointer;border:none;transition:transform .12s,background .12s,color .12s,border-color .12s}.nav-item{text-align:center;color:#1f2937;white-space:nowrap;background:0 0;border-radius:999px;padding:.72rem .25rem;font-weight:700}.nav-item:hover,.ghost-button:hover,.primary-button:hover{transform:translateY(-1px)}.nav-item.active{color:#2563eb;box-shadow:none;background:0 0}.nav-item.active:after{content:"";background:#2563eb;border-radius:999px;width:1.4rem;height:.16rem;margin:.34rem auto -.5rem;display:block}.icon-button{color:#64748b;cursor:pointer;background:#f8fafc;border:1px solid #94a3b847;border-radius:.82rem;width:2.8rem;height:2.8rem;font-size:.78rem;font-weight:800}.nav-action{background:#2f8df4;border-radius:.82rem;min-width:5.8rem;box-shadow:0 10px 20px #2f8df42e}.workspace{background:0 0;width:100%;max-width:1500px;margin:0 auto;padding:1.35rem 1.5rem 2rem}.workspace-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.1rem;padding:0 .25rem;display:flex}.workspace-meta{color:#5b6475;gap:.8rem;display:flex}.notice,.tag{border-radius:999px;align-items:center;padding:.45rem .7rem;font-size:.88rem;font-weight:700;display:inline-flex}.notice.success,.tag.success{color:#166534;background:#15803d1f}.notice.error,.tag.error,.danger-link{color:#b42318}.tag.neutral{color:#334155;background:#4755691a}.panel-stack{gap:1rem;display:grid}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;display:grid}.stat-card{color:#0f172a;background:#fff;border:1px solid #94a3b82e;border-radius:1.3rem;flex-direction:column;justify-content:space-between;min-height:8.5rem;padding:1.4rem;display:flex;box-shadow:0 14px 34px #1e40af0f}.stat-card strong{letter-spacing:-.06em;color:#1d4ed8;font-size:2.8rem}.stat-card.teal{border-top:3px solid #14b8a6}.stat-card.amber{border-top:3px solid #f59e0b}.stat-card.rose{border-top:3px solid #fb7185}.stat-card.slate{border-top:3px solid #64748b}.panel.card{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff;border:1px solid #94a3b82e;border-radius:1.15rem;min-width:0;padding:1.15rem 1.2rem;box-shadow:0 12px 30px #1e40af0d}.toolbar,.dual-column,.form-grid.two-columns,.form-grid.three-columns,.settings-grid{gap:1rem;display:grid}.toolbar{flex-wrap:wrap;align-items:flex-end;gap:.85rem;display:flex}.toolbar .field{flex:0 12rem}.toolbar>button,.toolbar>input[type=file]{flex:none}.form-grid{gap:1rem;display:grid}.form-grid.two-columns{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid.three-columns{grid-template-columns:repeat(3,minmax(0,1fr))}.dual-column{grid-template-columns:1fr .6fr}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-layout,.settings-content{gap:1rem;min-width:0;display:grid}.subnav{background:#fff;border:1px solid #0f172a14;border-radius:1.2rem;flex-wrap:wrap;gap:.45rem;width:100%;min-width:0;padding:.5rem;display:flex;overflow:visible}.subnav-item{cursor:pointer;color:#334155;white-space:nowrap;background:#f8fafc;border:none;border-radius:.8rem;min-height:2.45rem;padding:.55rem .9rem;font-weight:800;transition:transform .12s,background .12s,color .12s}.subnav-item:hover{transform:translateY(-1px)}.subnav-item.active{color:#fff;background:#155e75}.full-width{grid-column:1/-1}.field{gap:.45rem;display:grid}.field span{color:#46505f;font-size:.9rem;font-weight:700}.field input,.field select,.field textarea,.data-table input,.data-table select{width:100%;font:inherit;color:#0f172a;background:#fff;border:1px solid #94a3b847;border-radius:.78rem;padding:.7rem .85rem}.data-table input,.data-table select{border-radius:.7rem;min-width:5.5rem;padding:.45rem .5rem}.field textarea{resize:vertical;min-height:6.2rem}.compact input,.compact select{min-width:11rem}.full-span{grid-column:1/-1}.primary-button,.ghost-button{white-space:nowrap;border-radius:.82rem;justify-content:center;align-items:center;gap:.35rem;min-height:2.55rem;padding:.62rem 1rem;font-weight:700;line-height:1;display:inline-flex}.primary-button{color:#fff;background:#2f8df4;box-shadow:0 10px 20px #2f8df429}.ghost-button{color:#1f2937;background:#fff;border:1px solid #94a3b847}.file-button{cursor:pointer;max-width:14rem;position:relative;overflow:hidden}.file-button input{opacity:0;cursor:pointer;position:absolute;inset:0}.file-button span{text-overflow:ellipsis;overflow:hidden}.ghost-link,.danger-link{border-radius:999px;justify-content:center;align-items:center;min-height:2rem;padding:.32rem .62rem;font-weight:700;line-height:1;display:inline-flex}.ghost-link{color:#155e75;background:#ecfeff}.danger-link{background:#fff1f2}.primary-button:disabled,.ghost-button:disabled{cursor:not-allowed;opacity:.58;transform:none}.full-width,.full-span,.table-wrap{width:100%}.table-wrap{min-width:0;overflow:auto}.data-table{border-collapse:separate;border-spacing:0;width:100%;min-width:max-content}.data-table th,.data-table td{box-sizing:border-box;white-space:nowrap;background:0 0;border-bottom:1px solid #94a3b829;padding:.78rem .8rem}.wide-table th:first-child,.wide-table td:first-child{width:6.6rem;min-width:6.6rem;max-width:6.6rem}.wide-table th:nth-child(2),.wide-table td:nth-child(2){width:5.9rem;min-width:5.9rem;max-width:5.9rem}.data-table th{z-index:2;color:#475569;background:#f8fafc;position:sticky;top:0}.attendance-day-heading{text-align:center;width:3.45rem;min-width:3.45rem;padding:.52rem .58rem}.attendance-day-heading .day-number,.attendance-day-heading .weekday-label{line-height:1.1;display:block}.attendance-day-heading .day-number{color:#0f172a;font-size:.92rem;font-weight:800}.attendance-day-heading .weekday-label{color:#64748b;margin-top:.22rem;font-size:.76rem;font-weight:700}.wide-table .sticky-col{z-index:4;background:#fffffff7;position:sticky;left:0;box-shadow:10px 0 16px #0f172a0a}.wide-table .sticky-col.second{z-index:4;left:calc(6.6rem - 1px)}.wide-table thead .sticky-col{z-index:5;background:#f8fafc}.compact-table-wrap{max-height:20rem}.inline-actions{gap:.45rem;display:inline-flex}.section-head{justify-content:space-between;gap:1rem;margin-bottom:1rem;display:flex}.hint{color:#64748b;margin:.8rem 0 0;font-size:.92rem}.chip-list{flex-wrap:wrap;gap:.7rem;margin-top:1rem;display:flex}.chip{color:#2563eb;background:#eef6ff;border-radius:999px;align-items:center;padding:.55rem .85rem;font-weight:700;display:inline-flex}.resource-list{gap:.75rem;margin:1rem 0 0;padding:0;list-style:none;display:grid}.resource-list li{background:#f8fafc;border:1px solid #94a3b82e;border-radius:.95rem;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem .95rem;display:flex}.about-box,.upload-block,.empty-state{background:#f8fafc;border:1px dashed #94a3b852;border-radius:1rem;padding:1rem}.empty-state{text-align:center;color:#64748b}.upload-block{align-content:start;gap:.85rem;display:grid}.full-width{width:100%}@media (width<=1100px){.login-page{grid-template-columns:1fr}.login-hero,.login-panel,.workspace{padding:1.25rem}.stats-grid,.settings-grid,.dual-column,.form-grid.two-columns,.form-grid.three-columns{grid-template-columns:1fr}.topbar{padding:.85rem}.topbar-inner,.topbar-main{flex-direction:column;align-items:stretch}.topbar-inner{gap:.85rem;padding:.85rem}.topbar-main{gap:.85rem}.brand,.topbar-brand{min-width:0}.topbar-brand{border-right:none;padding:0}.topbar-actions{justify-content:space-between}.topbar-user{text-align:left;justify-content:space-between;min-width:0}.top-nav{flex-wrap:nowrap;gap:1.35rem;padding:.15rem 0 .45rem;overflow-x:auto}.nav-item{flex:none}}
