@import"https://fonts.googleapis.com/css2?family=Tajawal:wght@200;300;400;500;700;800;900&family=Cairo:wght@300;400;600;700;900&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Tajawal,Cairo,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.7;font-weight:400;--primary-start: #667eea;--primary-end: #764ba2;--primary-color: #667eea;--secondary-color: #764ba2;--text-dark: #1a202c;--text-color: #2d3748;--text-secondary: #718096;--text-light: #a0aec0;--background: #f7fafc;--background-alt: #edf2f7;--white: #ffffff;--surface: #ffffff;--border-color: #e2e8f0;--border-light: #edf2f7;--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--success-color: #48bb78;--success-light: #c6f6d5;--error-color: #f56565;--error-light: #fed7d7;--warning-color: #ed8936;--warning-light: #feebc8;--info-color: #4299e1;--info-light: #bee3f8;--radius-sm: .375rem;--radius: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);direction:rtl;text-align:right;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-height:100vh;background-color:var(--background);color:var(--text-color);font-size:16px}#root{min-height:100vh}a{text-decoration:none;color:inherit;transition:color .3s ease}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.2}ul,ol{list-style:none;padding:0;margin:0}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .3s ease}button:disabled{cursor:not-allowed;opacity:.6}input,textarea,select{font-family:inherit;font-size:inherit}input:focus,textarea:focus,select:focus{outline:none}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.fade-in{animation:fadeIn .4s ease-out}.slide-in-right{animation:slideInRight .4s ease-out}.slide-in-left{animation:slideInLeft .4s ease-out}.slide-up{animation:slideUp .4s ease-out}.scale-in{animation:scaleIn .3s ease-out}.glass-effect{background:#ffffffe6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.gradient-bg{background:linear-gradient(135deg,var(--primary-start) 0%,var(--primary-end) 100%)}.hover-lift{transition:transform var(--transition),box-shadow var(--transition)}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.hover-scale{transition:transform var(--transition)}.hover-scale:hover{transform:scale(1.02)}.skeleton{background:linear-gradient(90deg,var(--border-light) 0%,#f0f0f0 50%,var(--border-light) 100%);background-size:1000px 100%;animation:shimmer 2s infinite;border-radius:var(--radius)}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){:root{font-size:14px}}.sidebar{width:var(--sidebar-width);height:100vh;background:linear-gradient(180deg,#2c3e50,#34495e);color:#fff;display:flex;flex-direction:column;position:fixed;right:0;top:0;box-shadow:-2px 0 10px #0000001a;overflow:hidden;z-index:900;transition:width var(--transition-base),transform var(--transition-base),opacity var(--transition-base);will-change:transform,width}.sidebar.is-collapsed{width:var(--rail-width)}.sidebar.is-collapsed .sidebar-header h2,.sidebar.is-collapsed .sidebar-header p,.sidebar.is-collapsed .sidebar-footer .label,.sidebar.is-collapsed .sidebar-footer p,.sidebar.is-collapsed .sidebar-nav .label{display:none}.sidebar.is-collapsed .sidebar-footer{padding:16px 0;align-items:center}.sidebar.is-collapsed .logout-btn{justify-content:center}.sidebar-toggle{position:absolute;top:16px;left:16px;background:#ffffff26;border:0;color:#fff;width:32px;height:32px;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:background .2s ease,transform .2s ease}.sidebar-toggle:hover{background:#ffffff40;transform:scale(1.05)}.sidebar-header{padding:30px 20px;text-align:center;border-bottom:1px solid rgba(255,255,255,.1);position:relative}.sidebar-header h2{margin:0;font-size:24px;font-weight:600}.sidebar-header .logo{font-size:48px;margin-bottom:10px}.sidebar.is-collapsed .sidebar-header .logo{margin-bottom:0}.sidebar-header p{font-size:14px;color:#ffffffb3;margin:5px 0 0}.sidebar-nav{flex:1;padding:20px 0;overflow-y:auto;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.35) transparent}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff40;border-radius:999px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#fff6}.sidebar-nav ul{list-style:none;padding:0;margin:0}.sidebar-nav li{margin:5px 10px}.sidebar-nav a{display:flex;align-items:center;gap:15px;padding:15px 20px;color:#fffc;text-decoration:none;border-radius:8px;transition:transform .2s ease,background .2s ease,color .2s ease}.sidebar-nav a:hover{background:#ffffff1a;color:#fff;transform:translate(-3px)}.sidebar-nav a.active{background:#3498db4d;color:#fff;border-right:4px solid #3498db}.sidebar-nav .icon{font-size:20px;width:24px;text-align:center}.sidebar-nav .label{font-size:16px}.sidebar-footer{padding:20px;text-align:center;border-top:1px solid rgba(255,255,255,.1)}.logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;background:#e74c3c33;border:1px solid rgba(231,76,60,.4);color:#fff;border-radius:8px;cursor:pointer;transition:transform .2s ease,background .2s ease,border-color .2s ease;margin-bottom:15px;font-size:14px}.logout-btn:hover{background:#e74c3c4d;transform:translate(-3px)}.logout-btn .icon{font-size:18px}.sidebar-footer p{margin:0;font-size:12px;color:#ffffff80}@media(max-width:1280px){.sidebar{width:var(--sidebar-width-md)}}.mobile-bar{display:none}@media(max-width:1024px){.sidebar{width:min(88vw,360px);transform:translate(100%);opacity:0}.sidebar.sidebar--open{transform:translate(0);opacity:1}.sidebar.is-collapsed{width:min(88vw,360px)}.mobile-bar{position:sticky;top:0;z-index:901;display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:linear-gradient(180deg,#2c3e50,#34495e);color:#fff;box-shadow:0 1px 8px #0000001f}.mobile-bar__title{display:flex;align-items:center;gap:8px;font-weight:600}.mobile-bar__btn{border:0;border-radius:10px;padding:10px 14px;cursor:pointer;background:#ffffff2e;color:#fff;transition:transform .2s ease,background .2s ease}.mobile-bar__btn:hover{transform:translateY(-1px);background:#ffffff47}.sidebar-overlay{position:fixed;inset:0;background:#00000059;z-index:899;opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.sidebar-overlay.is-visible{opacity:1;pointer-events:auto}}@media(max-width:480px){.sidebar-header h2{font-size:18px}.sidebar-header p{font-size:12px}.sidebar-nav a{min-width:140px;padding:12px 16px}.logout-btn{font-size:13px;padding:10px 16px}}:root[dir=rtl] .sidebar-nav a:hover,:root[dir=rtl] .logout-btn:hover{transform:translate(3px)}.layout{display:flex;min-height:100vh;background:#f5f6fa;width:100%}.main-content{flex:1;margin-right:var(--sidebar-width);padding:clamp(20px,3vw,32px);min-height:100vh;transition:margin-right var(--transition-base);box-sizing:border-box}@media(max-width:1280px){.main-content{margin-right:var(--sidebar-width-md)}}@media(max-width:1024px){.layout{flex-direction:column}.main-content{margin-right:0;padding:clamp(18px,4vw,28px)}}@media(max-width:768px){.main-content{padding:clamp(16px,5vw,24px)}}@media(max-width:480px){.main-content{padding:clamp(12px,6vw,18px)}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.login-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;overflow:hidden}.circle{position:absolute;border-radius:50%;background:#ffffff1a;animation:float 20s infinite ease-in-out}.circle-1{width:300px;height:300px;top:-100px;right:-100px}.circle-2{width:200px;height:200px;bottom:-50px;left:-50px;animation-delay:5s}.circle-3{width:150px;height:150px;top:50%;right:10%;animation-delay:10s}@keyframes float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,30px) scale(1.1)}}.login-box{background:#fff;border-radius:20px;padding:50px 40px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:450px;position:relative;z-index:1;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:40px}.logo{font-size:64px;margin-bottom:20px;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-header h1{font-size:36px;color:#2c3e50;margin-bottom:10px;font-weight:700}.login-header p{color:#7f8c8d;font-size:16px}.login-form{margin-bottom:30px}.form-group{margin-bottom:25px}.form-group label{display:block;margin-bottom:8px;color:#2c3e50;font-weight:600;font-size:14px}.form-group input{width:100%;padding:15px 20px;border:2px solid #e2e8f0;border-radius:10px;font-size:16px;transition:all .3s ease;background:#f7fafc}.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#e2e8f0;cursor:not-allowed}.login-form .field-error{display:block;margin-top:6px;font-size:12px;color:var(--error-color);text-align:right}.error-message{padding:15px;background:#fee;border:1px solid #fcc;border-radius:10px;color:#c33;margin-bottom:20px;text-align:center;font-weight:500}.login-btn{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea66}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;padding-top:20px;border-top:1px solid #e2e8f0}.login-footer p{color:#7f8c8d;font-size:14px;margin:0}@media(max-width:480px){.login-box{padding:40px 30px;margin:20px}.login-header h1{font-size:28px}.logo{font-size:48px}}.dashboard{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;box-sizing:border-box}.dashboard-header{margin-bottom:40px;background:linear-gradient(135deg,#667eea,#764ba2);padding:clamp(28px,4vw,40px);border-radius:18px;color:#fff}.header-content{display:flex;justify-content:space-between;align-items:center}.logo-section{display:flex;align-items:center;gap:20px}.dashboard-logo{font-size:64px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.dashboard-header h1{font-size:42px;margin-bottom:5px;font-weight:700}.dashboard-header p{font-size:18px;opacity:.9}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(16px,3vw,24px);margin-bottom:clamp(24px,4vw,40px)}.stat-card{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;padding:30px;display:flex;align-items:center;gap:25px;box-shadow:0 4px 15px #00000014;transition:all .4s cubic-bezier(.175,.885,.32,1.275);border:2px solid transparent;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(135deg,#667eea,#764ba2);opacity:0;transition:opacity .3s ease}.stat-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 12px 30px #667eea40;border-color:#667eea}.stat-card:hover:before{opacity:1}.stat-icon{font-size:56px;width:85px;height:85px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:18px;flex-shrink:0;box-shadow:0 6px 20px #667eea4d;transition:transform .3s ease}.stat-card:hover .stat-icon{transform:scale(1.1) rotate(5deg)}.stat-details{flex:1}.stat-details h3{font-size:16px;color:#7f8c8d;margin-bottom:10px;font-weight:600;letter-spacing:.5px}.stat-number{font-size:36px;color:#2c3e50;font-weight:800;margin:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.quick-actions{background:#fff;border-radius:20px;padding:clamp(24px,4vw,35px);box-shadow:0 4px 15px #00000014;border:2px solid #f0f0f0}.quick-actions h2{font-size:28px;color:#2c3e50;margin-bottom:25px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:clamp(12px,2.5vw,18px)}.action-btn{display:flex;align-items:center;justify-content:center;gap:12px;padding:24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border:none;border-radius:15px;font-size:17px;font-weight:700;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 15px #667eea4d;letter-spacing:.5px}.action-btn:hover{transform:translateY(-5px) scale(1.05);box-shadow:0 8px 25px #667eea80;background:linear-gradient(135deg,#764ba2,#667eea)}.action-icon{font-size:24px}.welcome-section{margin-top:30px;background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;padding:clamp(28px,4vw,40px);box-shadow:0 4px 15px #00000014;text-align:center;border:2px solid #f0f0f0}.welcome-section h2{font-size:28px;color:#2c3e50;margin-bottom:20px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-section p{font-size:17px;color:#7f8c8d;line-height:2;max-width:900px;margin:0 auto;font-weight:500}.loading{text-align:center;padding:60px;font-size:18px;color:#7f8c8d}.admin-form-card{margin-top:30px;background:#fff;border-radius:20px;padding:clamp(26px,4vw,40px);box-shadow:0 6px 20px #00000014;border:2px solid #f0f0f0}.admin-form-card h2{font-size:28px;color:#2c3e50;margin-bottom:10px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-form-description{color:#7f8c8d;margin-bottom:25px;font-size:15px}.admin-form{display:flex;flex-direction:column;gap:20px}.admin-form .form-row{display:flex;gap:20px;flex-wrap:wrap}.admin-form .form-group{flex:1 1 240px;display:flex;flex-direction:column;gap:8px}.admin-form .form-group label{color:#2c3e50;font-weight:600;font-size:14px}.admin-form .form-group input,.admin-form .form-group select{padding:14px 18px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;transition:all .3s ease;background:#f7fafc;color:#2c3e50}.admin-form .form-group input:focus,.admin-form .form-group select:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.admin-form .form-group input:disabled,.admin-form .form-group select:disabled{background:#e2e8f0;cursor:not-allowed}.admin-form .field-error{margin-top:6px;font-size:12px;color:var(--error-color);display:block}.admin-form .hint{font-size:12px;color:#7f8c8d}.admin-form-error,.admin-form-success{padding:16px 20px;border-radius:12px;font-weight:500;margin-bottom:20px}.admin-form-error{background:#fee;border:1px solid #fcc;color:#c33}.admin-form-success{background:#ecfdf5;border:1px solid #bbf7d0;color:#047857}.admin-token-box{margin-top:15px;background:#fff;border:1px dashed #34d399;border-radius:12px;padding:clamp(12px,3vw,18px);display:flex;flex-direction:column;gap:10px}.admin-token-box code{display:block;background:#f1f5f9;padding:10px;border-radius:8px;font-family:Courier New,Courier,monospace;font-size:13px;color:#1e293b;direction:ltr;word-break:break-all}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-left:52px}.password-toggle{position:absolute;top:50%;left:16px;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;font-size:20px;line-height:1;color:#2c3e50;transition:color .3s ease;padding:4px}.password-toggle:hover,.password-toggle:focus{color:#667eea;outline:none}.admin-submit-btn{align-self:flex-start;padding:16px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:17px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 18px #667eea59}.admin-submit-btn:hover:not(:disabled){transform:translateY(-3px) scale(1.02);box-shadow:0 10px 28px #667eea73;background:linear-gradient(135deg,#764ba2,#667eea)}.admin-submit-btn:disabled{opacity:.7;cursor:not-allowed}.error-banner{background-color:#fee;border:1px solid #fcc;border-radius:12px;padding:15px 20px;margin-bottom:20px;color:#c33;display:flex;justify-content:space-between;align-items:center;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.retry-btn{background-color:#10b981;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.retry-btn:hover{background-color:#059669;transform:scale(1.05)}@media(max-width:1024px){.header-content{flex-direction:column;gap:24px;text-align:center}.logo-section{justify-content:center}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.stat-card{padding:24px}.quick-actions h2,.welcome-section h2,.admin-form-card h2{font-size:24px}.actions-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.welcome-section p{font-size:16px}.admin-form .form-row{gap:16px}}.stat-card-users .stat-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-card-users:hover{border-color:#667eea}.stat-card-users:hover:before{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-card-grades .stat-icon{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-card-grades:hover{border-color:#f093fb}.stat-card-grades:hover:before{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-card-subjects .stat-icon{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-card-subjects:hover{border-color:#4facfe}.stat-card-subjects:hover:before{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-subtitle{margin-top:8px;font-size:12px;color:#999;font-weight:500}.stat-subtitle span{background-color:#f0f0f0;padding:4px 10px;border-radius:12px;display:inline-block}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.dashboard-header{padding:30px 20px}.dashboard-logo{font-size:48px}.dashboard-header h1{font-size:32px}.error-banner{flex-direction:column;gap:10px;text-align:center}.retry-btn{width:100%}.admin-form-card{padding:30px 20px}.admin-form .form-row{flex-direction:column}.admin-submit-btn{width:100%;text-align:center}}@media(max-width:560px){.dashboard-header h1{font-size:28px}.dashboard-header p{font-size:16px}.stat-card{flex-direction:column;align-items:flex-start;gap:18px}.stat-icon{width:70px;height:70px;font-size:44px}.action-btn{padding:18px;font-size:15px}.admin-form .form-group{flex:1 1 100%}}.grades-page{max-width:1400px;margin:0 auto;padding:20px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh}.management-toolbar{display:flex;flex-wrap:wrap;gap:15px;align-items:center;justify-content:space-between;background:#ffffffd9;border-radius:18px;padding:18px 24px;box-shadow:0 8px 24px #667eea2e;border:1px solid rgba(118,75,162,.18);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.primary-btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:14px;padding:14px 24px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 10px 24px #764ba259;transition:transform .2s ease,box-shadow .2s ease;white-space:nowrap}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 16px 32px #764ba261}.grades-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:25px}.grade-card{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;padding:35px;box-shadow:0 4px 15px #00000014;transition:all .4s cubic-bezier(.175,.885,.32,1.275);border:2px solid transparent;position:relative;overflow:hidden}.grade-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(135deg,#667eea,#764ba2);opacity:0;transition:opacity .3s ease}.grade-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 12px 30px #667eea40;border-color:#667eea}.grade-card:hover:before{opacity:1}.grade-icon{font-size:64px;text-align:center;margin-bottom:20px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.1))}.grade-card h3{font-size:22px;color:#2c3e50;margin-bottom:25px;text-align:center;font-weight:700;letter-spacing:.5px}.grade-info{margin-bottom:25px;padding:20px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:15px;box-shadow:inset 0 2px 8px #0000000d}.info-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0}.info-item:not(:last-child){border-bottom:2px solid #cbd5e0;margin-bottom:8px}.info-label{font-weight:700;color:#667eea;font-size:15px;display:flex;align-items:center;gap:6px}.info-label:before{content:"•";font-size:20px}.info-value{color:#2c3e50;font-weight:600;font-size:15px;background:#fff;padding:6px 14px;border-radius:8px;box-shadow:0 2px 4px #0000000d}.visibility-chip{display:inline-flex;align-items:center;gap:6px;min-width:100px;justify-content:center;border-radius:999px;padding:6px 14px;font-weight:700;transition:background .2s ease,color .2s ease}.visibility-chip.is-visible{background:#10b9812e;color:#047857}.visibility-chip.is-hidden{background:#ef44442e;color:#b91c1c}.grade-actions{display:flex;gap:12px;justify-content:center}.grade-actions button{width:44px;height:44px;border-radius:14px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.grade-actions .btn-edit{background:#667eea2e;color:#4c51bf}.grade-actions .btn-edit:hover{background:#667eea47;transform:translateY(-2px);box-shadow:0 8px 16px #667eea52}.grade-actions .btn-delete{background:#f565652e;color:#c53030}.grade-actions .btn-delete:hover{background:#f5656547;transform:translateY(-2px);box-shadow:0 8px 16px #e53e3e52}.confirm-dialog{background:#fff;padding:32px;border-radius:18px;max-width:440px;width:92%;text-align:center;box-shadow:0 20px 48px #0000002e}.confirm-dialog h3{margin-bottom:14px;font-size:24px;color:#2d3748}.confirm-dialog p{color:#4a5568;font-size:16px;line-height:1.7;margin-bottom:26px}.confirm-actions{display:flex;gap:14px;justify-content:center}.confirm-actions .btn-cancel,.confirm-actions .btn-delete{flex:1;padding:14px 18px;border-radius:12px;font-weight:700;cursor:pointer;border:none;transition:transform .2s ease,box-shadow .2s ease}.confirm-actions .btn-delete:hover{transform:translateY(-2px);box-shadow:0 10px 20px #e53e3e8c}.toggle-section{padding:24px;border-radius:16px;background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid rgba(148,163,184,.2);box-shadow:0 2px 8px #0000000a;margin-bottom:24px;transition:all .3s ease}.toggle-section:hover{border-color:#667eea4d;box-shadow:0 4px 12px #667eea14}.toggle-section-header{margin-bottom:20px}.toggle-section-title{font-weight:700;color:#1e293b;font-size:16px;margin:0 0 6px;letter-spacing:-.2px}.toggle-section-description{font-size:13px;color:#64748b;margin:0;line-height:1.5}.toggle-controls{display:flex;flex-direction:column;gap:16px}.toggle-control{display:flex;align-items:center;justify-content:space-between;gap:20px;position:relative;cursor:pointer;-webkit-user-select:none;user-select:none;padding:12px 16px;border-radius:12px;background:#f8fafc;border:1px solid transparent;transition:all .2s ease;min-height:56px}.toggle-label-wrapper{flex:1;display:flex;align-items:center;min-width:0;order:1;pointer-events:none;position:relative;z-index:1}.toggle-switch-wrapper{flex-shrink:0;display:flex;align-items:center;order:2;pointer-events:none;position:relative;z-index:1}.toggle-control:hover{background:#f1f5f9;border-color:#667eea33}.toggle-control:active{transform:scale(.98)}.toggle-control input{position:absolute;opacity:0;width:100%;height:100%;margin:0;padding:0;border:0;cursor:pointer;z-index:10;inset:0}.toggle-switch{position:relative;width:64px;height:38px;border-radius:999px;background:#cbd5e1;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;box-shadow:inset 0 4px 8px #00000026,inset 0 -3px 6px #ffffff4d,0 3px 6px #0000001a,0 2px 4px #00000014,0 0 10px #fff3,0 0 6px #ffffff26;order:2;border:1px solid rgba(255,255,255,.3);overflow:hidden}.toggle-switch:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.4) 0%,rgba(255,255,255,.1) 50%,transparent 100%);border-radius:999px 999px 0 0;pointer-events:none}.toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.6) 0%,rgba(255,255,255,.2) 50%,transparent 100%);pointer-events:none;filter:blur(2px);box-shadow:0 0 8px #ffffff80}.toggle-text-on,.toggle-text-off{position:absolute;top:50%;transform:translateY(-50%);font-size:11px;font-weight:700;letter-spacing:.3px;z-index:1;pointer-events:none;transition:opacity .3s ease,color .3s ease;white-space:nowrap}.toggle-text-on{left:10px;color:#fffffff2;opacity:0;text-shadow:0 1px 3px rgba(0,0,0,.3);pointer-events:none}.toggle-text-off{right:10px;color:#94a3b8f2;opacity:1;text-shadow:0 1px 2px rgba(255,255,255,.6);pointer-events:none}.toggle-control input:not(:checked)~.toggle-switch-wrapper .toggle-switch .toggle-text-on{opacity:0!important;visibility:hidden}.toggle-control input:not(:checked)~.toggle-switch-wrapper .toggle-switch .toggle-text-off{opacity:1!important;visibility:visible}.toggle-control input:checked~.toggle-switch-wrapper .toggle-switch .toggle-text-on{opacity:1!important;visibility:visible}.toggle-control input:checked~.toggle-switch-wrapper .toggle-switch .toggle-text-off{opacity:0!important;visibility:hidden}.toggle-switch-checked .toggle-text-on{opacity:1!important;visibility:visible}.toggle-switch-checked .toggle-text-off{opacity:0!important;visibility:hidden}.toggle-switch:not(.toggle-switch-checked){background:linear-gradient(135deg,#cbd5e1,#94a3b8)!important;box-shadow:inset 0 3px 6px #00000026,inset 0 -2px 4px #ffffff4d,0 2px 4px #0000001a,0 1px 2px #00000014,0 0 8px #fff3,0 0 4px #ffffff26!important;border-color:#ffffff4d!important}.toggle-switch:not(.toggle-switch-checked) .toggle-text-on{opacity:0!important;visibility:hidden}.toggle-switch:not(.toggle-switch-checked) .toggle-text-off{opacity:1!important;visibility:visible}.toggle-switch:not(.toggle-switch-checked) .toggle-thumb{transform:translate(0)!important}.toggle-thumb{position:absolute;top:3px;right:3px;width:32px;height:32px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#f8fafc,#e2e8f0);box-shadow:0 5px 10px #00000040,0 3px 6px #0003,0 2px 4px #00000026,0 0 14px #fff6,0 0 8px #ffffff4d,inset 0 2px 3px #fffffff2,inset 0 -1px 2px #0000000d,0 0 0 1px #fff9;transition:all .3s cubic-bezier(.4,0,.2,1);transform:translate(0);border:1px solid rgba(255,255,255,.95);overflow:hidden;z-index:2}.toggle-thumb:before{content:"";position:absolute;top:4px;right:4px;width:12px;height:12px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,1) 0%,rgba(255,255,255,.6) 50%,rgba(255,255,255,.2) 80%,transparent 100%);pointer-events:none;filter:blur(1.5px);box-shadow:0 0 8px #fffc}.toggle-thumb:after{content:"";position:absolute;top:3px;right:3px;width:9px;height:9px;border-radius:50%;background:#fffffff2;pointer-events:none;filter:blur(.8px);box-shadow:0 0 4px #ffffffe6}.toggle-control:hover .toggle-thumb{box-shadow:0 5px 10px #0000004d,0 3px 6px #00000040,0 1px 3px #0003,0 0 16px #fff9,0 0 10px #ffffff80,0 0 4px #fff6,inset 0 1px 2px #fffffff2,inset 0 -1px 1px #0000000d,0 0 0 1px #ffffffb3;transform:translate(0) scale(1.05);background:radial-gradient(circle at 30% 30%,#fff,#f8fafc 45%,#e2e8f0)}.toggle-control:hover .toggle-thumb:before{background:radial-gradient(circle,rgba(255,255,255,1) 0%,rgba(255,255,255,.7) 50%,rgba(255,255,255,.3) 80%,transparent 100%);filter:blur(2px);box-shadow:0 0 12px #fff;width:14px;height:14px;top:3px;right:3px}.toggle-control:hover .toggle-thumb:after{background:#fff;filter:blur(1px);box-shadow:0 0 6px #fff;width:10px;height:10px;top:2px;right:2px}.toggle-control:active .toggle-thumb{transform:translate(0) scale(.95);box-shadow:0 2px 4px #0003,0 1px 2px #00000026,0 0 8px #ffffff4d,0 0 4px #fff3,inset 0 1px 2px #ffffffe6}.toggle-control:active .toggle-thumb:before{opacity:.7}.toggle-control:active .toggle-thumb:after{opacity:.8}.toggle-control input:checked~.toggle-switch-wrapper .toggle-switch{background:linear-gradient(135deg,#10b981,#059669)!important;box-shadow:inset 0 3px 6px #0003,inset 0 -2px 4px #fff3,0 0 0 3px #10b98126,0 2px 6px #10b9814d,0 1px 3px #0000001a,0 0 12px #ffffff4d,0 0 6px #ffffff40;border-color:#fff6}.toggle-control input:checked~.toggle-switch-wrapper .toggle-switch:before{background:linear-gradient(180deg,rgba(255,255,255,.5) 0%,rgba(255,255,255,.2) 50%,transparent 100%)}.toggle-control input:checked~.toggle-switch-wrapper .toggle-switch:after{background:radial-gradient(circle,rgba(255,255,255,.8) 0%,rgba(255,255,255,.4) 50%,transparent 100%);box-shadow:0 0 10px #ffffffb3;left:3px;top:3px}.toggle-switch-checked{background:linear-gradient(135deg,#10b981,#059669)!important;box-shadow:inset 0 3px 6px #0003,inset 0 -2px 4px #fff3,0 0 0 3px #10b98126,0 2px 6px #10b9814d,0 1px 3px #0000001a,0 0 12px #ffffff4d,0 0 6px #ffffff40!important;border-color:#fff6!important}.toggle-switch-checked:before{background:linear-gradient(180deg,rgba(255,255,255,.5) 0%,rgba(255,255,255,.2) 50%,transparent 100%)!important}.toggle-switch-checked:after{background:radial-gradient(circle,rgba(255,255,255,.8) 0%,rgba(255,255,255,.4) 50%,transparent 100%)!important;box-shadow:0 0 10px #ffffffb3!important;left:3px;top:3px}.toggle-control input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb{transform:translate(-26px);background:radial-gradient(circle at 30% 30%,#fff,#f0fdf4,#dcfce7);box-shadow:0 6px 14px #0000004d,0 4px 8px #00000040,0 2px 4px #0003,0 0 16px #ffffff80,0 0 10px #fff6,0 0 4px #ffffff4d,inset 0 2px 3px #fffffff2,inset 0 -1px 2px #0000000d,0 0 0 1px #fff9}.toggle-control input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb:before{background:radial-gradient(circle,rgba(255,255,255,1) 0%,rgba(255,255,255,.5) 70%,transparent 100%);filter:blur(1.5px)}.toggle-control input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb:after{background:#fffffff2;filter:blur(.8px)}.toggle-switch-checked .toggle-thumb{transform:translate(-26px)!important;background:radial-gradient(circle at 30% 30%,#fff,#f0fdf4,#dcfce7)!important;box-shadow:0 6px 14px #0000004d,0 4px 8px #00000040,0 2px 4px #0003,0 0 16px #ffffff80,0 0 10px #fff6,0 0 4px #ffffff4d,inset 0 2px 3px #fffffff2,inset 0 -1px 2px #0000000d,0 0 0 1px #fff9!important}.toggle-control:hover input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb{transform:translate(-26px) scale(1.05);background:radial-gradient(circle at 30% 30%,#fff,#f0fdf4 45%,#dcfce7);box-shadow:0 6px 14px #00000059,0 4px 8px #0000004d,0 2px 4px #00000040,0 0 18px #fff9,0 0 12px #ffffff80,0 0 6px #fff6,inset 0 2px 3px #fffffff2,inset 0 -1px 2px #0000000d,0 0 0 1px #ffffffb3}.toggle-control:hover input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb:before{background:radial-gradient(circle,rgba(255,255,255,1) 0%,rgba(255,255,255,.6) 70%,transparent 100%);filter:blur(2px);width:11px;height:11px}.toggle-control:hover input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb:after{background:#fff;filter:blur(1px);width:9px;height:9px}.toggle-control:active input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb{transform:translate(-26px) scale(.95);box-shadow:0 3px 6px #00000040,0 2px 4px #0003,inset 0 1px 2px #fffffff2,0 0 6px #ffffff4d}.toggle-control:active input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb:before{opacity:.7}.toggle-control:active input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb:after{opacity:.8}.toggle-control input:not(:checked)~.toggle-switch-wrapper .toggle-switch{background:linear-gradient(135deg,#cbd5e1,#94a3b8);box-shadow:inset 0 3px 6px #00000026,inset 0 -2px 4px #ffffff4d,0 2px 4px #0000001a,0 1px 2px #00000014,0 0 8px #fff3,0 0 4px #ffffff26;border-color:#ffffff4d}.toggle-control:hover input:not(:checked)~.toggle-switch-wrapper .toggle-switch{box-shadow:inset 0 3px 6px #00000026,inset 0 -2px 4px #ffffff4d,0 2px 4px #0000001a,0 1px 2px #00000014,0 0 12px #ffffff59,0 0 8px #ffffff4d,0 0 4px #ffffff40}.toggle-control:hover input:not(:checked)~.toggle-switch-wrapper .toggle-switch:before{background:linear-gradient(180deg,rgba(255,255,255,.5) 0%,rgba(255,255,255,.2) 50%,transparent 100%)}.toggle-control:hover input:not(:checked)~.toggle-switch-wrapper .toggle-switch:after{background:radial-gradient(circle,rgba(255,255,255,.7) 0%,rgba(255,255,255,.3) 50%,transparent 100%);box-shadow:0 0 10px #fff9;width:14px;height:14px}.toggle-control:hover input:checked~.toggle-switch-wrapper .toggle-switch{box-shadow:inset 0 3px 6px #0003,inset 0 -2px 4px #fff3,0 0 0 3px #10b98126,0 2px 6px #10b9814d,0 1px 3px #0000001a,0 0 16px #fff6,0 0 10px #ffffff59,0 0 5px #ffffff4d}.toggle-control:hover input:checked~.toggle-switch-wrapper .toggle-switch:before{background:linear-gradient(180deg,rgba(255,255,255,.6) 0%,rgba(255,255,255,.3) 50%,transparent 100%)}.toggle-control:hover input:checked~.toggle-switch-wrapper .toggle-switch:after{background:radial-gradient(circle,rgba(255,255,255,.9) 0%,rgba(255,255,255,.5) 50%,transparent 100%);box-shadow:0 0 14px #ffffffe6;width:14px;height:14px}.toggle-control input:focus-visible~.toggle-switch-wrapper .toggle-switch{outline:2px solid #10b981;outline-offset:3px}.toggle-control input:focus-visible:checked~.toggle-switch-wrapper .toggle-switch{box-shadow:inset 0 3px 6px #0003,inset 0 -2px 4px #fff3,0 0 0 4px #10b98140,0 2px 6px #10b9814d,0 1px 3px #0000001a}.toggle-label{font-size:16px;font-weight:600;color:#1e293b;line-height:1.5;transition:color .2s ease;letter-spacing:.2px;display:block;width:100%}@media(max-width:1024px){.management-header{gap:16px}.management-title h1{font-size:30px}.grades-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grade-card{padding:28px}.grade-info{padding:16px}}@media(min-width:640px){.toggle-controls{flex-direction:row;gap:20px}.toggle-control{flex:1;min-width:0}}@media(max-width:768px){.management-toolbar{flex-direction:column;align-items:stretch}.primary-btn{width:100%;justify-content:center}.grades-grid{grid-template-columns:1fr}.toggle-section{padding:20px}.toggle-section-header{margin-bottom:18px}.toggle-section-title{font-size:15px}.toggle-section-description{font-size:12px}.toggle-controls{gap:14px}.toggle-control{padding:14px 16px;min-height:60px}.toggle-label{font-size:15px}.toggle-switch{width:58px;height:35px}.toggle-thumb{width:29px;height:29px;top:3px;right:3px}.toggle-control input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb{transform:translate(-24px)}.toggle-text-on,.toggle-text-off{font-size:10px}}@media(max-width:560px){.grades-page{padding:16px}.grade-card h3{font-size:20px}.info-item{flex-direction:column;align-items:flex-start;gap:6px}.toggle-section{padding:16px;border-radius:12px}.toggle-section-header{margin-bottom:16px}.toggle-section-title{font-size:14px}.toggle-section-description{font-size:11px}.toggle-controls{gap:12px}.toggle-control{padding:12px 14px;min-height:56px;border-radius:10px}.toggle-switch{width:54px;height:32px}.toggle-thumb{width:26px;height:26px;top:3px;right:3px}.toggle-control input:checked~.toggle-switch-wrapper .toggle-switch .toggle-thumb{transform:translate(-22px)}.toggle-label{font-size:14px}.toggle-text-on,.toggle-text-off{font-size:9px}.toggle-text-on{left:8px}.toggle-text-off{right:8px}}@media(max-width:400px){.toggle-section{padding:14px}.toggle-control{padding:10px 12px;min-height:52px}}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out;padding:20px}.modal-content{background:var(--white);border-radius:var(--radius-xl);width:min(100%,560px);max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);position:relative}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track{background:var(--background);border-radius:var(--radius)}.modal-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius)}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:28px 32px;border-bottom:1px solid var(--border-light);background:linear-gradient(135deg,#f7fafc,#fff);border-radius:var(--radius-xl) var(--radius-xl) 0 0;position:sticky;top:0;z-index:10}.modal-header h2{font-size:24px;color:var(--text-dark);font-weight:800;margin:0;letter-spacing:-.5px}.modal-close{background:var(--background);border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition);flex-shrink:0}.modal-close:hover{background:var(--error-light);color:var(--error-color);transform:rotate(90deg)}.modal-content form{padding:clamp(24px,5vw,32px)}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:10px;color:var(--text-dark);font-weight:600;font-size:14px;letter-spacing:.2px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:14px 18px;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:15px;transition:all var(--transition);font-family:inherit;background:var(--white);color:var(--text-dark)}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--primary-color)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #667eea1a;background:var(--white)}.form-group textarea{min-height:120px;resize:vertical}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:left .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-left:2.5rem}.checkbox-group{display:flex;align-items:center;margin-bottom:16px}.checkbox-group label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:500!important;margin-bottom:0!important;-webkit-user-select:none;user-select:none}.checkbox-group input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--primary-color);transition:all var(--transition)}.checkbox-group input[type=checkbox]:hover{transform:scale(1.1)}.checkbox-group input[type=checkbox]:checked{animation:scaleIn .2s ease-out}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:24px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;padding:24px 32px;background:var(--background);border-top:1px solid var(--border-light);border-radius:0 0 var(--radius-xl) var(--radius-xl);position:sticky;bottom:0}.btn-submit,.btn-cancel{padding:13px 32px;border:none;border-radius:var(--radius-md);font-size:15px;font-weight:600;cursor:pointer;transition:all var(--transition);letter-spacing:.3px}.btn-submit{background:linear-gradient(135deg,var(--primary-start) 0%,var(--primary-end) 100%);color:#fff;box-shadow:0 4px 12px #667eea4d}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-submit:active{transform:translateY(0)}.btn-cancel{background:var(--white);color:var(--text-dark);border:2px solid var(--border-color)}.btn-cancel:hover{background:var(--background);border-color:var(--text-secondary)}@media(max-width:768px){.modal-content{width:min(100%,500px);margin:0 16px}.modal-header{padding:24px 28px}.form-row{grid-template-columns:1fr;gap:18px}.modal-actions{padding:20px 28px;flex-wrap:wrap;gap:10px}.modal-actions button{flex:1 1 48%}}@media(max-width:480px){.modal-overlay{padding:12px}.modal-content{width:100%;margin:0;border-radius:var(--radius-md)}.modal-header{padding:20px 22px}.modal-header h2{font-size:20px}.modal-close{width:40px;height:40px}.modal-content form{padding:22px}.modal-actions{padding:18px 22px;flex-direction:column-reverse;gap:12px}.modal-actions button{width:100%;flex:1 1 auto}}@media(max-width:640px){.modal-overlay{padding:0}.modal-content{max-width:100%;max-height:100vh;border-radius:0;margin:0}.modal-header{padding:20px 24px;border-radius:0}.modal-header h2{font-size:20px}.modal-content form{padding:24px}.form-row{grid-template-columns:1fr;gap:16px}.modal-actions{padding:16px 24px;flex-direction:column-reverse;border-radius:0}.btn-submit,.btn-cancel{width:100%}}.question-generator-page{display:flex;flex-direction:column;gap:24px}.generator-header{text-align:center}.generator-header h2{margin:0;font-size:24px;color:var(--text-dark)}.generator-header p{margin:8px 0 0;color:var(--text-secondary);font-size:15px}.question-generator-uploader{background:var(--white);border-radius:16px;padding:24px;box-shadow:0 12px 32px #667eea14;border:1px solid rgba(102,126,234,.12)}.upload-dropzone{border:2px dashed rgba(102,126,234,.35);border-radius:16px;padding:40px 20px;text-align:center;background:#667eea0d;cursor:pointer;transition:border-color var(--transition),background-color var(--transition),transform var(--transition);outline:none}.upload-dropzone.is-dragging{border-color:var(--primary-color);background:#667eea1f;transform:translateY(-2px)}.upload-dropzone.is-disabled{opacity:.6;cursor:not-allowed}.upload-icon{font-size:48px;margin-bottom:12px}.upload-dropzone h3{margin:0 0 8px;font-size:20px;color:var(--text-dark)}.upload-dropzone p{margin:4px 0;color:var(--text-secondary);font-size:14px}.upload-hint{font-size:12px;color:var(--text-secondary)}.uploaded-file-card{display:flex;flex-direction:column;gap:16px}.file-summary{display:flex;align-items:center;gap:16px;background:#667eea14;border-radius:14px;padding:16px}.file-summary .file-icon{font-size:36px}.file-summary h4{margin:0 0 4px;font-size:16px;color:var(--text-dark)}.file-summary p{margin:0;font-size:13px;color:var(--text-secondary)}.file-remove-btn{margin-inline-start:auto;background:transparent;border:1px solid rgba(239,68,68,.4);color:#ef4444;padding:6px 12px;border-radius:999px;cursor:pointer;transition:background-color var(--transition),color var(--transition)}.file-remove-btn:hover:not(:disabled){background:#ef44441a}.file-remove-btn:disabled{opacity:.6;cursor:not-allowed}.file-preview{background:#94a3b81a;border-radius:12px;padding:16px}.file-preview h5{margin:0 0 8px;font-size:14px;color:var(--text-dark)}.file-preview pre{margin:0;max-height:200px;overflow-y:auto;background:#fff9;padding:12px;border-radius:10px;direction:ltr;text-align:left;font-family:Courier New,Courier,monospace;font-size:12px;line-height:1.5}.upload-error{margin-top:12px;padding:12px 16px;background:#fee2e2;border:1px solid #fecaca;color:#b91c1c;border-radius:10px;font-size:14px}.generator-options{background:var(--white);border-radius:16px;padding:24px;box-shadow:0 12px 32px #667eea14;border:1px solid rgba(102,126,234,.12)}.generator-options h3{margin:0 0 20px;font-size:18px;color:var(--text-dark)}.options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:var(--text-secondary)}.form-group input,.form-group select{padding:10px 12px;border-radius:12px;border:1px solid var(--border-color);font-size:14px;background:#f8faffe6;transition:border-color var(--transition),box-shadow var(--transition),background-color var(--transition)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);background:var(--white);box-shadow:0 0 0 3px #667eea33}.checkbox-group{align-self:flex-start}.checkbox-inline{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.checkbox-inline input{width:18px;height:18px;accent-color:var(--primary-color)}.field-error{font-size:12px;color:var(--error-color)}.btn-generate-questions{width:100%;padding:14px 20px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:var(--white);font-size:16px;font-weight:600;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),opacity var(--transition)}.btn-generate-questions:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 24px #667eea33}.btn-generate-questions:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.questions-result{background:var(--white);border-radius:16px;padding:24px;box-shadow:0 12px 32px #667eea14;border:1px solid rgba(102,126,234,.12);display:flex;flex-direction:column;gap:20px}.result-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.result-header h3{margin:0;color:var(--success-color);font-size:18px}.btn-save-questions{padding:10px 16px;border:none;border-radius:12px;background:linear-gradient(135deg,#10b981,#0ea5e9);color:var(--white);font-weight:600;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),opacity var(--transition)}.btn-save-questions:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 18px #0ea5e940}.btn-save-questions:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.questions-list{display:flex;flex-direction:column;gap:16px}.questions-loading{padding:12px 16px;background:#3b82f61a;border-radius:12px;color:var(--primary-color);font-weight:500}.questions-empty{padding:14px 16px;border-radius:12px;background:#94a3b81f;color:var(--text-secondary);text-align:center;font-weight:500}.question-card{border:1px solid var(--border-light);border-radius:14px;padding:18px;transition:border-color var(--transition),box-shadow var(--transition)}.question-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.question-actions{display:flex;gap:8px;flex-wrap:wrap}.question-card:hover{border-color:#667eea66;box-shadow:0 10px 24px #667eea1f}.question-number{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:var(--white);border-radius:999px;font-size:12px;font-weight:600;margin-bottom:12px}.question-card h4{margin:0;font-size:16px;color:var(--text-dark);line-height:1.6}.question-edit-form{display:flex;flex-direction:column;gap:12px;margin-top:12px}.question-edit-form label{display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--text-secondary)}.question-edit-form textarea,.question-edit-form input{padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);font-size:14px;background:#f8faffe6;resize:vertical;min-height:80px}.question-edit-form input{min-height:auto}.question-options{margin-top:16px;display:flex;flex-direction:column;gap:10px}.option{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;background:#94a3b81f;border:1px solid rgba(148,163,184,.2);transition:background-color var(--transition),border-color var(--transition)}.option.is-correct{background:#10b98126;border-color:#10b98180}.option-letter{font-weight:700;color:var(--primary-color);min-width:26px}.question-meta{margin-top:18px;border-top:1px solid var(--border-light);padding-top:14px;display:flex;flex-direction:column;gap:10px}.correct-answer{color:var(--success-color);font-weight:600}.explanation{background:#e0f2fe;border-radius:10px;padding:12px;color:#0f172a;line-height:1.6}.explanation strong{color:#0f172a}.question-tags{display:flex;flex-wrap:wrap;gap:10px}.btn-secondary{padding:8px 14px;border-radius:10px;border:1px solid rgba(59,130,246,.3);background:#3b82f61f;color:var(--primary-color);font-weight:600;cursor:pointer;transition:background-color var(--transition),border-color var(--transition)}.btn-secondary:hover:not(:disabled){background:#3b82f633;border-color:#3b82f680}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-link{border:none;background:transparent;color:var(--primary-color);cursor:pointer;font-weight:600}.btn-link:disabled{opacity:.6;cursor:not-allowed}.btn-danger{padding:8px 14px;border-radius:10px;border:1px solid rgba(239,68,68,.4);background:#ef44441f;color:#b91c1c;font-weight:600;cursor:pointer;transition:background-color var(--transition),border-color var(--transition)}.btn-danger:hover:not(:disabled){background:#ef444433;border-color:#ef444499}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.tag{padding:6px 12px;background:#94a3b826;border-radius:999px;font-size:12px;color:var(--text-secondary)}.warning-banner{padding:16px 20px;background:#fff7ed;border:1px solid #f97316;border-radius:12px;color:#4a1d09;font-size:14px}.warning-banner code{background:#00000014;padding:2px 6px;border-radius:6px}@media(max-width:768px){.question-generator-page{gap:20px}.upload-dropzone{padding:32px 16px}.file-summary{flex-direction:column;align-items:flex-start}.btn-save-questions{width:100%;text-align:center}.result-header{flex-direction:column;align-items:flex-start}}.materials-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);min-height:100vh;box-sizing:border-box}.management-title p{margin:6px 0 0;color:#64748b;font-size:15px}.management-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:15px;justify-content:space-between;background:#fff;border-radius:18px;padding:18px 22px;border:1px solid rgba(102,126,234,.18);box-shadow:0 6px 18px #764ba22e}.search-field:focus-within{border-color:#667eea;background:#fff;box-shadow:0 6px 20px #667eea40}.primary-btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;padding:12px 20px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 8px 18px #764ba247;transition:transform .2s ease,box-shadow .2s ease;white-space:nowrap}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 14px 28px #764ba257}.materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.material-card{background:#fff;border-radius:15px;padding:30px;box-shadow:0 2px 10px #0000000d;transition:all .3s ease}.material-card:hover{transform:translateY(-5px);box-shadow:0 5px 20px #0000001a}.material-icon{font-size:56px;text-align:center;margin-bottom:15px}.material-card h3{font-size:20px;color:#2c3e50;margin-bottom:20px;text-align:center}.material-info{margin-bottom:20px}.material-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:15px;justify-content:center}.material-actions{display:flex;gap:10px;justify-content:center}.material-actions button{width:40px;height:40px;border-radius:12px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.material-actions .btn-questions{width:auto;padding:10px 16px;border-radius:16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:15px;font-weight:600;gap:8px}.material-actions .btn-questions:hover{transform:translateY(-2px);box-shadow:0 8px 18px #10b98159}.material-actions .btn-edit{background:#667eea2e;color:#4c51bf}.material-actions .btn-edit:hover{background:#667eea47;transform:translateY(-2px);box-shadow:0 8px 16px #667eea52}.material-actions .btn-delete{background:#f565652e;color:#c53030}.material-actions .btn-delete:hover{background:#f5656547;transform:translateY(-2px);box-shadow:0 8px 16px #e53e3e52}.btn-questions{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:18px;transition:all .3s}.btn-questions:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.confirm-dialog{background:#fff;padding:28px;border-radius:16px;box-shadow:0 18px 40px #00000029;max-width:420px;width:90%;text-align:center}.confirm-dialog p{color:#4a5568;font-size:15px;line-height:1.6;margin-bottom:22px}.confirm-actions .btn-cancel,.confirm-actions .btn-delete{flex:1;padding:12px 16px;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.confirm-actions .btn-delete:hover{transform:translateY(-2px);box-shadow:0 10px 20px #e53e3e80}@media(max-width:1024px){.materials-page{padding:clamp(14px,4vw,22px)}.materials-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}.material-card{padding:26px}.material-card h3{font-size:19px}}@media(max-width:768px){.management-toolbar{flex-direction:column;align-items:stretch}.primary-btn{width:100%;justify-content:center}.materials-grid{grid-template-columns:1fr}.hierarchy-path{font-size:11px;padding:8px}.hierarchy-item{padding:4px 8px;font-size:11px}}@media(max-width:560px){.material-card{padding:20px}.material-info-item{flex-direction:column;align-items:flex-start;gap:6px}.material-actions{flex-direction:column;gap:12px}}.units-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);min-height:100vh;box-sizing:border-box}.management-title p{margin:5px 0 0;color:#64748b;font-size:15px}.management-toolbar{display:flex;flex-wrap:wrap;gap:15px;align-items:center;justify-content:space-between;background:#fff;border-radius:18px;padding:18px 22px;border:1px solid rgba(102,126,234,.22);box-shadow:0 6px 18px #667eea26}.search-field{flex:1;min-width:240px;display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:14px;background:#f7fafc;border:2px solid transparent;transition:all .2s ease}.search-field:focus-within{border-color:#667eea;background:#fff;box-shadow:0 6px 18px #667eea40}.clear-search{border:none;background:#667eea29;color:#4c51bf;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background .2s ease}.clear-search:hover{transform:rotate(90deg);background:#667eea47}.primary-btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;padding:12px 20px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 8px 18px #667eea4d;transition:transform .2s ease,box-shadow .2s ease;white-space:nowrap}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 14px 26px #667eea59}.btn-icon{font-size:18px}.results-meta{margin-bottom:18px;color:#475569;font-size:14px;font-weight:600}.units-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.unit-card{background:#fff;border-radius:15px;padding:30px;box-shadow:0 2px 10px #0000000d;transition:all .3s ease}.unit-card:hover{transform:translateY(-5px);box-shadow:0 5px 20px #0000001a}.unit-icon{font-size:56px;text-align:center;margin-bottom:15px}.unit-card h3{font-size:20px;color:#2c3e50;margin-bottom:20px;text-align:center}.unit-info{margin-bottom:20px}.hierarchy-path{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;margin-bottom:15px;padding:12px;background:#f8f9fa;border-radius:8px;font-size:13px}.hierarchy-item{padding:6px 12px;background:#fff;border-radius:6px;color:#495057;font-weight:500;box-shadow:0 1px 3px #0000001a}.hierarchy-current{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600}.hierarchy-arrow{color:#adb5bd;font-weight:700;font-size:16px}.unit-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:15px;justify-content:center}.semester-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:600}.semester-1{background:#d4edda;color:#155724}.semester-2{background:#cce5ff;color:#004085}.badge-mcq{background:#f8d7da;color:#721c24}.unit-actions{display:flex;gap:10px;justify-content:center}.unit-actions button{width:40px;height:40px;border-radius:12px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.unit-actions .btn-edit{background:#667eea2e;color:#4c51bf}.unit-actions .btn-edit:hover{background:#667eea47;transform:translateY(-2px);box-shadow:0 8px 16px #667eea47}.unit-actions .btn-delete{background:#f565652e;color:#c53030}.unit-actions .btn-delete:hover{background:#f5656547;transform:translateY(-2px);box-shadow:0 8px 16px #e53e3e47}.modal-large{max-width:900px!important;max-height:90vh;overflow-y:auto}.modal-body{padding:0}.confirm-dialog{background:#fff;padding:28px;border-radius:16px;max-width:420px;width:90%;box-shadow:0 18px 40px #0000002e;text-align:center}.confirm-dialog h3{margin-bottom:12px;font-size:22px;color:#1f2937}.confirm-dialog p{margin-bottom:24px;color:#4a5568;font-size:15px;line-height:1.6}.confirm-actions .btn-cancel,.confirm-actions .btn-delete{flex:1;padding:12px 16px;border-radius:12px;border:none;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.confirm-actions .btn-cancel:hover{transform:translateY(-2px);box-shadow:0 8px 16px #cbd5e099}.confirm-actions .btn-delete:hover{transform:translateY(-2px);box-shadow:0 10px 18px #e53e3e80}@media(max-width:1024px){.units-page{padding:clamp(14px,4vw,22px)}.units-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}.unit-card{padding:26px}.unit-card h3{font-size:19px}}@media(max-width:768px){.management-toolbar{flex-direction:column;align-items:stretch}.primary-btn{width:100%;justify-content:center}.units-grid{grid-template-columns:1fr}.hierarchy-path{font-size:11px;padding:8px}.hierarchy-item{padding:4px 8px;font-size:11px}}@media(max-width:560px){.unit-card{padding:20px}.unit-info-item{flex-direction:column;align-items:flex-start;gap:6px}.unit-actions{flex-direction:column;gap:12px}}.subjects-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);min-height:100vh;box-sizing:border-box}.management-title h1{font-size:32px;color:#2c3e50;margin:0}.management-title p{margin:4px 0 0;color:#7f8c8d;font-size:15px}.management-toolbar{display:flex;gap:15px;flex-wrap:wrap;align-items:center;justify-content:space-between;background:#fff;border-radius:16px;padding:16px 20px;box-shadow:0 4px 12px #667eea1f;border:1px solid rgba(102,126,234,.2)}.search-field{flex:1;min-width:240px;display:flex;align-items:center;gap:10px;background:#f7fafc;border:2px solid transparent;border-radius:12px;padding:10px 14px;transition:all .2s ease}.search-field:focus-within{border-color:#667eea;background:#fff;box-shadow:0 6px 16px #667eea26}.search-icon{font-size:18px;color:#667eea}.clear-search{border:none;background:#667eea1a;color:#667eea;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s ease,transform .2s ease}.clear-search:hover{background:#667eea33;transform:rotate(90deg)}.primary-btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;padding:12px 20px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 6px 16px #667eea47;transition:transform .2s ease,box-shadow .2s ease;white-space:nowrap}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px #667eea59}.btn-icon{font-size:18px;line-height:1}.results-meta{margin-bottom:20px;color:#6c757d;font-size:14px;font-weight:500}.feedback-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-radius:12px;margin-bottom:20px;font-size:14px;font-weight:600}.feedback-banner button{background:transparent;border:none;color:inherit;font-size:20px;cursor:pointer;line-height:1}.subjects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.subject-card{background:#fff;border-radius:15px;padding:30px;box-shadow:0 2px 10px #0000000d;transition:all .3s ease}.subject-card:hover{transform:translateY(-5px);box-shadow:0 5px 20px #0000001a}.subject-icon{font-size:56px;text-align:center;margin-bottom:15px}.subject-card h3{font-size:20px;color:#2c3e50;margin-bottom:20px;text-align:center}.subject-info{margin-bottom:20px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f0f0f0}.info-label{font-weight:600;color:#6c757d;font-size:14px}.info-value{color:#2c3e50;font-weight:500;font-size:14px}.subject-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:15px;justify-content:center}.badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600}.badge-free{background:#d4edda;color:#155724}.badge-material-free{background:#cfe2ff;color:#084298}.badge-insta-free{background:#f8d7da;color:#721c24}.badge-voice{background:#d1ecf1;color:#0c5460}.badge-mcq{background:#fff3cd;color:#856404}.subject-actions{display:flex;gap:10px;justify-content:center}.subject-actions button{width:40px;height:40px;border-radius:12px;border:none;background:#f3f4ff;color:#4c51bf;font-size:18px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;display:flex;align-items:center;justify-content:center}.subject-actions .btn-edit{background:#667eea1f;color:#4c51bf}.subject-actions .btn-edit:hover{background:#667eea33;transform:translateY(-2px);box-shadow:0 8px 16px #667eea33}.subject-actions .btn-delete{background:#f565651f;color:#c53030}.subject-actions .btn-delete:hover{background:#f5656533;transform:translateY(-2px);box-shadow:0 8px 16px #e53e3e33}.checkbox-group{display:flex;align-items:center}.checkbox-group label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:400!important}.checkbox-group input[type=checkbox]{width:auto;cursor:pointer;transform:scale(1.2)}.warning-box{background:#fff3cd;border:2px solid #ffc107;border-radius:8px;padding:15px;margin-bottom:20px;color:#856404;text-align:center}.warning-box strong{display:block;margin-bottom:8px;font-size:16px}.warning-box small{display:block;margin-top:8px;font-size:13px;color:#856404;opacity:.9}.confirm-actions .btn-delete{background:linear-gradient(135deg,#fc8181,#e53e3e);color:#fff}.confirm-actions .btn-delete:hover{transform:translateY(-2px);box-shadow:0 8px 16px #e53e3e99}@media(max-width:1024px){.subjects-page{padding:clamp(14px,4vw,22px)}.subjects-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}.subject-card{padding:26px}.subject-card h3{font-size:19px}}@media(max-width:768px){.management-toolbar{flex-direction:column;align-items:stretch}.primary-btn{width:100%;justify-content:center}.subjects-grid{grid-template-columns:1fr}}@media(max-width:560px){.subject-card{padding:20px}.info-item{flex-direction:column;align-items:flex-start;gap:6px}.subject-actions{flex-direction:column;gap:12px}}.users-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;box-sizing:border-box}.management-title h1{font-size:34px;color:#2c3e50;margin:0}.management-title p{margin:5px 0 0;color:#4a5568;font-size:16px;font-weight:500}.management-toolbar{display:flex;flex-wrap:wrap;gap:15px;align-items:center;justify-content:space-between;background:#ffffffe6;border-radius:18px;padding:18px 24px;box-shadow:0 10px 30px #667eea2e;border:1px solid rgba(118,75,162,.15);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.search-field{flex:1;min-width:260px;display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:14px;border:2px solid transparent;background:#f7fafc;transition:all .2s ease}.search-field:focus-within{border-color:#667eea;background:#fff;box-shadow:0 10px 22px #667eea40}.search-field input{flex:1;border:none;background:transparent;font-size:15px;color:#2c3e50;outline:none}.search-icon{color:#667eea;font-size:18px}.clear-search{border:none;background:#667eea2e;color:#4c51bf;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background .2s ease}.clear-search:hover{transform:rotate(90deg);background:#667eea4d}.primary-btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:14px;padding:14px 24px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 12px 28px #764ba259;transition:transform .2s ease,box-shadow .2s ease;white-space:nowrap}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 18px 38px #764ba266}.users-table-container{background:#fff;border-radius:18px;box-shadow:0 10px 30px #0f172a14;overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.users-table th{padding:18px 20px;text-align:right;font-weight:600;font-size:14px;letter-spacing:.3px}.users-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .3s ease}.users-table tbody tr:hover{background-color:#f7fafc}.users-table td{padding:16px 20px;color:#2c3e50;font-size:14px}.user-name{display:flex;align-items:center;gap:12px;font-weight:500}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}.action-buttons button{border:none;width:40px;height:40px;border-radius:12px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,box-shadow .2s ease}.btn-edit{background:#667eea26;color:#4c51bf}.btn-edit:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea40}.btn-delete:hover{transform:translateY(-2px);box-shadow:0 8px 20px #ef444440}.modal-large{max-width:720px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.confirm-dialog h3{margin-bottom:12px;color:#2c3e50;font-size:22px}.confirm-dialog p{color:#4a5568;line-height:1.6;margin-bottom:24px;font-size:15px}.confirm-actions .btn-cancel{background:#edf2f7;color:#4a5568}@media(max-width:768px){.users-table-container{overflow-x:auto}.users-table{min-width:900px}.form-row{grid-template-columns:1fr}}@media(max-width:560px){.users-page{padding:clamp(14px,5vw,20px)}.management-title h1{font-size:26px}.management-title p{font-size:14px}.users-table{min-width:760px}}.codes-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);background:linear-gradient(135deg,#eef2ff,#e0e7ff,#f8fafc);min-height:100vh;box-sizing:border-box}.codes-table-container{background:#fff;border-radius:18px;box-shadow:0 18px 40px #0f172a14;overflow:hidden}.codes-table{width:100%;border-collapse:collapse}.codes-table thead{background:linear-gradient(135deg,#4c51bf,#6366f1,#8b5cf6);color:#fff}.codes-table th{padding:18px 20px;text-align:right;font-weight:600;font-size:14px;letter-spacing:.3px}.codes-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .3s ease}.codes-table tbody tr:hover{background-color:#f5f5ff}.codes-table tbody tr.is-deleted{opacity:.6;background:linear-gradient(90deg,#f8717114,#fff0)}.codes-table td{padding:16px 20px;color:#1f2937;font-size:14px}.code-id{font-family:Fira Code,Cairo,monospace;font-size:13px;color:#4b5563}.confirm-dialog{background:#fff;padding:30px;border-radius:16px;box-shadow:0 12px 32px #00000026;max-width:420px;width:90%;text-align:center}.confirm-dialog h3{margin-bottom:12px;color:#1f2937;font-size:22px}.confirm-dialog p{color:#4b5563;line-height:1.6;margin-bottom:24px;font-size:15px}.confirm-actions{display:flex;gap:12px;justify-content:center}.confirm-actions .btn-cancel,.confirm-actions .btn-delete{flex:1;padding:12px 16px;border-radius:10px;font-weight:600;cursor:pointer;border:none;transition:transform .2s ease,box-shadow .2s ease}.confirm-actions .btn-cancel{background:#e2e8f0;color:#475569}.confirm-actions .btn-cancel:hover{transform:translateY(-2px);box-shadow:0 8px 16px #cbd5e080}.confirm-actions .btn-delete{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.confirm-actions .btn-delete:hover{transform:translateY(-2px);box-shadow:0 10px 22px #dc262666}@media(max-width:768px){.codes-table-container{overflow-x:auto}.codes-table{min-width:960px}}@media(max-width:560px){.codes-page{padding:clamp(14px,5vw,20px)}.management-title h1{font-size:28px}.management-title p{font-size:14px}.codes-table{min-width:760px}}.code-subjects-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);background:linear-gradient(135deg,#f5f7ff,#ede9fe,#f8fafc);min-height:100vh;box-sizing:border-box}.code-subjects-table-container{background:#fff;border-radius:18px;box-shadow:0 18px 40px #0f172a14;overflow:hidden}.code-subjects-table{width:100%;border-collapse:collapse}.code-subjects-table thead{background:linear-gradient(135deg,#4338ca,#6366f1,#8b5cf6);color:#fff}.code-subjects-table th{padding:18px 20px;text-align:right;font-weight:600;font-size:14px;letter-spacing:.3px}.code-subjects-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .3s ease}.code-subjects-table tbody tr:hover{background-color:#f5f5ff}.code-subjects-table tbody tr.is-deleted{opacity:.6;background:linear-gradient(90deg,#f8717114,#fff0)}.code-subjects-table td{padding:16px 20px;color:#1f2937;font-size:14px}.code-value{font-weight:700;font-size:16px;color:#4338ca}.status-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;font-weight:600;font-size:13px;border:1px solid transparent}.status-chip.is-active{background:#10b9811f;color:#047857;border-color:#10b98166}.status-chip.is-inactive{background:#f871711f;color:#b91c1c;border-color:#f8717166}.no-data{background:#ffffffe6;border-radius:18px;padding:60px 30px;text-align:center;box-shadow:0 12px 26px #6366f11f}@media(max-width:768px){.code-subjects-table-container{overflow-x:auto}.code-subjects-table{min-width:960px}}@media(max-width:560px){.code-subjects-page{padding:clamp(14px,5vw,20px)}.management-title h1{font-size:28px}.management-title p{font-size:14px}.code-subjects-table{min-width:780px}}.payment-cards-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);background:linear-gradient(135deg,#eef2ff,#e0e7ff,#f8fafc);min-height:100vh;box-sizing:border-box}.primary-btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:14px;padding:14px 24px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 18px 40px #6366f159;transition:transform .2s ease,box-shadow .2s ease;white-space:nowrap}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 22px 46px #6366f16b}.btn-icon{font-size:20px;line-height:1}.payment-cards-table-container{background:#fff;border-radius:18px;box-shadow:0 18px 40px #0f172a14;overflow:hidden}.payment-cards-table{width:100%;border-collapse:collapse}.payment-cards-table thead{background:linear-gradient(135deg,#4338ca,#6366f1,#8b5cf6);color:#fff}.payment-cards-table th{padding:18px 20px;text-align:right;font-weight:600;font-size:14px;letter-spacing:.3px}.payment-cards-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .3s ease}.payment-cards-table tbody tr:hover{background-color:#f5f5ff}.payment-cards-table tbody tr.is-deleted{opacity:.6;background:linear-gradient(90deg,#f8717114,#fff0)}.payment-cards-table td{padding:16px 20px;color:#1f2937;font-size:14px}.card-id{font-family:Fira Code,Cairo,monospace;font-size:13px;color:#4b5563}.action-buttons button{border:none;width:40px;height:40px;border-radius:12px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease}.btn-edit{background:#6366f126;color:#4338ca}.btn-edit:hover{transform:translateY(-2px);box-shadow:0 8px 20px #6366f140}.btn-delete{background:#ef444426;color:#b91c1c}.btn-delete:hover:not([disabled]){transform:translateY(-2px);box-shadow:0 8px 20px #ef444440}.btn-delete[disabled]{opacity:.4;cursor:not-allowed}.field-hint{display:block;margin-top:6px;color:#6b7280;font-size:12px}.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;background:#f1f5f9;border-radius:12px;padding:14px 18px;margin-bottom:16px;border:1px solid rgba(148,163,184,.4)}.meta-label{display:block;color:#475569;font-size:13px;font-weight:600;margin-bottom:4px}.meta-value{color:#1f2937;font-size:14px;font-weight:600}@media(max-width:992px){.management-title h1{font-size:30px}.management-toolbar{flex-direction:column;align-items:stretch}.primary-btn{width:100%;justify-content:center}}@media(max-width:768px){.payment-cards-table-container{overflow-x:auto}.payment-cards-table{min-width:820px}}@media(max-width:560px){.payment-cards-page{padding:clamp(14px,5vw,20px)}.management-title h1{font-size:28px}.management-title p{font-size:14px}.payment-cards-table{min-width:720px}}.user-payments-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);background:linear-gradient(135deg,#eef2ff,#e0e7ff,#f8fafc);min-height:100vh;box-sizing:border-box}.management-toolbar{display:flex;flex-wrap:wrap;gap:15px;align-items:center;justify-content:space-between;background:#ffffffeb;border-radius:18px;padding:18px 24px;box-shadow:0 15px 35px #4f46e52e;border:1px solid rgba(79,70,229,.16);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-payments-table-container{background:#fff;border-radius:18px;box-shadow:0 18px 40px #0f172a14;overflow:hidden}.user-payments-table{width:100%;border-collapse:collapse}.user-payments-table thead{background:linear-gradient(135deg,#4c51bf,#6366f1,#8b5cf6);color:#fff}.user-payments-table th{padding:18px 20px;text-align:right;font-weight:600;font-size:14px;letter-spacing:.3px}.user-payments-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .3s ease}.user-payments-table tbody tr:hover{background-color:#f5f5ff}.user-payments-table tbody tr.is-deleted{opacity:.6;background:linear-gradient(90deg,#f8717114,#fff0)}.user-payments-table td{padding:16px 20px;color:#1f2937;font-size:14px}.payment-id{font-family:Fira Code,Cairo,monospace;font-size:13px;color:#4b5563}.status-chip{display:inline-flex;align-items:center;justify-content:center;min-width:120px;padding:6px 10px;border-radius:999px;font-size:13px;font-weight:700}.status-chip.is-active{background:#3b82f62e;color:#1d4ed8}@media(max-width:992px){.management-title h1{font-size:30px}.management-toolbar{flex-direction:column;align-items:stretch}}@media(max-width:768px){.user-payments-table-container{overflow-x:auto}.user-payments-table{min-width:1100px}}@media(max-width:560px){.user-payments-page{padding:clamp(14px,5vw,20px)}.management-title h1{font-size:28px}.management-title p{font-size:14px}.user-payments-table{min-width:780px}}.quiz-types-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);background:linear-gradient(135deg,#f5f7ff,#ede9fe,#f8fafc);min-height:100vh;box-sizing:border-box}.management-toolbar{display:flex;flex-wrap:wrap;gap:15px;align-items:center;justify-content:space-between;background:#ffffffeb;border-radius:18px;padding:18px 24px;box-shadow:0 15px 35px #6366f12e;border:1px solid rgba(99,102,241,.16);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.search-field:focus-within{border-color:#6366f1;background:#fff;box-shadow:0 12px 28px #6366f140}.search-icon{color:#6366f1;font-size:18px}.clear-search{border:none;background:#6366f12e;color:#4338ca;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background .2s ease}.clear-search:hover{transform:rotate(90deg);background:#6366f14d}.quiz-types-table-container{background:#fff;border-radius:18px;box-shadow:0 18px 40px #0f172a14;overflow:hidden}.quiz-types-table{width:100%;border-collapse:collapse}.quiz-types-table thead{background:linear-gradient(135deg,#4338ca,#6366f1,#8b5cf6);color:#fff}.quiz-types-table th{padding:18px 20px;text-align:right;font-weight:600;font-size:14px;letter-spacing:.3px}.quiz-types-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .3s ease}.quiz-types-table tbody tr:hover{background-color:#f5f5ff}.quiz-types-table tbody tr.is-deleted{opacity:.6;background:linear-gradient(90deg,#f8717114,#fff0)}.quiz-types-table td{padding:16px 20px;color:#1f2937;font-size:14px}.quiz-type-id{font-family:Fira Code,Cairo,monospace;font-size:13px;color:#4b5563}.no-data{background:#ffffffe6;border-radius:18px;padding:60px 30px;text-align:center;box-shadow:0 12px 26px #4f46e51f}@media(max-width:992px){.management-title h1{font-size:30px}.management-toolbar{flex-direction:column;align-items:stretch}.quiz-types-table{min-width:880px}}@media(max-width:768px){.quiz-types-table-container{overflow-x:auto}}@media(max-width:560px){.quiz-types-page{padding:clamp(14px,5vw,20px)}.management-title h1{font-size:28px}.management-title p{font-size:14px}.quiz-types-table{min-width:720px}}.code-attempts-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);background:linear-gradient(135deg,#f5f7ff,#e0f2ff,#f8fafc);min-height:100vh;box-sizing:border-box}.management-header{display:flex;flex-direction:column;gap:20px;margin-bottom:25px}.management-title h1{font-size:34px;color:#1f2937;margin:0}.management-title p{margin:5px 0 0;color:#4b5563;font-size:16px;font-weight:500}.management-toolbar{display:flex;flex-wrap:wrap;gap:15px;align-items:center;justify-content:space-between;background:#ffffffeb;border-radius:18px;padding:18px 24px;box-shadow:0 15px 35px #0e74902e;border:1px solid rgba(14,116,144,.16);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.search-field{flex:1;min-width:260px;display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:14px;border:2px solid transparent;background:#f8fafc;transition:all .2s ease}.search-field:focus-within{border-color:#0ea5e9;background:#fff;box-shadow:0 12px 28px #0ea5e940}.search-field input{flex:1;border:none;background:transparent;font-size:15px;color:#1f2937;outline:none}.search-icon{color:#0ea5e9;font-size:18px}.clear-search{border:none;background:#0ea5e92e;color:#0369a1;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background .2s ease}.clear-search:hover{transform:rotate(90deg);background:#0ea5e94d}.results-meta{margin-bottom:18px;color:#475569;font-size:15px;font-weight:600}.feedback-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 22px;border-radius:14px;margin-bottom:24px;font-size:15px;font-weight:600}.feedback-banner button{background:transparent;border:none;color:inherit;font-size:22px;cursor:pointer;line-height:1}.feedback-banner.is-success{background:#ecfdf5;border:1px solid #34d399;color:#047857}.feedback-banner.is-error{background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c}.code-attempts-table-container{background:#fff;border-radius:18px;box-shadow:0 18px 40px #0f172a14;overflow:hidden}.code-attempts-table{width:100%;border-collapse:collapse}.code-attempts-table thead{background:linear-gradient(135deg,#0ea5e9,#0284c7,#0f172a);color:#fff}.code-attempts-table th{padding:18px 20px;text-align:right;font-weight:600;font-size:14px;letter-spacing:.3px}.code-attempts-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .3s ease}.code-attempts-table tbody tr:hover{background-color:#e0f2ff}.code-attempts-table tbody tr.is-deleted{opacity:.6;background:linear-gradient(90deg,#f8717114,#fff0)}.code-attempts-table td{padding:16px 20px;color:#1f2937;font-size:14px}.attempt-id{font-family:Fira Code,Cairo,monospace;font-size:13px;color:#4b5563}.status-chip{display:inline-flex;align-items:center;justify-content:center;min-width:90px;padding:6px 10px;border-radius:999px;font-size:13px;font-weight:700}.status-chip.is-active{background:#10b9812e;color:#047857}.status-chip.is-inactive{background:#ef44442e;color:#b91c1c}.no-data{background:#ffffffe6;border-radius:18px;padding:60px 30px;text-align:center;box-shadow:0 12px 26px #0e74901f}.no-data-icon{font-size:48px;margin-bottom:16px}.no-data h3{margin-bottom:8px;color:#1f2937}.no-data p{color:#4b5563}@media(max-width:992px){.management-title h1{font-size:30px}.management-toolbar{flex-direction:column;align-items:stretch}.code-attempts-table{min-width:880px}}@media(max-width:768px){.code-attempts-table-container{overflow-x:auto}}@media(max-width:560px){.code-attempts-page{padding:clamp(14px,5vw,20px)}.management-title h1{font-size:28px}.management-title p{font-size:14px}.code-attempts-table{min-width:720px}}.quizzes-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);min-height:100vh;box-sizing:border-box}.toolbar-filters{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.toolbar-select{min-width:160px;padding:10px 14px;border-radius:12px;border:1px solid var(--border-color);background:#fff;font-size:14px;transition:border-color var(--transition),box-shadow var(--transition)}.toolbar-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea26}.primary-btn{padding:10px 18px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:var(--white);font-weight:600;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),opacity var(--transition)}.primary-btn:hover{transform:translateY(-1px);box-shadow:0 12px 25px #667eea40}.secondary-btn{padding:10px 16px;border-radius:12px;border:1px solid var(--border-color);background:#fff;font-weight:600;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),opacity var(--transition)}.secondary-btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px #94a3b833}.quizzes-table-container{background:var(--white);border-radius:16px;border:1px solid rgba(102,126,234,.12);box-shadow:0 10px 30px #667eea14;overflow:hidden}.quizzes-table{width:100%;border-collapse:collapse}.quizzes-table thead{background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:var(--white)}.quizzes-table th{padding:16px 18px;text-align:right;font-size:14px;font-weight:600}.quizzes-table td{padding:16px 18px;border-bottom:1px solid var(--border-light);color:var(--text-dark);font-size:14px}.action-buttons{display:flex;gap:8px}.action-buttons button{border:none;background:transparent;font-size:18px;cursor:pointer;transition:transform var(--transition),opacity var(--transition)}.action-buttons button:hover{transform:scale(1.1);opacity:.85}.quiz-form .form-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px}.quiz-form .form-group{flex:1;min-width:220px;display:flex;flex-direction:column;gap:6px}.quiz-form .form-group input,.quiz-form .form-group select,.quiz-form .form-group textarea{padding:12px 14px;border-radius:12px;border:1px solid var(--border-color);background:#fff;font-size:14px;transition:border-color var(--transition),box-shadow var(--transition)}.quiz-form .form-group textarea{resize:vertical}.quiz-form .form-group input:focus,.quiz-form .form-group select:focus,.quiz-form .form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea26}.field-error{color:var(--error-color);font-size:12px}.form-section{margin-bottom:20px;display:flex;flex-direction:column;gap:12px}.section-header{display:flex;align-items:center;justify-content:space-between}.answer-row{display:flex;flex-wrap:wrap;gap:16px;padding:12px;border-radius:12px;background:#667eea0d}.answer-actions{display:flex;align-items:center;gap:12px}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:14px}.icon-btn{border:none;background:transparent;font-size:18px;cursor:pointer;transition:transform var(--transition),opacity var(--transition)}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn:hover:not(:disabled){transform:scale(1.1);opacity:.8}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.quiz-details{display:flex;flex-direction:column;gap:20px}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.details-label{display:block;font-weight:600;color:var(--text-secondary)}.details-value{display:block;color:var(--text-dark)}.question-block,.answers-block{background:#667eea0d;border-radius:12px;padding:16px}.answers-block ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.answers-block li{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:10px;background:#94a3b826;color:var(--text-dark)}.answer-flag{font-weight:600;color:var(--success-color)}@media(max-width:768px){.toolbar-filters{width:100%}.quiz-form .form-row,.answer-row,.modal-actions{flex-direction:column}}.user-quiz-attempts-page{max-width:var(--app-max-width);margin:0 auto;padding:clamp(16px,3vw,24px);min-height:100vh;box-sizing:border-box}.user-quiz-attempts-table-container{background:var(--white);border-radius:16px;border:1px solid rgba(102,126,234,.12);box-shadow:0 10px 30px #667eea14;overflow:hidden}.user-quiz-attempts-table{width:100%;border-collapse:collapse}.user-quiz-attempts-table thead{background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:var(--white)}.user-quiz-attempts-table th,.user-quiz-attempts-table td{padding:16px 18px;text-align:right;font-size:14px;border-bottom:1px solid var(--border-light)}.user-quiz-attempts-table tbody tr:hover{background:#667eea14}.user-quiz-attempts-table .attempt-id{font-family:Courier New,Courier,monospace;font-size:13px;direction:ltr}.user-quiz-attempts-table .btn-view{border:none;background:transparent;font-size:18px;cursor:pointer;transition:transform var(--transition),opacity var(--transition)}.user-quiz-attempts-table .btn-view:hover{transform:scale(1.1);opacity:.85}.user-quiz-attempt-details{display:flex;flex-direction:column;gap:20px}.user-quiz-attempt-details .details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.user-quiz-attempt-details .details-label{font-weight:600;color:var(--text-secondary)}.user-quiz-attempt-details .details-value{color:var(--text-dark)}.answers-block{background:#667eea0d;border-radius:12px;padding:16px}.answers-block ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.answers-block li{background:#94a3b826;border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:8px}.answers-block li.is-correct{background:#10b9812e;border:1px solid rgba(16,185,129,.45)}.answers-block .answer-meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--text-secondary);font-size:13px}@media(max-width:768px){.answers-block li{font-size:14px}.answers-block .answer-meta{flex-direction:column}}.notifications-page{padding:24px;max-width:1200px;margin:0 auto}.notifications-page .form-group{margin-bottom:20px}.notifications-page .form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-color)}.notifications-page .form-group input,.notifications-page .form-group textarea,.notifications-page .form-group select{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius);font-size:14px;transition:border-color var(--transition-fast);font-family:inherit}.notifications-page .form-group input:focus,.notifications-page .form-group textarea:focus,.notifications-page .form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.notifications-page .form-group textarea{resize:vertical;min-height:100px}.notifications-page .warning-box{background-color:var(--warning-light);border:1px solid var(--warning-color);border-radius:var(--radius);padding:12px 16px;margin-bottom:20px;color:var(--text-color)}.notifications-page .modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-light)}.notifications-page .btn-primary{background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:#fff;border:none;padding:12px 24px;border-radius:var(--radius);font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow)}.notifications-page .btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.notifications-page .btn-primary:disabled{opacity:.6;cursor:not-allowed}:root{--app-max-width: 1440px;--sidebar-width: 250px;--sidebar-width-md: 220px;--page-padding: clamp(16px, 2.5vw, 32px);--gap-xs: 8px;--gap-sm: 12px;--gap-md: 16px;--gap-lg: 24px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--transition-base: .2s ease}#root,body{min-height:100vh;width:100%}body{margin:0;font-family:Cairo,sans-serif;background:#f5f6fa}.app-container{min-height:100vh;display:flex;width:100%}.content-wrapper{flex:1;padding:var(--page-padding);width:min(100%,var(--app-max-width));margin:0 auto;box-sizing:border-box}.card{background:#fff;border-radius:var(--radius-md);padding:clamp(16px,2vw,24px);box-shadow:0 2px 10px #0000000d;transition:transform .3s ease,box-shadow .3s ease}.card:hover{transform:translateY(-2px);box-shadow:0 5px 20px #0000001a}.btn{padding:12px 24px;border-radius:var(--radius-sm);font-weight:600;font-size:14px;cursor:pointer;transition:all .3s ease;border:none;outline:none}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-secondary{background:#e2e8f0;color:#2c3e50}.btn-secondary:hover{background:#cbd5e0}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}@media(max-width:1280px){:root{--sidebar-width: 230px}}@media(max-width:1024px){body{background:#eef2ff}.content-wrapper{padding:clamp(14px,3vw,24px)}}@media(max-width:768px){:root{--page-padding: clamp(12px, 4vw, 20px)}.card{padding:clamp(14px,4vw,20px)}.btn{padding:10px 18px;font-size:13px}}@media(max-width:480px){.btn{width:100%}}.management-header{max-width:var(--app-max-width);margin:0 auto 24px}.management-toolbar{gap:var(--gap-md)}div[class*=table-container]{overflow-x:auto;border-radius:var(--radius-lg)}div[class*=table-container] table{width:100%}@media(max-width:1024px){.management-header{gap:16px}.management-title h1{font-size:clamp(26px,5vw,30px)}.management-toolbar{flex-direction:column;align-items:stretch}.management-toolbar .primary-btn{width:100%;justify-content:center}.search-field{min-width:100%}div[class*=table-container] table{min-width:720px}}@media(max-width:768px){.management-title{text-align:center}.management-toolbar{gap:var(--gap-sm)}div[class*=table-container]{margin-bottom:16px}}@media(max-width:560px){.search-field{padding:10px 12px}.management-title h1{font-size:clamp(22px,6vw,26px)}.management-title p{font-size:14px}}
