:root{--bg: #f2f6f9;--surface: #ffffff;--surface-sunken: #f2f6fa;--surface-hover: #f5f8fb;--border: #e1e8ee;--border-strong: #c9d6e0;--text: #16222c;--text-secondary: #46586a;--muted: #5b6b78;--text-disabled: #9aa8b4;--accent: #005985;--accent-strong: #00496d;--accent-soft: #d9ecf5;--accent-faint: #ecf5fa;--on-accent: #ffffff;--brand-orange: #f4891e;--brand-cyan: #29b6d1;--ok: #0e7a44;--ok-dot: #18a558;--ok-soft: #d9f3e4;--ok-faint: #ecfaf2;--warn: #b45309;--warn-soft: #fdf1e2;--unsynced: #545f6d;--unsynced-dot: #8a93a0;--unsynced-soft: #eef1f4;--danger: #c92a2a;--danger-strong: #a82222;--danger-dot: #e23d3d;--danger-soft: #fdecec;--danger-faint: #fdf6f6;--conflict: #6d28d9;--conflict-soft: #f0e9fc;--grade-low: var(--danger);--grade-high: var(--ok);--gc-1: #005985;--gc-2: #0b7d95;--gc-3: #0e7a44;--gc-4: #6d28d9;--gc-5: #b45309;--gc-6: #c25e85;--grad-brand: linear-gradient(120deg, #29b6d1 0%, #0a7fae 48%, #005985 100%);--grad-brand-strong: linear-gradient(120deg, #1798b3 0%, #00679a 48%, #00496d 100%);--grad-warm: linear-gradient(120deg, #f4891e 0%, #fbb03b 100%);--gcg-1: linear-gradient(135deg, #29b6d1, #005985);--gcg-2: linear-gradient(135deg, #34d0b6, #0b7d95);--gcg-3: linear-gradient(135deg, #5fc26b, #0e7a44);--gcg-4: linear-gradient(135deg, #a78bfa, #6d28d9);--gcg-5: linear-gradient(135deg, #fbb03b, #d96f0b);--gcg-6: linear-gradient(135deg, #f193b6, #c25e85);--font-sans: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;--font-display: "Nunito", var(--font-sans);--fs-xs: .75rem;--fs-sm: .8125rem;--fs-base: .9375rem;--fs-md: 1.0625rem;--fs-lg: 1.25rem;--fs-xl: 1.5rem;--radius-xs: 4px;--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--radius-full: 999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 48px;--shadow-xs: 0 1px 2px rgba(13, 38, 59, .05);--shadow-sm: 0 1px 3px rgba(13, 38, 59, .07), 0 1px 2px rgba(13, 38, 59, .04);--shadow-md: 0 4px 12px -2px rgba(13, 38, 59, .1), 0 2px 4px rgba(13, 38, 59, .05);--shadow-lg: 0 16px 40px -8px rgba(13, 38, 59, .18), 0 4px 12px rgba(13, 38, 59, .08);--ring: 0 0 0 3px rgba(0, 89, 133, .18);--ring-danger: 0 0 0 3px rgba(201, 42, 42, .15);--ease-out: cubic-bezier(.2, 0, 0, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-spring: cubic-bezier(.34, 1.3, .36, 1);--dur-fast: .12s;--dur-base: .16s;--dur-slow: .2s;--dur-enter: .24s;--z-sticky-cell: 1;--z-sticky-head: 2;--z-scroll-fade: 4;--z-header: 20;--z-overlay: 50;--primary: var(--accent);--primary-dark: var(--accent-strong);--green: var(--ok-dot);--amber: var(--warn);--red: var(--danger);--shadow: var(--shadow-sm);font-synthesis:none}*{box-sizing:border-box}html,body,#app{height:100%;margin:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);font-size:var(--fs-base);line-height:1.5;-webkit-font-smoothing:antialiased}.app{min-height:100%;display:flex;flex-direction:column}.app__main{flex:1;padding:20px;max-width:1280px;width:100%;margin:0 auto}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-strong);text-decoration:underline}.link-btn{background:none;border:0;padding:0;font:inherit;color:var(--accent);cursor:pointer;text-align:left}.link-btn:hover{text-decoration:underline}h1{font-family:var(--font-display);font-weight:800;font-size:var(--fs-lg);letter-spacing:-.01em;margin:0 0 var(--space-4);color:var(--text)}h2{font-family:var(--font-display);font-weight:700;font-size:var(--fs-md);margin:0 0 var(--space-3)}table.journal td,table.journal th,.grade-input,.cal__day,.group-card__metrics b,.stat-chip__value,input[type=date].input,input[type=month].input{font-variant-numeric:tabular-nums}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);padding:8px 14px;border-radius:var(--radius);cursor:pointer;font-family:var(--font-sans);font-size:var(--fs-base);font-weight:500;transition:background-color var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out),transform 80ms var(--ease-out)}.btn:hover:not(:disabled){background:var(--surface-hover)}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.btn--primary:hover:not(:disabled){background:var(--accent-strong);border-color:var(--accent-strong)}.btn--danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn--danger:hover:not(:disabled){background:var(--danger-strong);border-color:var(--danger-strong)}.btn--danger-outline{background:var(--surface);border-color:#f0c4c4;color:var(--danger)}.btn--danger-outline:hover:not(:disabled){background:var(--danger-faint);border-color:var(--danger)}.btn--ghost{background:transparent;border-color:transparent}.btn--ghost:hover:not(:disabled){background:var(--surface-hover)}.btn--push-right{margin-left:auto}a.btn:hover{text-decoration:none}.btn--busy{position:relative;color:transparent!important;pointer-events:none}.btn--busy:disabled{opacity:1}.btn--busy:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;animation:kf-spin .6s linear infinite}.btn--busy:not(.btn--primary):not(.btn--danger):after{border-color:#16222c33;border-top-color:var(--text-secondary)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:var(--fs-sm);color:var(--muted);font-weight:600;transition:color var(--dur-base) var(--ease-out)}.field:focus-within>label{color:var(--accent)}.field--end{align-self:flex-end}.input,select.input,textarea.input{border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:9px 11px;font-family:var(--font-sans);font-size:var(--fs-base);background:#fff;color:var(--text);width:100%;transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),background-color var(--dur-fast) var(--ease-out)}.input:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}.input--xs{width:90px}.input--note{min-width:160px}textarea.input--note{resize:none;field-sizing:content;min-height:36px;max-height:96px;max-width:260px;overflow-y:auto;white-space:normal;display:block}.form-error{min-height:22px}.spacer{flex:1}.switch{display:inline-flex;align-items:center;gap:8px;cursor:pointer}.switch input{position:absolute;opacity:0}.switch__track{width:36px;height:20px;border-radius:var(--radius-full);background:var(--unsynced-dot);position:relative;flex:none;transition:background-color var(--dur-base) var(--ease-out)}.switch__track:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:var(--shadow-xs);transition:transform var(--dur-base) var(--ease-out)}.switch input:checked+.switch__track{background:var(--ok-dot)}.switch input:checked+.switch__track:after{transform:translate(16px)}.switch input:focus-visible+.switch__track{outline:2px solid var(--accent);outline-offset:2px}.error-text{color:var(--danger);font-size:.9rem}.muted{color:var(--muted)}.visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.badge{display:inline-flex;align-items:center;padding:1px 8px;border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:600}.badge--warn{background:var(--danger-soft);color:var(--danger)}.badge-warn{color:var(--danger)}.status-pill{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:600}.status-pill--planned{background:var(--accent-soft);color:var(--accent-strong)}.status-pill--conducted{background:var(--ok-soft);color:var(--ok)}.status-pill--cancelled{background:var(--danger-soft);color:var(--danger)}.status-pill--neutral{background:var(--unsynced-soft);color:var(--unsynced)}.banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--fs-sm)}.banner--error{background:var(--danger-soft);border:1px solid #f0c4c4;color:var(--danger)}.banner--info{background:var(--accent-faint);border:1px solid var(--accent-soft);color:var(--accent-strong)}.save-status{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-xs);font-weight:600;transition:color var(--dur-base) var(--ease-out)}.save-status:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--unsynced-dot);flex:none;transition:background-color var(--dur-base) var(--ease-out)}.save-status--synced{color:var(--ok)}.save-status--synced:before{background:var(--ok-dot)}.save-status--saving{color:var(--warn)}.save-status--saving:before{background:var(--warn)}.save-status--unsynced{color:var(--unsynced)}.save-status--unsynced:before{background:var(--unsynced-dot)}.save-status--error{color:var(--danger)}.save-status--error:before{background:var(--danger-dot)}.save-status--conflict{color:var(--conflict)}.save-status--conflict:before{background:var(--conflict)}.save-status--compact{gap:0}.save-status--saving:before{animation:kf-pulse-ring 1.2s var(--ease-out) infinite}.save-status--just-synced:before{animation:kf-pop .3s var(--ease-spring)}.save-status--error:before,.save-status--conflict:before{animation:kf-shake .3s var(--ease-out) 1}.skeleton{background:linear-gradient(90deg,var(--surface-sunken) 25%,#e9eff5 37%,var(--surface-sunken) 63%);background-size:400% 100%;animation:kf-shimmer 1.4s linear infinite;border-radius:var(--radius-sm)}.skeleton--text{height:12px}.skeleton--title{height:18px;width:60%}.skeleton--cell{height:28px}.skeleton-card{height:132px;border-radius:var(--radius)}.empty-state{text-align:center;padding:var(--space-8) var(--space-6);color:var(--muted)}.empty-state__art{width:48px;height:48px;margin:0 auto var(--space-3);color:var(--brand-cyan)}.empty-state__title{font-family:var(--font-display);font-weight:800;font-size:var(--fs-md);color:var(--text);margin-bottom:var(--space-1)}.stat-row{display:flex;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap}.stat-chip{display:inline-flex;flex-direction:column;gap:2px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:110px}.stat-chip__value{font-family:var(--font-display);font-weight:800;font-size:1.15rem;color:var(--accent)}.stat-chip span{font-size:var(--fs-xs);color:var(--muted)}.avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-soft);color:var(--accent-strong);font:600 var(--fs-xs)/28px var(--font-sans);text-align:center;flex:none}.journal-table-shell{position:relative}.journal-table-wrap{overflow:auto;max-height:calc(100vh - 280px);max-height:calc(100dvh - 280px);min-height:200px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}table.journal{border-collapse:collapse;width:100%;font-size:.9rem}table.journal th,table.journal td{border:1px solid var(--border);padding:5px 8px;text-align:center;white-space:nowrap}table.journal thead th{position:sticky;top:0;background:var(--surface-sunken);font-weight:600;color:var(--muted);z-index:var(--z-sticky-head);box-shadow:inset 0 -1px 0 var(--border-strong);white-space:pre-line;line-height:1.25;vertical-align:middle}table.journal th.col-student,table.journal td.col-student{text-align:left;position:sticky;left:0;background:var(--surface);min-width:180px;z-index:var(--z-sticky-cell)}table.journal thead th.col-student{z-index:3;background:var(--surface-sunken)}table.journal tbody td{transition:background-color var(--dur-slow) var(--ease-out),color var(--dur-slow) var(--ease-out)}tr.row--absent td{background:var(--danger-faint);color:var(--muted)}tr.row--absent td.col-student{background:var(--danger-faint)}tr.row--absent .link-btn{color:var(--muted);text-decoration:line-through;text-decoration-color:var(--border-strong)}table.journal th.col-average,table.journal td.col-average{border-left:2px solid var(--border-strong);font-weight:700}table.journal td.col-readonly{background:var(--surface-sunken);color:var(--muted)}.grade-readonly{display:inline-block;min-width:42px;color:var(--muted)}.journal__student-cell{display:flex;align-items:center;gap:8px;justify-content:space-between}.table-hint{margin-top:8px;font-size:var(--fs-sm)}table.journal--locked tbody td{background:var(--surface-sunken);color:var(--muted)}table.journal--locked tbody td.col-student{background:var(--surface-sunken)}table.journal--locked .grade-input:disabled,table.journal--locked .input:disabled{color:var(--muted)}.grade-input{width:42px;border:1px solid transparent;border-radius:var(--radius-xs);padding:5px 2px;text-align:center;font-size:.92rem;font-family:var(--font-sans);background:transparent;color:var(--text);-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield;transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),background-color var(--dur-fast) var(--ease-out)}.grade-input::-webkit-outer-spin-button,.grade-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.grade-input:hover{border-color:var(--border-strong)}.grade-input:focus{outline:none;border-color:var(--accent);background:var(--accent-faint);box-shadow:var(--ring)}.grade-input:disabled{color:var(--text-disabled);background:transparent}.grade-input--low{color:var(--grade-low);font-weight:600}.grade-input--high{color:var(--grade-high);font-weight:600}.grade-input--saved{animation:kf-save-flash .8s var(--ease-out) 1}.grade-input--invalid{animation:kf-shake .3s var(--ease-out) 1;border-color:var(--danger)!important;box-shadow:var(--ring-danger)}tr.row--flash td{animation:kf-save-flash .8s var(--ease-out) 1}.scroll-fade{position:absolute;top:1px;bottom:1px;width:24px;z-index:var(--z-scroll-fade);pointer-events:none;opacity:0;transition:opacity var(--dur-base) var(--ease-out)}.scroll-fade--left{left:1px;border-radius:var(--radius) 0 0 var(--radius);background:linear-gradient(to right,rgba(13,38,59,.1),transparent)}.scroll-fade--right{right:1px;border-radius:0 var(--radius) var(--radius) 0;background:linear-gradient(to left,rgba(13,38,59,.1),transparent)}.journal-table-shell--more-left .scroll-fade--left,.journal-table-shell--more-right .scroll-fade--right{opacity:1}.att-seg{display:inline-flex;gap:2px;padding:2px;border:1px solid var(--border-strong);border-radius:var(--radius-full);background:var(--surface)}.att-seg__btn{border:0;background:transparent;min-width:32px;height:26px;border-radius:var(--radius-full);font:600 var(--fs-xs) var(--font-sans);color:var(--muted);cursor:pointer;transition:background-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.att-seg__btn:hover:not(:disabled){background:var(--surface-hover);color:var(--text-secondary)}.att-seg__btn--present[aria-checked=true]{background:var(--ok-soft);color:var(--ok)}.att-seg__btn--absent[aria-checked=true]{background:var(--danger-soft);color:var(--danger)}.att-seg__btn--cancelled[aria-checked=true]{background:var(--surface-sunken);color:var(--text-secondary)}.att-seg--disabled{opacity:.5;pointer-events:none}.header{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:var(--z-header)}.header:after{content:"";display:block;height:2px;background:linear-gradient(90deg,var(--accent) 0%,var(--brand-orange) 100%)}.header__inner{max-width:1280px;margin:0 auto;padding:10px 20px;display:flex;align-items:center;gap:14px}.header__brand{font-family:var(--font-display);font-weight:800}.header__brand span{color:var(--accent)}.header__brand:hover{text-decoration:none;color:var(--accent)}.header__spacer{flex:1}.header__name{color:var(--muted);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.group-card{position:relative;border-top:3px solid var(--gc-accent, var(--accent));cursor:pointer;text-align:left;width:100%;font:inherit;color:inherit;transition:transform .18s var(--ease-out),box-shadow .18s var(--ease-out),border-color .18s var(--ease-out)}.group-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-strong);border-top-color:var(--gc-accent, var(--accent))}.group-card:active{transform:translateY(-1px) scale(.99)}.group-card__title{display:block;font-family:var(--font-display);font-weight:700;font-size:var(--fs-md);margin:0 0 var(--space-3);transition:color var(--dur-base) var(--ease-out)}.group-card:hover .group-card__title{color:var(--accent)}.group-card__arrow{position:absolute;right:14px;top:14px;opacity:0;transform:translate(-4px);transition:opacity var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out);color:var(--accent)}.group-card:hover .group-card__arrow,.group-card:focus-visible .group-card__arrow{opacity:1;transform:none}.group-card__metrics{display:flex;gap:16px;margin-top:10px;color:var(--muted);font-size:.85rem}.group-card__metrics b{color:var(--text);font-size:1rem;display:block}.lesson-bar{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end}.lesson-bar .field{margin-bottom:0;min-width:130px}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:14px 0}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f162373;display:flex;align-items:center;justify-content:center;z-index:var(--z-overlay)}.dialog{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;width:min(440px,92vw);box-shadow:var(--shadow-lg)}.dialog h2{font-family:var(--font-display)}.dialog--danger{border-top:3px solid var(--danger)}.dialog__actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal__wd{text-align:center;font-size:.8rem;color:var(--muted);font-weight:600;padding:4px 0}.cal__cell{min-height:66px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:6px;cursor:default;display:flex;flex-direction:column;gap:5px;align-items:flex-start;font:inherit;color:inherit;text-align:left;transition:background-color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}.cal__cell:hover{background:var(--accent-faint)}.cal__cell--empty,.cal__cell--empty:hover{background:transparent;border-color:transparent;cursor:default}.cal__cell--today{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}.cal__cell--has{cursor:pointer;box-shadow:var(--shadow-xs)}.cal__cell--has:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}.cal__cell--has:active{transform:none}.cal__day{font-size:.85rem;color:var(--muted)}.cal__day--today{background:var(--accent);color:var(--on-accent);width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:600}.cal__add{opacity:0;color:var(--muted);transition:opacity var(--dur-fast) var(--ease-out)}.cal__cell:not(.cal__cell--has):not(.cal__cell--empty):hover .cal__add{opacity:.6}.cal__pill{align-self:flex-start;font-size:.72rem;font-weight:600;padding:2px 7px;border-radius:var(--radius-full);color:var(--text-secondary);background:var(--surface-sunken)}.cal__pill--planned{background:var(--accent-soft);color:var(--accent-strong)}.cal__pill--conducted{background:var(--ok-soft);color:var(--ok)}.cal__pill--cancelled{background:var(--danger-soft);color:var(--danger)}.cal-legend{display:flex;gap:14px;align-items:center;font-size:var(--fs-xs);color:var(--muted)}.cal-legend i{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px}.cal-toolbar__label{font-family:var(--font-display);min-width:160px;text-align:center;font-weight:700}.auth{max-width:380px;margin:clamp(24px,8vh,96px) auto;position:relative}.auth:before,.auth:after{content:"";position:fixed;z-index:-1;width:420px;height:420px;border-radius:50%;pointer-events:none}.auth:before{top:-120px;right:-80px;background:radial-gradient(closest-side,rgba(41,182,209,.16),transparent 70%)}.auth:after{bottom:-140px;left:-100px;background:radial-gradient(closest-side,rgba(244,137,30,.12),transparent 70%)}.auth .card{border-radius:var(--radius-lg);padding:var(--space-6);transition:box-shadow var(--dur-base) var(--ease-out)}.auth .card:focus-within{box-shadow:var(--shadow-md)}.auth__brand{text-align:center;margin-bottom:18px}.auth__brand b{color:var(--accent)}.auth__wordmark{font-family:var(--font-display);font-weight:800;font-size:var(--fs-xl);color:var(--accent)}.auth__wordmark b{color:var(--brand-orange)}.field--password{position:relative}.field--password .input{padding-right:38px}.field__eye{position:absolute;right:6px;bottom:5px;border:0;background:none;padding:6px;cursor:pointer;color:var(--muted);border-radius:var(--radius-xs);line-height:0}.field__eye:hover{color:var(--text)}.check-icon{width:48px;height:48px;margin:0 auto var(--space-3);display:block;color:var(--ok)}.pw-hint{font-size:var(--fs-sm);color:var(--muted);margin:4px 0 0;transition:color var(--dur-base) var(--ease-out)}.pw-hint--ok{color:var(--ok)}.pw-hint--ok:before{content:"✓ "}.countdown-bar{height:3px;border-radius:2px;background:var(--accent);transform-origin:left;animation:kf-countdown 2.5s linear both}@keyframes kf-fade-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes kf-fade-in{0%{opacity:0}to{opacity:1}}@keyframes kf-pop{0%{transform:scale(.6)}60%{transform:scale(1.25)}to{transform:scale(1)}}@keyframes kf-pulse-ring{0%{box-shadow:0 0 #b4530959}70%{box-shadow:0 0 0 6px #b4530900}to{box-shadow:0 0 #b4530900}}@keyframes kf-save-flash{0%{background-color:var(--ok-soft)}to{background-color:transparent}}@keyframes kf-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}@keyframes kf-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes kf-spin{to{transform:rotate(360deg)}}@keyframes kf-draw{to{stroke-dashoffset:0}}@keyframes kf-badge-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes kf-countdown{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.route-enter-active{transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}.route-leave-active{transition:opacity var(--dur-fast) var(--ease-in)}.route-enter-from{opacity:0;transform:translateY(6px)}.route-leave-to{opacity:0}.fade-enter-active{transition:opacity var(--dur-base) var(--ease-out)}.fade-leave-active{transition:opacity var(--dur-fast) var(--ease-in)}.fade-enter-from,.fade-leave-to{opacity:0}.fade-rise-enter-active{transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}.fade-rise-leave-active{transition:opacity var(--dur-fast) var(--ease-in)}.fade-rise-enter-from{opacity:0;transform:translateY(4px)}.fade-rise-leave-to{opacity:0}.dialog-enter-active{transition:opacity var(--dur-slow) var(--ease-out)}.dialog-leave-active{transition:opacity var(--dur-fast) var(--ease-in)}.dialog-enter-from,.dialog-leave-to{opacity:0}.dialog-enter-active .dialog{transition:transform var(--dur-slow) var(--ease-spring)}.dialog-enter-from .dialog{transform:scale(.96) translateY(8px)}.dialog-leave-active .dialog{transition:transform var(--dur-fast) var(--ease-in)}.dialog-leave-to .dialog{transform:scale(.98) translateY(4px)}.slide-left-enter-active,.slide-right-enter-active{transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}.slide-left-leave-active,.slide-right-leave-active{transition:opacity var(--dur-fast) var(--ease-in),transform var(--dur-fast) var(--ease-in)}.slide-left-enter-from{opacity:0;transform:translate(24px)}.slide-left-leave-to{opacity:0;transform:translate(-16px)}.slide-right-enter-from{opacity:0;transform:translate(-24px)}.slide-right-leave-to{opacity:0;transform:translate(16px)}.stagger-item{animation:kf-fade-rise var(--dur-enter) var(--ease-out) both;animation-delay:calc(min(var(--i, 0),12)*35ms)}.auth__brand{animation:kf-fade-rise var(--dur-enter) var(--ease-out) both}.auth .card{animation:kf-fade-rise var(--dur-enter) var(--ease-out) 60ms both}.card--shake{animation:kf-shake .3s var(--ease-out) 1}.check-icon circle{stroke-dasharray:151;stroke-dashoffset:151;animation:kf-draw .5s var(--ease-out) forwards}.check-icon path{stroke-dasharray:36;stroke-dashoffset:36;animation:kf-draw .35s var(--ease-out) .35s forwards}.badge--pulse{animation:kf-badge-pulse 1.2s var(--ease-out) 2}.icon{width:18px;height:18px;flex:none;vertical-align:-3px}.icon--sm{width:14px;height:14px;vertical-align:-2px}.icon--lg{width:24px;height:24px}.page-hero{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:var(--grad-brand);color:#fff;padding:18px 22px;margin-bottom:var(--space-5);box-shadow:var(--shadow-md);animation:kf-hero-in .42s var(--ease-out) both}.page-hero:before,.page-hero:after{content:"";position:absolute;border-radius:50%;background:#ffffff1f;pointer-events:none}.page-hero:before{width:220px;height:220px;right:-60px;top:-120px}.page-hero:after{width:130px;height:130px;right:130px;bottom:-80px;background:#f4891e40}.page-hero__crumbs{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);margin-bottom:4px;color:#ffffffd9;position:relative;z-index:1}.page-hero__crumbs a{color:#fff;font-weight:600}.page-hero__crumbs a:hover{color:#fff}.page-hero__row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;position:relative;z-index:1}.page-hero__title{font-family:var(--font-display);font-weight:800;font-size:1.45rem;margin:0;color:#fff;display:flex;align-items:center;gap:10px}.page-hero__title .icon--lg{color:#ffffffe6}.page-hero__sub{font-size:var(--fs-sm);color:#ffffffd9;margin:2px 0 0}.page-hero__side{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.hero-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-full);background:#ffffff29;border:1px solid rgba(255,255,255,.28);color:#fff;font-size:var(--fs-sm);font-weight:600;white-space:nowrap}.hero-chip b{font-family:var(--font-display);font-weight:800}.page-hero__tabs{position:absolute;top:12px;right:14px;z-index:2;display:inline-flex;gap:3px;padding:3px;background:#ffffff24;border:1px solid rgba(255,255,255,.28);border-radius:var(--radius-full)}.hero-tab{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:var(--radius-full);color:#fff;font-size:var(--fs-sm);font-weight:600;transition:background-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}a.hero-tab:hover{color:#fff;text-decoration:none;background:#ffffff2e}.hero-tab--active,a.hero-tab--active:hover{background:#fff;color:var(--accent-strong)}a.hero-chip{transition:background-color var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}a.hero-chip:hover{color:#fff;text-decoration:none;background:#ffffff42;transform:translateY(-1px)}.hero-chip--warn{background:#f4891e4d;border-color:#ffc88c8c}a.hero-chip--warn:hover{background:#f4891e6b}.btn--primary{background:var(--grad-brand);border-color:transparent}.btn--primary:hover:not(:disabled){background:var(--grad-brand-strong);border-color:transparent;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--primary:active:not(:disabled){transform:scale(.97);box-shadow:none}.chip{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-full);background:var(--surface-sunken);font-size:var(--fs-sm);font-weight:600;color:var(--text-secondary)}.chip .icon{color:var(--accent)}.chip--warn{background:var(--danger-soft);color:var(--danger)}.chip--warn .icon{color:var(--danger)}.progress{height:6px;border-radius:var(--radius-full);background:var(--surface-sunken);overflow:hidden}.progress__bar{height:100%;border-radius:var(--radius-full);background:var(--grad-warm);transition:width .6s var(--ease-out)}.stat-chip{flex-direction:row;align-items:center;gap:12px;padding:12px 16px;box-shadow:var(--shadow-xs)}.stat-chip__icon{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:var(--accent-faint);color:var(--accent);flex:none}.stat-chip__body{display:flex;flex-direction:column;gap:1px}.stat-chip__value{font-size:1.3rem;line-height:1.15}.search{position:relative;min-width:220px}.search .icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.search .input{padding-left:36px;border-radius:var(--radius-full)}.group-card{border-top:0;padding:0;overflow:hidden}.group-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:var(--shadow-lg)}.group-card__cover{position:relative;overflow:hidden;height:64px;padding:0 14px;background:var(--gc-grad, var(--grad-brand));color:#fff;display:flex;align-items:center;justify-content:space-between;gap:10px}.group-card__cover:before,.group-card__cover:after{content:"";position:absolute;border-radius:50%;background:#ffffff29;transition:transform .3s var(--ease-out)}.group-card__cover:before{width:110px;height:110px;right:-28px;top:-40px}.group-card__cover:after{width:60px;height:60px;right:70px;bottom:-34px}.group-card:hover .group-card__cover:before{transform:scale(1.15)}.group-card__initial{position:relative;z-index:1;font-family:var(--font-display);font-weight:800;font-size:1.5rem}.group-card__cover .hero-chip{position:relative;z-index:1}.group-card__body{padding:12px 14px 14px}.group-card__title{margin-bottom:var(--space-1)}.group-card__textbook{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:var(--fs-sm);margin:2px 0 10px}.group-card__chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.group-card .progress{margin-top:10px}.cal__cell{border-radius:10px}.cal__cell--weekend{background:var(--surface-sunken)}.cal__cell--today{border-color:var(--brand-cyan);box-shadow:0 0 0 3px #29b6d140}.cal__cell--has:hover{transform:translateY(-2px) scale(1.02);box-shadow:var(--shadow-md)}.cal__pill{display:inline-flex;align-items:center;gap:4px}.cal__day--today{background:var(--grad-brand)}.cal-legend .icon{vertical-align:-2px}.lesson-card{position:relative;overflow:hidden}.lesson-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--grad-brand)}.lesson-card--conducted:before{background:var(--ok-dot)}.lesson-card--cancelled:before{background:var(--danger-dot)}.lesson-num-badge{width:46px;height:46px;border-radius:12px;background:var(--grad-brand);color:#fff;display:grid;place-items:center;font:800 1.15rem var(--font-display);box-shadow:var(--shadow-sm);flex:none}.lesson-card--cancelled .lesson-num-badge{background:var(--danger-soft);color:var(--danger)}table.journal tbody tr:nth-child(2n) td{background:#fafcfe}table.journal tbody tr:hover td,table.journal tbody tr:hover td.col-student{background:var(--surface-hover)}table.journal tbody tr.row--absent td,table.journal tbody tr.row--absent td.col-student{background:var(--danger-faint)}table.journal.journal--locked tbody tr td,table.journal.journal--locked tbody tr td.col-student{background:var(--surface-sunken)}table.journal tbody tr.row--unmarked td{background:var(--warn-soft)}table.journal tbody tr.row--unmarked .att-seg{border-color:var(--warn);box-shadow:0 0 0 3px #b453092e}.avg-pill{display:inline-flex;min-width:40px;justify-content:center;padding:2px 9px;border-radius:var(--radius-full);background:var(--surface-sunken);font-weight:700;font-variant-numeric:tabular-nums}.avg-pill--low{background:var(--danger-soft);color:var(--danger)}.avg-pill--high{background:var(--ok-soft);color:var(--ok)}.autosave-hint{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-xs);color:var(--muted)}.auth:before{background:radial-gradient(closest-side,rgba(41,182,209,.28),transparent 70%);animation:kf-float 9s ease-in-out infinite alternate}.auth:after{background:radial-gradient(closest-side,rgba(244,137,30,.22),transparent 70%);animation:kf-float 11s ease-in-out infinite alternate-reverse}.auth__wordmark{font-size:1.9rem;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.auth__wordmark b{-webkit-text-fill-color:var(--brand-orange)}.auth .card{position:relative;overflow:hidden}.auth .card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#29b6d1,#005985 55%,#f4891e)}.avatar{background:var(--grad-brand);color:#fff;box-shadow:0 0 0 2px var(--surface),0 0 0 3px #29b6d173}.contacts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.payer-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;padding:8px 0;border-top:1px dashed var(--border);font-size:var(--fs-sm);margin-top:8px}.payer-link{display:inline-flex;align-items:center;gap:5px;white-space:nowrap;font-weight:600}.radio-opt{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;cursor:pointer;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;transition:border-color var(--dur-fast) var(--ease-out),background-color var(--dur-fast) var(--ease-out)}.radio-opt:hover{background:var(--surface-hover)}.radio-opt:has(input:checked){border-color:var(--accent);background:var(--accent-faint)}.radio-opt input{margin-top:3px;accent-color:var(--accent);flex:none}.stagger-item{animation:kf-pop-in .32s var(--ease-out) both;animation-delay:calc(min(var(--i, 0),12)*55ms)}@keyframes kf-hero-in{0%{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:none}}@keyframes kf-pop-in{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:none}}@keyframes kf-float{0%{transform:translate(0)}to{transform:translate(20px,26px)}}@media (max-width: 640px){.app__main{padding:12px}.lesson-bar{gap:8px}.cal{gap:3px}.cal__cell{min-height:52px;padding:4px}.cal-legend{display:none}.journal-table-wrap{max-height:calc(100vh - 220px);max-height:calc(100dvh - 220px)}.att-seg__btn{min-width:38px;height:32px}.header__name{display:none}.auth:before,.auth:after{display:none}.page-hero{padding:14px 16px}.page-hero__title{font-size:1.2rem}.page-hero__tabs{position:static;margin-bottom:8px}.stat-chip{min-width:0;flex:1}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-delay:0s!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.save-status--saving:not(.save-status--compact):after{content:"…"}.skeleton{animation:none}}
