@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Playfair+Display:wght@400;700&display=swap";:root{--brand-50: #f0fdfa;--brand-100: #ccfbf1;--brand-200: #99f6e4;--brand-300: #5eead4;--brand-400: #2dd4bf;--brand-500: #14b8a6;--brand-600: #0d9488;--brand-700: #0f766e;--brand-800: #115e59;--brand-900: #134e4a;--brand-950: #042f2e;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--slate-950: #020617;--red-50: #fef2f2;--red-100: #fee2e2;--red-500: #ef4444;--red-600: #dc2626;--red-700: #b91c1c;--amber-50: #fffbeb;--amber-100: #fef3c7;--amber-500: #f59e0b;--amber-600: #d97706;--amber-700: #b45309;--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--purple-50: #faf5ff;--purple-100: #f3e8ff;--purple-500: #a855f7;--purple-600: #9333ea;--purple-700: #7c3aed;--green-50: #f0fdf4;--green-100: #dcfce7;--green-500: #22c55e;--green-600: #16a34a;--green-700: #15803d;--orange-50: #fff7ed;--orange-100: #ffedd5;--orange-500: #f97316;--orange-600: #ea580c;--emerald-50: #ecfdf5;--emerald-100: #d1fae5;--emerald-500: #10b981;--emerald-600: #059669;--pink-50: #fdf2f8;--pink-100: #fce7f3;--pink-500: #ec4899;--pink-600: #db2777;--indigo-50: #eef2ff;--indigo-100: #e0e7ff;--indigo-500: #6366f1;--indigo-600: #4f46e5;--font-sans: "Outfit", system-ui, -apple-system, sans-serif;--font-serif: "Playfair Display", Georgia, serif;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 30px -5px rgba(0, 0, 0, .08);--shadow-xl: 0 20px 50px -10px rgba(0, 0, 0, .12);--shadow-2xl: 0 25px 60px -15px rgba(0, 0, 0, .18);--shadow-brand: 0 4px 14px rgba(13, 148, 136, .25);--shadow-brand-lg: 0 8px 20px rgba(13, 148, 136, .35);--radius-xs: .375rem;--radius-sm: .5rem;--radius: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-2xl: 1.5rem;--radius-3xl: 2rem;--radius-full: 9999px;--sidebar-width: 280px;--header-height: 64px;--transition: .25s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{background:linear-gradient(135deg,#f0fdfa,#f1f5f9,#f0fdfa);font-family:var(--font-sans);color:var(--slate-800);overflow:hidden;height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100vh;overflow:hidden}.custom-select-container{position:relative;width:100%;z-index:1}.custom-select-container.is-open{z-index:9999}.custom-select-trigger{width:100%;padding:.7rem 1rem;background:#fff;border:1.5px solid var(--slate-200);border-radius:var(--radius);font-size:.875rem;font-weight:600;color:var(--slate-700);display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all var(--transition)}.custom-select-trigger:hover{border-color:var(--brand-400);background-color:var(--brand-50)}.custom-select-trigger.active{border-color:var(--brand-500);box-shadow:0 0 0 3px #14b8a61f}.custom-select-trigger i{font-size:.75rem;color:var(--slate-400);transition:transform .3s}.custom-select-trigger i.rotate{transform:rotate(180deg)}.custom-select-dropdown{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--slate-100);box-shadow:var(--shadow-xl);overflow:visible;animation:slideInDown .2s ease-out}.custom-select-option{padding:.75rem 1rem;font-size:.85rem;font-weight:500;color:var(--slate-600);cursor:pointer;transition:all .1s}.custom-select-option:hover{background:var(--brand-50);color:var(--brand-700);padding-left:1.25rem}.custom-select-option.selected{background:var(--brand-500);color:#fff}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}::selection{background:var(--brand-200);color:var(--brand-900)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--slate-300);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--brand-500)}a{text-decoration:none;color:inherit}button{border:none;background:none;cursor:pointer;font-family:inherit;font-size:inherit}input,select,textarea{font-family:inherit}img{max-width:100%;display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.fade-in{animation:fadeIn .5s ease-out forwards}.fade-in-down{animation:fadeInDown .35s ease-out forwards}.fade-in-scale{animation:fadeInScale .4s ease-out forwards}.slide-in-left{animation:slideInLeft .4s ease-out forwards}.slide-in-right{animation:slideInRight .4s ease-out forwards}.stagger>*{opacity:0;animation:fadeIn .4s ease-out forwards}.stagger>*:nth-child(1){animation-delay:.05s}.stagger>*:nth-child(2){animation-delay:.1s}.stagger>*:nth-child(3){animation-delay:.15s}.stagger>*:nth-child(4){animation-delay:.2s}.stagger>*:nth-child(5){animation-delay:.25s}.stagger>*:nth-child(6){animation-delay:.3s}.stagger>*:nth-child(7){animation-delay:.35s}.stagger>*:nth-child(8){animation-delay:.4s}.glass-panel{background:#fffc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.7);box-shadow:0 4px 30px #0000000a}.glass-dark{background:#0f172ad9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08)}.btn-primary{background:linear-gradient(135deg,var(--brand-600) 0%,var(--brand-700) 100%);color:#fff;padding:.6rem 1.4rem;border-radius:var(--radius);font-weight:600;font-size:.825rem;transition:all var(--transition);box-shadow:var(--shadow-brand);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;border:none;white-space:nowrap;position:relative;overflow:hidden;letter-spacing:.01em}.btn-primary:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 60%);opacity:0;transition:opacity var(--transition)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-brand-lg)}.btn-primary:hover:before{opacity:1}.btn-primary:active{transform:translateY(0);box-shadow:var(--shadow-brand)}.btn-primary.btn-red{background:linear-gradient(135deg,var(--red-500) 0%,var(--red-700) 100%);box-shadow:0 4px 14px #dc262640}.btn-primary.btn-red:hover{box-shadow:0 8px 20px #dc262659}.btn-primary.btn-blue{background:linear-gradient(135deg,var(--brand-500) 0%,var(--brand-700) 100%);box-shadow:0 4px 14px #14b8a640}.btn-primary.btn-blue:hover{box-shadow:0 8px 20px #14b8a659}.btn-green{background:linear-gradient(135deg,var(--green-500) 0%,var(--green-700) 100%)!important;box-shadow:0 4px 14px #16a34a40!important}.btn-green:hover{box-shadow:0 8px 20px #16a34a59!important}.btn-primary.btn-orange{background:linear-gradient(135deg,var(--orange-500) 0%,var(--orange-600) 100%);box-shadow:0 4px 14px #f9731640}.btn-primary.btn-purple{background:linear-gradient(135deg,var(--purple-500) 0%,var(--purple-700) 100%);box-shadow:0 4px 14px #9333ea40}.btn-primary.btn-sm{padding:.4rem .9rem;font-size:.7rem}.btn-primary.btn-lg{padding:.875rem 2rem;font-size:1rem;border-radius:var(--radius-lg)}.btn-secondary{background:#fff;color:var(--slate-700);padding:.6rem 1.4rem;border-radius:var(--radius);font-weight:600;font-size:.825rem;transition:all var(--transition);border:1.5px solid var(--slate-200);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--brand-50);border-color:var(--brand-300);color:var(--brand-700);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-ghost{padding:.5rem 1rem;border-radius:var(--radius);font-weight:600;font-size:.825rem;color:var(--slate-500);transition:all var(--transition);display:inline-flex;align-items:center;gap:.5rem}.btn-ghost:hover{background:var(--slate-100);color:var(--slate-700)}.btn-icon{width:34px;height:34px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;transition:all var(--transition);font-size:.8rem;color:var(--slate-400)}.btn-icon:hover{background:var(--slate-100);color:var(--slate-700)}.btn-icon.danger:hover{background:var(--red-50);color:var(--red-500)}.input-field{width:100%;padding:.7rem 1rem;border-radius:var(--radius);border:1.5px solid var(--slate-200);background-color:#fff;font-size:.875rem;transition:all var(--transition);outline:none;color:var(--slate-800);font-weight:500}.input-field:focus{border-color:var(--brand-400);box-shadow:0 0 0 3px #14b8a61f}.input-field::placeholder{color:var(--slate-400);font-weight:400}.input-field:disabled{background:var(--slate-50);color:var(--slate-500);cursor:not-allowed}textarea.input-field{resize:vertical;min-height:90px;line-height:1.6}select.input-field{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5' /%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:1rem;padding-right:2.75rem}select.input-field:hover{border-color:var(--brand-300)}.input-label{display:block;font-size:.65rem;font-weight:800;color:var(--slate-500);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;margin-left:.1rem}.input-group{position:relative}.input-group .input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--slate-400);font-size:.875rem;pointer-events:none}.input-group .input-field{padding-left:2.75rem}.card{background:#fff;border-radius:var(--radius-xl);border:1px solid rgba(0,0,0,.04);box-shadow:var(--shadow);transition:all var(--transition);overflow:hidden}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--brand-100)}.card-static{background:#fff;border-radius:var(--radius-xl);border:1px solid rgba(0,0,0,.04);box-shadow:var(--shadow);overflow:hidden}.card-interactive{background:#fff;border-radius:var(--radius-xl);border:1px solid rgba(0,0,0,.04);box-shadow:var(--shadow);transition:all var(--transition);cursor:pointer}.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--brand-200)}.badge{padding:.2rem .65rem;border-radius:var(--radius-full);font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:.3rem;white-space:nowrap}.badge-admin{background:linear-gradient(135deg,var(--purple-50),var(--purple-100));color:var(--purple-700)}.badge-teacher{background:linear-gradient(135deg,var(--blue-50),var(--blue-100));color:var(--blue-700)}.badge-student{background:linear-gradient(135deg,var(--brand-50),var(--brand-100));color:var(--brand-700)}.badge-family{background:linear-gradient(135deg,var(--amber-50),var(--amber-100));color:var(--amber-700)}.badge-success{background:linear-gradient(135deg,var(--green-50),var(--green-100));color:var(--green-700)}.badge-danger{background:linear-gradient(135deg,var(--red-50),var(--red-100));color:var(--red-700)}.badge-warning{background:linear-gradient(135deg,var(--amber-50),var(--amber-100));color:var(--amber-700)}.badge-info{background:linear-gradient(135deg,var(--brand-50),var(--brand-100));color:var(--brand-700)}.badge-neutral{background:var(--slate-100);color:var(--slate-600)}.badge-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--slate-100)}.data-table{width:100%;text-align:left;font-size:.85rem;border-collapse:collapse}.data-table thead{background:linear-gradient(135deg,var(--slate-50) 0%,rgba(240,253,250,.5) 100%)}.data-table th{padding:.875rem 1.5rem;font-size:.6rem;font-weight:800;color:var(--slate-400);text-transform:uppercase;letter-spacing:.1em}.data-table td{padding:.875rem 1.5rem}.data-table tbody tr{transition:background var(--transition);border-bottom:1px solid var(--slate-50)}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:#f0fdfa80}.stat-card{background:#fff;border-radius:var(--radius-xl);padding:1.5rem;border:1px solid rgba(0,0,0,.04);box-shadow:var(--shadow);transition:all var(--transition);position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;top:0;right:0;width:100px;height:100px;background:radial-gradient(circle at top right,rgba(20,184,166,.03),transparent 70%)}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.stat-card .stat-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:1rem}.stat-card .stat-label{font-size:.625rem;font-weight:700;color:var(--slate-400);text-transform:uppercase;letter-spacing:.08em}.stat-card .stat-value{font-size:2rem;font-weight:800;color:var(--slate-800);margin-top:.2rem;letter-spacing:-.02em}.stat-card .stat-detail{font-size:.7rem;font-weight:600;margin-top:.35rem;padding:.15rem .6rem;border-radius:var(--radius-sm);display:inline-block}.sidebar-nav{padding:.75rem}.nav-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.65rem .85rem;font-size:.825rem;font-weight:500;border-radius:var(--radius-lg);color:var(--slate-500);transition:all var(--transition);cursor:pointer;position:relative;margin-bottom:2px}.nav-item:hover{background:var(--brand-50);color:var(--brand-700);transform:translate(2px)}.nav-item.active{background:linear-gradient(135deg,var(--brand-600),var(--brand-700));color:#fff;font-weight:700;box-shadow:var(--shadow-brand)}.nav-item.active:hover{transform:none}.nav-item i{width:1.25rem;text-align:center;font-size:.9rem}.nav-section-title{padding:0 .85rem;font-size:.575rem;font-weight:800;color:var(--slate-400);text-transform:uppercase;letter-spacing:.18em;margin-bottom:.4rem;margin-top:1.75rem}.nav-section-title:first-child{margin-top:.5rem}.modal-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#02061773;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .25s;overflow-y:auto;padding:2rem}.modal-overlay.open{opacity:1;pointer-events:all}.modal-container{background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);width:100%;max-width:42rem;max-height:calc(100vh - 4rem);display:flex;flex-direction:column;transform:scale(.92) translateY(10px);transition:transform .3s cubic-bezier(.34,1.56,.64,1);border:1px solid rgba(255,255,255,.5);margin:auto}.modal-overlay.open .modal-container{transform:scale(1) translateY(0)}.modal-header{padding:1.25rem 1.75rem;border-bottom:1px solid var(--slate-100);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#f0fdfa80,#fff);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0}.modal-header h3{font-family:var(--font-serif);font-weight:700;font-size:1.1rem;color:var(--brand-900)}.modal-body{padding:2rem;overflow-y:auto}.modal-close{width:2.25rem;height:2.25rem;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--slate-400);transition:all var(--transition)}.modal-close:hover{background:var(--red-50);color:var(--red-500);transform:rotate(90deg)}.form-stack{display:flex;flex-direction:column;gap:1.25rem}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.form-grid .full-width{grid-column:span 2}.form-group{display:flex;flex-direction:column;gap:.3rem}.checkbox-group{display:flex;align-items:center;gap:.6rem;margin-top:.5rem}.checkbox-group input[type=checkbox]{width:1.1rem;height:1.1rem;accent-color:var(--brand-600);cursor:pointer;border-radius:4px}.checkbox-group label{font-size:.85rem;color:var(--slate-600);font-weight:500;cursor:pointer}.tab-bar{background:#fff;border:1.5px solid var(--slate-200);padding:.3rem;border-radius:var(--radius-lg);display:inline-flex;gap:.2rem;box-shadow:var(--shadow-xs)}.tab-btn{padding:.55rem 1.5rem;border-radius:var(--radius);font-size:.8rem;font-weight:700;transition:all var(--transition);color:var(--slate-500);cursor:pointer;letter-spacing:.01em}.tab-btn:hover{color:var(--slate-800);background:var(--slate-50)}.tab-btn.active{background:linear-gradient(135deg,var(--brand-600),var(--brand-700));color:#fff;box-shadow:var(--shadow-brand)}.quick-action-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:1rem}.quick-action{padding:1.25rem 1rem;background:var(--slate-50);border-radius:var(--radius-xl);display:flex;flex-direction:column;align-items:center;gap:.65rem;transition:all var(--transition);cursor:pointer;border:1.5px solid transparent}.quick-action:hover{background:#fff;border-color:var(--brand-200);box-shadow:var(--shadow-md);transform:translateY(-3px)}.quick-action .qa-icon{width:2.75rem;height:2.75rem;background:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);font-size:1.05rem;transition:all var(--transition)}.quick-action:hover .qa-icon{transform:scale(1.12);box-shadow:var(--shadow-md)}.quick-action span{font-size:.7rem;font-weight:700;color:var(--slate-600);text-align:center}.att-toggle-btn{padding:.4rem .85rem;border-radius:var(--radius);font-size:.7rem;font-weight:700;border:1.5px solid var(--slate-200);color:var(--slate-500);transition:all var(--transition);cursor:pointer}.att-toggle-btn.present-active{background:linear-gradient(135deg,var(--brand-50),var(--brand-100));color:var(--brand-700);border-color:var(--brand-200);box-shadow:0 2px 8px #14b8a626}.att-toggle-btn.absent-active{background:linear-gradient(135deg,var(--red-50),var(--red-100));color:var(--red-700);border-color:var(--red-100);box-shadow:0 2px 8px #ef444426}.att-toggle-btn.late-active{background:linear-gradient(135deg,var(--amber-50),var(--amber-100));color:var(--amber-700);border-color:var(--amber-100);box-shadow:0 2px 8px #f59e0b26}.att-toggle-btn:hover:not(.present-active):not(.absent-active):not(.late-active){background:var(--slate-50);border-color:var(--slate-300)}.schedule-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.75rem;text-align:center}.schedule-day{background:#fff;padding:.5rem;border-radius:var(--radius-xl);border:1.5px solid var(--slate-100);display:flex;flex-direction:column;min-height:280px;transition:all var(--transition)}.schedule-day:hover{border-color:var(--brand-200);box-shadow:var(--shadow-sm)}.schedule-day.weekend{background:var(--slate-50);border-color:var(--slate-100)}.schedule-day-header{font-weight:800;color:var(--brand-800);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;padding:.6rem;border-bottom:1.5px solid var(--slate-100);margin-bottom:.5rem}.schedule-day.weekend .schedule-day-header{color:var(--slate-400)}.schedule-block{padding:.6rem;background:linear-gradient(135deg,var(--brand-50) 0%,white 100%);border-radius:var(--radius);border-left:3px solid var(--brand-500);box-shadow:var(--shadow-xs);text-align:left;margin-bottom:.4rem;transition:all var(--transition)}.schedule-block:hover{box-shadow:var(--shadow-sm);transform:scale(1.02)}.schedule-block .sb-time{font-size:.575rem;font-weight:700;color:var(--slate-400);margin-bottom:.15rem;letter-spacing:.03em}.schedule-block .sb-name{font-size:.7rem;font-weight:700;color:var(--brand-800);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.schedule-block .sb-class{font-size:.575rem;color:var(--slate-500)}.spinner{animation:spin 1s linear infinite;font-size:1.5rem;color:var(--brand-500)}.loading-center{display:flex;justify-content:center;align-items:center;padding:4rem 0}.hero-banner{background:linear-gradient(135deg,var(--brand-950) 0%,var(--brand-800) 40%,var(--brand-700) 100%);background-size:200% 200%;animation:gradientShift 8s ease infinite;padding:2.5rem;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);color:#fff;position:relative;overflow:hidden}.hero-banner:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='white' fill-opacity='0.03'%3E%3Cpath d='M20 20.5V18H0v-2h20v-2H0v-2h20v-2H0V8h20V6H0V4h20V2H0V0h22v20h2V0h2v20h2V0h2v20h2V0h2v20h2V0h2v22H20v-1.5zM0 20h2v20H0V20zm4 0h2v20H4V20zm4 0h2v20H8V20zm4 0h2v20h-2V20zm4 0h2v20h-2V20zm4 0h2v20h-2V20zM0 20'/%3E%3C/g%3E%3C/svg%3E");pointer-events:none}.hero-banner .hero-icon{position:absolute;top:-10px;right:-10px;padding:2rem;opacity:.08;font-size:10rem;animation:float 4s ease-in-out infinite}.hero-banner .hero-content{position:relative;z-index:2}.hero-date{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;opacity:.6;margin-bottom:.75rem}.hero-title{font-family:var(--font-serif);font-size:2.75rem;font-weight:700;margin-bottom:.5rem;letter-spacing:-.01em}.hero-subtitle{font-size:.9rem;opacity:.75;max-width:32rem;line-height:1.6}.message-card{display:flex;gap:.875rem;padding:1rem 1.25rem;border-radius:var(--radius-lg);transition:all var(--transition);cursor:pointer;border:1.5px solid transparent}.message-card:hover{background:var(--slate-50);border-color:var(--slate-100)}.message-card.active{background:linear-gradient(135deg,var(--brand-50) 0%,rgba(240,253,250,.5) 100%);border-color:var(--brand-200)}.message-avatar{width:2.75rem;height:2.75rem;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--brand-100),var(--brand-200));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;color:var(--brand-700);flex-shrink:0}.message-content{flex:1;min-width:0}.message-sender{font-weight:700;font-size:.85rem;color:var(--slate-800)}.message-preview{font-size:.75rem;color:var(--slate-400);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:.15rem}.message-time{font-size:.6rem;color:var(--slate-400);white-space:nowrap;font-weight:600}.chat-bubble{max-width:75%;padding:.875rem 1.15rem;border-radius:var(--radius-xl);font-size:.85rem;line-height:1.55;position:relative;animation:fadeIn .3s ease-out}.chat-bubble.sent{background:linear-gradient(135deg,var(--brand-600),var(--brand-700));color:#fff;border-bottom-right-radius:var(--radius-xs);margin-left:auto}.chat-bubble.received{background:var(--slate-100);color:var(--slate-700);border-bottom-left-radius:var(--radius-xs)}.chat-time{font-size:.55rem;opacity:.6;margin-top:.35rem;text-align:right;font-weight:600}.certificate-border{border:8px double var(--brand-900);outline:2px solid var(--brand-600);outline-offset:6px;padding:3rem}@media(max-width:1024px){.schedule-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.form-grid .full-width{grid-column:span 1}.schedule-grid{grid-template-columns:1fr 1fr}.hero-title{font-size:1.75rem}.quick-action-grid{grid-template-columns:repeat(2,1fr)}}.empty-state{text-align:center;padding:3rem 2rem;color:var(--slate-400)}.empty-state i{font-size:2.5rem;margin-bottom:1rem;opacity:.3}.empty-state p{font-size:.85rem;font-style:italic}.page-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-section-header h3{font-family:var(--font-serif);font-weight:700;font-size:1.15rem;color:var(--slate-800)}.text-center{text-align:center}.text-right{text-align:right}.font-serif{font-family:var(--font-serif)}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.divider{height:1px;background:linear-gradient(90deg,transparent,var(--slate-200),transparent);margin:1.5rem 0}.dialog-overlay{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:#02061780;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:2rem;animation:dialogFadeIn .2s ease}.dialog-overlay.open{opacity:1}@keyframes dialogFadeIn{0%{opacity:0}to{opacity:1}}@keyframes dialogSlideIn{0%{transform:scale(.9) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.dialog-box{background:#fff;border-radius:var(--radius-2xl);box-shadow:0 25px 60px #00000040,0 0 0 1px #ffffff1a;padding:2rem 2rem 1.5rem;max-width:420px;width:100%;text-align:center;animation:dialogSlideIn .3s cubic-bezier(.34,1.56,.64,1)}.dialog-icon-wrap{width:56px;height:56px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.4rem}.dialog-title{font-family:var(--font-serif);font-size:1.15rem;font-weight:700;color:var(--slate-800);margin-bottom:.5rem}.dialog-message{font-size:.85rem;color:var(--slate-500);line-height:1.6;margin-bottom:1.5rem}.dialog-actions{display:flex;gap:.75rem;justify-content:center}.dialog-btn{padding:.6rem 1.5rem;border-radius:var(--radius-lg);font-size:.8rem;font-weight:700;cursor:pointer;transition:all var(--transition);min-width:100px}.dialog-btn-cancel{background:var(--slate-100);color:var(--slate-600);border:1.5px solid var(--slate-200)}.dialog-btn-cancel:hover{background:var(--slate-200);color:var(--slate-800)}.dialog-btn-confirm{background:linear-gradient(135deg,var(--brand-600),var(--brand-700));color:#fff;border:none;box-shadow:var(--shadow-brand)}.dialog-btn-confirm:hover{transform:translateY(-1px);box-shadow:0 6px 20px #14b8a659}.dialog-btn-confirm.danger{background:linear-gradient(135deg,var(--red-500),var(--red-600));box-shadow:0 4px 14px #ef444440}.dialog-btn-confirm.danger:hover{box-shadow:0 6px 20px #ef444459}
