@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap";:root{--bg: #050914;--panel: rgba(255, 255, 255, .06);--panel-soft: rgba(255, 255, 255, .03);--panel-strong: rgba(255, 255, 255, .1);--border: rgba(255, 255, 255, .08);--text: #e2e8f0;--muted: #94a3b8;--accent: #67e8f9;--accent-2: #8b5cf6;--error: #f87171;--glow-1: rgba(103, 232, 249, .12);--glow-2: rgba(139, 92, 246, .12);--glow-3: rgba(14, 165, 233, .1);--blur-1: rgba(103, 232, 249, .45);--blur-2: rgba(139, 92, 246, .4);--blur-3: rgba(14, 165, 233, .38)}*{box-sizing:border-box}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}body{margin:0;font-family:Inter,Space Grotesk,system-ui,-apple-system,sans-serif;background:radial-gradient(circle at 20% 20%,var(--glow-1),transparent 32%),radial-gradient(circle at 80% 10%,var(--glow-2),transparent 35%),radial-gradient(circle at 20% 80%,var(--glow-3),transparent 32%),var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}.calendar-builder{display:grid;grid-template-columns:240px minmax(0,1fr);gap:16px;align-items:flex-start;margin-top:12px;overflow:visible}.builder-sidebar{width:240px;padding:12px;background:linear-gradient(135deg,var(--panel),var(--panel-soft));border:1px solid var(--border);border-radius:14px;box-shadow:0 10px 30px #00000040;position:sticky;left:0;align-self:flex-start;height:min(70vh,640px);display:flex;flex-direction:column;gap:12px}.builder-grid-scroll{flex:1;overflow:auto;height:min(70vh,640px);max-height:min(70vh,640px);min-width:0;min-height:360px;border:1px solid var(--border);border-radius:14px;background:radial-gradient(circle at 20% 20%,var(--panel-soft),transparent 35%),radial-gradient(circle at 80% 0%,var(--panel),transparent 40%),var(--panel-soft);padding:0;box-shadow:inset 0 0 0 1px var(--panel-soft),0 12px 30px #00000040}.builder-grid{position:relative;min-width:max-content}.builder-grid-base,.builder-grid-overlay{display:grid;grid-auto-flow:row;grid-auto-rows:var(--calendar-row-height, 110px);gap:0;width:100%;height:100%}.builder-grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2}.builder-grid-base .grid-head,.builder-grid-base .grid-row{display:contents}.builder-grid-base .grid-cell{min-height:var(--calendar-row-height, 110px);border:1px solid var(--border);background:var(--panel-soft);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:8px;color:var(--text);font-size:13px}.builder-grid-base .head{background:var(--panel-strong);font-weight:600;text-align:center;position:sticky;top:0;z-index:3;min-height:var(--calendar-header-height, 56px);padding:6px 8px;font-size:12px}.builder-grid-base .time-col{width:var(--calendar-time-col, 90px);text-align:right;padding-right:10px;color:var(--muted);font-variant-numeric:tabular-nums;position:sticky;left:0;z-index:6;background:var(--panel-strong)}.builder-grid-base .head.time-col{z-index:7;background:var(--panel-strong)}.builder-grid-base .drop-cell{position:relative;background:linear-gradient(180deg,var(--panel-soft),var(--panel));overflow:hidden}.builder-grid-base .drop-cell:hover{outline:1px dashed rgba(159,178,255,.6)}.calendar-readonly .drop-cell:hover{outline:none}.builder-grid-base .drop-cell,.builder-grid-base .head,.builder-grid-base .time-col{box-sizing:border-box}.grid-pill{position:relative;padding:12px 14px;border-radius:14px;color:#0d1a2d;font-weight:700;box-shadow:0 10px 25px #00000040;display:flex;flex-direction:column;justify-content:center;gap:4px;margin:0;opacity:.94;width:100%;height:100%;min-height:70px;max-width:100%;overflow:hidden;z-index:3;box-sizing:border-box;pointer-events:auto}.grid-pill .pill-title{line-height:1.2}.grid-pill:after{content:"";position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.28),transparent 55%);opacity:.35;pointer-events:none}.grid-pill .pill-meta{font-size:12px;color:#0d1a2db3}.grid-pill .pill-remove{position:absolute;top:4px;right:6px;background:#00000026;border:none;color:#0d1a2d;border-radius:50%;width:20px;height:20px;cursor:pointer}.grid-pill .pill-resize{position:absolute;left:12px;right:12px;bottom:6px;height:6px;border-radius:999px;background:#0d1a2d33;cursor:ns-resize}.grid-pill .pill-resize.active{background:#0d1a2d59}.subject-chips{display:flex;flex-direction:column;gap:8px;margin-top:12px;flex:1;overflow:auto;padding-right:6px}.subject-chips::-webkit-scrollbar{width:6px}.subject-chips::-webkit-scrollbar-thumb{background:var(--panel-strong);border-radius:999px}.drag-chip{padding:10px 12px;border-radius:12px;color:#0d1a2d;font-weight:700;cursor:grab;box-shadow:0 10px 25px #00000040;border:1px solid var(--border);opacity:.9;transition:transform .12s ease,opacity .12s ease}.drag-chip.readonly{cursor:default;opacity:.65}.drag-chip:active{cursor:grabbing;transform:scale(.98);opacity:1}.builder-grid-scroll::-webkit-scrollbar{height:8px;width:8px}.builder-grid-scroll::-webkit-scrollbar-thumb{background:var(--panel-strong);border-radius:8px}.builder-grid-scroll::-webkit-scrollbar-track{background:transparent}.chip-row.wrap{flex-wrap:wrap;gap:6px}.field.compact{width:100%}.zoom-row{display:flex;align-items:center;gap:10px}.zoom-value{min-width:48px;text-align:center;font-weight:600;color:#c7d2fe}.bg-animated{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;z-index:0;pointer-events:none}.bg-blur{position:absolute;filter:blur(110px);opacity:.9;animation:drift 9s ease-in-out infinite alternate;mix-blend-mode:screen}[data-theme=light] .bg-blur{opacity:.55;mix-blend-mode:normal}.bg-1{width:520px;height:520px;background:radial-gradient(circle,var(--blur-1),transparent 62%);top:-120px;left:-60px;animation-delay:0s}.bg-2{width:520px;height:520px;background:radial-gradient(circle,var(--blur-2),transparent 62%);bottom:-140px;right:-100px;animation-delay:1.2s}.bg-3{width:420px;height:420px;background:radial-gradient(circle,var(--blur-3),transparent 62%);top:35%;right:12%;animation-delay:.6s}@keyframes drift{0%{transform:translateZ(0) scale(1) rotate(0)}to{transform:translate3d(-40px,30px,0) scale(1.1) rotate(6deg)}}.auth-shell{width:min(80vw,1440px);max-width:1440px;margin:0 auto;padding:36px 24px 80px;display:flex;flex-direction:column;gap:24px;min-height:100vh;position:relative;z-index:1}.panel-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;width:100%}.panel-title{display:flex;align-items:flex-start;gap:12px}.panel-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;color:var(--accent);background:var(--panel-strong);box-shadow:inset 0 0 0 1px var(--border);animation:floatSoft 6s ease-in-out infinite}.panel-icon svg{width:22px;height:22px}.badge-row-compact{gap:10px;align-items:center}.top-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:14px;background:var(--panel);box-shadow:0 8px 24px #0f172a14}.brand-logo{width:120px;height:44px;display:flex;align-items:center}.brand-logo img{height:100%;width:auto}.app-footer{margin-top:auto;padding:14px;border:1px solid var(--border);border-radius:14px;background:var(--panel);box-shadow:none;display:flex;justify-content:center}.app-footer a{color:var(--muted);font-weight:600;text-decoration:none}.app-footer a:hover{color:var(--text);text-decoration:underline}.cta-buttons{margin-top:14px;display:flex;gap:10px}.floating-badge{position:absolute;bottom:12px;right:-8px;padding:10px 14px;border-radius:999px;background:#67e8f929;border:1px solid rgba(103,232,249,.4);font-weight:700;color:#a5f3fc;box-shadow:0 10px 26px #67e8f92e}.service-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.service-chip{display:inline-flex;align-items:center;gap:10px;padding:12px 14px;border-radius:14px;border:1px solid rgba(103,232,249,.35);background:var(--panel);box-shadow:0 10px 26px #67e8f91f}.service-chip .spark{width:10px;height:10px;border-radius:999px;background:radial-gradient(circle,#67e8f9e6,#8b5cf6b3);box-shadow:0 0 16px #67e8f9cc}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:10px}.feature-chip{border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--panel-soft);font-weight:600}.timeline{display:flex;flex-direction:column;gap:10px;margin-top:12px}.timeline-item{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:flex-start}.timeline-item .dot{width:10px;height:10px;border-radius:999px;background:var(--accent);margin-top:6px;box-shadow:0 0 14px #67e8f999}.contact-actions{display:flex;gap:10px;flex-wrap:wrap}.top-bar-meta{display:flex;flex-direction:column;gap:2px}.brand-text{font-weight:700}.language-switcher{display:flex;align-items:center;gap:8px;margin-left:auto;flex-wrap:wrap;row-gap:6px}.language-label{color:var(--muted);font-size:13px}.switch-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.theme-toggle{display:inline-flex;align-items:center;gap:6px;padding:4px;border-radius:999px;border:1px solid var(--border);background:var(--panel-soft)}.theme-toggle-button{width:32px;height:32px;border-radius:999px;display:grid;place-items:center;color:#1e293b;transition:all .18s ease}.theme-toggle-button svg{width:18px;height:18px}.theme-toggle-button.active{color:#f59e0b;background:#fbbf242e;box-shadow:inset 0 0 0 1px #f59e0b73}[data-theme=dark] .theme-toggle-button{color:#f8fafc;background:#0b1020;box-shadow:inset 0 0 0 1px #e2e8f033}.logout-button{display:inline-flex;align-items:center;gap:8px}.logout-button svg{width:18px;height:18px}.lang-chip{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:10px;padding:8px 10px;cursor:pointer;font-weight:600}.lang-chip.active{border-color:var(--accent);color:#0b1020;background:var(--accent)}.muted{color:var(--muted);margin:0}.auth-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:start}.hero-card{border:1px solid var(--border);border-radius:18px;padding:32px;background:linear-gradient(145deg,var(--panel),var(--panel-soft));box-shadow:none}.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:12px;color:var(--muted);margin:0 0 8px}.hero-card h1{margin:0 0 10px;font-size:32px;line-height:1.2}.hero-subtitle{margin:0 0 14px;color:var(--muted);line-height:1.6}.badge-row{display:flex;flex-wrap:wrap;gap:10px;margin:12px 0 20px}.hero-visual{display:flex;flex-direction:column;gap:10px;align-items:flex-start;width:100%;margin:12px 0 18px}.hero-image{border-radius:18px;border:1px solid var(--border);background:var(--panel);display:flex;align-items:center;justify-content:center;padding:16px 20px;width:min(360px,100%)}.hero-image img{width:min(200px,65%);height:auto;opacity:.92}.hero-chip-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start}.hero-chip{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:999px;padding:6px 12px;font-weight:600;font-size:12px;text-align:center;position:relative;overflow:hidden}.hero-chip:nth-child(4n+1){background:linear-gradient(135deg,rgba(103,232,249,.2),var(--panel));border-color:#67e8f959}.hero-chip:nth-child(4n+2){background:linear-gradient(135deg,rgba(139,92,246,.2),var(--panel));border-color:#8b5cf659}.hero-chip:nth-child(4n+3){background:linear-gradient(135deg,rgba(14,165,233,.2),var(--panel));border-color:#0ea5e959}.hero-chip:nth-child(4n+4){background:linear-gradient(135deg,rgba(250,204,21,.18),var(--panel));border-color:#facc1552}.feature-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:var(--panel);border:1px solid var(--border);color:var(--text);font-weight:600;font-size:13px}.feature-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;color:var(--accent);background:var(--panel-strong)}.feature-icon svg{width:14px;height:14px}.promo-block{display:grid;grid-template-columns:1fr 1fr;gap:16px}.promo-card{display:flex;gap:12px;align-items:flex-start;padding:12px;border-radius:14px;border:1px solid var(--border);background:var(--panel)}.promo-icon{width:36px;height:36px;border-radius:12px;display:grid;place-items:center;color:var(--accent);background:var(--panel-strong);flex-shrink:0}.promo-icon svg{width:20px;height:20px}.promo-title{margin:0 0 4px;font-weight:700}.form-card{border:1px solid var(--border);border-radius:18px;padding:28px;background:var(--panel);box-shadow:none;display:flex;flex-direction:column;gap:18px}.form-header h2{margin:0;font-size:22px}.form-header p{margin:4px 0 0}.form-fields{display:flex;flex-direction:column;gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-weight:600}.field input{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--panel-strong);color:var(--text);font-size:15px}.field input::placeholder{color:var(--muted)}.field select{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--panel-strong);color:var(--text);font-size:15px}.field select:disabled{opacity:.6;cursor:not-allowed}.field select:focus{outline:2px solid var(--accent);outline-offset:1px}.primary-button{border:none;border-radius:12px;padding:12px;font-weight:700;cursor:pointer;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0b1020;box-shadow:0 14px 40px #8b5cf659}.primary-button:disabled{opacity:.6;cursor:not-allowed}.primary-button.loading:after{content:"…";margin-left:6px}.wide{width:100%}.error{margin:0;color:var(--error);font-weight:600}.form-footer{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.divider{flex:1;height:1px;background:var(--border)}.profile-card{margin-top:10px;border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--panel)}.profile-header{display:flex;justify-content:space-between;align-items:center;gap:10px}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-top:8px}.profile-panel{margin-top:18px;border:1px solid var(--border);border-radius:16px;padding:18px;background:var(--panel);box-shadow:none}.profile-panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.view-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:12px}.view-card{padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--panel-soft);box-shadow:none;position:relative;overflow:hidden}.view-card h4{margin:4px 0 0}.courses-panel,.attendance-panel{position:relative}.courses-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;margin-top:14px}.classes-group-list{display:flex;flex-direction:column;gap:18px;margin-top:14px}.classes-group-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:var(--panel)}.term-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:8px}.term-card{padding:12px;border-radius:14px;border:1px solid var(--border);background:var(--panel)}.vacations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.class-week-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-top:12px}.class-week-column{display:flex;flex-direction:column;gap:8px;padding:10px;border-radius:12px;border:1px solid var(--border);background:var(--panel)}.class-week-head{font-weight:600;font-size:13px}.class-session{border-radius:10px;padding:8px;background:var(--panel-strong);border:1px solid var(--border)}.class-month-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;margin-top:12px}.class-month-head{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.class-month-cell{min-height:92px;border-radius:10px;border:1px solid var(--border);background:var(--panel);padding:6px;display:flex;flex-direction:column;gap:4px}.class-month-cell.empty{background:transparent;border:none}.class-month-date{font-size:12px;font-weight:600}.class-month-session{display:flex;justify-content:space-between;gap:6px;padding:4px 6px;border-radius:8px;border:1px solid var(--border);background:var(--panel-strong);font-size:11px}.attendance-grid{display:grid;grid-template-columns:minmax(260px,1fr) minmax(520px,2fr);gap:16px;margin-top:16px}.attendance-mode-toggle{display:inline-flex;gap:8px;padding:6px;border-radius:999px;border:1px solid var(--border);background:var(--panel-soft);flex-wrap:wrap}.attendance-control{display:flex;flex-direction:column;gap:12px}.attendance-status{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:var(--panel)}.attendance-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}.attendance-stage{background:radial-gradient(circle at top right,rgba(56,189,248,.12),transparent 45%)}.attendance-stage-grid{display:grid;grid-template-columns:minmax(240px,1fr) minmax(260px,1fr);gap:16px;align-items:start}.attendance-visual{display:flex;flex-direction:column;gap:12px}.attendance-visual-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.attendance-qr,.attendance-scanner{border-radius:16px;border:1px solid var(--border);background:var(--panel-strong);min-height:260px;display:grid;place-items:center;overflow:hidden}.attendance-qr img{width:240px;height:240px;border-radius:12px;background:#fff;padding:8px}.attendance-scanner video{width:100%;height:100%;object-fit:cover}.attendance-placeholder{text-align:center;padding:20px}.attendance-feedback{background:#10b9811f;border:1px solid rgba(16,185,129,.4);color:#34d399;padding:8px 12px;border-radius:10px;font-size:13px;font-weight:600}.attendance-list{display:flex;flex-direction:column;gap:12px}.attendance-list-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.attendance-records{display:flex;flex-direction:column;gap:10px;max-height:360px;overflow:auto;padding-right:4px}.attendance-record{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding:12px;border-radius:14px;border:1px solid var(--border);background:var(--panel)}.attendance-record h4{margin:6px 0 0;font-size:15px}.attendance-history{display:flex;flex-direction:column;gap:14px;margin-top:18px}.attendance-history-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.attendance-history-range{display:inline-flex;gap:8px;padding:6px;border-radius:999px;border:1px solid var(--border);background:var(--panel-soft);flex-wrap:wrap}.attendance-history-grid{display:grid;grid-template-columns:minmax(260px,1fr) minmax(360px,2fr);gap:16px}.attendance-history-filters{display:flex;flex-direction:column;gap:12px}.attendance-history-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.attendance-summary-card{border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--panel-soft);text-align:left}.attendance-history-list{display:flex;flex-direction:column;gap:12px}.attendance-history-list-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.attendance-history-items{display:flex;flex-direction:column;gap:10px;max-height:340px;overflow:auto;padding-right:4px}.attendance-history-item{border:1px solid var(--border);border-radius:14px;padding:12px;background:var(--panel);color:var(--text);text-align:left;display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,.8fr);gap:12px;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.attendance-history-item-main{display:flex;flex-direction:column;gap:4px}.attendance-history-item:hover{transform:translateY(-2px);border-color:#67e8f966;box-shadow:0 10px 24px #0003}.attendance-history-item.active{border-color:#67e8f9a6;box-shadow:0 12px 30px #67e8f91f}.attendance-history-item-meta{display:flex;flex-direction:column;gap:6px;align-items:flex-end;text-align:right}.attendance-history-detail{display:flex;flex-direction:column;gap:12px;background:radial-gradient(circle at top left,rgba(56,189,248,.12),transparent 55%)}.attendance-history-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.attendance-history-attendees{display:flex;flex-direction:column;gap:10px}.attendance-history-attendees-list{display:flex;flex-direction:column;gap:8px;max-height:260px;overflow:auto;padding-right:4px}.attendance-history-attendee{display:flex;justify-content:space-between;gap:12px;border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--panel)}.payments-panel{position:relative}.payments-header-actions{display:flex;gap:8px;flex-wrap:wrap}.payments-grid{display:grid;grid-template-columns:minmax(260px,1fr) minmax(320px,1.2fr);gap:16px;margin-top:16px;align-items:start}.payments-column{display:flex;flex-direction:column;gap:14px}.payment-setup{background:radial-gradient(circle at top left,rgba(103,232,249,.12),transparent 55%)}.payment-summary-card{background:radial-gradient(circle at top right,rgba(139,92,246,.12),transparent 60%)}.payment-group-meta{display:flex;flex-direction:column;gap:8px}.payment-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.payment-metric{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--panel-soft)}.payment-summary-foot{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:10px}.payment-scanner-card{background:radial-gradient(circle at top right,rgba(56,189,248,.12),transparent 55%)}.payment-scanner{position:relative;border-radius:16px;border:1px solid var(--border);background:var(--panel-strong);min-height:260px;overflow:hidden;display:grid;place-items:center}.payment-scanner video{width:100%;height:100%;object-fit:cover}.payment-scan-overlay{position:absolute;top:12px;right:12px;bottom:12px;left:12px;border:1px solid rgba(103,232,249,.35);border-radius:14px;overflow:hidden;pointer-events:none}.payment-scan-line{position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,transparent,rgba(103,232,249,.9),transparent);animation:paymentScan 2.4s ease-in-out infinite}.payment-scan-hint{margin:0;font-size:13px;color:var(--muted)}.payment-status-card{background:radial-gradient(circle at top left,rgba(139,92,246,.12),transparent 55%)}.payment-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-top:6px}.payment-message{border:1px solid rgba(103,232,249,.3);border-radius:12px;padding:10px 12px;background:#67e8f914}.payment-message p{margin:0}.payment-message p+p{margin-top:6px}.payment-steps{display:grid;gap:8px;margin-top:12px}.payment-step{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted)}.payment-step-dot{width:10px;height:10px;border-radius:999px;border:2px solid rgba(148,163,184,.5);background:#94a3b833}.payment-step.done .payment-step-dot{border-color:var(--accent);background:var(--accent)}.payment-step.current .payment-step-dot{border-color:#f59e0b;background:#f59e0b}.payment-step.error .payment-step-dot{border-color:#f87171;background:#f87171}.payment-step.idle .payment-step-dot{border-color:#94a3b866;background:#94a3b833}.payment-status-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.payment-recent-card{margin-top:16px}.payment-recent-list{display:flex;flex-direction:column;gap:10px;max-height:280px;overflow:auto;padding-right:4px}.payment-recent-item{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--panel)}.payment-modal{width:min(700px,96vw)}.payment-modal-body{display:flex;flex-direction:column;gap:14px;margin-top:10px}.payment-modal-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.payment-amount-input{display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:12px;padding:4px 10px;background:var(--panel-strong)}.payment-amount-input input{border:none;background:transparent;padding:8px 4px;color:var(--text);font-size:15px;width:100%}.payment-amount-input input::placeholder{color:var(--muted)}.payment-amount-input input:focus{outline:none}.payment-currency{color:var(--muted);font-weight:600}.payment-modal-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}@keyframes paymentScan{0%{transform:translateY(0);opacity:.6}50%{transform:translateY(calc(100% - 4px));opacity:1}to{transform:translateY(0);opacity:.6}}.course-card{border:1px solid var(--border);border-radius:14px;padding:14px;background:linear-gradient(145deg,var(--panel),var(--panel-soft));box-shadow:none;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.course-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 10% 0%,rgba(14,165,233,.12),transparent 40%);opacity:.6;pointer-events:none;transition:opacity .3s ease}.course-card:hover:before{opacity:.9}.privacy-page{display:flex;flex-direction:column;gap:24px;max-width:1100px}.privacy-hero{display:flex;flex-direction:column;gap:8px}.privacy-policy-page{display:flex;flex-direction:column;gap:16px}.privacy-policy-frame{width:100%;min-height:78vh;border:none;border-radius:18px;background:transparent}.privacy-hero h1{margin:0;font-size:clamp(28px,3.4vw,40px)}.privacy-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.privacy-list{margin:0;padding-left:20px;display:grid;gap:6px;color:var(--muted)}.privacy-list li{line-height:1.5}.privacy-contact{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:0}.privacy-contact a{color:var(--accent);text-decoration:none;font-weight:600}.privacy-contact a:hover{text-decoration:underline}.privacy-actions{display:flex;justify-content:flex-start}.schedule-overrides{border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--panel);display:flex;flex-direction:column;gap:10px}.schedule-overrides-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.schedule-overrides-grid{display:grid;gap:8px}.day-override-row{display:grid;grid-template-columns:minmax(120px,1fr) repeat(2,minmax(120px,1fr)) auto;gap:8px;align-items:center}.day-chip{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:999px;padding:6px 10px;font-weight:600;text-align:center}.course-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap}.course-card-head .section-headline{flex:1 1 260px;min-width:0}.course-card-head .pill{flex-shrink:0;margin-left:auto}.section-headline{display:flex;align-items:flex-start;gap:12px}.section-icon{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;color:var(--accent);background:var(--panel-strong);box-shadow:inset 0 0 0 1px var(--border);flex-shrink:0}.section-icon svg{width:20px;height:20px}.course-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;color:var(--muted);font-size:13px}.course-foot{display:flex;justify-content:space-between;align-items:center;gap:8px}.course-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.search-actions{display:flex;justify-content:flex-end;margin-top:6px}.professor-results{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-top:12px}.professor-result{border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--panel-soft);box-shadow:none;display:flex;flex-direction:column;gap:6px;text-align:left;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;color:var(--text)}.professor-ident{display:flex;align-items:center;gap:10px}.professor-avatar{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#2dd4bf2e,#60a5fa2e);color:var(--text);font-weight:700;letter-spacing:.02em;border:1px solid var(--border)}.professor-result:hover{border-color:#67e8f973;box-shadow:0 12px 30px #67e8f91f;transform:translateY(-2px)}.professor-result.selected{border-color:#67e8f9cc;box-shadow:0 14px 34px #67e8f92e}.professor-result h4{margin:0}.professor-result-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;flex-wrap:wrap}.professor-result-head .pill{flex-shrink:0;margin-left:auto}.professor-profile{margin-top:14px;padding:12px;border-radius:14px;border:1px solid var(--border);background:var(--panel);box-shadow:none;display:flex;flex-direction:column;gap:12px}.professor-assignments{margin-top:6px;padding-top:12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.professor-assignments-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.professor-assignment-card{padding:12px}.assignment-groups{display:grid;gap:8px;margin-top:8px}.assignment-group{border:1px dashed var(--border);border-radius:12px;padding:8px 10px;background:var(--panel-soft)}.assignment-group h4{margin:0;font-size:14px}.professors-panel{position:relative;overflow:hidden}.professors-panel:before{content:"";position:absolute;top:-120px;right:-120px;width:320px;height:320px;background:radial-gradient(circle,rgba(45,212,191,.18),transparent 60%);opacity:.6;pointer-events:none;animation:pulseSoft 8s ease-in-out infinite}.students-panel{position:relative;overflow:hidden}.students-panel:before{content:"";position:absolute;top:-140px;left:-120px;width:320px;height:320px;background:radial-gradient(circle,rgba(103,232,249,.18),transparent 62%);opacity:.65;pointer-events:none;animation:pulseSoft 9s ease-in-out infinite}.students-list{display:flex;flex-direction:column;gap:16px}.students-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.student-card{text-align:left;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;font:inherit;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.student-card:hover{border-color:#67e8f973;box-shadow:0 14px 32px #67e8f91f;transform:translateY(-2px)}.student-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.student-avatar{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,#67e8f933,#8b5cf633);color:var(--text);font-weight:700;border:1px solid var(--border)}.student-avatar.large{width:64px;height:64px;border-radius:20px;font-size:18px}.status-pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid var(--border);line-height:1.2;min-height:24px;white-space:nowrap}.status-approved{background:#22c55e2e;border-color:#22c55e73;color:#22c55e}.status-pending{background:#facc152e;border-color:#facc1573;color:#facc15}.status-rejected{background:#f871712e;border-color:#f8717173;color:#f87171}.status-cancelled{background:#94a3b82e;border-color:#94a3b866;color:#cbd5f5}.student-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:12px}.student-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-top:14px}.students-detail{display:flex;flex-direction:column;gap:18px}.students-detail-actions{display:flex;justify-content:flex-start}.student-detail-card{display:flex;flex-direction:column;gap:14px}.student-detail-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.student-detail-grid,.insight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.insight-card{border:1px solid var(--border);border-radius:16px;padding:14px;background:var(--panel)}.students-course-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.student-course-card{background:var(--panel-soft)}.student-course-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:10px}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.empty-state{border:1px dashed var(--border);border-radius:14px;padding:18px;text-align:center;background:var(--panel-soft);margin-top:14px;box-shadow:none}.fab{position:relative;padding:12px 16px;box-shadow:0 12px 32px #67e8f940}.small{font-size:13px}.profile-grid-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;margin-top:14px}.full-row{grid-column:1 / -1}.phone-list{display:flex;flex-direction:column;gap:8px}.phone-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.panel-actions{margin-top:12px;display:flex;justify-content:flex-end;gap:8px}.dashboard-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:flex-start;margin-top:22px}.nav-menu{position:sticky;top:16px;border:1px solid var(--border);border-radius:14px;padding:14px 12px;background:linear-gradient(180deg,var(--panel-strong),var(--panel-soft));box-shadow:none;display:flex;flex-direction:column;gap:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow:hidden;position:relative}.nav-menu:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(120deg,var(--glow-1),var(--glow-2));opacity:.5}.nav-label{margin:0 0 4px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:12px}.nav-item{width:100%;text-align:left;border:1px solid var(--border);border-radius:10px;padding:10px;background:var(--panel-soft);color:var(--text);cursor:pointer;font-weight:600;transition:all .18s ease;position:relative;overflow:hidden;display:flex;align-items:center;gap:10px}.nav-icon{width:28px;height:28px;display:grid;place-items:center;border-radius:10px;background:var(--panel-strong);color:var(--accent);flex-shrink:0}.nav-icon svg{width:18px;height:18px}.nav-item:hover{border-color:#67e8f999;transform:translate(3px);box-shadow:0 8px 26px #67e8f92e}.nav-item.active{border-color:#67e8f9b3;background:linear-gradient(135deg,#67e8f938,#0ea5e92e);color:var(--text);box-shadow:0 12px 28px #67e8f959,0 0 0 1px var(--border) inset;text-shadow:0 1px 6px rgba(15,23,42,.35)}.nav-item:before{content:"";width:8px;height:8px;border-radius:50%;background:#67e8f9cc;box-shadow:0 0 0 6px #67e8f924;transition:transform .2s ease,opacity .2s ease;opacity:.6}.nav-item.active:before{transform:scale(1.15);opacity:1}.nav-item:after{content:"";position:absolute;top:-40%;right:-10%;bottom:-40%;left:-10%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.22),transparent);opacity:0;transform:translate(-60%);transition:opacity .2s ease;pointer-events:none}.nav-item:hover:after{opacity:.55;animation:nav-shimmer 2.6s ease-in-out forwards}@keyframes nav-shimmer{0%{transform:translate(-60%) rotate(6deg)}55%{transform:translate(60%) rotate(6deg)}to{transform:translate(60%) rotate(6deg)}}.nav-label-row{display:flex;align-items:center;justify-content:space-between;gap:8px;line-height:1;width:100%}.nav-badge{margin-top:0;padding:2px 6px;min-width:18px;height:18px;justify-content:center;font-size:11px;line-height:1;align-self:center;background:#ef4444;border-color:#ef4444;color:#fff}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:20px}.primary-button:disabled,.ghost-button:disabled{opacity:.6;cursor:not-allowed}.text-button,.link-button{background:none;border:none;color:var(--text);cursor:pointer;font-weight:600}.link-button{color:var(--accent)}.signup-row{display:flex;align-items:center;gap:8px;font-size:14px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;padding:18px;z-index:50}.confirm-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.confirm-modal{max-width:420px;width:min(420px,92vw);text-align:center;background:var(--panel)}.confirm-icon{width:54px;height:54px;border-radius:16px;margin:0 auto 12px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#f97316,#ef4444);box-shadow:0 10px 26px #ef444440}.confirm-icon svg{width:26px;height:26px}.confirm-actions{display:flex;justify-content:center;gap:10px;margin-top:16px;flex-wrap:wrap}.confirm-actions .confirm-yes,.confirm-actions .confirm-no{border:none;border-radius:999px;padding:10px 16px;font-weight:700;cursor:pointer;color:#0b1020}.confirm-actions .confirm-yes{background:linear-gradient(135deg,#ef4444,#f97316);color:#fff}.confirm-actions .confirm-no{background:linear-gradient(135deg,#34d399,#60a5fa);color:#0b1020}.modal-card{background:var(--panel-strong);border:1px solid var(--border);border-radius:18px;padding:18px;width:min(1500px,98vw);box-shadow:0 18px 60px #0000004d;background-image:linear-gradient(145deg,var(--glow-1),var(--glow-2))}.course-editor-modal{border-color:#38bdf859;background-image:radial-gradient(circle at top right,var(--glow-1),transparent 50%),linear-gradient(140deg,var(--panel-strong),var(--panel))}.course-edit-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:10px}.course-edit-title{margin-top:8px;font-weight:600;color:var(--text)}.signup-large{width:min(880px,98vw)}.class-modal{display:flex;flex-direction:column;gap:18px;width:100%}.class-modal.rtl{direction:rtl;text-align:right}.class-modal.rtl h3,.class-modal.rtl h4,.class-modal.rtl .eyebrow,.class-modal.rtl .section-head>div,.class-modal.rtl .field-label{text-align:right}.class-modal.rtl .field,.class-modal.rtl .field-row,.class-modal.rtl .term-card,.class-modal.rtl .vacations-grid,.class-modal.rtl .courses-grid,.class-modal.rtl .chip-row{direction:rtl}.class-modal.rtl input,.class-modal.rtl select,.class-modal.rtl button{direction:rtl;text-align:right}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.modal-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.modal-header h3{margin:4px 0 0}.ghost-button{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:10px;padding:8px 12px;cursor:pointer}.signup-options{margin-top:16px;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px}.signup-card{border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--panel);display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center}.signup-icon{width:40px;height:40px;display:grid;place-items:center;border-radius:12px;background:var(--panel-strong);font-size:20px}.signup-title{margin:0;font-weight:700}.signup-form{display:flex;flex-direction:column;gap:16px;max-height:70vh;overflow:auto;padding-right:6px}.signup-section{border:1px solid var(--border);border-radius:12px;padding:14px;background:linear-gradient(135deg,var(--panel),var(--panel-soft));display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 30px #00000026}.section-head h4{margin:0}.section-head .muted{margin-top:4px}.chip-grid{display:flex;flex-wrap:wrap;gap:8px}.category-block{display:flex;flex-direction:column;gap:10px}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.category-card{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:16px;padding:12px 14px;text-align:left;cursor:pointer;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.category-card h5{margin:0;font-size:14px}.category-card .muted{margin:0;font-size:12px;line-height:18px}.category-card:hover{transform:translateY(-2px);border-color:#67e8f966}.category-card.active{border-color:#67e8f999;background:linear-gradient(135deg,#67e8f929,#8b5cf61f);box-shadow:0 12px 32px #0f172a40}.category-card-top{display:flex;align-items:center;gap:10px;margin-bottom:6px}.category-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:999px;font-size:10px;letter-spacing:.8px;text-transform:uppercase;background:var(--panel-strong);color:var(--text)}.tag{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:12px;padding:8px 10px;cursor:pointer}.tag-active{background:#67e8f92e;border-color:#67e8f980}.tag-locked{cursor:not-allowed;opacity:.75}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.chip{border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:999px;padding:8px 12px;cursor:pointer;font-weight:600;transition:all .12s ease}.chip-active{background:#67e8f92e;border-color:#67e8f999;color:#0b1020;box-shadow:0 10px 26px #67e8f92e}.field-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.consent-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:var(--panel-soft)}.consent-row input[type=checkbox]{margin-top:3px}.consent-row a{color:var(--accent);text-decoration:none}.consent-row a:hover{text-decoration:underline}.signup-actions{display:flex;justify-content:flex-end;gap:10px}.success{color:#22c55e;font-weight:600}textarea{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--panel-strong);color:var(--text);font-family:Inter,Space Grotesk,system-ui,-apple-system,sans-serif;resize:vertical;min-height:120px}textarea:focus{outline:2px solid var(--accent);outline-offset:1px}.signup-form::-webkit-scrollbar{width:8px}.signup-form::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:10px}.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-weight:600;font-size:12px;border:1px solid var(--border);line-height:1.2;min-height:24px;white-space:nowrap}.pill-warning{background:#f472b629;border-color:#f472b673;color:#f472b6;margin-top:8px}.pill-error{background:#f8717129;border-color:#f8717173;color:#f87171}.pill-muted{background:#94a3b824;border-color:#94a3b859;color:#cbd5f5}.ghost-button.danger{border-color:#f8717173;color:#f87171}@keyframes floatSoft{0%{transform:translateY(0)}50%{transform:translateY(-4px)}to{transform:translateY(0)}}@keyframes pulseSoft{0%{transform:scale(1);opacity:.4}50%{transform:scale(1.05);opacity:.65}to{transform:scale(1);opacity:.4}}@media(max-width:1200px){.auth-shell{width:min(92vw,1200px)}}@media(max-width:960px){.auth-grid{grid-template-columns:1fr}.panel-hero{flex-direction:column;align-items:flex-start}.hero-visual{grid-template-columns:1fr}.hero-chip-row{justify-content:center}.promo-block{grid-template-columns:1fr}.top-bar{flex-wrap:wrap}.attendance-grid,.attendance-stage-grid,.attendance-record,.attendance-history-grid,.attendance-history-item{grid-template-columns:1fr}.attendance-history-item-meta{align-items:flex-start;text-align:left}.attendance-history-attendee{flex-direction:column;align-items:flex-start}.payments-grid,.payment-status-grid,.payment-recent-item,.payment-modal-summary,.dashboard-layout{grid-template-columns:1fr}.nav-menu{position:relative;flex-direction:row;flex-wrap:wrap;gap:6px}.nav-item{flex:1 1 160px}}@media(max-width:720px){.auth-shell{width:min(96vw,680px);padding:24px 16px 64px;gap:18px}.top-bar{padding:10px 12px}.brand-logo{width:96px;height:36px}.language-switcher{width:100%;justify-content:space-between}.switch-group{gap:6px}.theme-toggle{padding:3px}.theme-toggle-button{width:28px;height:28px}.dashboard-layout{grid-template-columns:1fr;gap:18px}.nav-menu{position:static;flex-direction:row;align-items:center;overflow-x:auto;padding:8px;gap:8px}.nav-label{display:none}.nav-item{padding:8px 10px;border-radius:999px;min-width:max-content;gap:6px}.nav-item:hover{transform:none}.nav-icon{width:26px;height:26px;border-radius:999px}.auth-grid{gap:18px}.hero-card,.form-card{padding:22px}.hero-visual{grid-template-columns:1fr;gap:12px}.hero-shot,.hero-chip-row{display:none}.badge-row{gap:6px}.feature-badge{font-size:12px;padding:6px 10px}.panel-hero{flex-direction:column;align-items:flex-start}.panel-icon{width:40px;height:40px}.section-icon{width:32px;height:32px}.courses-grid,.professor-results{grid-template-columns:1fr}.course-card{padding:12px}.course-card:before{opacity:.35}.privacy-page{gap:18px}.privacy-grid{grid-template-columns:1fr}.privacy-policy-frame{min-height:70vh;border-radius:14px}.course-card-head{flex-direction:column;align-items:flex-start;gap:8px}.student-card-head,.student-detail-header{flex-direction:column;align-items:flex-start}.status-pill{align-self:flex-start}.field-row{grid-template-columns:1fr}.modal-card{padding:14px;border-radius:16px}}@media(max-width:540px){.hero-card h1{font-size:26px}.hero-subtitle,.muted{font-size:13px}.form-header h2{font-size:20px}.profile-panel{padding:12px}.course-card{padding:10px}.nav-menu{gap:6px}}html[dir=rtl]{direction:rtl}
