:root{--bg:#f4f6f8;--surface:#fff;--surface-alt:#fafbfc;--line:#e2e8f0;--line-strong:#cbd5e1;--text:#1f2937;--text-soft:#6b7280;--brand:#0f766e;--brand-dark:#115e59;--brand-soft:#e6fffb;--danger:#dc2626;--danger-soft:#fef2f2;--radius-lg:18px;--radius-md:12px;--radius-sm:10px;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Segoe UI,Arial,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}#root{min-height:100vh}.app-shell{width:min(1180px,100% - 32px);margin:0 auto;padding:16px 0 40px}.app-main,.page-grid,.student-list,.week-lessons,.attendance-board{gap:20px;display:grid}.navbar{border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--line);margin-bottom:24px;padding:14px 20px}.navbar-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.brand-block{align-items:center;gap:12px;display:flex}.brand-mark{background:var(--brand);color:#fff;border-radius:12px;place-items:center;width:40px;height:40px;font-weight:700;display:grid}.brand-copy h1,.page-header h2,.section-header h3,.panel-headline h3,.modal-copy h3,.week-column-header h4{color:var(--text);margin:0;font-weight:700}.brand-copy h1{font-size:1.1rem}.brand-copy p,.page-header p,.helper-copy,.student-subline,.meta-line,.page-header-meta,.section-header p,.week-column-header p,.schedule-empty,.empty-state p,.label{color:var(--text-soft);margin:0}.nav-links,.hero-actions,.page-header-actions,.header-actions,.inline-actions,.modal-actions,.attendance-controls,.grade-controls,.group-meta{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.nav-link,.back-link,.page-link{color:var(--text-soft);align-items:center;gap:8px;display:inline-flex}.back-link-button{width:fit-content;font:inherit;cursor:pointer;background:0 0;border:0;padding:0}.nav-link.active,.nav-link:hover,.back-link:hover,.page-link:hover{color:var(--brand-dark)}.nav-role{background:var(--surface-alt);min-height:32px;color:var(--text-soft);border-radius:999px;align-items:center;padding:0 12px;font-size:.9rem;display:inline-flex}.nav-logout{background:0 0;border:0;padding:0}.navbar-back-row{margin-top:10px}.page-header{border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:20px;padding:24px;display:flex}.page-header-main{gap:8px;display:grid}.page-header h2{font-size:clamp(1.9rem,4vw,2.5rem);line-height:1.05}.page-header-meta{flex-wrap:wrap;gap:14px;font-size:.95rem;display:flex}.surface{border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--line);padding:24px}.surface+.surface{margin-top:20px}.section-header,.panel-headline,.schedule-toolbar,.week-column-header,.attendance-table-head,.attendance-head{justify-content:space-between;align-items:center;gap:16px;display:flex}.section-header,.panel-headline,.attendance-head{margin-bottom:20px}.group-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;display:grid}.group-card,.student-item,.lesson-card,.week-column,.attendance-row,.modal-card,.empty-state{border-radius:var(--radius-md);border:1px solid var(--line);background:var(--surface-alt)}.group-card,.week-column,.lesson-card,.student-item,.attendance-row{padding:18px}.group-card{gap:14px;display:grid}.group-card h3,.lesson-card h3{margin:0;font-size:1.1rem;font-weight:700}.group-meta-minimal{color:var(--text-soft);font-size:.94rem}.button{border:1px solid var(--line);background:var(--surface);min-height:40px;color:var(--text);border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:0 16px;font-weight:500;display:inline-flex}.button:hover:not(:disabled){border-color:var(--line-strong)}.button:disabled{opacity:.5;cursor:not-allowed}.button-primary{background:var(--brand);border-color:var(--brand);color:#fff}.button-primary:hover:not(:disabled){background:var(--brand-dark);border-color:var(--brand-dark)}.button-secondary,.button-ghost{background:var(--surface)}.button-danger{background:var(--danger-soft);color:var(--danger);border-color:#fecaca}.button-full{width:100%}.tab-shell{gap:20px;display:grid}.group-tabs{background:var(--surface-alt);border:1px solid var(--line);border-radius:999px;gap:6px;padding:4px;display:inline-flex}.group-tab{min-height:40px;color:var(--text-soft);background:0 0;border:0;border-radius:999px;align-items:center;gap:8px;padding:0 16px;display:inline-flex}.group-tab span{background:#ffffffd9;border-radius:999px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;font-size:.8rem;display:inline-flex}.group-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px #0f172a14}.tab-panel{min-height:360px}.group-view{display:grid}.material-list{gap:12px}.student-item{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.icon-button{border:1px solid var(--line);background:var(--surface);width:36px;height:36px;color:var(--text-soft);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.icon-button:hover{border-color:var(--line-strong);color:var(--brand-dark)}.student-name{margin:0;font-size:1rem;font-weight:600}.student-subline{margin-top:4px;font-size:.92rem}.schedule-toolbar{margin-bottom:18px}.tag,.status-chip{border:1px solid var(--line);background:var(--surface);min-height:36px;color:var(--text-soft);border-radius:999px;align-items:center;gap:8px;padding:0 12px;font-size:.9rem;display:inline-flex}.status-chip.success{color:var(--brand-dark);background:var(--brand-soft);border-color:#99f6e4}.attendance-pill{border:1px solid var(--line);background:var(--surface);min-height:34px;color:var(--text-soft);border-radius:999px;align-items:center;padding:0 12px;font-size:.9rem;display:inline-flex}.attendance-pill.present{background:var(--brand-soft);color:var(--brand-dark);border-color:#99f6e4}.attendance-pill.absent{background:var(--danger-soft);color:var(--danger);border-color:#fecaca}.week-grid-scroll{overflow-x:auto}.week-grid{grid-template-columns:repeat(7,minmax(170px,1fr));gap:12px;min-width:1220px;display:grid}.week-column{gap:14px;display:grid}.week-column-header h4{font-size:.98rem}.week-column-header p{margin-top:2px;font-size:.86rem}.day-add-button{border-radius:50%;min-width:36px;min-height:36px;padding:0}.schedule-empty{padding:10px 0 0;font-size:.9rem}.lesson-card{gap:12px;display:grid}.lesson-card-compact{padding:12px 14px;display:block}.lesson-card-compact-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.attendance-head h3{margin:0;font-size:1.25rem}.attendance-table-head{border-bottom:1px solid var(--line);color:var(--text-soft);padding:0 18px 12px;font-size:.92rem}.attendance-table-head span:first-child{flex:1}.attendance-table-head span:nth-child(2),.attendance-table-head span:nth-child(3){width:240px}.attendance-row{grid-template-columns:minmax(180px,1fr) 240px 240px;align-items:center;gap:18px;display:grid}.attendance-student{gap:4px;display:grid}.attendance-row-readonly{grid-template-columns:minmax(180px,1fr) 180px 120px}.attendance-value-cell{align-items:center;display:flex}.grade-value{border:1px solid var(--line);min-width:44px;min-height:34px;color:var(--text-soft);background:var(--surface);border-radius:999px;justify-content:center;align-items:center;padding:0 12px;display:inline-flex}.grade-value.filled{color:var(--text)}.attendance-toggle,.grade-button{border:1px solid var(--line);background:var(--surface);min-width:44px;min-height:38px;color:var(--text);border-radius:999px;padding:0 12px}.attendance-toggle.active-present{background:var(--brand-soft);color:var(--brand-dark);border-color:#99f6e4}.attendance-toggle.active-absent{background:var(--danger-soft);color:var(--danger);border-color:#fecaca}.grade-button.active{border-color:var(--brand);color:var(--brand)}.grade-clear{color:var(--text-soft)}.input-stack{gap:8px;display:grid}.label{font-size:.92rem}.input-field,.textarea-field,.select-field{border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface);width:100%;color:var(--text);padding:13px 14px}.input-field:focus,.textarea-field:focus,.select-field:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #0f766e14}.textarea-field{resize:vertical;min-height:104px}.input-error{color:var(--danger);font-size:.88rem}.modal-overlay{z-index:40;background:#0f172a52;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-card{background:var(--surface);width:min(100%,520px);max-height:calc(100vh - 48px);padding:24px;overflow:auto}.modal-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.modal-copy{gap:4px;display:grid}.modal-body{gap:14px;margin-top:20px;display:grid}.danger-note{border-radius:var(--radius-md);background:var(--danger-soft);color:var(--danger);border:1px solid #fecaca;gap:6px;padding:14px;display:grid}.danger-note strong{color:var(--text)}.empty-state{text-align:center;padding:28px}.empty-state strong{margin-bottom:8px;display:block}.login-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{border-radius:var(--radius-lg);border:1px solid var(--line);background:var(--surface);gap:24px;width:min(100%,440px);padding:28px;display:grid}.login-copy h1{margin:0;font-size:2rem}.login-copy p{color:var(--text-soft);margin-top:6px}.login-form{gap:16px;display:grid}.login-accounts{gap:12px;display:grid}.login-account{border-radius:var(--radius-md);border:1px solid var(--line);background:var(--surface-alt);gap:4px;padding:14px 16px;display:grid}.form-error{border-radius:var(--radius-sm);background:var(--danger-soft);color:var(--danger);border:1px solid #fecaca;padding:12px 14px}.pulse-in{animation:none}@media (width<=960px){.page-header,.section-header,.panel-headline,.schedule-toolbar,.attendance-table-head,.attendance-row,.student-item,.navbar-row,.modal-header{flex-direction:column;grid-template-columns:1fr;align-items:stretch}.attendance-table-head{display:none}.attendance-row{grid-template-columns:1fr}}@media (width<=720px){.app-shell{width:min(100% - 20px,1180px);padding-top:12px}.surface,.page-header,.modal-card{padding:18px}.group-tabs{width:100%}.group-tab{flex:1 1 0;justify-content:center}}
