*{box-sizing:border-box}:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--accent-500: #8b5cf6;--accent-600: #7c3aed;--accent-700: #6d28d9;--success-50: #f0fdf4;--success-500: #22c55e;--success-600: #16a34a;--success-700: #15803d;--warning-50: #fffbeb;--warning-500: #f59e0b;--warning-600: #d97706;--error-50: #fef2f2;--error-500: #ef4444;--error-600: #dc2626;--error-700: #b91c1c;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--background: #f8fafc;--surface: #ffffff;--text-primary: #0f172a;--text-secondary: #64748b;--text-tertiary: #94a3b8;--border-light: #e2e8f0;--border-medium: #cbd5e1;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 280px;--sidebar-collapsed-width: 70px}body{margin:0;padding:0;font-size:15px;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-primary);background:var(--background)}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-600) 100%);padding:20px}.login-card{background:var(--surface);padding:48px;border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);max-width:480px;width:100%;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-card h1{margin:0 0 12px;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-600) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;font-size:32px;font-weight:800;letter-spacing:-.5px}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:36px;font-size:15px;font-weight:500}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-primary);font-size:14px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid var(--border-light);border-radius:var(--radius-md);font-size:15px;transition:all var(--transition-base);background-color:var(--gray-50);color:var(--text-primary);font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-500);outline:none;background-color:var(--surface);box-shadow:0 0 0 4px #3b82f61a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--gray-100);cursor:not-allowed;opacity:.6}.form-group textarea{min-height:100px;resize:vertical}.login-btn,.btn-primary,.btn-secondary,.btn-danger,.btn-small,.btn-danger-small,.btn-secondary-small,.btn-cancel-small{padding:12px 24px;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-base);font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;font-family:inherit;position:relative;overflow:hidden}.login-btn,.btn-primary{background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-600) 100%);color:#fff;box-shadow:var(--shadow-md)}.login-btn:before,.btn-primary:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--primary-700) 0%,var(--accent-700) 100%);opacity:0;transition:opacity var(--transition-base)}.login-btn:hover:not(:disabled):before,.btn-primary:hover:not(:disabled):before{opacity:1}.login-btn>*,.btn-primary>*{position:relative;z-index:1}.login-btn:hover:not(:disabled),.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.login-btn:active:not(:disabled),.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-md)}.login-btn:disabled,.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:var(--shadow-sm)}.btn-secondary,.btn-secondary-small{background:var(--gray-600);color:#fff;box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled),.btn-secondary-small:hover:not(:disabled){background:var(--gray-700);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-danger,.btn-danger-small{background:var(--error-600);color:#fff;box-shadow:var(--shadow-sm)}.btn-danger:hover:not(:disabled),.btn-danger-small:hover:not(:disabled){background:var(--error-700);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-small,.btn-danger-small,.btn-secondary-small,.btn-cancel-small{padding:8px 16px;font-size:13px}.btn-cancel-small{background:var(--gray-400);color:#fff}.btn-cancel-small:hover:not(:disabled){background:var(--gray-500);transform:translateY(-1px)}.btn-large{padding:16px 32px;font-size:16px;margin-top:24px}.login-hint{margin-top:32px;padding:20px;background:var(--gray-50);border-radius:var(--radius-lg);font-size:14px;color:var(--text-secondary);text-align:center;border-left:4px solid var(--primary-600)}.login-hint p{margin:8px 0}.login-hint code{background:var(--gray-200);padding:4px 8px;border-radius:var(--radius-sm);font-family:Monaco,Courier New,monospace;color:var(--primary-600);font-weight:600;font-size:13px}.error-box{background:var(--error-50);border:1px solid var(--error-500);color:var(--error-700);padding:12px 16px;border-radius:var(--radius-md);margin-bottom:20px;font-size:14px;border-left:4px solid var(--error-600)}.admin-dashboard{display:flex;min-height:100vh;background:var(--background);position:relative}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,#2d3748,#1a202c);color:#fff;transition:width var(--transition-slow);position:fixed;left:0;top:0;bottom:0;z-index:100;flex-shrink:0;box-shadow:var(--shadow-xl);overflow-y:auto;overflow-x:hidden}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#0003}.sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.sidebar.closed{width:var(--sidebar-collapsed-width)}.sidebar-header{padding:24px 20px;background:#0000004d;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1);min-height:80px}.sidebar-header h2{margin:0;font-size:19px;font-weight:700;white-space:nowrap;overflow:hidden;transition:opacity var(--transition-base)}.sidebar.closed .sidebar-header h2{opacity:0;width:0}.sidebar-toggle{background:#ffffff1a;border:none;color:#fff;padding:10px 14px;border-radius:var(--radius-md);cursor:pointer;font-size:20px;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;min-width:40px;flex-shrink:0}.sidebar-toggle:hover{background:#fff3;transform:scale(1.05)}.user-info{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1);background:#3b82f61a;transition:all var(--transition-base)}.sidebar.closed .user-info{padding:12px 10px;text-align:center}.user-info p{margin:6px 0;font-size:14px;transition:opacity var(--transition-base);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.closed .user-info p{opacity:0;height:0;margin:0}.user-info strong{font-size:16px;font-weight:600}.user-role{color:#93c5fd;font-size:13px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.sidebar-nav{padding:16px 0;overflow-y:auto;flex:1}.nav-item{display:flex;align-items:center;padding:14px 20px;margin:4px 12px;color:#ffffffd9;text-decoration:none;transition:all var(--transition-base);border-radius:var(--radius-lg);font-size:15px;font-weight:500;white-space:nowrap;gap:12px}.sidebar.closed .nav-item{justify-content:center;padding:14px 10px;margin:4px 8px}.sidebar.closed .nav-item span{display:none}.nav-item:hover{background:#ffffff1a;color:#fff;transform:translate(4px)}.sidebar.closed .nav-item:hover{transform:translate(0)}.nav-item.active{background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-600) 100%);color:#fff;box-shadow:var(--shadow-md)}.logout-btn{position:sticky;bottom:0;left:0;right:0;margin:16px;padding:14px 20px;background:linear-gradient(135deg,var(--error-600) 0%,var(--error-700) 100%);color:#fff;border:none;border-radius:var(--radius-lg);cursor:pointer;font-weight:600;font-size:15px;transition:all var(--transition-base);box-shadow:var(--shadow-md);white-space:nowrap}.sidebar.closed .logout-btn{padding:14px 10px;font-size:18px}.logout-btn:hover{background:linear-gradient(135deg,var(--error-700) 0%,#7f1d1d 100%);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.logout-btn:active{transform:translateY(0)}.main-content{flex:1;background:var(--background);overflow-y:auto;margin-left:var(--sidebar-width);transition:margin-left var(--transition-slow);min-height:100vh}.sidebar.closed+.main-content,.sidebar.closed~.main-content{margin-left:var(--sidebar-collapsed-width)}.page-header{padding:32px 40px;background:var(--surface);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:20px;position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2}.page-header>div{flex:1;min-width:200px}.page-header h1{margin:0 0 8px;color:var(--text-primary);font-size:32px;font-weight:800;letter-spacing:-.5px}.subtitle{color:var(--text-secondary);margin:0;font-size:15px;font-weight:500}.page-content{padding:32px 40px;max-width:100%}.dashboard-home{max-width:100%}.dashboard-home>h1{padding:32px 40px 0;margin:0;color:var(--text-primary);font-size:32px;font-weight:800}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;padding:32px 40px}.dashboard-card{background:var(--surface);padding:32px;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:2px solid transparent;transition:all var(--transition-slow);position:relative;overflow:hidden}.dashboard-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-600) 100%);transform:scaleX(0);transition:transform var(--transition-slow)}.dashboard-card:hover{border-color:var(--primary-500);transform:translateY(-6px);box-shadow:var(--shadow-xl)}.dashboard-card:hover:before{transform:scaleX(1)}.dashboard-card h3{margin:0 0 12px;color:var(--text-primary);font-size:22px;font-weight:700;display:flex;align-items:center;gap:12px}.dashboard-card p{color:var(--text-secondary);margin-bottom:20px;font-size:15px;line-height:1.6}.card-link{display:inline-flex;align-items:center;gap:8px;color:var(--primary-600);text-decoration:none;font-weight:600;font-size:15px;transition:all var(--transition-base)}.card-link:hover{gap:12px;color:var(--accent-600)}.filters{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;align-items:center}.filters select,.search-input,.filter-input{padding:12px 16px;border:2px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;min-width:180px;background-color:var(--surface);transition:all var(--transition-base);color:var(--text-primary)}.filters select:focus,.search-input:focus,.filter-input:focus{border-color:var(--primary-500);outline:none;box-shadow:0 0 0 4px #3b82f61a}.search-input,.filter-input{flex:1;min-width:280px}.classes-list,.students-table,.admit-cards-table,.timetables-table{background:var(--surface);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-md);border:1px solid var(--border-light);overflow-x:auto}table{width:100%;border-collapse:separate;border-spacing:0}table th{background:linear-gradient(135deg,var(--gray-50) 0%,var(--gray-100) 100%);padding:16px;text-align:left;font-weight:700;color:var(--text-primary);border-bottom:2px solid var(--border-light);font-size:13px;text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:10;white-space:nowrap}table th:first-child{border-top-left-radius:var(--radius-lg)}table th:last-child{border-top-right-radius:var(--radius-lg)}table td{padding:16px;border-bottom:1px solid var(--gray-100);font-size:14px;color:var(--text-primary)}table tbody tr{transition:all var(--transition-base)}table tbody tr:hover{background:var(--gray-50);box-shadow:0 2px 8px #0000000a}table tbody tr:last-child td{border-bottom:none}.student-thumb{width:48px;height:56px;object-fit:cover;border-radius:var(--radius-md);border:2px solid var(--border-light);transition:all var(--transition-base);cursor:pointer}.student-thumb:hover{transform:scale(2);border-color:var(--primary-500);box-shadow:var(--shadow-xl);z-index:100}.no-photo{width:48px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--gray-100) 0%,var(--gray-200) 100%);border-radius:var(--radius-md);font-size:24px;border:2px solid var(--border-light)}.no-data{text-align:center;padding:60px 40px;color:var(--text-secondary);font-size:16px}.class-card{background:linear-gradient(135deg,var(--gray-50) 0%,var(--gray-100) 100%);padding:24px;border-radius:var(--radius-xl);margin-bottom:20px;border:2px solid var(--border-light);transition:all var(--transition-base)}.class-card:hover{border-color:var(--border-medium);box-shadow:var(--shadow-md)}.class-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.class-header h3{margin:0;color:var(--text-primary);font-size:20px;font-weight:700}.class-actions{display:flex;gap:12px;flex-wrap:wrap}.groups-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;margin-top:16px}.group-item{background:var(--surface);padding:16px 20px;border-radius:var(--radius-lg);display:flex;justify-content:space-between;align-items:center;border:2px solid var(--border-light);transition:all var(--transition-base);font-weight:500;font-size:14px}.group-item:hover{border-color:var(--border-medium);box-shadow:var(--shadow-sm)}.add-form,.add-group-form,.generation-form{background:var(--surface);padding:24px;border-radius:var(--radius-xl);margin-bottom:24px;box-shadow:var(--shadow-md);border:2px solid var(--border-light)}.add-form h3,.add-group-form h3{margin:0 0 20px;color:var(--text-primary);font-size:18px;font-weight:700}.add-form input,.add-form textarea,.add-form select,.add-group-form input,.add-group-form textarea{width:100%;padding:12px 16px;margin-bottom:16px;border:2px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;background-color:var(--gray-50);transition:all var(--transition-base);font-family:inherit}.add-form input:focus,.add-form textarea:focus,.add-form select:focus,.add-group-form input:focus,.add-group-form textarea:focus{border-color:var(--primary-500);outline:none;background-color:var(--surface);box-shadow:0 0 0 4px #3b82f61a}.form-buttons{display:flex;gap:12px;flex-wrap:wrap}.info-box{background:linear-gradient(135deg,var(--primary-50) 0%,#dbeafe 100%);padding:24px;border-radius:var(--radius-xl);margin-top:24px;border:2px solid var(--primary-200);border-left:6px solid var(--primary-500);box-shadow:var(--shadow-sm)}.info-box h4{margin:0 0 16px;color:var(--primary-700);font-size:18px;font-weight:700}.info-box ul{margin:0;padding-left:24px;color:var(--primary-900);line-height:1.8;font-size:14px}.info-box ul li{margin-bottom:8px}.result-box{background:linear-gradient(135deg,var(--success-50) 0%,#d1fae5 100%);padding:24px;border-radius:var(--radius-xl);margin-top:24px;border:2px solid #86efac;border-left:6px solid var(--success-600);box-shadow:var(--shadow-sm)}.result-box h3{margin:0 0 16px;color:var(--success-700);font-size:20px;font-weight:700}.result-box p{color:var(--success-700);font-size:15px;margin:12px 0}.generation-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin:32px 0;padding:32px;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-600) 100%);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl)}.stat-item{display:flex;flex-direction:column;gap:12px;padding:24px;background:#ffffff26;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);transition:all var(--transition-slow)}.stat-item:hover{background:#ffffff40;transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stat-label{font-size:14px;color:#fffffff2;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:32px;font-weight:800;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.2);letter-spacing:-1px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border-radius:var(--radius-2xl);padding:36px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-2xl);animation:slideUp .3s ease-out}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px}.modal-content::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:4px}.modal-content h2{margin:0 0 28px;color:var(--text-primary);font-size:28px;font-weight:700}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h2{margin:0}.close-btn{background:var(--gray-100);border:none;width:40px;height:40px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-600);transition:all var(--transition-base)}.close-btn:hover{background:var(--gray-200);color:var(--gray-900);transform:rotate(90deg)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.photo-preview{margin-top:16px;text-align:center;padding:16px;background:var(--gray-50);border-radius:var(--radius-lg);border:2px dashed var(--border-light)}.photo-preview img{max-width:220px;max-height:220px;border-radius:var(--radius-lg);border:3px solid var(--primary-500);box-shadow:var(--shadow-md)}.modal-actions,.modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:2px solid var(--gray-100)}.action-buttons{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.loading{text-align:center;padding:80px 40px;font-size:18px;color:var(--text-secondary);font-weight:500}.loading:after{content:"...";animation:dots 1.5s steps(4,end) infinite}@keyframes dots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}.info-message{text-align:center;padding:40px;color:var(--text-secondary);background:var(--gray-50);border-radius:var(--radius-lg);margin:20px 0}.hall-ticket-preview{max-width:900px;margin:0 auto}.hall-ticket-actions{display:flex;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}.hall-ticket{background:var(--surface);padding:40px;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:2px solid var(--border-light)}.hall-ticket-header{text-align:center;border-bottom:3px solid var(--gray-800);padding-bottom:20px;margin-bottom:30px}.hall-ticket-header h1{margin:0;color:var(--gray-800);font-size:32px}.hall-ticket-header h2{margin:10px 0 0;color:var(--text-secondary);font-size:18px;font-weight:400}.student-section{display:grid;grid-template-columns:150px 1fr;gap:30px;margin-bottom:30px}.student-photo img{width:150px;height:180px;object-fit:cover;border:3px solid var(--gray-800);border-radius:var(--radius-md)}.student-details h3{margin:0 0 15px;color:var(--gray-800)}.student-details table{width:100%}.student-details td{padding:8px 12px;border-bottom:1px solid var(--gray-200)}.qr-codes-section{margin:30px 0}.qr-codes-section h3{margin:0 0 20px;color:var(--gray-800);text-align:center}.qr-codes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;justify-items:center}.qr-code-item{text-align:center}.qr-code-item img{width:250px;height:250px;border:2px solid var(--gray-300);border-radius:var(--radius-md)}.qr-code-item p{margin:10px 0 0;color:var(--text-secondary)}.hall-ticket-footer{margin-top:30px;padding-top:20px;border-top:2px solid var(--gray-200);text-align:center;color:var(--text-secondary)}.signature-note{margin-top:15px;font-size:12px;font-style:italic;color:var(--text-tertiary)}.settings{max-width:1200px;margin:0 auto}.settings-section{background:var(--surface);border-radius:var(--radius-xl);padding:36px;margin-bottom:32px;box-shadow:var(--shadow-md);border:2px solid var(--border-light);transition:all var(--transition-slow)}.settings-section:hover{border-color:var(--border-medium);box-shadow:var(--shadow-lg)}.settings-section h2{margin:0 0 16px;color:var(--text-primary);font-size:24px;font-weight:700}.section-description{color:var(--text-secondary);margin-bottom:28px;line-height:1.7;font-size:15px}.key-info-box{background:linear-gradient(135deg,var(--gray-50) 0%,var(--gray-100) 100%);border-left:6px solid var(--primary-600);padding:24px;margin-bottom:28px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--gray-300)}.info-row:last-child{border-bottom:none}.info-row .label{font-weight:600;color:var(--text-secondary)}.info-row .value{color:var(--text-primary)}.info-row code{background:var(--gray-200);padding:4px 8px;border-radius:var(--radius-sm);font-family:Courier New,monospace;font-size:13px}.button-group{display:flex;gap:15px;margin-bottom:25px;flex-wrap:wrap}.public-key-preview{background:var(--gray-50);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:20px;margin-top:20px}.public-key-preview h4{margin:0 0 15px;color:var(--text-secondary)}.key-content{background:#2d2d2d;color:#f8f8f2;padding:20px;border-radius:var(--radius-md);overflow-x:auto;font-family:Courier New,monospace;font-size:12px;line-height:1.6;white-space:pre-wrap;word-break:break-all}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:20px}.info-card{background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-600) 100%);color:#fff;padding:25px;border-radius:var(--radius-xl);display:flex;align-items:center;gap:15px;box-shadow:var(--shadow-md);transition:transform var(--transition-base)}.info-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.info-card-icon{font-size:36px;opacity:.9}.info-card-content h3{margin:0 0 5px;font-size:16px;font-weight:600}.info-card-content p{margin:0 0 5px;font-size:18px;font-weight:700}.info-card-content small{font-size:12px;opacity:.9}.filters-section{padding:0 0 20px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{font-weight:600;color:var(--text-primary);font-size:14px}@media print{.hall-ticket-actions,.sidebar,.page-header,.filters{display:none!important}.main-content{padding:0;margin:0}.hall-ticket{box-shadow:none;border:none}}@media (max-width: 1280px){.page-header,.page-content{padding:28px 32px}.dashboard-cards{padding:28px 32px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width: 1024px){:root{--sidebar-width: 260px}.dashboard-cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}table{font-size:13px}table th,table td{padding:12px 10px}}@media (max-width: 768px){body{font-size:14px}.sidebar{position:fixed;z-index:1000;height:100vh;width:var(--sidebar-width)!important;transform:translate(-100%);transition:transform var(--transition-slow)}.sidebar.open{transform:translate(0)}.sidebar.closed{transform:translate(-100%);width:var(--sidebar-width)!important}.main-content{margin-left:0!important}.page-header{padding:20px;position:relative}.page-header h1{font-size:24px}.page-content{padding:20px}.dashboard-home>h1{padding:20px 20px 0;font-size:24px}.dashboard-cards{padding:20px;grid-template-columns:1fr}.student-section{grid-template-columns:1fr;text-align:center}.filters{flex-direction:column;align-items:stretch}.filters select,.search-input,.filter-input{width:100%;min-width:100%}.form-row{grid-template-columns:1fr}.modal-content{padding:24px;max-height:85vh}.btn-primary,.btn-secondary,.btn-danger{width:100%;justify-content:center}.generation-stats{grid-template-columns:1fr;padding:24px}table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.action-buttons{flex-direction:column;width:100%}.action-buttons button{width:100%}.class-header{flex-direction:column;align-items:flex-start}.class-actions{width:100%}.groups-list{grid-template-columns:1fr}.hall-ticket-actions{flex-direction:column}.sidebar.open~.main-content:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}@media (max-width: 480px){.login-card{padding:32px 24px}.page-header h1{font-size:20px}.dashboard-card{padding:24px}.modal-content h2{font-size:20px}.stat-value{font-size:24px}}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.p-1{padding:8px}.p-2{padding:16px}.p-3{padding:24px}.p-4{padding:32px}*{scrollbar-width:thin;scrollbar-color:var(--gray-400) var(--gray-100)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:var(--gray-100)}*::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:5px}*::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}#root{width:100%;max-width:1200px}.container{background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d}.header{text-align:center;margin-bottom:40px}.header h1{color:#667eea;font-size:2.5rem;margin-bottom:10px}.header p{color:#666;font-size:1.1rem}.tabs{display:flex;gap:10px;margin-bottom:30px;justify-content:center;border-bottom:2px solid #e0e0e0;padding-bottom:10px}.tab{padding:12px 30px;background:transparent;border:none;border-bottom:3px solid transparent;color:#666;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;margin-bottom:-12px}.tab:hover{color:#667eea;background:#f8f9ff;border-radius:8px 8px 0 0}.tab.active{color:#667eea;border-bottom-color:#667eea;background:#f8f9ff;border-radius:8px 8px 0 0}.form-container{display:grid;grid-template-columns:1fr 1fr;gap:30px}.form-section{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:8px;font-weight:600;color:#333;font-size:.95rem}.form-group input{padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.file-upload{position:relative;padding:40px;border:2px dashed #e0e0e0;border-radius:8px;text-align:center;cursor:pointer;transition:all .3s}.file-upload:hover{border-color:#667eea;background:#f8f9ff}.file-upload input[type=file]{position:absolute;opacity:0;width:100%;height:100%;top:0;left:0;cursor:pointer}.file-upload-label{color:#666;font-size:.95rem}.file-name{margin-top:10px;color:#667eea;font-weight:600}.qr-mode-selector{display:flex;gap:15px;margin-bottom:10px}.mode-option{flex:1;display:flex;align-items:center;gap:10px;padding:15px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s}.mode-option:hover{border-color:#667eea;background:#f8f9ff}.mode-option.active{border-color:#667eea;background:#f0f3ff}.mode-option input[type=radio]{cursor:pointer}.mode-content{display:flex;flex-direction:column;gap:4px}.mode-content strong{color:#333;font-size:.95rem}.mode-content small{color:#666;font-size:.8rem}.button-container{grid-column:1 / -1;display:flex;justify-content:center;margin-top:10px}.generate-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 60px;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .3s}.generate-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}.generate-btn:active{transform:translateY(0)}.generate-btn:disabled{background:#ccc;cursor:not-allowed;transform:none}.result-section{margin-top:40px;padding-top:40px;border-top:2px solid #f0f0f0;text-align:center}.result-section h2{color:#333;margin-bottom:30px;font-size:1.8rem}.id-card{display:flex;gap:30px;background:linear-gradient(135deg,#f8f9ff,#e8ebff);padding:30px;border-radius:15px;align-items:center;justify-content:center;flex-wrap:wrap}.id-card-photo{display:flex;gap:20px;align-items:center;flex:1;min-width:280px}.student-photo{width:150px;height:150px;object-fit:cover;border-radius:10px;border:3px solid white;box-shadow:0 5px 20px #00000026}.student-info{flex:1}.student-info p{margin:8px 0;color:#333;font-size:1rem;text-align:left}.photo-preview{text-align:center;padding:15px;background:#fff;border-radius:10px;box-shadow:0 4px 15px #0000001a}.photo-preview h4{margin:0 0 15px;color:#667eea;font-size:1rem}.student-photo-preview{width:150px;height:150px;object-fit:cover;border-radius:10px;border:3px solid #667eea;box-shadow:0 5px 20px #00000026}.photo-info{margin:10px 0 0;color:#666;font-size:.85rem}.qr-section{display:flex;flex-direction:column;align-items:center;gap:10px}.qr-image{width:250px;height:250px;border-radius:10px;box-shadow:0 10px 30px #00000026;background:#fff;padding:10px}.qr-note{color:#667eea;font-weight:600;font-size:.9rem;margin:0}.qr-size{color:#333;font-weight:600;font-size:.95rem;margin:8px 0}.payload-details{margin-top:15px;width:100%;text-align:left}.payload-details summary{cursor:pointer;padding:10px 15px;background:linear-gradient(135deg,#667eea15,#764ba215);border:2px solid #667eea;border-radius:8px;font-weight:600;color:#667eea;transition:all .2s;-webkit-user-select:none;user-select:none}.payload-details summary:hover{background:linear-gradient(135deg,#667eea25,#764ba225);transform:translateY(-1px)}.payload-details[open] summary{border-bottom-left-radius:0;border-bottom-right-radius:0;margin-bottom:0}.payload-json{background:#2d2d2d;color:#f8f8f2;padding:15px;border-radius:0 0 8px 8px;border:2px solid #667eea;border-top:none;margin:0;overflow-x:auto;font-family:Monaco,Courier New,monospace;font-size:.85rem;line-height:1.5;max-height:300px;overflow-y:auto}.signature-info{background:#f8f9ff;padding:20px;border-radius:10px;margin-top:20px;text-align:left;width:100%}.signature-info h3{color:#667eea;margin-bottom:15px}.signature-info p{margin:8px 0;color:#555;font-size:.9rem;word-break:break-all}.signature-info strong{color:#333}.loading{color:#667eea;font-size:1.1rem;margin:20px 0}.error{color:#dc3545;background:#fee;padding:15px;border-radius:8px;margin:20px 0}.verify-test-btn{background:linear-gradient(135deg,#00bfa5,#00897b);color:#fff;border:none;padding:14px 40px;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .3s}.verify-test-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #00bfa566}.verify-test-btn:disabled{background:#ccc;cursor:not-allowed;transform:none}.verification-result{margin-top:30px;padding:25px;border-radius:15px;animation:slideIn .3s ease-out}.verification-result.valid{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:3px solid #4caf50}.verification-result.invalid{background:linear-gradient(135deg,#ffebee,#ffcdd2);border:3px solid #f44336}.verification-result h3{margin-bottom:15px;font-size:1.5rem}.verification-result.valid h3{color:#2e7d32}.verification-result.invalid h3{color:#c62828}.verification-msg{color:#1b5e20;font-size:1.1rem;margin-bottom:20px}.error-msg{color:#b71c1c;font-size:1rem}.verified-data{background:#fff;padding:20px;border-radius:10px;margin:20px 0}.verified-data h4{color:#667eea;margin-bottom:15px}.verified-data p{margin:10px 0;color:#333;font-size:1rem}.verified-data strong{color:#667eea;min-width:100px;display:inline-block}.verified-photo{background:#fff;padding:20px;border-radius:10px;margin:20px 0;text-align:center}.verified-photo h4{color:#667eea;margin-bottom:15px}.verified-photo-img{width:150px;height:150px;object-fit:cover;border-radius:10px;border:3px solid #4caf50;box-shadow:0 5px 20px #00000026}.offline-note{margin-top:20px;padding:15px;background:#fff3e0;border-left:4px solid #ff9800;border-radius:5px;color:#e65100;font-weight:600}@media (max-width: 768px){.form-container{grid-template-columns:1fr}.container{padding:20px}.header h1{font-size:2rem}.generate-btn,.verify-test-btn{width:100%}.verified-data strong{min-width:80px}.qr-codes-container{flex-direction:column}.qr-code-item{width:100%}}.multi-qr-section{margin-top:30px}.qr-instructions{text-align:center;margin-bottom:30px;padding:20px;background:#f8f9ff;border-radius:12px}.qr-instructions h3{color:#667eea;margin-bottom:10px}.qr-instructions p{color:#666;font-size:1rem}.qr-codes-container{display:flex;gap:30px;justify-content:center;margin-bottom:30px;flex-wrap:wrap}.qr-code-item{flex:1;min-width:280px;max-width:400px;padding:20px;background:#f8f9ff;border-radius:12px;text-align:center;border:2px solid #e0e0e0;transition:all .3s}.qr-code-item:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.qr-code-item h4{color:#667eea;margin-bottom:15px;font-size:1.1rem}.qr-code-item .qr-image{max-width:100%;height:auto;margin-bottom:15px;border-radius:8px}.qr-size{color:#888;font-size:.9rem;margin-bottom:10px}.qr-note{color:#666;font-size:.95rem;font-weight:500}.scan-instructions{background:#fff3cd;border:2px solid #ffc107;border-radius:12px;padding:20px;margin-bottom:20px}.scan-instructions h4{color:#856404;margin-bottom:15px}.scan-instructions ol{color:#856404;margin-left:25px}.scan-instructions li{margin-bottom:10px;font-size:1rem}
