.dashboard-page{padding:24px}.dashboard-page__header{margin-bottom:24px}.dashboard-page__title{margin:0 0 8px;color:#111827}.dashboard-page__subtitle{margin:0;color:#6b7280}.dashboard-grid{display:grid;gap:20px;margin-bottom:24px}.dashboard-grid--cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.dashboard-grid--main{grid-template-columns:1.4fr 1fr}.dashboard-card,.dashboard-section-card,.course-student-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 6px 18px #0000000d}.dashboard-card{padding:20px}.dashboard-card__title{margin:0;color:#6b7280;font-size:14px}.dashboard-card__value{margin:10px 0 6px;font-size:28px;color:#111827}.dashboard-card__subtitle{margin:0;color:#9ca3af;font-size:13px}.dashboard-section-card{padding:20px}.dashboard-section-card__title{margin:0 0 16px;color:#111827}.dashboard-empty{color:#6b7280;margin:0}.dashboard-list__item{padding:12px 0;border-bottom:1px solid #eeeeee}.dashboard-list__item--last{border-bottom:none}.dashboard-list__subtitle{margin-top:4px;color:#6b7280}.subject-progress-list{display:grid;gap:14px}.subject-progress-item__header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:6px}.subject-progress-item__left,.subject-progress-item__right{display:flex;align-items:center;gap:10px}.subject-progress-item__icon{font-size:20px}.subject-progress-item__name{font-weight:600}.subject-progress-item__label{font-size:13px;color:#6b7280}.subject-progress-item__percent{font-weight:700;color:#111827}.progress-bar{width:100%;height:10px;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress-bar__fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#3b82f6,#14b8a6)}.course-student-grid{display:grid;gap:12px}.course-student-card{padding:14px 16px}.course-student-card__top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.course-student-card__subject{font-weight:700;color:#111827}.course-student-card__student{margin-top:4px;font-size:14px;color:#6b7280}.course-student-card__badge{font-size:13px;font-weight:600;padding:6px 10px;border-radius:999px;background:#eff6ff;color:#1d4ed8;white-space:nowrap}.course-student-card__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:10px;font-size:14px;color:#374151}.course-student-card__progress{margin-bottom:10px}.course-student-card__note{font-size:14px;color:#6b7280}@media (max-width: 900px){.dashboard-grid--main{grid-template-columns:1fr}}.chatbox-container{background:#111827;padding:20px;border-radius:16px;color:#e5e7eb}.chatbox-title{color:#3b82f6;font-weight:700;margin-bottom:15px}.chatbox-login input{padding:8px;border-radius:6px;margin-right:6px;border:none}.chatbox-login button{background:#0284c7;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer}.chatbox-participants{margin-bottom:15px;padding:12px;background:#0f172a;border-radius:12px;border:1px solid #334155}.chatbox-participants select{margin-top:10px;padding:8px;border-radius:8px;width:100%;background:#1f2937;color:#fff;border:1px solid #475569}.chatbox-messages{width:100%;min-height:250px;max-height:400px;overflow-y:auto;border:1px solid #374151;border-radius:16px;padding:12px;background:#1f2937}.chat-message-row{display:flex;margin-bottom:10px}.chat-message-row.sent{justify-content:flex-end}.chat-message-row.received{justify-content:flex-start}.chat-bubble{max-width:75%;padding:10px;border-radius:12px;background:#1f2937;word-break:break-word;border:2px solid transparent}.chat-bubble.sent{border-color:#2563eb}.chat-bubble.received{border-color:#facc15}.chat-sender{font-size:14px;font-weight:700;color:#22c55e;margin-bottom:4px}.chat-text{font-size:14px;color:#e5e7eb}.chat-time{font-size:10px;color:#9ca3af;margin-top:4px}.chat-input-container{display:flex;gap:6px;margin-top:10px;align-items:center}.chat-input-container textarea{flex:1;padding:10px;border-radius:14px;background:#374151;color:#e5e7eb;border:none;resize:none}.chat-input-container button{background:#0284c7;color:#fff;border:none;padding:10px 14px;border-radius:12px;cursor:pointer}.chat-emoji-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.chat-emoji{cursor:pointer;font-size:1.4rem;transition:transform .2s}.chat-emoji:hover{transform:scale(1.2)}.chat-empty{color:#9ca3af;font-weight:700;text-align:center;margin-top:20px}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;color:#1f2937;background:#f7f8fb}html,body,#root{width:100%;min-height:100%;margin:0;padding:0;overflow-x:hidden}*,*:before,*:after{box-sizing:border-box}body{background:linear-gradient(180deg,#f7f9fc,#eef3fb);min-height:100vh}img,video,iframe,svg,canvas{max-width:100%;height:auto;display:block}button{font:inherit}a{color:#2563eb;text-decoration:none}.layout-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr;width:100%}.page-shell{display:flex;flex-direction:column;min-width:0;width:100%}.topbar{padding:24px;background:#fff;border-bottom:1px solid #e5e7eb;width:100%}.page-title{margin:0;font-size:1.5rem}.page-subtitle{margin:6px 0 0;color:#6b7280}.content-area{padding:24px;width:100%;min-width:0}.page-grid{display:grid;gap:20px;width:100%;min-width:0}.two-columns{grid-template-columns:repeat(2,minmax(0,1fr))}.messages-grid{grid-template-columns:320px minmax(0,1fr)}.card{background:#fff;border-radius:18px;padding:20px;box-shadow:0 6px 18px #1118270d;width:100%;min-width:0}.card-title{margin:0 0 12px;font-size:1.05rem}.simple-list{margin:0;padding-left:20px;display:grid;gap:8px}.subject-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;width:100%}.subject-card{border:none;border-radius:20px;padding:28px 20px;display:flex;flex-direction:column;align-items:center;gap:12px;justify-items:start;cursor:pointer;width:100%;min-width:0}.emoji{font-size:2.6rem}.subject-name{font-weight:600;font-size:1rem}.schedule-list{display:grid;gap:12px}.schedule-row{display:flex;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid #e5e7eb;flex-wrap:wrap}.schedule-row p{margin:6px 0 0}.metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;width:100%}.metric-card{background:#fff;padding:18px;border-radius:18px;box-shadow:0 6px 18px #1118270d;width:100%;min-width:0}.metric-label{display:block;color:#6b7280;margin-bottom:8px}.metric-value{font-size:1.4rem}.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{width:100%;max-width:520px;background:#fff;border-radius:20px;padding:32px;box-shadow:0 18px 50px #0f172a14;border:1px solid #e5e7eb}.auth-header h1{margin:0 0 8px;font-size:2rem}.auth-header p{margin:0 0 24px;color:#6b7280}.auth-form{display:grid;gap:16px}.auth-form label{display:grid;gap:8px;font-size:.95rem;font-weight:600}.auth-form input,.auth-form select{width:100%;min-width:0;padding:14px 16px;border:1px solid #d1d5db;border-radius:14px;font-size:1rem;outline:none;background:#fff}.auth-form input:focus,.auth-form select:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1a}.primary-btn{border:none;border-radius:14px;padding:14px 18px;background:#2563eb;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;width:100%;max-width:100%}.primary-btn:disabled{opacity:.7;cursor:not-allowed}.form-error{background:#fef2f2;color:#b91c1c;padding:12px 14px;border-radius:12px;border:1px solid #fecaca}.form-success{background:#ecfdf5;color:#047857;padding:12px 14px;border-radius:12px;border:1px solid #a7f3d0}.auth-footer{margin-top:18px;text-align:center;color:#6b7280}.grid-2{display:grid;gap:16px}.simple-page{min-height:100vh;display:grid;place-items:center;padding:32px;text-align:center}.app-container{min-height:100vh;display:flex;flex-direction:column;width:100%}.app-header{position:fixed;top:0;left:0;right:0;width:100%;height:90px;background:linear-gradient(90deg,#2c5364,#0f2027,#203a43);display:flex;justify-content:space-between;align-items:center;padding:0 16px;gap:12px;z-index:1000}.header-left{display:flex;align-items:center;flex-shrink:0}.header-logo{height:85px;max-height:85px;width:auto;display:block;object-fit:contain;flex-shrink:0}.header-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:6px;min-width:0}.header-user{color:#fff;font-weight:500;font-size:14px;line-height:1.2;white-space:nowrap}.header-logout-btn,.header-login-btn{border:none;border-radius:10px;padding:8px 14px;background:#2563eb;color:#fff;font-size:.9rem;font-weight:700;cursor:pointer;text-decoration:none;white-space:nowrap;line-height:1.1}.header-logout-btn:hover,.header-login-btn:hover{opacity:.9}.language-select{padding:4px 8px;margin-right:0;border-radius:6px;border:1px solid #ccc;cursor:pointer;font-size:13px;white-space:nowrap}.app-footer{position:fixed;bottom:0;left:0;right:0;width:100%;background:linear-gradient(90deg,#2c5364,#0f2027,#203a43);padding:8px 16px;color:#fb923c;text-align:center;z-index:1000}.footer-content{display:flex;justify-content:center;align-items:center;gap:24px;flex-wrap:wrap;margin-bottom:4px}.footer-section{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.footer-links{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.footer-section a{color:#ccc;text-decoration:none;font-size:13px;line-height:1.2}.footer-section a:hover{color:#fff}.footer-copy{font-size:12px;margin:2px 0 0;line-height:1.2}.app-shell{display:grid;grid-template-columns:260px minmax(0,1fr);flex:1;min-height:calc(100vh - 120px);margin-top:90px;margin-bottom:52px;width:100%}.sidebar{background:#0f172a;color:#fff;padding:20px;display:flex;flex-direction:column;gap:20px;min-width:0;width:100%}.sidebar-brand a{color:#fff;font-size:1.25rem;font-weight:800}.sidebar-role{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:16px;padding:14px;display:grid;gap:6px}.sidebar-role span{font-size:.75rem;opacity:.8}.sidebar-nav{display:grid;gap:8px;width:100%}.sidebar-nav a{display:block;background:#ffffff26;padding:14px 16px;border-radius:14px;color:#fff;font-weight:500;transition:all .2s ease;width:100%;word-break:break-word}.sidebar-nav a:hover{transform:translateY(-2px);background:#ffffff40;box-shadow:0 8px 18px #00000026}.sidebar-nav a.active{background:#fff;color:#1e40af;font-weight:600;box-shadow:0 10px 22px #0003}.sidebar-logout{margin-top:auto}.main-content{padding:24px;background:transparent;width:100%;min-width:0;overflow-x:hidden}.homepage{min-height:100%;background:linear-gradient(135deg,#6366f1,#3b82f6,#06b6d4);color:#fff;width:100%}.home-hero{text-align:center;margin-bottom:40px}.home-title{font-size:36px;font-weight:800;margin-bottom:16px;background:linear-gradient(90deg,#f59e0b,#fbbf24,#d4af37);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.home-subtitle{font-size:18px;font-weight:500;color:#fde68a;max-width:800px;margin:0 auto 12px}.home-description{font-size:15px;color:#d1d5db;max-width:900px;margin:0 auto}.home-description-card{background:linear-gradient(135deg,#16a34a,#15803d);color:#e2e8f0;padding:24px 28px;border-radius:16px;margin:20px auto 0;max-width:900px;box-shadow:0 10px 25px #0000004d;width:100%}.page-section h1{margin-top:0;margin-bottom:10px}.home-grid{display:grid;gap:16px;margin-top:24px;width:100%}.info-card{background:#1e293b;color:#fff;border-radius:18px;padding:20px;border:1px solid #334155;box-shadow:0 12px 30px #0f172a2e;text-align:center;display:flex;flex-direction:column;align-items:center;transition:transform .25s ease,box-shadow .25s ease,background .25s ease;width:100%;min-width:0}.info-card:hover{transform:translateY(-6px) scale(1.02);background:#334155;box-shadow:0 16px 36px #0f172a47}.info-card h3{margin-bottom:10px;color:#3b82f6;font-size:1.4rem;font-weight:700}.info-card p{color:#e2e8f0}.subjects-page{min-height:100%;background:linear-gradient(135deg,#0f172a,#4c1d95,#2563eb);padding:24px;color:#fff;width:100%}.subject-card{background:#ffffff14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,.1);transition:all .25s ease}.subject-card:hover{transform:translateY(-6px) scale(1.03);background:#334155;box-shadow:0 0 20px #6366f199}.messages-page-centered{width:100%;min-height:100%;display:flex;justify-content:center;padding:40px 20px;background:radial-gradient(circle at 12% 18%,rgba(37,99,235,.28),transparent 30%),radial-gradient(circle at 85% 12%,rgba(16,185,129,.28),transparent 30%),radial-gradient(circle at 50% 100%,rgba(6,182,212,.2),transparent 35%),linear-gradient(135deg,#f0fdf4,#e0f2fe 40%,#ecfeff,#f8fafc);background-attachment:fixed}.messages-chat-wrapper{width:100%;max-width:980px;padding:12px;border-radius:28px;background:#fff9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 20px 60px #10b9811f;min-width:0}.messages-chat-wrapper .info-card{max-width:520px;margin:0 auto;text-align:center}.dashboard-page{min-height:100%;padding:32px 20px;background:linear-gradient(135deg,#0f172a,#1e3a8a,#06b6d4);color:#0f172a;width:100%}.dashboard-page__header{text-align:center;margin-bottom:28px}.dashboard-page__title{margin:0 0 10px;font-size:2rem;font-weight:800;color:#ffffffd9}.dashboard-page__subtitle{margin:0 auto;max-width:760px;color:#16a34a;font-size:1.1rem}.dashboard-theme{padding:14px;border-radius:24px;width:100%}.dashboard-grid--cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px;margin-bottom:22px;width:100%}.dashboard-grid--main{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:20px;margin-bottom:22px;width:100%}.dashboard-theme .card,.dashboard-theme .metric-card{background:#fff;color:#1f2937;border-radius:20px;padding:20px;border:1px solid #e5e7eb;box-shadow:0 10px 30px #0f172a14;transition:transform .2s ease,box-shadow .2s ease}.dashboard-theme .metric-card:hover,.dashboard-theme .card:hover{transform:translateY(-3px);box-shadow:0 14px 34px #0f172a1f}.dashboard-theme .card-title,.dashboard-theme .metric-label{display:block;margin-bottom:8px;font-weight:600}.dashboard-theme .metric-value{font-size:2rem;font-weight:800}.dashboard-theme .metric-label,.dashboard-theme .card-title,.dashboard-theme .metric-value,.dashboard-theme p,.dashboard-theme li,.dashboard-theme span,.dashboard-theme td,.dashboard-theme th{color:#0f172a}.dashboard-theme table{width:100%;border-collapse:collapse;table-layout:auto}.dashboard-theme th,.dashboard-theme td{padding:14px 16px;text-align:left;word-break:break-word}.dashboard-theme th{background:#f8fafc;color:#334155;font-weight:700}.dashboard-theme td{color:#475569}.dashboard-theme tr+tr td,.dashboard-theme tr+tr th{border-top:1px solid #e5e7eb}.dashboard-theme--student .card-title,.dashboard-theme--student .metric-label{color:#1d4ed8}.dashboard-theme--student .metric-value{color:#2563eb}.dashboard-theme--teacher .card-title,.dashboard-theme--teacher .metric-label{color:#6d28d9}.dashboard-theme--teacher .metric-value{color:#7c3aed}.dashboard-theme--admin .card-title,.dashboard-theme--admin .metric-label{color:#374151}.dashboard-theme--admin .metric-value{color:#111827}.dashboard-theme--parent .card-title,.dashboard-theme--parent .metric-label{color:#0f766e}.dashboard-theme--parent .metric-value{color:#059669}.lesson-actions{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}.schedule-page{display:grid;gap:20px;width:100%}.lesson-form{display:grid;gap:18px;width:100%}.form-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));width:100%}.lesson-form label{display:grid;gap:8px;font-weight:600}.lesson-form input,.lesson-form select,.lesson-form textarea{width:100%;min-width:0;padding:12px 14px;border-radius:12px;border:1px solid #d1d5db;font:inherit;background:#fff}.lesson-card-button{width:100%;text-align:left;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.lesson-card-button:hover{transform:translateY(-3px);box-shadow:0 10px 22px #0f172a14;border-color:#93c5fd}.active-lesson{border-color:#2563eb;box-shadow:0 10px 22px #2563eb1f}.lesson-card-top{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:10px;flex-wrap:wrap}.lesson-status{background:#dbeafe;color:#1d4ed8;padding:6px 10px;border-radius:999px;font-size:.85rem;font-weight:700}.lesson-details{display:grid;gap:18px;width:100%}.lesson-detail-block h3,.lesson-detail-block h4{margin-top:0;margin-bottom:10px}.lesson-detail-block p{margin:6px 0;word-break:break-word}.lesson-action-row{display:flex;flex-wrap:wrap;gap:12px}.secondary-btn{border:1px solid #cbd5e1;background:#fff;color:#0f172a;border-radius:12px;padding:12px 16px;font:inherit;font-weight:600;cursor:pointer;max-width:100%}.secondary-btn:hover{background:#f8fafc}.video-call-placeholder{display:grid;gap:12px}.video-box{min-height:220px;border-radius:18px;border:2px dashed #94a3b8;display:grid;place-items:center;background:#f8fafc;color:#475569;font-weight:600;width:100%;text-align:center;padding:16px}.empty-state{padding:24px;border:1px dashed #cbd5e1;border-radius:16px;background:#f8fafc}.empty-state h3{margin-top:0;margin-bottom:8px}.student-select-block{display:grid;gap:12px;width:100%}.student-select-block h4{margin:0}.student-checkbox-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));width:100%}.student-check-card{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid #dbe2ea;border-radius:14px;background:#fff;min-width:0}.download-btn{background-color:#28a745;color:#fff;border:none}.download-btn:hover{background-color:#218838}.uploaded-material{color:#0d6efd;font-weight:500;margin-top:6px}.uploaded-material-link{color:inherit;text-decoration:underline;font-weight:600;word-break:break-word}.uploaded-material-link:hover{opacity:.8}.uploaded-material-block{margin-top:8px}.replace-material-btn{background-color:#f59e0b;color:#fff;border:none}.replace-material-btn:hover{opacity:.9}.teacher-schedule-card{background:radial-gradient(circle at top left,rgba(59,130,246,.18),transparent 28%),radial-gradient(circle at top right,rgba(16,185,129,.16),transparent 26%),linear-gradient(145deg,#0f172af5,#1e293beb);border:1px solid rgba(148,163,184,.18);border-radius:24px;box-shadow:0 18px 40px #0f172a47,inset 0 1px #ffffff0a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:28px;width:100%}.teacher-schedule-title{text-align:center;font-size:1.9rem;font-weight:800;margin:0 0 10px;padding:14px 0 10px;color:#60a5fa;letter-spacing:.3px}.teacher-schedule-card label{color:#e2e8f0;font-weight:600}.teacher-schedule-card input,.teacher-schedule-card select,.teacher-schedule-card textarea{background:#0f172ad1;color:#f8fafc;border:1px solid rgba(148,163,184,.22);border-radius:14px;width:100%;min-width:0}.teacher-schedule-card input::placeholder,.teacher-schedule-card textarea::placeholder{color:#94a3b8}.teacher-schedule-card input:focus,.teacher-schedule-card select:focus,.teacher-schedule-card textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 4px #3b82f624;outline:none}.teacher-schedule-card .student-check-card{background:#1e293bc7;border:1px solid rgba(148,163,184,.18);color:#f8fafc}.teacher-schedule-card .student-select-block h4,.teacher-schedule-card small{color:#cbd5e1}.teacher-schedule-card .primary-btn{background:linear-gradient(135deg,#2563eb,#14b8a6);color:#fff;border:none;box-shadow:0 12px 24px #2563eb3d}.teacher-schedule-card .primary-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 16px 28px #2563eb52}.teacher-schedule-card input[type=datetime-local]{background:#f8fafc;color:#0f172a;border:1px solid #cbd5e1}.schedule-left-card{background-color:#1f2937;color:#1f2937}.schedule-right-card{background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#1e293b;border:1px solid #c7d2fe}.profile-page{min-height:100%;padding:32px 24px;background:radial-gradient(circle at 10% 15%,rgba(59,130,246,.18),transparent 25%),radial-gradient(circle at 90% 10%,rgba(16,185,129,.16),transparent 25%),radial-gradient(circle at 50% 100%,rgba(168,85,247,.14),transparent 30%),linear-gradient(135deg,#0b1220,#0f172a,#020617);background-attachment:fixed;width:100%}.profile-page .card{max-width:820px;margin:0 auto;background:#0f172ac7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(148,163,184,.18);border-radius:24px;box-shadow:0 20px 50px #00000059,0 0 0 1px #ffffff0a inset;padding:28px;width:100%}.profile-title{font-size:2.2rem;font-weight:800;text-align:center;margin-bottom:10px;color:#60a5fa}.profile-page p{text-align:center;color:#cbd5e1;margin-bottom:24px}.profile-page label{color:#e2e8f0;font-weight:600}.profile-page input,.profile-page textarea{background:#0f172ad9;color:#f8fafc;border:1px solid rgba(148,163,184,.22);border-radius:12px;width:100%;min-width:0}.profile-page input::placeholder,.profile-page textarea::placeholder{color:#94a3b8}.profile-page input:focus,.profile-page textarea:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 4px #3b82f61f}.profile-page .primary-btn{background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:14px;font-weight:700}.profile-page .primary-btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px #2563eb59}.profile-page .profile-links-box{background:#1e293bbf;border:1px solid rgba(148,163,184,.18);border-radius:16px;color:#e2e8f0}.learning-hub-page{min-height:100%;padding:32px 24px;border-radius:28px;background:radial-gradient(circle at top left,rgba(99,102,241,.22),transparent 32%),radial-gradient(circle at top right,rgba(6,182,212,.18),transparent 30%),radial-gradient(circle at bottom left,rgba(59,130,246,.14),transparent 28%),linear-gradient(180deg,#f8fbff,#eef4ff);box-shadow:inset 0 1px #ffffffb3,0 20px 50px #2563eb14;width:100%}.learning-hub-tabs{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}.learning-hub-tab{padding:11px 16px;border-radius:12px;border:1px solid #cbd5e1;background:#ffffffc7;color:#0f172a;cursor:pointer;font-weight:700;transition:all .22s ease;box-shadow:0 6px 18px #0f172a0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:100%}.learning-hub-tab:hover{transform:translateY(-2px);border-color:#93c5fd;box-shadow:0 12px 24px #2563eb1f}.learning-hub-tab.active{border:1px solid transparent;background:linear-gradient(135deg,#2563eb,#4f46e5);color:#fff;box-shadow:0 12px 28px #3b82f647}.learning-hub-card{background:#1e293b;border:1px solid rgba(148,163,184,.22);border-radius:20px;padding:16px;box-shadow:0 10px 30px #0f172a14,0 0 0 1px #ffffff59 inset;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;width:100%;min-width:0}.learning-hub-card:hover{transform:translateY(-4px);box-shadow:0 18px 34px #2563eb1f,0 0 0 1px #ffffff8c inset;border-color:#60a5fa59}.learning-hub-soft-box{padding:16px;border-radius:14px;background:#f8fafcf2;border:1px solid #e2e8f0;width:100%}.learning-hub-grid-2{display:grid;grid-template-columns:320px minmax(0,1fr);gap:20px;align-items:start;width:100%}.learning-hub-grid-video{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(0,1fr);gap:20px;align-items:start;width:100%}.learning-hub-grid-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;width:100%}.learning-hub-form-card{margin-top:12px;margin-bottom:20px;background:#ffffffdb;border:1px solid #dbeafe;border-radius:20px;padding:18px;box-shadow:0 12px 30px #0f172a14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%}.learning-hub-input,.learning-hub-select,.learning-hub-textarea{width:100%;min-width:0;padding:10px 12px;border-radius:12px;border:1px solid #334155;background:#020617;color:#f8fafc;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.learning-hub-input:focus,.learning-hub-select:focus,.learning-hub-textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 4px #3b82f61f}.learning-hub-secondary-btn{border:1px solid #cbd5e1;background:#f8fafc;color:#0f172a;border-radius:10px;padding:10px 14px;cursor:pointer;transition:all .2s ease;max-width:100%}.learning-hub-secondary-btn:hover{background:#fff;box-shadow:0 8px 18px #0f172a14}.learning-hub-video-item{text-align:left;padding:12px;border-radius:12px;border:1px solid #cbd5e1;background:#f8fafc;cursor:pointer;transition:all .2s ease;width:100%}.learning-hub-video-item:hover{transform:translateY(-2px);border-color:#93c5fd;box-shadow:0 10px 20px #3b82f614}.learning-hub-video-item.active{border:1px solid #2563eb;background:#dbeafe;box-shadow:0 10px 22px #2563eb1f}.results-page{min-height:100%;padding:28px;background:radial-gradient(circle at 12% 18%,rgba(34,197,94,.16),transparent 22%),radial-gradient(circle at 88% 14%,rgba(59,130,246,.18),transparent 24%),radial-gradient(circle at 50% 100%,rgba(168,85,247,.14),transparent 30%),linear-gradient(135deg,#06131f,#0b1f33 38%,#102a43 68%,#0f172a);background-attachment:fixed;border-radius:28px;box-shadow:inset 0 1px #ffffff0a,0 24px 60px #02061752;width:100%}.results-page .section-card{background:linear-gradient(145deg,#161c2deb,#111827e0);border:1px solid rgba(148,163,184,.18);border-radius:22px;box-shadow:0 10px 30px #00000059,0 0 0 1px #ffffff08 inset;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:premiumFloat 6s ease-in-out infinite;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease;width:100%;min-width:0}.results-page .section-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px #0000006b,0 0 25px #3b82f61f;border-color:#60a5fa47}@keyframes premiumFloat{0%{transform:translateY(0)}50%{transform:translateY(-3px)}to{transform:translateY(0)}}.results-page-title{text-align:center;font-size:28px;margin:0;padding:20px 0;color:#3b82f6;letter-spacing:.3px}.results-page div,.results-page div *{color:#fff!important}.results-list{display:flex;flex-direction:column;gap:14px;width:100%}.result-item{padding:18px 20px;border-radius:18px;background:#ffffff14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);width:100%;min-width:0}.result-item:hover{transform:translateY(-2px);border-color:#7dd3fc47;box-shadow:0 12px 28px #0000003d,0 0 16px #0ea5e914}.results-page input,.results-page select,.results-page textarea{background:#0f172ad9;color:#f8fafc;border:1px solid rgba(148,163,184,.22);border-radius:12px;width:100%;min-width:0}.results-page input::placeholder,.results-page textarea::placeholder{color:#94a3b8}.results-page input:focus,.results-page select:focus,.results-page textarea:focus{outline:none;border-color:#38bdf8b3;box-shadow:0 0 0 3px #38bdf81f}.results-page .primary-btn{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border:none;border-radius:12px;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease}.results-page .primary-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 22px #2563eb47}.results-list--student{display:grid;grid-template-columns:repeat(3,minmax(270px,1fr));gap:20px;margin-top:30px;width:100%}.results-page .card{background:transparent;box-shadow:none;border:none}.latest-results-title{color:#3b82f6;font-size:1.8rem;font-weight:800;text-align:center;margin:0}.results-full-width{grid-column:1 / -1}.admin-users-table{width:100%;border-collapse:collapse;margin-top:.5rem;display:block;overflow-x:auto;white-space:nowrap}.admin-users-table th,.admin-users-table td{padding:.85rem 1rem;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:middle}.admin-users-table th{font-weight:700;background:#f9fafb}.admin-block-btn{padding:.45rem .8rem;border:none;border-radius:8px;cursor:pointer;background:#111827;color:#fff;font-weight:600}@media (min-width: 700px){.grid-2{grid-template-columns:1fr 1fr}}@media (min-width: 900px){.home-grid{grid-template-columns:repeat(auto-fit,minmax(220px,260px));justify-content:center}}@media (max-width: 900px){.layout-shell{grid-template-columns:1fr}.nav-list{flex-direction:row;overflow-x:auto}.two-columns,.messages-grid,.dashboard-grid--main,.learning-hub-grid-2,.learning-hub-grid-video{grid-template-columns:1fr}.results-list--student{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 820px){.app-header{height:80px;padding:0 12px}.header-logo{max-height:68px}.header-right{gap:8px}.header-logout-btn,.header-login-btn{padding:7px 12px;font-size:.85rem}.header-user{font-size:12px}.language-select{font-size:12px;padding:4px 6px}.app-shell{grid-template-columns:1fr;margin-top:80px;margin-bottom:56px;min-height:calc(100vh - 136px)}.sidebar{padding:18px}.sidebar-nav{grid-auto-flow:column;grid-auto-columns:minmax(160px,1fr);overflow-x:auto;padding-bottom:6px}.main-content{padding:20px}.app-footer{padding:8px 10px}.footer-content{gap:10px;margin-bottom:2px}.footer-section{justify-content:center}.footer-links{gap:8px;justify-content:center}.footer-section a{font-size:12px}.footer-copy{font-size:11px}}@media (max-width: 700px){.app-header{height:72px;padding:0 10px;gap:8px}.header-logo{max-height:60px}.header-right{gap:6px}.header-logout-btn,.header-login-btn{padding:6px 10px;font-size:.78rem}.header-user{font-size:11px}.language-select{font-size:11px;padding:3px 6px}.app-shell{margin-top:72px}.topbar,.content-area,.subjects-page,.dashboard-page,.profile-page,.learning-hub-page,.results-page,.messages-page-centered,.main-content{padding-left:16px;padding-right:16px}.auth-card{padding:24px}.teacher-schedule-card,.profile-page .card,.learning-hub-form-card,.results-page .section-card{padding:20px}}@media (max-width: 600px){.subject-grid,.metric-grid,.dashboard-grid--cards,.results-list--student,.form-grid,.student-checkbox-grid{grid-template-columns:1fr}.home-title{font-size:28px}.home-subtitle,.home-description{font-size:15px}.dashboard-page__title,.profile-title,.teacher-schedule-title{font-size:1.6rem}.footer-content{flex-direction:row;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap}.schedule-row,.lesson-card-top,.lesson-action-row{flex-direction:column}.messages-chat-wrapper{padding:10px;border-radius:20px}.results-page,.learning-hub-page{border-radius:20px}}@media (max-width: 480px){.app-header{padding:8px 10px;height:68px}.header-user{display:none}.header-logo{max-height:54px}.header-logout-btn,.header-login-btn{padding:6px 8px;font-size:.74rem}.language-select{font-size:10px;padding:3px 5px;margin-right:0;width:100%}.app-shell{margin-top:68px}.app-footer{padding:12px 10px}.main-content,.topbar,.content-area,.subjects-page,.dashboard-page,.profile-page,.learning-hub-page,.results-page,.messages-page-centered{padding-left:12px;padding-right:12px}.auth-page,.simple-page{padding:16px}.auth-card{padding:20px 16px;border-radius:16px}.card,.metric-card,.teacher-schedule-card,.profile-page .card,.learning-hub-form-card,.results-page .section-card{border-radius:16px}.header-right span{padding-right:0}}.admin-page-bg{min-height:100vh;padding:24px;background:radial-gradient(circle at 15% 25%,rgba(0,120,255,.15),transparent 40%),radial-gradient(circle at 85% 75%,rgba(0,255,200,.12),transparent 40%),linear-gradient(135deg,#0f172a,#020617);position:relative}.table-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-users-table{width:100%;min-width:700px;border-collapse:collapse;border-radius:12px;overflow:hidden;background:#ffffff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.admin-users-table th{text-align:left;padding:14px;font-weight:600;background:#ffffff0f;white-space:nowrap}.admin-users-table td{padding:12px 14px;border-top:1px solid rgba(255,255,255,.05);white-space:nowrap}.admin-users-table tr:hover{background:#ffffff08}.admin-block-btn{padding:6px 12px;border-radius:8px;border:none;cursor:pointer;background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;font-weight:500;transition:all .25s ease}.admin-block-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0096ff4d}.admin-block-btn:disabled{opacity:.6;cursor:not-allowed}.section-card{background:#ffffff0d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;padding:20px;box-shadow:0 10px 30px #0006}@media (max-width: 768px){.admin-page-bg,.section-card{padding:12px}.admin-users-table th,.admin-users-table td{padding:10px;font-size:13px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:#fff;width:100%;max-width:520px;border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:12px;box-shadow:0 10px 30px #0003;max-height:90vh;overflow-y:auto}.modal h2{font-size:18px;margin-bottom:4px}.modal input,.modal textarea{width:100%;padding:12px;border-radius:8px;border:1px solid #ccc;font-size:14px;outline:none}.modal textarea{min-height:100px;resize:vertical}.modal button{padding:12px;border:none;border-radius:8px;cursor:pointer;font-size:14px;transition:background .2s ease}.modal button:first-of-type{background:#007bff;color:#fff}.modal button:first-of-type:hover{background:#0069d9}.modal button:last-of-type{background:#e0e0e0}.modal button:last-of-type:hover{background:#c7c7c7}@media (max-width: 480px){.modal{padding:16px;border-radius:10px}.modal h2{font-size:16px}.modal input,.modal textarea,.modal button{font-size:13px;padding:10px}}@media (min-width: 481px) and (max-width: 768px){.modal{max-width:480px;padding:20px}}@media (min-width: 769px) and (max-width: 1200px){.modal{max-width:520px}}@media (min-width: 1201px){.modal{max-width:600px}}
