@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,600;9..144,700&family=DM+Sans:wght@300;400;500;600&display=swap";@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=Playfair+Display:ital,wght@0,500;0,600;0,700;1,500;1,600&display=swap";:root{--color-crimson-900: #2D0607;--color-crimson-800: #3D0A0C;--color-crimson-700: #4B0C0E;--color-crimson-600: #6B1315;--color-crimson-500: #7A1A1D;--color-crimson-400: #9B2528;--color-crimson-300: #C44044;--color-crimson-200: #E07073;--color-crimson-100: #F5B8BA;--color-gold-700: #8B6020;--color-gold-600: #A87830;--color-gold-500: #C9933A;--color-gold-400: #D9A850;--color-gold-300: #E8B85A;--color-gold-200: #F2D08A;--color-gold-100: #FAF0D0;--color-cream-100: #FDF8F0;--color-cream-200: #F5ECD7;--color-cream-300: #E8D9C0;--color-cream-400: #C8B8A0;--color-cream-500: #A89880;--color-cream-600: #887060;--color-cream-700: #5A4840;--color-bg: var(--color-crimson-900);--color-surface: var(--color-crimson-800);--color-surface-raised: var(--color-crimson-700);--color-border: rgba(201, 147, 58, .18);--color-border-hover: rgba(201, 147, 58, .4);--color-primary: var(--color-crimson-700);--color-primary-hover: var(--color-crimson-500);--color-accent: var(--color-gold-500);--color-accent-hover: var(--color-gold-400);--color-text-primary: var(--color-cream-200);--color-text-secondary: var(--color-cream-500);--color-text-muted: var(--color-cream-600);--color-success: #3DAA6A;--color-success-bg: rgba(61, 170, 106, .12);--color-error: #E05A5A;--color-error-bg: rgba(224, 90, 90, .12);--color-warning: #E8943A;--color-warning-bg: rgba(232, 148, 58, .12);--color-info: #5A9EE0;--color-info-bg: rgba(90, 158, 224, .12);--font-display: "Fraunces", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-size-6xl: 3.75rem;--font-weight-light: 300;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-snug: 1.375;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--letter-spacing-tight: -.02em;--letter-spacing-normal: 0em;--letter-spacing-wide: .04em;--letter-spacing-wider: .08em;--letter-spacing-widest: .15em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6);--shadow-glow-gold: 0 0 24px rgba(201, 147, 58, .2);--shadow-glow-gold-strong: 0 0 40px rgba(201, 147, 58, .35);--shadow-glow-crimson: 0 0 24px rgba(75, 12, 14, .6);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--z-base: 0;--z-raised: 10;--z-overlay: 100;--z-modal: 200;--z-toast: 300;--z-top: 400;--container-max-width: 1200px;--container-padding: var(--space-6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-surface)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-hover)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:var(--radius-sm)}::selection{background:#c9933a40;color:var(--color-cream-100)}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}img{display:block;max-width:100%;height:auto}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit}ul,ol{list-style:none}.container{width:100%;max-width:var(--container-max-width);margin-inline:auto;padding-inline:var(--container-padding)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.gold-divider{width:60px;height:2px;background:linear-gradient(90deg,var(--color-gold-500),var(--color-gold-300));border-radius:var(--radius-full)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:var(--line-height-tight);color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}h1{font-size:var(--font-size-5xl);letter-spacing:var(--letter-spacing-tight)}h2{font-size:var(--font-size-4xl);letter-spacing:var(--letter-spacing-tight)}h3{font-size:var(--font-size-3xl)}h4{font-size:var(--font-size-2xl)}h5{font-size:var(--font-size-xl)}h6{font-size:var(--font-size-lg)}.text-display{font-family:var(--font-display);font-size:var(--font-size-6xl);font-weight:var(--font-weight-bold);line-height:1.05;letter-spacing:var(--letter-spacing-tight)}p{color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-accent)}.text-error{color:var(--color-error)}.font-display{font-family:var(--font-display)}.font-body{font-family:var(--font-body)}.font-light{font-weight:var(--font-weight-light)}.font-regular{font-weight:var(--font-weight-regular)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.overline{font-family:var(--font-body);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-widest);text-transform:uppercase;color:var(--color-accent)}.text-gradient-gold{background:linear-gradient(135deg,var(--color-gold-300),var(--color-gold-500),var(--color-gold-300));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.google-login-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.google-login-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-3);background:#0003;border:1px solid var(--color-crimson-400);border-radius:40px;padding:14px 40px;font-family:var(--font-body);font-size:.85rem;font-weight:300;color:#fff;letter-spacing:.08em;cursor:pointer;outline:none;box-shadow:inset 0 0 10px #9b25281a,0 0 15px #4b0c0e4d;transition:all .3s ease;position:relative;overflow:hidden;min-width:260px}.google-login-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:40px;box-shadow:inset 0 0 15px var(--color-crimson-600);pointer-events:none;opacity:.6}.google-login-btn:hover:not(:disabled){background:#2d060766;box-shadow:inset 0 0 15px #c8252833,0 0 25px #4b0c0e80;transform:translateY(-1px)}.google-login-btn:active:not(:disabled){transform:translateY(0)}.google-login-btn:disabled{opacity:.6;cursor:not-allowed}.google-login-btn__icon{width:20px;height:20px;flex-shrink:0}.google-login-btn__text{width:140px;text-align:left}.google-login-btn__spinner{width:20px;height:20px;flex-shrink:0;box-sizing:border-box;border:2px solid rgba(201,147,58,.3);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.google-login-error{font-size:var(--font-size-sm);color:var(--color-error);text-align:center}.auth-guard-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg)}.loading-spinner{width:40px;height:40px;border:3px solid rgba(201,147,58,.2);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.policy-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .3s ease-out}.policy-modal-content{background:#1c0406;width:100%;max-width:650px;max-height:85vh;border-radius:var(--radius-xl);border:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #00000080}.policy-modal-header{padding:var(--space-6) var(--space-8);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.policy-modal-header h2{margin:0;font-family:var(--font-display);font-size:var(--font-size-2xl);color:var(--color-accent)}.policy-close-btn{background:transparent;border:none;color:var(--color-text-secondary);font-size:2rem;line-height:1;cursor:pointer;transition:color .2s}.policy-close-btn:hover{color:var(--color-text-primary)}.policy-modal-body{padding:var(--space-8);overflow-y:auto;font-family:var(--font-body);color:var(--color-text-secondary);line-height:1.6}.policy-updated{font-size:.85rem;font-style:italic;margin-bottom:var(--space-6);opacity:.6}.policy-modal-body section{margin-bottom:var(--space-8)}.policy-modal-body h3{color:var(--color-text-primary);font-size:var(--font-size-lg);margin-bottom:var(--space-3);font-family:var(--font-display)}.policy-modal-body ul{margin-top:var(--space-3);padding-left:var(--space-5)}.policy-modal-body li{margin-bottom:var(--space-2)}.policy-modal-footer{padding:var(--space-6) var(--space-8);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end}.policy-btn-primary{background:var(--color-accent);color:#000;border:none;padding:var(--space-3) var(--space-8);border-radius:var(--radius-full);font-weight:600;cursor:pointer;transition:transform .2s}.policy-btn-primary:hover{transform:translateY(-2px);background:#e5c284}.login-page{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;color:#fff;font-family:var(--font-body);background:#1a0203;box-shadow:inset 0 0 120px #00000080}.login-video-wrapper{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden}.login-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center 5%;transform:scale(1.35);transform-origin:center 15%}.login-video-scrim{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:linear-gradient(to bottom,#00000026,#0a010133 38%,#280506cc 58%,#150203f5 75%,#0a0000)}.login-mobile-header{position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 20px;display:flex;align-items:center;justify-content:flex-start;background:linear-gradient(to bottom,rgba(0,0,0,.5) 0%,transparent 100%)}.login-mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:60px}.login-mobile-content{width:100%;display:flex;flex-direction:column;align-items:center;gap:16px;padding:0 32px;animation:fade-up .9s cubic-bezier(.16,1,.3,1) both;animation-delay:.2s}.login-desktop-panel{display:none}@media(min-width:900px){.login-video-wrapper{left:44%;right:0;top:0;bottom:0}.login-video{transform:scale(1);object-position:center 8%}.login-video-scrim{background:linear-gradient(to right,#37080aeb,#2d060799 20%,#1e040533 42%,#0000)}.login-mobile-header,.login-mobile-overlay{display:none}.login-desktop-panel{display:flex;position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;flex-direction:column;align-items:flex-start;justify-content:center;padding:0 0 0 8vw;background:linear-gradient(to right,rgba(38,5,6,1) 0%,rgba(50,8,9,.99) 22%,rgba(68,11,13,.95) 40%,rgba(55,9,10,.78) 58%,rgba(35,5,6,.4) 75%,rgba(15,2,3,.12) 88%,transparent 100%)}.login-desktop-menu-btn{position:fixed;top:28px;left:28px;z-index:30}.login-desktop-content{display:flex;flex-direction:column;align-items:flex-start;gap:0;max-width:480px;animation:fade-up .9s cubic-bezier(.16,1,.3,1) both;animation-delay:.1s}}.login-logo-image{width:100%;max-width:260px;height:auto;object-fit:contain;filter:drop-shadow(0 4px 24px rgba(155,37,40,.45))}@media(min-width:900px){.login-logo-image{max-width:420px;filter:drop-shadow(0 4px 32px rgba(155,37,40,.55))}}.login-subtitle{font-size:.72rem;font-weight:700;letter-spacing:.38em;color:#ffffff8c;text-transform:uppercase;margin:4px 0 0 2px}@media(min-width:900px){.login-subtitle{font-size:.9rem;letter-spacing:.48em;margin-top:8px;margin-left:0;text-align:center;width:100%;max-width:420px}}.login-action-area{margin-top:28px;width:100%;display:flex;justify-content:center}@media(min-width:900px){.login-action-area{justify-content:center;margin-top:24px;margin-left:0;width:100%;max-width:420px}}.login-quotes{display:none}@media(min-width:900px){.login-quotes{display:flex;flex-direction:column;align-items:flex-start;margin-top:56px;margin-left:0;min-height:90px;overflow:hidden;padding-top:24px;border-top:1px solid rgba(155,37,40,.3);width:100%;max-width:420px}}.login-quote-inner{transition:opacity .35s ease}.login-quote-inner.fading{opacity:0}.login-quote-body{font-size:.78rem;color:#ffffff80;line-height:1.65;text-transform:uppercase;letter-spacing:.06em;margin:0;max-width:360px}.login-quote-author{font-size:.62rem;font-weight:600;color:#9b2528d9;letter-spacing:.15em;text-transform:uppercase;margin-top:8px}.login-pagination{margin-top:20px;display:flex;gap:10px}.login-dot{width:5px;height:5px;border-radius:50%;background:transparent;border:1px solid rgba(255,255,255,.35);cursor:pointer;transition:all .3s ease;padding:0}.login-dot.active{background:#9b2528e6;border-color:#9b2528e6;transform:scale(1.4)}.login-footer{display:none}@media(min-width:900px){.login-footer{display:flex;position:fixed;bottom:28px;left:6vw;z-index:25}.login-footer-nav{display:flex;gap:20px;align-items:center}.login-footer-icon{display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.25);border-radius:50%;width:30px;height:30px;opacity:.5;cursor:pointer;color:#fff;text-decoration:none;transition:opacity .2s ease,border-color .2s ease}.login-footer-icon:hover{opacity:.9;border-color:#9b2528cc}}.login-icon-btn{background:transparent;border:none;color:#fff;display:flex;align-items:center;justify-content:center;width:44px;height:44px;cursor:pointer;transition:opacity .2s ease;padding:0}.login-icon-btn:hover{opacity:.7}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s ease}.sidebar-overlay.open{opacity:1;pointer-events:auto}.sidebar-panel{position:absolute;top:0;left:0;bottom:0;width:80%;max-width:290px;background:linear-gradient(160deg,#1a0405,#0a0000);border-right:1px solid rgba(155,37,40,.2);transform:translate(-100%);transition:transform .4s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column}.sidebar-overlay.open .sidebar-panel{transform:translate(0)}.sidebar-header{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center}.sidebar-logo-image{height:28px;width:auto;object-fit:contain}.sidebar-nav{flex:1;padding:32px 24px;display:flex;flex-direction:column;gap:20px}.sidebar-link{color:#ffffffbf;text-decoration:none;font-size:.9rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;transition:color .2s ease;background:none;border:none;cursor:pointer;padding:0;font-family:inherit;text-align:left}.sidebar-link:hover{color:#fff}.sidebar-footer{padding:20px 24px;border-top:1px solid rgba(255,255,255,.08);text-align:center;font-size:.68rem;color:#ffffff40;letter-spacing:.05em}.sidebar-socials{padding:0 24px 20px;display:flex;gap:16px;justify-content:center}.sidebar-social-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.15);color:#fff9;transition:all .2s ease}.sidebar-social-icon:hover{color:#fff;border-color:#9b2528cc;background:#9b25281a}@keyframes fade-up{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}.animate-slide-up{animation:fade-up .7s cubic-bezier(.16,1,.3,1) both}.delay-100{animation-delay:80ms}.delay-200{animation-delay:.16s}.delay-300{animation-delay:.24s}.delay-400{animation-delay:.32s}.shell{display:flex;min-height:100dvh;background:var(--color-bg);color:var(--color-text-primary);font-family:var(--font-body)}.shell-sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;z-index:var(--z-overlay);display:flex;flex-direction:column;background:linear-gradient(180deg,#1c0406,#0d0101);border-right:1px solid var(--color-border);transform:translate(-260px);transition:transform .38s cubic-bezier(.16,1,.3,1)}@media(min-width:900px){.shell-sidebar{transform:translate(0);position:sticky;top:0;height:100dvh;flex-shrink:0}}.shell-sidebar--open{transform:translate(0)}.shell-sidebar__brand{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-6) var(--space-6);border-bottom:1px solid rgba(201,147,58,.15)}.shell-brand-logo{height:36px;width:auto;max-width:100%;object-fit:contain}.shell-nav{flex:1;padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-1)}.shell-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;letter-spacing:.03em;transition:background var(--transition-fast),color var(--transition-fast)}.shell-nav-link:hover{background:#c9933a14;color:var(--color-text-primary)}.shell-nav-link--active{background:#c9933a24;color:var(--color-accent);border-left:2px solid var(--color-accent);padding-left:calc(var(--space-4) - 2px)}.shell-nav-link__icon{display:flex;align-items:center;opacity:.8}.shell-nav-link--active .shell-nav-link__icon{opacity:1}.shell-sidebar__footer{padding:var(--space-5) var(--space-4);border-top:1px solid rgba(255,255,255,.06)}.shell-logout-btn{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);font-family:var(--font-body);text-align:left}.shell-logout-btn:hover{background:#e05a5a1a;color:var(--color-error)}.shell-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:calc(var(--z-overlay) - 1)}.shell-overlay--open{display:block}@media(min-width:900px){.shell-overlay{display:none!important}}.shell-body{flex:1;display:flex;flex-direction:column;min-width:0;min-height:100dvh}@media(min-width:900px){.shell-body{margin-left:0}}.shell-topbar{position:sticky;top:0;z-index:var(--z-raised);display:flex;align-items:center;gap:var(--space-4);padding:0 var(--space-6);height:64px;background:#0d0101d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);flex-shrink:0}.shell-hamburger{display:flex;background:transparent;border:none;color:var(--color-text-primary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);transition:background var(--transition-fast);flex-shrink:0}.shell-hamburger:hover{background:#ffffff12}@media(min-width:900px){.shell-hamburger{display:none}}.shell-topbar__title{flex:1}.shell-page-title{font-family:var(--font-body);font-size:var(--font-size-base);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-secondary);margin:0}.shell-user-container{position:relative;margin-left:auto}.shell-user{display:flex;align-items:center;gap:var(--space-3);background:transparent;border:1px solid transparent;padding:var(--space-1) var(--space-2);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);color:inherit;font-family:inherit}.shell-user:hover,.shell-user--active{background:#ffffff0d;border-color:#c9933a33}.shell-user__avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(201,147,58,.4);flex-shrink:0}.shell-user__avatar--placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-crimson-700);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:700}.shell-user__info{display:flex;flex-direction:column;align-items:flex-end}.shell-user__name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}.shell-user__role{font-size:.68rem;font-weight:500;color:var(--color-accent);text-transform:uppercase;letter-spacing:.08em}.shell-user-dropdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100}.shell-user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:220px;background:#1c0406;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:101;padding:var(--space-1) 0;animation:slideDown .25s cubic-bezier(.16,1,.3,1)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.shell-user-dropdown__header{padding:var(--space-3) var(--space-4)}.shell-user-dropdown__name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin:0}.shell-user-dropdown__email{font-size:.75rem;color:var(--color-text-secondary);margin:0;word-break:break-all}.shell-user-dropdown__item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);border:none;background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-align:left}.shell-user-dropdown__item:hover{background:#ffffff0d;color:var(--color-text-primary)}.shell-user-dropdown__item--logout:hover{color:var(--color-error);background:#e05a5a14}@media(max-width:480px){.shell-user__info{display:none}}.shell-main{flex:1;padding:var(--space-8) var(--space-6);max-width:1100px;width:100%;margin:0 auto}@media(max-width:600px){.shell-main{padding:var(--space-6) var(--space-4)}}.dashboard-loading{display:flex;align-items:center;justify-content:center;min-height:100dvh;background:var(--color-bg)}.dashboard-welcome{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-10);padding-bottom:var(--space-8);border-bottom:1px solid var(--color-border)}.dashboard-welcome__greeting{font-size:var(--font-size-sm);font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);margin:0 0 var(--space-2)}.dashboard-welcome__name{font-family:var(--font-display);font-size:var(--font-size-4xl);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-3);line-height:var(--line-height-tight)}.dashboard-welcome__badge{display:inline-block;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:var(--radius-full);background:#c9933a1f;color:var(--color-accent);border:1px solid rgba(201,147,58,.3)}.dashboard-welcome__badge[data-role=admin],.dashboard-welcome__badge[data-role=teacher]{background:#5a9ee01f;color:var(--color-info);border-color:#5a9ee04d}.dashboard-section{margin-bottom:var(--space-12)}.dashboard-section__title{font-family:var(--font-body);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted);margin:0 0 var(--space-5)}.dashboard-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-4);margin-bottom:var(--space-8)}.dashboard-stat-card{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-6);background:#ffffff08;border:1px solid var(--color-border);border-radius:var(--radius-xl);text-decoration:none;transition:border-color var(--transition-base),background var(--transition-base),transform var(--transition-fast)}.dashboard-stat-card:hover{border-color:var(--color-border-hover);background:#ffffff0f;transform:translateY(-2px)}.dashboard-stat-card--success{border-color:#3daa6a33}.dashboard-stat-card--success:hover{border-color:#3daa6a73}.dashboard-stat-card--warning{border-color:#e8943a33}.dashboard-stat-card--warning:hover{border-color:#e8943a73}.dashboard-stat-card__value{font-family:var(--font-display);font-size:var(--font-size-5xl);font-weight:600;color:var(--color-text-primary);line-height:1}.dashboard-stat-card__label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500;margin-top:var(--space-2)}.dashboard-stat-card__hint{font-size:var(--font-size-xs);color:var(--color-accent);margin-top:auto;padding-top:var(--space-4);opacity:.7}.dashboard-stat-card:hover .dashboard-stat-card__hint{opacity:1}.dashboard-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-5)}.dashboard-card{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-8);background:#ffffff08;border:1px solid var(--color-border);border-radius:var(--radius-xl);text-decoration:none;color:inherit;transition:border-color var(--transition-base),background var(--transition-base),transform var(--transition-fast)}.dashboard-card:not(.dashboard-card--muted):hover{border-color:var(--color-border-hover);background:#ffffff0f;transform:translateY(-2px)}.dashboard-card--muted{opacity:.55;cursor:default}.dashboard-card__icon{font-size:1.6rem;margin-bottom:var(--space-1)}.dashboard-card__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:600;color:var(--color-text-primary);margin:0}.dashboard-card__desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0;flex:1}.dashboard-card__link{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent);margin-top:var(--space-2)}.dashboard-card__coming-soon{display:inline-block;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);background:#ffffff0d;border-radius:var(--radius-full);padding:3px 10px;margin-top:var(--space-2);align-self:flex-start}.onboarding-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:var(--space-8) var(--space-6) var(--space-16);background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(75,12,14,.8) 0%,var(--color-bg) 60%);position:relative;overflow:hidden}.onboarding-bg-orb{position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(201,147,58,.06) 0%,transparent 70%);top:-200px;left:50%;transform:translate(-50%);pointer-events:none;z-index:0}.onboarding-header{text-align:center;margin-bottom:var(--space-8);z-index:1}.onboarding-header__logo{height:48px;width:auto;max-width:100%;object-fit:contain;margin-bottom:var(--space-2)}.onboarding-progress{display:flex;align-items:flex-start;gap:0;margin-bottom:var(--space-8);z-index:1;width:100%;max-width:680px}.progress-step{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);flex:1;position:relative}.progress-step:not(:last-child):after{content:"";position:absolute;top:16px;left:calc(50% + 16px);right:calc(-50% + 16px);height:2px;background:var(--color-border);z-index:-1}.progress-step--done:not(:last-child):after{background:var(--color-gold-500)}.progress-step__dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);border:2px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);transition:all var(--transition-base);z-index:1}.progress-step--done .progress-step__dot{background:var(--color-gold-500);border-color:var(--color-gold-500);color:var(--color-crimson-900)}.progress-step--active .progress-step__dot{background:var(--color-crimson-600);border-color:var(--color-gold-500);color:var(--color-gold-300);box-shadow:0 0 0 4px #c9933a26}.progress-step__label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:center;white-space:nowrap}.progress-step--active .progress-step__label{color:var(--color-accent);font-weight:var(--font-weight-medium)}.onboarding-card{width:100%;max-width:680px;background:#2d0607a6;border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-10);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-lg),0 0 0 1px #c9933a0d inset;z-index:1;animation:card-enter .3s ease both}.onboarding-step-title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-3)}.onboarding-fields{display:flex;flex-direction:column;gap:var(--space-5)}.field-row{display:flex;flex-direction:column;gap:var(--space-2)}.field-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.field-hint{font-weight:var(--font-weight-regular);color:var(--color-text-muted);font-size:var(--font-size-xs)}.field-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.field-section-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-accent);letter-spacing:var(--letter-spacing-wide);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border)}.field-group{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.field-input,.field-select,.field-textarea{width:100%;padding:var(--space-3) var(--space-4);background:#ffffff0a;border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none}.field-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23A89880' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8)}.field-select option{background:var(--color-surface);color:var(--color-text-primary)}.field-input::placeholder,.field-textarea::placeholder{color:var(--color-text-muted)}.field-input--readonly{background:#ffffff08!important;border-color:#ffffff0d!important;color:var(--color-text-muted)!important;cursor:not-allowed;opacity:.8}.field-input:focus,.field-select:focus,.field-textarea:focus{outline:none;border-color:var(--color-border-hover);box-shadow:0 0 0 3px #c9933a1f}.field-textarea{resize:vertical;line-height:var(--line-height-relaxed)}.field-input--signature{font-family:var(--font-display);font-size:var(--font-size-lg);font-style:italic;letter-spacing:.02em}.checkbox-grid{display:flex;flex-wrap:wrap;gap:var(--space-3)}.checkbox-card{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:all var(--transition-fast)}.checkbox-card:hover{border-color:var(--color-border-hover);color:var(--color-text-primary)}.checkbox-card--checked{background:#c9933a1f;border-color:var(--color-gold-500);color:var(--color-accent)}.checkbox-card input[type=checkbox]{accent-color:var(--color-accent);width:16px;height:16px}.radio-group{display:flex;gap:var(--space-3)}.radio-card{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:all var(--transition-fast)}.radio-card:hover{border-color:var(--color-border-hover)}.radio-card--checked{background:#c9933a1f;border-color:var(--color-gold-500);color:var(--color-accent);font-weight:var(--font-weight-medium)}.radio-card input[type=radio]{accent-color:var(--color-accent)}.declaration-box{background:#c9933a0f;border:1px solid rgba(201,147,58,.2);border-radius:var(--radius-lg);padding:var(--space-5)}.declaration-label{display:flex;gap:var(--space-3);align-items:flex-start;font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);cursor:pointer}.declaration-label input[type=checkbox]{accent-color:var(--color-accent);width:18px;height:18px;flex-shrink:0;margin-top:2px}.onboarding-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-border)}.btn{padding:var(--space-3) var(--space-8);border-radius:var(--radius-lg);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border:none;transition:all var(--transition-fast)}.btn--primary{background:linear-gradient(135deg,var(--color-gold-600),var(--color-gold-500));color:var(--color-crimson-900);font-weight:var(--font-weight-semibold)}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-gold-500),var(--color-gold-400));box-shadow:var(--shadow-glow-gold);transform:translateY(-1px)}.btn--primary:disabled{opacity:.6;cursor:not-allowed}.btn--secondary{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.btn--secondary:hover{border-color:var(--color-border-hover);color:var(--color-text-primary);background:#ffffff0a}.onboarding-error{color:var(--color-error);font-size:var(--font-size-sm);padding:var(--space-3) var(--space-4);background:var(--color-error-bg);border-radius:var(--radius-md);border:1px solid rgba(224,90,90,.2)}.onboarding-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-4);color:var(--color-text-secondary);font-size:var(--font-size-sm)}@media(max-width:600px){.onboarding-card{padding:var(--space-6) var(--space-4)}.field-group{grid-template-columns:1fr}.progress-step__label{display:none}}.onboarding-card--welcome{border-color:#c9933a38}.welcome-letter{display:flex;flex-direction:column;gap:var(--space-5);padding:var(--space-4) 0 var(--space-2);animation:letter-fade-in .5s ease both}@keyframes letter-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.welcome-letter__salutation{font-family:var(--font-body);font-size:var(--font-size-base);color:var(--color-cream-300)}.welcome-letter__body,.welcome-letter__verse{font-family:var(--font-body);font-size:var(--font-size-base);line-height:1.75;color:var(--color-cream-300)}.welcome-letter__sign{display:flex;flex-direction:column;gap:var(--space-1);padding-top:var(--space-2)}.welcome-letter__sign-name{font-family:var(--font-body);font-size:var(--font-size-base);color:var(--color-cream-300)}.welcome-screen{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-8);animation:welcome-fade-in .8s ease both}@keyframes welcome-fade-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.welcome-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(60px)}.welcome-orb--1{width:320px;height:320px;background:radial-gradient(circle,rgba(201,147,58,.12) 0%,transparent 70%);top:-120px;left:50%;transform:translate(-50%);animation:orb-pulse 6s ease-in-out infinite}.welcome-orb--2{width:200px;height:200px;background:radial-gradient(circle,rgba(75,12,14,.35) 0%,transparent 70%);bottom:-80px;right:-60px;animation:orb-pulse 8s ease-in-out infinite reverse}@keyframes orb-pulse{0%,to{opacity:.7;transform:translate(-50%) scale(1)}50%{opacity:1;transform:translate(-50%) scale(1.12)}}.welcome-emblem{position:relative;z-index:1;animation:emblem-enter .9s cubic-bezier(.22,1,.36,1) .1s both}.welcome-emblem svg{filter:drop-shadow(0 0 18px rgba(201,147,58,.45));animation:emblem-spin-idle 20s linear infinite}@keyframes emblem-enter{0%{opacity:0;transform:scale(.6) rotate(-20deg)}to{opacity:1;transform:scale(1) rotate(0)}}@keyframes emblem-spin-idle{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.welcome-headline-wrap{position:relative;z-index:1;animation:welcome-fade-in .7s ease .25s both}.welcome-overline{font-family:var(--font-body);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing-widest);text-transform:uppercase;color:var(--color-gold-400);margin-bottom:var(--space-3)}.welcome-headline{font-family:var(--font-display);font-size:clamp(2.6rem,6vw,4rem);font-weight:var(--font-weight-light);line-height:1.1;letter-spacing:-.01em;background:linear-gradient(160deg,var(--color-cream-100) 0%,var(--color-gold-300) 50%,var(--color-gold-500) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-5)}.welcome-headline--sub{font-style:italic;font-weight:var(--font-weight-light);font-size:.85em;background:linear-gradient(135deg,var(--color-gold-200),var(--color-gold-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-divider{display:flex;align-items:center;justify-content:center;gap:var(--space-3)}.welcome-divider__line{display:block;width:64px;height:1px;background:linear-gradient(90deg,transparent,rgba(201,147,58,.6),transparent)}.welcome-divider__diamond{font-size:7px;color:var(--color-gold-400);line-height:1}.welcome-body{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-6);animation:welcome-fade-in .7s ease .45s both}.welcome-body__para{font-family:var(--font-body);font-size:var(--font-size-base);line-height:1.75;color:var(--color-cream-400);max-width:42ch}.welcome-lines{display:flex;flex-direction:column;gap:var(--space-1)}.welcome-line{display:block;font-family:var(--font-display);font-style:italic;font-size:clamp(1.1rem,2.8vw,1.5rem);color:var(--color-cream-200);opacity:0;transform:translate(-12px)}.welcome-line--1{animation:line-slide-in .6s cubic-bezier(.22,1,.36,1) .7s both}.welcome-line--2{animation:line-slide-in .6s cubic-bezier(.22,1,.36,1) .9s both}.welcome-line--3{animation:line-slide-in .6s cubic-bezier(.22,1,.36,1) 1.1s both;background:linear-gradient(90deg,var(--color-gold-200),var(--color-gold-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:var(--font-weight-semibold);font-style:normal}@keyframes line-slide-in{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.welcome-badge{position:relative;z-index:1;display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-body);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase;color:var(--color-cream-600);animation:welcome-fade-in .7s ease 1.3s both}.welcome-badge__dot{display:block;width:4px;height:4px;border-radius:50%;background:var(--color-gold-600)}@media(max-width:600px){.onboarding-card--welcome{padding:var(--space-8) var(--space-5)}.welcome-headline{font-size:2.4rem}}.profile-loading{display:flex;justify-content:center;padding:var(--space-16)}.profile-hero{display:flex;align-items:center;gap:var(--space-6);padding-bottom:var(--space-8);margin-bottom:var(--space-10);border-bottom:1px solid var(--color-border)}.profile-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid rgba(201,147,58,.5);flex-shrink:0}.profile-avatar--placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-crimson-600),var(--color-crimson-800));color:var(--color-gold-300);font-family:var(--font-display);font-size:var(--font-size-3xl);font-weight:600}.profile-hero__info{display:flex;flex-direction:column;gap:var(--space-2)}.profile-hero__name{font-family:var(--font-display);font-size:var(--font-size-3xl);font-weight:600;color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.profile-hero__email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.profile-status-badge{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-full);padding:4px 12px;width:fit-content}.profile-status-badge--verified{color:var(--color-success);background:var(--color-success-bg);border:1px solid rgba(61,170,106,.25)}.profile-status-badge--pending{color:var(--color-gold-300);background:#c9933a1a;border:1px solid rgba(201,147,58,.25)}.profile-status-badge--error{color:var(--color-crimson-400);background:#dc26261a;border:1px solid rgba(220,38,38,.25)}.profile-sections{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-5)}.profile-section{background:#ffffff08;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3)}.profile-section__title{font-size:var(--font-size-xs);font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--color-accent);margin:0 0 var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid rgba(201,147,58,.15)}.profile-field{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-4);padding:var(--space-2) 0;border-bottom:1px solid rgba(255,255,255,.04)}.profile-field:last-child{border-bottom:none}.profile-field__label{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0;font-weight:500}.profile-field__value{font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:right;word-break:break-word}@media(max-width:600px){.profile-hero{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.profile-avatar{width:64px;height:64px}.profile-hero__name{font-size:var(--font-size-2xl)}.profile-sections{grid-template-columns:1fr}}.admin-content{display:flex;flex-direction:column;gap:var(--space-6)}.admin-page-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border);gap:var(--space-4);flex-wrap:wrap}@media(max-width:640px){.admin-page-header{flex-direction:column;align-items:flex-start}}.admin-stats{display:flex;gap:var(--space-6)}.admin-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.admin-stat__value{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-accent);line-height:1}.admin-stat__value--success{color:var(--color-success)}.admin-stat__value--warning{color:var(--color-warning)}.admin-stat__label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.admin-toolbar{display:flex;align-items:center;gap:var(--space-3);width:100%;flex-wrap:wrap}@media(max-width:640px){.admin-toolbar{flex-direction:column;align-items:stretch}}.admin-search-input{flex:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:inherit;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.admin-search-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #c9933a1f}.admin-view-switcher{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.admin-view-btn{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-family:inherit;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-surface);border:none;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap}.admin-input,.admin-select{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:inherit;outline:none;transition:border-color var(--transition-fast)}.admin-input:focus,.admin-select:focus{border-color:var(--color-accent)}.admin-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23c9933a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:32px}.admin-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all var(--transition-fast);font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent}.admin-btn--primary{background:var(--color-accent);color:var(--color-bg)}.admin-btn--primary:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-1px)}.admin-btn--secondary{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text-primary)}.admin-btn--secondary:hover{border-color:var(--color-accent)}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-checkbox-label{display:flex;align-items:center;gap:8px;font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer}.admin-table-wrapper{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-xl)}.admin-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.admin-table thead{background:var(--color-surface);border-bottom:1px solid var(--color-border)}.admin-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;color:var(--color-text-muted)}.admin-table__row{border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast)}.admin-table__row:last-child{border-bottom:none}.admin-table__row:hover{background:#c9933a0a}.admin-table td{padding:var(--space-3) var(--space-4);vertical-align:middle}.admin-table__name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.admin-table__cell-muted{color:var(--color-text-secondary)}.admin-table__empty{text-align:center;padding:var(--space-10);color:var(--color-text-muted)}.admin-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid var(--color-border);flex-shrink:0}.admin-avatar--placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-crimson-600),var(--color-crimson-500));color:var(--color-gold-300);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);font-family:var(--font-display)}.admin-status-badge{display:inline-block;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase}.admin-status-badge[data-status=completed]{background:#4ade8026;color:var(--success);border-color:#4ade804d}.admin-status-badge[data-status=pending]{background:#c9933a1f;color:var(--color-accent);border:1px solid rgba(201,147,58,.2)}.admin-student-card__location{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--space-1)}.admin-student-card__btn{margin-top:auto;padding-top:var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-accent);background:none;border:none;font-family:inherit;cursor:pointer;text-align:left;padding-left:0;transition:color var(--transition-fast)}.admin-student-card__btn:hover{color:var(--color-accent-hover)}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-4);padding-top:var(--space-2)}.admin-page-btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-family:inherit;font-weight:var(--font-weight-medium);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.admin-page-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.admin-page-btn:disabled{opacity:.35;cursor:not-allowed}.admin-page-info{font-size:var(--font-size-sm);color:var(--color-text-muted)}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:100;animation:fadeIn .2s ease}.detail-panel{position:fixed;top:0;right:0;width:100%;max-width:480px;height:100vh;background:var(--color-bg);border-left:1px solid var(--color-border);z-index:101;display:flex;flex-direction:column;animation:slideInRight .25s cubic-bezier(.16,1,.3,1);overflow-y:auto}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.detail-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-bg);z-index:1}.detail-panel__identity{display:flex;align-items:center;gap:var(--space-3)}.detail-panel__identity .admin-avatar{width:48px;height:48px;font-size:var(--font-size-lg)}.detail-panel__name{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.detail-panel__email{font-size:var(--font-size-xs);color:var(--color-text-muted)}.detail-panel__actions{display:flex;align-items:center;gap:var(--space-2)}.detail-panel__close{width:32px;height:32px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}.detail-panel__close:hover{background:var(--color-error-bg);color:var(--color-error)}.detail-panel__body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-6)}.detail-section{display:flex;flex-direction:column;gap:var(--space-3)}.detail-section__title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);color:var(--color-accent);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-2)}.detail-field{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-4)}.detail-field__label{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0}.detail-field__value{font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:right;word-break:break-word}.admin-loading{display:flex;justify-content:center;padding:var(--space-16)}.admin-error{color:var(--color-error);text-align:center;padding:var(--space-8)}.fees-page{max-width:880px;margin:0 auto;padding:var(--space-4) var(--space-4) var(--space-8) var(--space-4)}.fees-year-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.fees-year-display{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-accent);letter-spacing:var(--letter-spacing-tight);min-width:5ch;text-align:center}.fees-download-btn{background:linear-gradient(135deg,#c9933a,#ebdcb9);color:#1a0304;border:none;border-radius:var(--radius-md);padding:8px 18px;font-family:Playfair Display,serif;font-weight:700;font-size:14px;cursor:pointer;transition:all var(--transition-fast) ease;box-shadow:0 4px 10px #0000004d;display:inline-flex;align-items:center;gap:8px}.fees-download-btn:hover:not(:disabled){opacity:.95;transform:translateY(-1px);box-shadow:0 6px 14px #c9933a40}.fees-download-btn:disabled{opacity:.5;cursor:not-allowed}.fee-card-container{display:flex;justify-content:center;width:100%}.fee-card-photo-wrapper{position:relative;width:100%;max-width:720px;aspect-ratio:2599 / 3626;container-type:inline-size;box-shadow:0 12px 40px #0009,0 0 30px #c9933a26;border:1px solid rgba(201,147,58,.3);border-radius:12px;overflow:hidden}.fee-card-photo-img{width:100%;height:100%;object-fit:cover;display:block}.overlay-text{position:absolute;font-family:Playfair Display,serif;font-weight:600;color:#ebdcb9;font-size:2.7cqw;line-height:1.2;white-space:nowrap;pointer-events:none}.overlay-name{left:36.5%;top:20.3%}.overlay-address{left:28.5%;top:25%}.overlay-number{left:28.5%;top:29.4%}.overlay-cell{position:absolute;font-family:var(--font-sans);color:#1a0304;font-size:2.2cqw;font-weight:500;text-align:center;pointer-events:none;height:3%;display:flex;align-items:center;justify-content:center}.overlay-date{left:32.1%;width:17%}.overlay-fee{left:51.2%;width:12.7%;color:#2b8a51;font-size:2.2cqw;font-weight:700;display:flex;align-items:center;justify-content:center;gap:.5cqw}.fees-status-icon--verify{width:1.1em;height:1.1em;flex-shrink:0}.overlay-sign{left:66%;width:27.5%;font-family:Playfair Display,serif;font-style:italic;font-weight:600;color:#554124;font-size:2.1cqw}.fees-error{text-align:center;color:var(--color-error);padding:var(--space-8);font-size:var(--font-size-sm)}.admin-fees-page{max-width:900px;margin:0 auto;padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-8)}.admin-fees-search-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-6)}.admin-fees-search-header{text-align:center}.admin-fees-section-title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-accent);margin:0 0 var(--space-2) 0}.admin-fees-section-hint{font-size:var(--font-size-base);color:var(--color-text-muted);margin:0}.admin-fees-search-wrapper{position:relative}.admin-fees-search-input{width:100%;background:var(--color-surface-raised);border:1px solid var(--color-border-hover);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-lg);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);box-sizing:border-box}.admin-fees-search-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #c9933a1f}.admin-fees-search-input::placeholder{color:var(--color-text-muted)}.admin-fees-search-spinner{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}.admin-fees-dropdown{position:absolute;top:calc(100% + var(--space-2));left:0;right:0;background:var(--color-surface-raised);border:1px solid var(--color-border-hover);border-radius:var(--radius-lg);z-index:var(--z-overlay);overflow:hidden;box-shadow:var(--shadow-lg);list-style:none;margin:0;padding:0;max-height:280px;overflow-y:auto}.admin-fees-dropdown--empty{padding:var(--space-4);color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center}.admin-fees-dropdown-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);cursor:pointer;border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.admin-fees-dropdown-avatar-container{position:relative;width:32px;height:32px;border-radius:50%;flex-shrink:0;overflow:hidden}.admin-fees-dropdown-avatar{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.admin-fees-dropdown-avatar-fallback{width:100%;height:100%;background:var(--color-accent);color:var(--color-bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold)}.admin-fees-dropdown-info{display:flex;flex-direction:column;gap:2px}.admin-fees-dropdown-item:last-child{border-bottom:none}.admin-fees-dropdown-item:hover{background:var(--color-crimson-600)}.admin-fees-dropdown-name{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.admin-fees-dropdown-email{font-size:var(--font-size-xs);color:var(--color-text-muted)}.admin-fees-student-profile-card{display:flex;align-items:center;gap:var(--space-4);background:linear-gradient(145deg,#c9933a1a,#c9933a05);border:1px solid rgba(201,147,58,.2);border-radius:var(--radius-2xl);padding:var(--space-4) var(--space-5);margin-bottom:var(--space-6);box-shadow:0 4px 20px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.admin-fees-student-profile-avatar{position:relative;width:48px;height:48px;border-radius:50%;background:var(--color-accent);color:var(--color-bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);flex-shrink:0;box-shadow:0 2px 10px #c9933a66;overflow:hidden}.admin-fees-avatar-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.admin-fees-student-profile-info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.admin-fees-student-badge__name{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-accent);letter-spacing:var(--letter-spacing-wide);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-fees-student-badge__email{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-fees-student-badge__label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);font-weight:var(--font-weight-medium)}.fees-year-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-5);margin-bottom:var(--space-6)}.fees-year-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-surface-raised);border:1px solid var(--color-border);color:var(--color-accent);font-size:var(--font-size-xl);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);line-height:1}.fees-year-btn:hover:not(:disabled){background:var(--color-crimson-600);border-color:var(--color-border-hover)}.fees-year-btn:disabled{opacity:.35;cursor:not-allowed}.fees-year-display{font-family:var(--font-display);font-size:var(--font-size-3xl);font-weight:var(--font-weight-semibold);color:var(--color-accent);letter-spacing:var(--letter-spacing-tight);min-width:5ch;text-align:center}.admin-fees-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}@media(max-width:640px){.admin-fees-grid{grid-template-columns:repeat(2,1fr)}}.admin-fees-month-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-5);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base);box-shadow:var(--shadow-sm)}.admin-fees-month-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-border-hover)}.admin-fees-month-card--paid{border-color:#3daa6a66;background:linear-gradient(135deg,rgba(61,170,106,.08) 0%,var(--color-surface) 70%)}.admin-fees-month-card--paid:hover{border-color:#3daa6a99;box-shadow:0 6px 16px #3daa6a26}.admin-fees-month-card--pending{border-color:#e05a5a66;background:linear-gradient(135deg,rgba(224,90,90,.08) 0%,var(--color-surface) 70%)}.admin-fees-month-card--pending:hover{border-color:#e05a5a99;box-shadow:0 6px 16px #e05a5a26}.fees-month-name{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-wide)}.admin-fees-month-status{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);min-height:52px;justify-content:center}.admin-fees-status-badge{display:flex;align-items:center;gap:var(--space-1);padding:4px 12px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider)}.admin-fees-status-badge--paid{background:#3daa6a26;color:#3daa6a;border:1px solid rgba(61,170,106,.3)}.admin-fees-status-badge--pending{background:#e05a5a26;color:#e05a5a;border:1px solid rgba(224,90,90,.3)}.admin-fees-status-badge--blank{background:var(--color-surface-raised);color:var(--color-text-muted);border:1px solid var(--color-border)}.fees-status-icon{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold)}.fees-status-icon--verify{width:16px;height:16px;flex-shrink:0}.fees-paid-date{font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:center;margin-top:2px}.admin-fees-actions{width:100%;display:flex;justify-content:center;margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.admin-fees-btn{border:none;border-radius:var(--radius-lg);padding:var(--space-2) var(--space-4);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:opacity var(--transition-fast),transform var(--transition-fast),background var(--transition-fast);width:100%}.admin-fees-btn:disabled{opacity:.5;cursor:not-allowed}.admin-fees-btn:hover:not(:disabled){transform:translateY(-1px)}.admin-fees-btn--pay{background:var(--color-accent);color:var(--color-bg);box-shadow:var(--shadow-sm)}.admin-fees-btn--pay:hover:not(:disabled){background:#d7a44a;box-shadow:var(--shadow-md)}.admin-fees-btn--unmark{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.admin-fees-btn--unmark:hover:not(:disabled){background:#e05a5a1a;color:#e05a5a;border-color:#e05a5a}.admin-fees-confirm{display:flex;align-items:center;gap:var(--space-2);width:100%}.admin-fees-confirm__text{font-size:var(--font-size-xs);color:var(--color-text-primary);font-weight:var(--font-weight-semibold);flex-shrink:0}.admin-fees-btn--confirm-yes{background:#e05a5a;color:#fff;flex:1;padding:var(--space-1) var(--space-2)}.admin-fees-btn--confirm-no{background:var(--color-surface-raised);color:var(--color-text-primary);border:1px solid var(--color-border);flex:1;padding:var(--space-1) var(--space-2)}.admin-fees-placeholder{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-16) var(--space-8);border:1px dashed var(--color-border);border-radius:var(--radius-xl);text-align:center}.admin-fees-placeholder__icon{font-size:3rem;color:var(--color-border)}.admin-fees-placeholder__text{color:var(--color-text-muted);font-size:var(--font-size-sm);max-width:320px;line-height:var(--line-height-relaxed);margin:0}.fees-loading{display:flex;justify-content:center;padding:var(--space-16) 0}.admin-fees-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-6);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-2)}.admin-fees-tab{display:flex;align-items:center;gap:var(--space-2);background:transparent;border:none;padding:var(--space-3) var(--space-5);font-family:var(--font-display);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-lg) var(--radius-lg) 0 0;transition:all var(--transition-fast);position:relative}.admin-fees-tab svg.tab-icon{width:16px;height:16px;stroke-width:2px}.admin-fees-tab:hover{color:var(--color-text-primary);background:var(--color-surface-raised)}.admin-fees-tab--active{color:var(--color-accent)}.admin-fees-tab--active:after{content:"";position:absolute;bottom:calc(-1 * var(--space-2) - 1px);left:0;right:0;height:3px;background:var(--color-accent);border-radius:3px 3px 0 0}.admin-fees-list-section{display:flex;flex-direction:column;gap:var(--space-6)}.admin-fees-list-toolbar{display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:space-between;background:var(--color-surface);padding:var(--space-4);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.admin-fees-list-filters{display:flex;gap:var(--space-3);flex-wrap:wrap}.admin-table-wrapper{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);overflow-x:auto;box-shadow:var(--shadow-sm)}.admin-table{width:100%;border-collapse:collapse;text-align:left}.admin-table th{padding:var(--space-4) var(--space-5);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.admin-table td{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);vertical-align:middle}.admin-table__row{transition:background var(--transition-fast)}.admin-table__row:hover{background:var(--color-surface-raised)}.admin-table__student{display:flex;align-items:center;gap:var(--space-3)}.admin-table__avatar-fallback{width:36px;height:36px;border-radius:50%;background:var(--color-accent);color:var(--color-bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold)}.admin-table__name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.admin-table__email{font-size:var(--font-size-xs);color:var(--color-text-muted)}.admin-table__cell-muted{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.text-sm{font-size:var(--font-size-xs)}.admin-table__empty{text-align:center;padding:var(--space-8);color:var(--color-text-muted);font-style:italic}.admin-view-switcher{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;height:38px}.admin-view-btn{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-family:inherit;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-surface);border:none;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;height:100%}.admin-view-btn:hover{background:#c9933a14;color:var(--color-text-primary)}.admin-view-btn--active{background:#c9933a26;color:var(--color-accent)}.admin-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-5)}.admin-student-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);cursor:pointer;transition:border-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base)}.admin-student-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-glow-gold);transform:translateY(-2px)}.admin-student-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.admin-student-card__name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-base)}.admin-student-card__email{font-size:var(--font-size-xs);color:var(--color-text-muted)}.admin-empty{grid-column:1 / -1;text-align:center;color:var(--color-text-muted);padding:var(--space-10)}@media(max-width:640px){.admin-fees-btn-tick{display:none!important}.admin-fees-list-toolbar{flex-direction:column;align-items:stretch;gap:var(--space-3)}.admin-fees-list-filters{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:var(--space-2)!important;width:100%}.admin-fees-list-filters .admin-select{width:100%;font-size:var(--font-size-xs)!important;padding:var(--space-2) var(--space-1)!important;background-position:right 4px center!important;padding-right:20px!important}.admin-fees-toolbar-search-view{flex-direction:column;align-items:stretch!important;width:100%}.admin-fees-toolbar-search-view .admin-search-input,.admin-fees-toolbar-search-view .admin-view-switcher{width:100%}.admin-fees-toolbar-search-view .admin-view-btn{flex:1;text-align:center}}.email-page{padding:var(--space-6) 0;max-width:900px;margin:0 auto}.email-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-6);border-bottom:1px solid var(--color-border);padding-bottom:0}.email-tab{background:transparent;border:none;color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-family-serif);padding:var(--space-3) var(--space-5);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-base);border-radius:var(--radius-sm) var(--radius-sm) 0 0;letter-spacing:.02em}.email-tab:hover{color:var(--color-text-secondary);background:var(--color-surface-raised)}.email-tab--active{color:var(--color-gold);border-bottom-color:var(--color-gold)}.email-section{display:flex;flex-direction:column;gap:var(--space-5)}.email-card{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);transition:border-color var(--transition-base)}.email-card:hover{border-color:var(--color-border-hover)}.email-card__title{font-family:var(--font-family-serif);font-size:var(--font-size-lg);color:var(--color-gold);margin:0 0 var(--space-2)}.email-card__desc{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0 0 var(--space-4);line-height:1.6}.email-toggle{display:inline-flex;align-items:center;gap:var(--space-3);cursor:pointer;-webkit-user-select:none;user-select:none}.email-toggle input{display:none}.email-toggle__track{position:relative;width:48px;height:26px;background:var(--color-border);border-radius:999px;transition:background var(--transition-base);flex-shrink:0}.email-toggle input:checked+.email-toggle__track{background:var(--color-gold)}.email-toggle__thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--transition-base);box-shadow:0 1px 4px #0006}.email-toggle input:checked~.email-toggle__track .email-toggle__thumb{transform:translate(22px)}.email-toggle__label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.email-toggle--large .email-toggle__track{width:56px;height:30px}.email-toggle--large .email-toggle__thumb{width:24px;height:24px}.email-toggle--large input:checked~.email-toggle__track .email-toggle__thumb{transform:translate(26px)}.email-provider-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.email-provider-card{display:flex;align-items:center;gap:var(--space-4);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);cursor:pointer;transition:all var(--transition-base)}.email-provider-card input{display:none}.email-provider-card:hover{border-color:var(--color-border-hover)}.email-provider-card--selected{border-color:var(--color-gold);background:#c9a84c14;box-shadow:0 0 0 3px #c9a84c1f}.email-provider-card__icon{font-size:28px;flex-shrink:0}.email-provider-card__name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-sm)}.email-provider-card__desc{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.email-field{display:flex;flex-direction:column;gap:var(--space-2)}.email-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.email-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);padding:var(--space-3) var(--space-4);transition:border-color var(--transition-base),box-shadow var(--transition-base);outline:none;font-family:var(--font-family-body)}.email-input:focus{border-color:var(--color-gold);box-shadow:0 0 0 3px #c9a84c26}.email-input--mono{font-family:Courier New,monospace;font-size:var(--font-size-xs);letter-spacing:.04em}.email-textarea{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:12px;font-family:Courier New,monospace;padding:var(--space-4);resize:vertical;min-height:200px;line-height:1.5;-moz-tab-size:2;tab-size:2;transition:border-color var(--transition-base),box-shadow var(--transition-base);outline:none}.email-textarea:focus{border-color:var(--color-gold);box-shadow:0 0 0 3px #c9a84c26}.email-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0;line-height:1.5}.email-hint a,.email-callout a{color:var(--color-gold)}.email-callout{background:#c9a84c14;border:1px solid rgba(201,168,76,.25);border-radius:var(--radius-md);padding:var(--space-4);font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--space-4);line-height:1.6}.email-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.email-actions{display:flex;justify-content:flex-end}.email-btn{display:inline-flex;align-items:center;gap:var(--space-2);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);padding:var(--space-3) var(--space-5);cursor:pointer;transition:all var(--transition-base);font-family:var(--font-family-body)}.email-btn:disabled{opacity:.55;cursor:not-allowed}.email-btn--save{background:linear-gradient(135deg,var(--color-gold),#a07830);color:var(--color-bg-primary)}.email-btn--save:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #c9a84c66}.email-btn--large{padding:var(--space-4) var(--space-8);font-size:var(--font-size-base)}.email-btn--preview{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary)}.email-btn--preview:hover:not(:disabled){border-color:var(--color-border-hover);color:var(--color-text-primary)}.email-btn--test{background:var(--color-surface-raised);border:1px solid rgba(201,168,76,.3);color:var(--color-gold)}.email-btn--test:hover:not(:disabled){background:#c9a84c1a;border-color:var(--color-gold)}.email-template-card{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);transition:border-color var(--transition-base)}.email-template-card:hover{border-color:var(--color-border-hover)}.email-template-card__header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-3);cursor:pointer;-webkit-user-select:none;user-select:none}.email-template-card__header-left{display:flex;align-items:center;gap:var(--space-4)}.email-template-card__chevron{font-size:12px;color:var(--color-gold);transition:transform var(--transition-base);transform:rotate(-90deg)}.email-template-card__chevron--expanded{transform:rotate(0)}.email-template-card__body{display:flex;flex-direction:column;gap:var(--space-4);padding-top:var(--space-4);margin-top:var(--space-4);border-top:1px solid var(--color-border);animation:slideDownFade .2s ease-out}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.email-template-card__title{font-family:var(--font-family-serif);font-size:var(--font-size-lg);color:var(--color-gold);margin:0 0 var(--space-1)}.email-template-card__id{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0}.email-template-card__id code{background:var(--color-surface);padding:1px 6px;border-radius:4px;font-family:monospace;font-size:11px;color:var(--color-text-secondary)}.email-params{background:#c9a84c0d;border:1px dashed rgba(201,168,76,.3);border-radius:var(--radius-md);padding:var(--space-4)}.email-params__title{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0 0 var(--space-3);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.06em}.email-params__chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.email-param-chip{display:inline-flex;flex-direction:column;align-items:flex-start;gap:2px;background:var(--color-surface);border:1px solid rgba(201,168,76,.3);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs);font-family:monospace;color:var(--color-gold);cursor:pointer;transition:all var(--transition-base);text-align:left}.email-param-chip:hover{background:#c9a84c1f;border-color:var(--color-gold);transform:translateY(-1px);box-shadow:0 2px 8px #c9a84c33}.email-param-chip__desc{font-family:var(--font-family-body);font-size:10px;color:var(--color-text-muted);font-style:italic}.email-template-actions{display:flex;align-items:center;gap:var(--space-3);justify-content:flex-end;flex-wrap:wrap}.email-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.email-preview-modal{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.email-preview-modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.email-preview-close{background:none;border:none;color:var(--color-text-muted);font-size:18px;cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:color var(--transition-base)}.email-preview-close:hover{color:var(--color-text-primary)}.email-preview-iframe{flex:1;border:none;width:100%;min-height:500px;background:#fff}.email-toast{padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);animation:slideDown .3s ease}.email-toast--success{background:#4ade801f;border:1px solid rgba(74,222,128,.3);color:#4ade80}.email-toast--error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#f87171}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.email-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#f87171;padding:var(--space-4) var(--space-5);font-size:var(--font-size-sm)}.email-loading{display:flex;justify-content:center;padding:var(--space-12)}.email-templates-list{display:flex;flex-direction:column;gap:var(--space-6)}.email-templates-intro{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.6;margin:0}.email-empty{text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--space-10)}@media(max-width:640px){.email-provider-cards,.email-grid-2{grid-template-columns:1fr}.email-template-actions{flex-direction:column;align-items:stretch}.email-template-actions .email-btn{justify-content:center}.email-preview-overlay{padding:var(--space-3);align-items:flex-end}.email-preview-modal{max-height:90vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}}
