:root{--primary-color: #6366F1;--primary-light: #818CF8;--primary-dark: #4F46E5;--secondary-color: #10B981;--secondary-light: #34D399;--error-color: #EF4444;--warning-color: #F59E0B;--success-color: #22C55E;--gray-50: #0B1220;--gray-100: #111827;--gray-200: #1F2937;--gray-300: #374151;--gray-400: #4B5563;--gray-500: #6B7280;--gray-600: #9CA3AF;--gray-700: #D1D5DB;--gray-800: #E5E7EB;--gray-900: #F3F4F6;--bg: #0b1220;--surface: #0f172a;--surface-2: #111827;--overlay: rgba(2, 6, 23, .6);--line: rgba(148, 163, 184, .18);--text-high: #E5E7EB;--text-muted: #9CA3AF;--white: #FFFFFF;--black: #000000;--border-radius: 8px;--border-radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .25);--shadow: 0 2px 6px 0 rgb(0 0 0 / .35);--shadow-md: 0 8px 16px -2px rgb(0 0 0 / .45);--shadow-lg: 0 16px 28px -6px rgb(0 0 0 / .55);--shadow-xl: 0 28px 40px -10px rgb(0 0 0 / .6);--transition: all .25s ease;--transition-fast: all .15s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;line-height:1.5}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:var(--text-high);background-color:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:block}#root{min-height:100vh;width:100%}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:1px solid transparent;border-radius:var(--border-radius);font-size:.9rem;font-weight:600;text-decoration:none;cursor:pointer;transition:var(--transition);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--primary-dark),var(--primary-light));color:var(--white);box-shadow:0 8px 20px #4f46e540}.btn-primary:hover{filter:brightness(1.05);transform:translateY(-1px)}.btn-secondary{background:linear-gradient(135deg,#059669,var(--secondary-color));color:var(--white);box-shadow:0 8px 20px #10b98140}.btn-secondary:hover{transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--text-high);border:1px solid var(--line)}.btn-outline:hover{border-color:var(--primary-color);color:var(--white)}.btn-ghost{background:#ffffff0f;color:var(--white);border:1px solid rgba(255,255,255,.12)}.btn-ghost:hover{background:#ffffff1f}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.btn-lg{padding:1rem 2rem;font-size:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.animate-in{opacity:0;transform:translateY(20px);transition:all .6s ease}.animate-in.appear{opacity:1;transform:translateY(0)}.spinner{width:2rem;height:2rem;border:3px solid rgba(255,255,255,.15);border-top:3px solid var(--primary-light);border-radius:50%;animation:spin 1s linear infinite}.spinner-white{border-color:#fff3;border-top-color:var(--white)}.message{display:flex;align-items:center;gap:.5rem;padding:1rem;border-radius:var(--border-radius);font-size:.9rem;margin:1rem 0;border:1px solid var(--line);background:var(--surface);color:var(--text-high)}.message-error{border-color:#ef444459;background:#ef44441f;color:#fecaca}.message-warning{border-color:#f59e0b59;background:#f59e0b1f;color:#fde68a}.message-success{border-color:#22c55e59;background:#22c55e1f;color:#bbf7d0}.message-info{border-color:#6366f159;background:#6366f11f;color:#c7d2fe}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.form-label{font-size:.9rem;font-weight:500;color:var(--text-muted)}.form-input,.form-select{padding:.75rem;border:1px solid var(--line);border-radius:var(--border-radius);font-size:1rem;transition:var(--transition);background:var(--surface-2);color:var(--text-high)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px #6366f126}.card{background:var(--surface);border-radius:var(--border-radius-lg);padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--line)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--line)}.card-title{font-size:1.25rem;font-weight:600;color:var(--text-high)}.grid{display:grid;gap:1rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.container{padding:0 .75rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.btn{padding:.65rem 1.25rem;font-size:.9rem}}@media (max-width: 480px){html{font-size:14px}.container{padding:0 .5rem}.card{padding:1rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 600px at 20% -10%,rgba(99,102,241,.12),transparent 60%),radial-gradient(1100px 500px at 100% 0%,rgba(16,185,129,.1),transparent 60%),linear-gradient(180deg,#0b1220,#0f172a 30%,#0b1220);padding:2rem;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="0.5"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');pointer-events:none}.login-card{background:#111827e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:2.25rem;box-shadow:var(--shadow-xl);width:100%;max-width:450px;border:1px solid var(--line);position:relative;z-index:1}.login-header{text-align:center;margin-bottom:2.5rem}.login-header h1{font-size:2.25rem;font-weight:800;background:linear-gradient(135deg,var(--primary-color),var(--primary-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.35rem;letter-spacing:.2px}.login-subtitle{color:var(--text-muted);font-size:1rem;font-weight:500}.login-form{display:flex;flex-direction:column;gap:1.5rem}.input-with-icon{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;z-index:2;font-size:1.2rem;color:var(--gray-400)}.input-with-icon input{padding-left:3rem;width:100%;height:3.25rem;border:1px solid var(--line);border-radius:var(--border-radius-lg);font-size:1rem;transition:var(--transition);background:var(--surface-2);color:var(--text-high)}.input-with-icon input:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 4px #6366f126}.input-with-icon input:focus+.input-icon{color:var(--primary-color)}.login-button{height:3.25rem;background:linear-gradient(135deg,var(--primary-dark),var(--primary-light));color:var(--white);border:none;border-radius:var(--border-radius-lg);font-size:1rem;font-weight:700;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:.5rem;box-shadow:0 10px 25px #4f46e547}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #4f46e54d}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.button-icon{font-size:1.1rem}.spinner{width:1.25rem;height:1.25rem;border:2px solid rgba(255,255,255,.3);border-top:2px solid var(--white);border-radius:50%;animation:spin 1s linear infinite}.error-message{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#ef44441f;border:1px solid rgba(239,68,68,.35);border-radius:var(--border-radius-lg);color:#fecaca;font-size:.9rem;animation:fadeIn .3s ease}.error-icon{font-size:1.1rem;flex-shrink:0}.login-footer{text-align:center;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--line)}.login-footer p{color:var(--gray-500);font-size:.85rem}@media (max-width: 768px){.login-container{padding:1rem}.login-card{padding:2rem;max-width:100%;margin:0 .5rem}.login-header h1{font-size:2rem}.input-with-icon input,.login-button{height:3rem}}@media (max-width: 480px){.login-card{padding:1.5rem;margin:0}.login-header{margin-bottom:2rem}.login-header h1{font-size:1.75rem}.login-subtitle{font-size:.9rem}}.homepage-container{min-height:100vh;background:radial-gradient(1200px 600px at 20% -10%,rgba(99,102,241,.12),transparent 60%),radial-gradient(1100px 500px at 100% 0%,rgba(16,185,129,.1),transparent 60%),linear-gradient(180deg,#0b1220,#0f172a 30%,#0b1220);display:flex;flex-direction:column;padding:2rem;gap:2rem}.homepage-header{display:flex;justify-content:space-between;align-items:center;background:#111827bf;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);padding:1.25rem 1.75rem;border:1px solid var(--line);flex-wrap:wrap;gap:1rem}.header-content h1{color:var(--white);font-size:2rem;font-weight:600;margin-bottom:.5rem}.welcome-text{opacity:.9;font-weight:400}.student-name{display:block;font-weight:700;margin-top:.25rem}.formation-name{color:#fffc;font-size:1rem;margin:0}.logout-button{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:var(--white);padding:.65rem 1.25rem;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:.5rem;font-weight:700}.logout-button:hover{background:#fff3;transform:translateY(-2px)}.homepage-body{flex:1;display:flex;flex-direction:column;gap:2rem;max-width:1200px;width:100%;margin:0 auto}.user-card{background:#111827e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);padding:1.75rem;box-shadow:var(--shadow-lg);border:1px solid var(--line)}.user-card-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--line)}.user-avatar{width:3.5rem;height:3.5rem;background:linear-gradient(135deg,var(--primary-dark),var(--primary-light));color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:800;box-shadow:0 10px 22px #6366f159}.user-meta h2{font-size:1.4rem;font-weight:800;color:var(--text-high);margin-bottom:.15rem}.user-id{color:var(--text-muted);font-size:.9rem;font-weight:600}.user-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.9rem 1rem;background:#1f2937a6;border-radius:var(--border-radius);border-left:4px solid var(--primary-color);border:1px solid var(--line)}.detail-label{font-weight:700;color:var(--text-muted);font-size:.9rem}.detail-value{font-weight:700;color:var(--text-high);text-align:right}.semestre-badge{background:linear-gradient(135deg,var(--secondary-color),var(--secondary-light));color:var(--white);padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.detail-info{color:var(--gray-500);font-size:.8rem;margin-left:.5rem}.quick-actions{background:#111827e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);padding:1.75rem;box-shadow:var(--shadow-lg);border:1px solid var(--line)}.quick-actions h2{font-size:1.6rem;font-weight:800;color:var(--text-high);margin-bottom:1.25rem;text-align:center}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.action-card{background:#1f2937bf;border-radius:var(--border-radius-lg);padding:1.5rem;border:1px solid var(--line);cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:1.25rem;box-shadow:var(--shadow-sm)}.action-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.action-icon{width:4rem;height:4rem;border-radius:var(--border-radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--white);flex-shrink:0}.bulletin-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.schedule-icon{background:linear-gradient(135deg,var(--secondary-color),var(--secondary-light))}.absence-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.action-content h3{font-size:1.2rem;font-weight:800;color:var(--text-high);margin-bottom:.35rem}.action-content p{color:var(--text-muted);font-size:.9rem;line-height:1.4}.homepage-footer{text-align:center;padding:1rem;color:#ffffffb3;font-size:.85rem}@media (max-width: 1024px){.actions-grid{grid-template-columns:repeat(2,1fr)}.user-details{grid-template-columns:1fr;gap:1rem}}@media (max-width: 768px){.homepage-container{padding:1rem;gap:1.5rem}.homepage-header{flex-direction:column;text-align:center;padding:1.5rem}.header-content h1{font-size:1.75rem}.user-card,.quick-actions{padding:1.5rem}.user-card-header{flex-direction:column;text-align:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.5rem}.user-details{gap:1rem}.detail-item{flex-direction:column;text-align:center;gap:.5rem}.actions-grid{grid-template-columns:1fr}.action-card{flex-direction:column;text-align:center;padding:1.5rem}}@media (max-width: 480px){.homepage-container{padding:.5rem}.user-card,.quick-actions{padding:1rem}.user-avatar{width:3rem;height:3rem;font-size:1.25rem}.user-meta h2{font-size:1.25rem}.action-icon{width:3rem;height:3rem;font-size:1.25rem}.action-content h3{font-size:1.1rem}}.schedule-page{min-height:100vh;background:radial-gradient(1200px 600px at 20% -10%,rgba(99,102,241,.12),transparent 60%),radial-gradient(1100px 500px at 100% 0%,rgba(16,185,129,.1),transparent 60%),linear-gradient(180deg,#0b1220,#0f172a 30%,#0b1220);padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem}.page-header{display:flex;align-items:center;gap:1rem;background:#111827bf;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);padding:1rem 1.25rem;border:1px solid var(--line)}.back-button{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:var(--white);padding:.5rem 1rem;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);font-size:.9rem;font-weight:700;white-space:nowrap}.back-button:hover{background:#ffffff4d;transform:translate(-2px)}.page-header h1{color:var(--white);font-size:1.6rem;font-weight:800;margin:0}.schedule-controls{background:#111827e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);padding:1.25rem;border:1px solid var(--line);box-shadow:var(--shadow-md)}.controls-grid{display:grid;grid-template-columns:1fr 2fr;gap:2rem;align-items:end}.class-selector{display:flex;flex-direction:column;gap:.5rem}.class-selector label{color:var(--text-high);font-weight:700;font-size:1rem}.class-selector select{padding:.7rem;border-radius:var(--border-radius);border:1px solid var(--line);font-size:1rem;cursor:pointer;transition:var(--transition);background:var(--surface-2);color:var(--text-high)}.class-selector select:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px #6366f126}.week-navigation{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.week-navigation button{background:var(--surface-2);border:1px solid var(--line);color:var(--text-high);padding:.7rem 1.25rem;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition);font-size:.9rem;font-weight:700;white-space:nowrap;flex:1;min-width:140px}.week-navigation button:hover{border-color:var(--primary-color);background:var(--primary-color);color:var(--white);transform:translateY(-2px)}.loading-message{text-align:center;color:var(--white);padding:2rem;background:#111827b3;border-radius:var(--border-radius-lg);border:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.loading-message .spinner{margin:0 auto 1rem}.loading-message p{margin:.5rem 0}.schedule-content{flex:1;background:#111827eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);padding:1.5rem;box-shadow:var(--shadow-lg);border:1px solid var(--line);display:flex;flex-direction:column;min-height:600px}.week-header{text-align:center;margin-bottom:1.5rem;padding-bottom:1.1rem;border-bottom:1px solid var(--line)}.week-header h2{color:var(--text-high);font-size:1.4rem;font-weight:800;margin:0 0 .85rem;line-height:1.3}.class-info{display:flex;flex-direction:column;align-items:center;gap:.75rem}.selected-class{color:var(--text-muted);font-size:1rem;margin:0;font-weight:600}.test-data-badge{background:linear-gradient(135deg,#334155,#1f2937);color:#fde68a;padding:.4rem .9rem;border-radius:25px;font-size:.8rem;font-weight:800;border:1px solid var(--line);box-shadow:var(--shadow-sm)}.mobile-day-tabs{display:none;gap:.5rem;margin:.25rem 0 1rem}.day-tab{background:var(--surface-2);border:1px solid var(--line);color:var(--text-high);padding:.5rem .75rem;border-radius:999px;cursor:pointer;font-size:.85rem;font-weight:800}.day-tab.active{background:var(--primary-color);color:var(--white);border-color:var(--primary-color)}.schedule-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;flex:1;min-height:500px}.day-column{background:#0206174d;border-radius:var(--border-radius-lg);border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:var(--transition);box-shadow:var(--shadow-sm)}.day-column:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.day-column.today{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f126}.day-column.weekend{background:#02061726;opacity:.9}.day-header{background:#111827b3;padding:.85rem;border-bottom:1px solid var(--line);text-align:center;flex-shrink:0}.day-column.today .day-header{background:var(--primary-color);color:var(--white)}.day-column.weekend .day-header{background:#1f293780}.day-header h3{margin:0;font-size:.95rem;font-weight:800;text-transform:capitalize;line-height:1.3;color:var(--text-high)}.day-events{padding:.6rem .6rem .8rem;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.day-events::-webkit-scrollbar{width:4px}.day-events::-webkit-scrollbar-track{background:#11182799}.day-events::-webkit-scrollbar-thumb{background:#94a3b859;border-radius:2px}.event-item{background:linear-gradient(135deg,#1e293be6,#0f172ae6);border-left:4px solid var(--primary-color);border-radius:10px;padding:.6rem .7rem;transition:var(--transition);cursor:pointer;box-shadow:var(--shadow-sm);border:1px solid var(--line)}.event-item:hover{background:#1e293bf2;transform:translate(4px);box-shadow:var(--shadow-md)}.event-time{font-size:.78rem;font-weight:800;color:var(--primary-light);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.4px}.event-title{font-size:.88rem;font-weight:800;color:var(--text-high);margin-bottom:.35rem;line-height:1.28;word-break:break-word}.event-location{font-size:.78rem;color:var(--text-muted);margin-bottom:.2rem;word-break:break-word;display:flex;align-items:center;gap:.25rem}.event-description{font-size:.75rem;color:var(--text-muted);line-height:1.4;word-break:break-word;font-style:italic}.no-events{text-align:center;color:var(--text-muted);font-style:italic;padding:2rem 1rem;font-size:.9rem;flex:1;display:flex;align-items:center;justify-content:center;border:1px dashed var(--line);border-radius:var(--border-radius);background:#0f172a73}@media (max-width: 1400px){.schedule-grid{gap:.75rem}.day-events{padding:.75rem;gap:.5rem}}@media (max-width: 1200px){.schedule-page{padding:1rem}.controls-grid{grid-template-columns:1fr;gap:1.5rem}.week-navigation{justify-content:stretch}.week-navigation button{min-width:120px}}@media (max-width: 1024px){.schedule-grid{grid-template-columns:repeat(5,1fr)}.day-column.weekend{display:none}.schedule-content{padding:1.5rem}}@media (max-width: 768px){.schedule-page{padding:.75rem;gap:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1rem}.page-header h1{font-size:1.5rem}.schedule-controls{padding:1rem}.week-navigation{gap:.5rem}.week-navigation button{padding:.5rem 1rem;font-size:.85rem;min-width:100px}.schedule-content{padding:1rem;min-height:400px}.week-header h2{font-size:1.25rem}.mobile-day-tabs{display:flex;flex-wrap:nowrap;overflow-x:auto}.schedule-grid{grid-template-columns:1fr;justify-items:center}.day-column{width:min(680px,100%);margin:0 auto}.day-header{padding:.75rem .5rem}.day-header h3{font-size:.85rem}.day-events{padding:.5rem}.event-item{padding:.6rem .75rem}.event-title{font-size:1rem}.event-time,.event-location{font-size:.9rem}}@media (max-width: 480px){.schedule-grid{grid-template-columns:repeat(2,1fr)}.week-navigation{flex-direction:column}.week-navigation button{width:100%}}@media (max-width: 360px){.schedule-grid{grid-template-columns:1fr}}.gap-item{background:#22c55e14;border:1px dashed rgba(34,197,94,.35);color:#86efac;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;letter-spacing:.2px}.bulletin-page{min-height:100vh;background:radial-gradient(1200px 600px at 20% -10%,rgba(99,102,241,.12),transparent 60%),radial-gradient(1100px 500px at 100% 0%,rgba(16,185,129,.1),transparent 60%),linear-gradient(180deg,#0b1220,#0f172a 30%,#0b1220);padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;color:var(--white)}.bulletin-page h1{color:var(--white);text-align:center;margin-bottom:2rem;font-size:2.5rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.bulletin{display:flex;flex-direction:column;gap:1.5rem}.ue-card{background:#1e293bf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);padding:1.5rem;border-left:5px solid var(--primary-color);box-shadow:0 10px 25px #0000004d;color:var(--gray-100);border:1px solid rgba(148,163,184,.1)}.ue-card h3{font-size:1.3rem;margin-bottom:1rem;color:var(--primary-color);border-bottom:2px solid rgba(148,163,184,.3);padding-bottom:.5rem}.ue-moyenne{background:#334155cc;padding:1rem;border-radius:var(--border-radius);margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;border:1px solid rgba(148,163,184,.2)}.ue-moyenne strong{font-size:1.2rem;color:var(--primary-color)}.rang{color:var(--gray-300);font-size:.9rem;margin-left:1rem}.modules h4{color:var(--gray-200);margin:1.5rem 0 1rem;font-size:1.1rem;text-transform:uppercase;letter-spacing:.5px}.module-item{background:#334155e6;padding:1rem;margin-bottom:.5rem;border-radius:var(--border-radius);border:1px solid rgba(148,163,184,.3);cursor:pointer;transition:all .2s ease;display:flex;justify-content:space-between;align-items:center;color:var(--gray-100)}.module-item:hover{background:#475569e6;transform:translate(5px);box-shadow:0 4px 12px #0003}.module-item.selected{background:var(--primary-color);color:var(--white);border-color:var(--primary-color)}.absences-page{min-height:100vh;background:linear-gradient(135deg,#1e293b,#0f172a);padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;color:var(--white)}.absences-page h1{color:var(--white);text-align:center;margin-bottom:2rem;font-size:2.5rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.absences-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-item{background:#1e293bf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem;border-radius:var(--border-radius-lg);box-shadow:0 10px 25px #0000004d;color:var(--gray-100);border:1px solid rgba(148,163,184,.1)}.summary-item strong{font-size:1.5rem;color:var(--error-color);display:block;margin-top:.5rem}.no-absences{background:#10b981f2;color:var(--white);padding:2rem;border-radius:var(--border-radius-lg);text-align:center;font-size:1.2rem;font-weight:600;box-shadow:0 10px 25px #0000004d}.absences-container{display:flex;flex-direction:column;gap:1.5rem}.day-card{background:#1e293bf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);padding:1.5rem;box-shadow:0 10px 25px #0000004d;color:var(--gray-100);border:1px solid rgba(148,163,184,.1)}.day-card h2{color:var(--primary-color);margin-bottom:1rem;font-size:1.3rem;text-transform:capitalize;border-bottom:2px solid rgba(148,163,184,.3);padding-bottom:.5rem}.sessions-list{display:flex;flex-direction:column;gap:1rem}.session-item{background:#334155e6;padding:1rem;border-radius:var(--border-radius);border:1px solid rgba(148,163,184,.3);display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;color:var(--gray-100)}.session-time{font-weight:600;color:var(--gray-100)}.duration{color:var(--gray-300);font-size:.9rem;font-weight:400;margin-left:.5rem}.session-info{color:var(--gray-200)}.teacher-name{font-weight:500}.bulletin-page,.absences-page{min-height:100vh;background:radial-gradient(1200px 600px at 20% -10%,rgba(99,102,241,.12),transparent 60%),radial-gradient(1100px 500px at 100% 0%,rgba(16,185,129,.1),transparent 60%),linear-gradient(180deg,#0b1220,#0f172a 30%,#0b1220);padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem;color:var(--text-high)}.bulletin-page h1,.absences-page h1{color:var(--white);text-align:center;margin:0 0 1.25rem;font-size:2.25rem;font-weight:700;letter-spacing:.2px;text-shadow:0 2px 18px rgba(0,0,0,.45)}.back-button{background:#1e293b99;border:1px solid var(--line);padding:.65rem 1.25rem;border-radius:var(--border-radius-lg);color:var(--text-high);font-weight:600;cursor:pointer;transition:var(--transition);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-sm);align-self:flex-start}.back-button:hover{background:#334155cc;transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.bulletin{display:flex;flex-direction:column;gap:1rem}.ue-card{background:linear-gradient(180deg,#111827e6,#0f172ae6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);padding:1.25rem;border-left:5px solid var(--primary-color);box-shadow:var(--shadow-lg);color:var(--text-high);border:1px solid var(--line)}.ue-card h3{font-size:1.25rem;margin-bottom:.85rem;color:var(--primary-light);border-bottom:1px solid var(--line);padding-bottom:.5rem;font-weight:700}.ue-moyenne{background:#1e293b99;padding:.85rem 1rem;border-radius:var(--border-radius);margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--line)}.ue-moyenne strong{font-size:1.1rem;color:var(--primary-light)}.rang{color:var(--text-muted);font-size:.9rem;margin-left:.75rem}.modules h4{color:var(--text-muted);margin:1rem 0 .75rem;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px}.module-item{background:#1f2937a6;padding:.9rem 1rem;margin-bottom:.5rem;border-radius:var(--border-radius);border:1px solid var(--line);cursor:pointer;transition:var(--transition-fast);display:flex;justify-content:space-between;align-items:center;color:var(--text-high)}.module-item strong{font-weight:800;letter-spacing:.2px}.module-item:hover{background:#334155b3;transform:translate(4px);box-shadow:var(--shadow)}.module-item.selected{background:linear-gradient(135deg,var(--primary-dark),var(--primary-light));color:var(--white);border-color:var(--primary-color)}.absences-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-bottom:1.25rem}.summary-item{background:#111827d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:1.1rem;border-radius:var(--border-radius-lg);box-shadow:var(--shadow);color:var(--text-high);border:1px solid var(--line)}.summary-item.warning{border-left:5px solid var(--error-color)}.summary-item.info{border-left:5px solid var(--primary-color)}.summary-item strong{font-size:1.25rem;color:#fecaca;display:block;margin-top:.35rem}.no-absences{background:linear-gradient(135deg,#22c55ef2,#10b981f2);color:var(--white);padding:1.25rem 1.5rem;border-radius:var(--border-radius-lg);text-align:center;font-size:1.05rem;font-weight:700;box-shadow:var(--shadow-lg)}.absences-container{display:flex;flex-direction:column;gap:1rem}.day-card{background:#111827e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--border-radius-lg);padding:1.1rem;box-shadow:var(--shadow);color:var(--text-high);border:1px solid var(--line)}.day-card h2{color:var(--primary-light);margin-bottom:.85rem;font-size:1.2rem;text-transform:capitalize;border-bottom:1px solid var(--line);padding-bottom:.5rem}.sessions-list{display:flex;flex-direction:column;gap:.75rem}.session-item{background:#1f2937b3;padding:.9rem 1rem;border-radius:var(--border-radius);border:1px solid var(--line);display:grid;grid-template-columns:auto 1fr auto;gap:.75rem;align-items:center;color:var(--text-high)}.session-item.absent{border-left:4px solid var(--error-color)}.session-time{font-weight:700;color:var(--text-high)}.duration{color:var(--text-muted);font-size:.9rem;margin-left:.35rem}.session-info{color:var(--text-high);opacity:.9}.teacher-name{font-weight:600}.session-status{padding:.4rem .9rem;border-radius:999px;font-size:.85rem;font-weight:700;text-align:center}@media (max-width: 1024px){.bulletin-page h1,.absences-page h1{font-size:2rem}}@media (max-width: 768px){.bulletin-page,.absences-page{padding:1rem}.absences-summary{grid-template-columns:1fr;gap:.85rem}.session-item{grid-template-columns:1fr;gap:.5rem;text-align:center}.ue-card{padding:1rem}.ue-moyenne{flex-direction:column;align-items:flex-start;gap:.35rem}}@media (max-width: 480px){.bulletin-page,.absences-page{padding:.75rem}.day-card h2{font-size:1.05rem}.back-button{width:100%;text-align:center}}.session-status{padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;text-align:center}.session-status.warning{background:var(--error-color);color:var(--white)}.back-button{background:#1e293be6;border:1px solid rgba(148,163,184,.3);padding:.75rem 1.5rem;border-radius:var(--border-radius-lg);color:var(--white);font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 12px #0003;align-self:flex-start}.back-button:hover{background:#334155f2;transform:translateY(-2px);box-shadow:0 8px 20px #0000004d;border-color:var(--primary-color)}@media (max-width: 768px){.bulletin-page,.absences-page{padding:1rem}.bulletin-page h1,.absences-page h1{font-size:1.8rem}.absences-summary{grid-template-columns:1fr;gap:1rem}.session-item{grid-template-columns:1fr;gap:.5rem;text-align:center}.ue-card{padding:1rem}.ue-moyenne{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (max-width: 480px){.bulletin-page,.absences-page{padding:.5rem}.day-card h2{font-size:1.1rem}.back-button{width:100%;text-align:center}}.error-boundary{display:flex;justify-content:center;align-items:center;min-height:200px;padding:2rem}.error-content{background:#111827eb;border-radius:var(--border-radius-lg);padding:2rem;text-align:center;box-shadow:var(--shadow-lg);border:1px solid var(--line);max-width:500px;width:100%}.error-icon{font-size:4rem;margin-bottom:1rem;display:block}.error-content h3{color:#fecaca;margin:0 0 1rem;font-size:1.5rem;font-weight:800}.error-content p{color:var(--text-muted);margin:0 0 2rem;line-height:1.6;font-size:1rem}.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.retry-button{background:var(--error-color);color:var(--white);border:none;padding:.75rem 1.5rem;border-radius:var(--border-radius);cursor:pointer;font-weight:800;font-size:.9rem;transition:var(--transition);display:flex;align-items:center;gap:.5rem;box-shadow:0 10px 24px #ef444440}.retry-button:hover{background:#dc2626;transform:translateY(-2px);box-shadow:var(--shadow-md)}.status-message{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border-radius:var(--border-radius-lg);font-size:.95rem;font-weight:700;margin:1rem 0;border:1px solid var(--line);background:#111827e6;color:var(--text-high)}.status-message-error{border-color:#ef444459;background:#ef44441f;color:#fecaca}.status-message-warning{color:#fde68a;border-color:#f59e0b59;background:#f59e0b1f}.status-message-success{color:#bbf7d0;border-color:#22c55e59;background:#22c55e1f}.status-message-info{color:#c7d2fe;border-color:#6366f159;background:#6366f11f}.status-icon{font-size:1.25rem;flex-shrink:0}.status-content{flex:1}.status-title{font-weight:600;margin-bottom:.25rem}.status-description{opacity:.8;font-size:.9rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;background:#111827e6;border-radius:var(--border-radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--line)}.loading-spinner-large{width:3rem;height:3rem;border:4px solid var(--gray-200);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-title{color:var(--text-high);font-size:1.25rem;font-weight:800;margin-bottom:.5rem}.loading-description{color:var(--text-muted);font-size:.9rem;text-align:center;line-height:1.5}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.75rem;text-align:center;background:#0f172a73;border-radius:var(--border-radius-lg);border:1px dashed var(--line)}.empty-state-icon{font-size:4rem;color:var(--gray-400);margin-bottom:1rem}.empty-state-title{color:var(--text-high);font-size:1.25rem;font-weight:800;margin-bottom:.5rem}.empty-state-description{color:var(--text-muted);font-size:.9rem;line-height:1.5;max-width:400px}@media (max-width: 768px){.error-boundary{padding:1rem;min-height:150px}.error-content{padding:1.5rem}.error-content h3{font-size:1.25rem}.error-icon{font-size:3rem}.loading-container{padding:2rem 1rem}.loading-spinner-large{width:2.5rem;height:2.5rem}.empty-state{padding:3rem 1rem}.empty-state-icon{font-size:3rem}}@media (max-width: 480px){.error-actions{flex-direction:column}.retry-button{width:100%;justify-content:center}.status-message{flex-direction:column;text-align:center}}#root{width:100%;min-height:100vh;margin:0;padding:0;text-align:left}.app-container{width:100%;min-height:100vh;display:flex;flex-direction:column}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.read-the-docs{color:var(--gray-500)}*{box-sizing:border-box}html{width:100%;height:100%}body{width:100%;min-height:100vh;margin:0;padding:0;overflow-x:hidden}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
