@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--font: "Inter", system-ui, sans-serif;--bg: #f0f4ff;--bg-secondary: #e8eeff;--surface: #ffffff;--surface-2: #f5f7ff;--border: #e2e8f0;--text: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--primary: #6366f1;--primary-dark: #4f46e5;--primary-light: #818cf8;--secondary: #06b6d4;--accent: #8b5cf6;--success: #10b981;--warning: #f59e0b;--error: #f43f5e;--info: #3b82f6;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow: 0 4px 16px rgba(0,0,0,.1);--shadow-lg: 0 12px 40px rgba(0,0,0,.14);--shadow-primary: 0 4px 24px rgba(99,102,241,.25);--radius-sm: 8px;--radius: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 9999px;--transition: .2s ease;--transition-slow: .4s ease;--nav-bg: rgba(255,255,255,.85);--nav-border: rgba(226,232,240,.8);--glass-bg: rgba(255,255,255,.7);--glass-border: rgba(255,255,255,.9)}[data-theme=dark]{--bg: #080c1a;--bg-secondary: #0d1224;--surface: #111827;--surface-2: #1a2236;--border: #1e2d45;--text: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #475569;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow: 0 4px 16px rgba(0,0,0,.5);--shadow-lg: 0 12px 40px rgba(0,0,0,.6);--shadow-primary: 0 4px 24px rgba(99,102,241,.4);--nav-bg: rgba(8,12,26,.9);--nav-border: rgba(30,45,69,.9);--glass-bg: rgba(17,24,39,.75);--glass-border: rgba(30,45,69,.8)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;transition:background var(--transition-slow),color var(--transition-slow);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:var(--font)}input,select,textarea{font-family:var(--font)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.page{padding-top:80px;min-height:100vh}.page-content{padding:2.5rem 0 4rem}.gradient-text{background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.5rem;border-radius:var(--radius-full);font-weight:600;font-size:.9rem;transition:all var(--transition);border:none;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 28px #6366f166}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border);transform:translateY(-1px)}.btn-danger{background:rgba(244,63,94,.12);color:var(--error);border:1px solid rgba(244,63,94,.25)}.btn-danger:hover:not(:disabled){background:rgba(244,63,94,.2);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-sm{padding:.4rem 1rem;font-size:.8rem}.btn-lg{padding:.875rem 2rem;font-size:1rem}.btn-full{width:100%;justify-content:center}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;transition:all var(--transition)}.card:hover{box-shadow:var(--shadow-lg)}.card-body{padding:1.5rem}.card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.card-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);background:var(--surface-2)}.glass-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-lg)}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}.form-label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.form-input{width:100%;padding:.75rem 1rem;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.95rem;transition:all var(--transition);outline:none}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f126}.form-input::-moz-placeholder{color:var(--text-muted)}.form-input::placeholder{color:var(--text-muted)}.form-input.error{border-color:var(--error);box-shadow:0 0 0 3px #f43f5e1f}.form-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.95rem;cursor:pointer;outline:none;transition:all var(--transition);-webkit-appearance:none;-moz-appearance:none;appearance:none;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='%236366f1' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f126}.form-error{font-size:.8rem;color:var(--error);margin-top:.25rem}.form-hint{font-size:.8rem;color:var(--text-muted)}.alert{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;margin-bottom:1.25rem}.alert-error{background:rgba(244,63,94,.1);color:var(--error);border:1px solid rgba(244,63,94,.2)}.alert-success{background:rgba(16,185,129,.1);color:var(--success);border:1px solid rgba(16,185,129,.2)}.alert-info{background:rgba(59,130,246,.1);color:var(--info);border:1px solid rgba(59,130,246,.2)}.alert-warning{background:rgba(245,158,11,.1);color:var(--warning);border:1px solid rgba(245,158,11,.2)}.badge{display:inline-flex;align-items:center;padding:.2rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase}.badge-active{background:rgba(16,185,129,.15);color:var(--success);border:1px solid rgba(16,185,129,.3)}.badge-cancelled{background:rgba(244,63,94,.12);color:var(--error);border:1px solid rgba(244,63,94,.25)}.badge-completed{background:rgba(59,130,246,.12);color:var(--info);border:1px solid rgba(59,130,246,.25)}.badge-inactive{background:rgba(148,163,184,.12);color:var(--text-muted);border:1px solid rgba(148,163,184,.25)}.badge-primary{background:rgba(99,102,241,.12);color:var(--primary);border:1px solid rgba(99,102,241,.25)}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:.4rem}.status-dot-active{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot-inactive{background:var(--text-muted)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem;color:var(--text-secondary)}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--border) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.65);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:480px;width:100%;animation:slideUp .25s ease}.modal-header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--border)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end}.page-header{margin-bottom:2.5rem}.page-header h1{font-size:2rem;font-weight:800;margin-bottom:.4rem}.page-header p{color:var(--text-secondary);font-size:1rem}.divider{height:1px;background:var(--border);margin:1.5rem 0}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state .empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:.5rem}.empty-state p{color:var(--text-secondary);margin-bottom:1.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeInUp .5s ease both}@media (max-width: 768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-header h1{font-size:1.5rem}.container{padding:0 1rem}}@media (max-width: 480px){.btn-lg{padding:.75rem 1.5rem}}.navbar{position:fixed;top:0;left:0;right:0;z-index:500;background:var(--nav-bg);border-bottom:1px solid var(--nav-border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:background var(--transition-slow)}.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:68px;gap:1.5rem}.navbar-logo{display:flex;align-items:center;gap:.5rem;font-size:1.2rem;font-weight:800;flex-shrink:0;transition:opacity var(--transition)}.navbar-logo:hover{opacity:.85}.logo-icon{font-size:1.4rem}.logo-text{letter-spacing:-.02em}.navbar-links{display:flex;align-items:center;gap:.25rem;flex:1;justify-content:center}.nav-link{padding:.5rem 1rem;border-radius:var(--radius-full);font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition);position:relative}.nav-link:hover{color:var(--text);background:var(--surface-2)}.nav-link.active{color:var(--primary);background:rgba(99,102,241,.1);font-weight:600}.navbar-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.theme-toggle{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-full);width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all var(--transition);cursor:pointer}.theme-toggle:hover{background:var(--border);transform:scale(1.05)}.user-chip{display:flex;align-items:center;gap:.5rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-full);padding:.25rem .75rem .25rem .25rem}.user-avatar{width:28px;height:28px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.user-name{font-size:.85rem;font-weight:600}.user-role-badge{font-size:.7rem;font-weight:700;padding:.1rem .5rem;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em}.user-role-badge.admin{background:rgba(139,92,246,.2);color:var(--accent)}.user-role-badge.user{background:rgba(6,182,212,.2);color:var(--secondary)}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px;cursor:pointer}.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all var(--transition)}.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{display:none;flex-direction:column;padding:.75rem 1.5rem 1.25rem;border-top:1px solid var(--border);background:var(--nav-bg);animation:fadeIn .15s ease}.mobile-nav-link{padding:.75rem 0;font-size:.95rem;font-weight:500;color:var(--text-secondary);border:none;background:none;text-align:left;cursor:pointer;border-bottom:1px solid var(--border);transition:color var(--transition)}.mobile-nav-link:last-child{border-bottom:none}.mobile-nav-link:hover,.mobile-nav-link.active{color:var(--primary)}.mobile-nav-link.danger{color:var(--error)}.mobile-menu-divider{height:1px;background:var(--border);margin:.25rem 0}@media (max-width: 768px){.navbar-links,.user-name,.user-role-badge{display:none}.hamburger,.mobile-menu{display:flex}.navbar-actions .btn{display:none}}@media (max-width: 480px){.user-chip{display:none}}.home{overflow:hidden}.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:6rem 0 4rem;overflow:hidden}.hero-glow{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}.hero-glow-1{width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.18) 0%,transparent 70%);top:-100px;right:-100px}.hero-glow-2{width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,.15) 0%,transparent 70%);bottom:0;left:-50px}.hero-content{text-align:center;max-width:780px;margin:0 auto;position:relative;z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(99,102,241,.12);color:var(--primary-light);border:1px solid rgba(99,102,241,.25);border-radius:var(--radius-full);padding:.35rem 1rem;font-size:.85rem;font-weight:600;margin-bottom:1.75rem}.hero-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:900;line-height:1.1;letter-spacing:-.03em;margin-bottom:1.25rem}.hero-subtitle{font-size:1.15rem;color:var(--text-secondary);max-width:560px;margin:0 auto 2.5rem;line-height:1.7}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.stats-section{padding:3rem 0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.stat-card{text-align:center;padding:2rem 1rem;border-radius:var(--radius-lg);transition:transform var(--transition)}.stat-card:hover{transform:translateY(-4px)}.stat-value{font-size:2.2rem;font-weight:900;margin-bottom:.35rem}.stat-label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.features-section{padding:5rem 0}.section-header{text-align:center;margin-bottom:3.5rem}.section-header h2{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;letter-spacing:-.02em;margin-bottom:.75rem}.section-header p{color:var(--text-secondary);font-size:1.05rem}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.feature-card{padding:2rem;border-radius:var(--radius-lg);transition:all var(--transition);cursor:default}.feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:#6366f14d}.feature-icon{font-size:2.25rem;margin-bottom:1rem}.feature-card h3{font-size:1.05rem;font-weight:700;margin-bottom:.5rem}.feature-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.cta-section{padding:4rem 0 6rem}.cta-card{text-align:center;padding:4rem 2rem;position:relative;overflow:hidden}.cta-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,rgba(99,102,241,.1) 0%,transparent 70%);pointer-events:none}.cta-card h2{font-size:clamp(1.75rem,4vw,2.25rem);font-weight:800;margin-bottom:.75rem}.cta-card p{color:var(--text-secondary);font-size:1.05rem;margin-bottom:2rem}.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}@media (max-width: 900px){.features-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.features-grid,.stats-grid{grid-template-columns:1fr}.hero-title{font-size:2.2rem}}.guest-demo-strip{margin-top:2.25rem;display:flex;flex-direction:column;align-items:center;gap:.85rem;padding:1.25rem 1.75rem;background:rgba(255,255,255,.04);border:1px dashed rgba(99,102,241,.35);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.guest-demo-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);letter-spacing:.01em}.guest-demo-btns{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.btn-guest{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.35rem;border-radius:var(--radius-full);font-size:.9rem;font-weight:700;cursor:pointer;border:none;transition:all .22s ease;white-space:nowrap;position:relative;overflow:hidden}.btn-guest:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(255,255,255,.08);opacity:0;transition:opacity .2s}.btn-guest:hover:not(:disabled):before{opacity:1}.btn-guest:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #00000040}.btn-guest:active:not(:disabled){transform:translateY(0)}.btn-guest:disabled{opacity:.65;cursor:not-allowed}.btn-guest-admin{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.btn-guest-user{background:linear-gradient(135deg,#0ea5e9,#06b6d4);color:#fff}.guest-role-icon{font-size:1rem}.guest-error{font-size:.82rem;color:var(--error, #f87171);margin-top:.25rem}.demo-section{padding:2rem 0 6rem}.demo-card{background:rgba(255,255,255,.03);border:1px solid rgba(99,102,241,.18);border-radius:var(--radius-xl, 1.5rem);padding:3.5rem 2.5rem;position:relative;overflow:hidden}.demo-card:before{content:"";position:absolute;top:-60px;left:50%;transform:translate(-50%);width:500px;height:220px;background:radial-gradient(ellipse at center,rgba(99,102,241,.12) 0%,transparent 70%);pointer-events:none}.demo-header{text-align:center;margin-bottom:2.75rem}.demo-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(99,102,241,.12);color:var(--primary-light, #818cf8);border:1px solid rgba(99,102,241,.28);border-radius:var(--radius-full);padding:.3rem .9rem;font-size:.8rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1rem}.demo-header h2{font-size:clamp(1.6rem,3.5vw,2.25rem);font-weight:800;letter-spacing:-.02em;margin-bottom:.65rem}.demo-header p{color:var(--text-secondary);font-size:1rem;max-width:520px;margin:0 auto;line-height:1.65}.demo-roles{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.demo-role-card{border-radius:var(--radius-lg);padding:2rem 1.75rem;display:flex;flex-direction:column;gap:.75rem;position:relative;overflow:hidden;transition:transform .22s ease,box-shadow .22s ease}.demo-role-card:hover{transform:translateY(-5px)}.demo-admin{background:linear-gradient(145deg,rgba(99,102,241,.12),rgba(139,92,246,.08));border:1px solid rgba(99,102,241,.28)}.demo-admin:hover{box-shadow:0 12px 40px #6366f133}.demo-user{background:linear-gradient(145deg,rgba(14,165,233,.12),rgba(6,182,212,.08));border:1px solid rgba(14,165,233,.28)}.demo-user:hover{box-shadow:0 12px 40px #0ea5e933}.demo-role-icon{font-size:2.5rem}.demo-role-card h3{font-size:1.2rem;font-weight:800;letter-spacing:-.01em}.demo-role-card>p{color:var(--text-secondary);font-size:.9rem;line-height:1.55;flex:1}.demo-credentials{display:flex;flex-direction:column;gap:.3rem;padding:.75rem 1rem;background:rgba(0,0,0,.18);border-radius:var(--radius-md, .5rem);font-size:.82rem;font-family:Courier New,monospace;color:var(--text-secondary);border:1px solid rgba(255,255,255,.06)}.btn-full-demo{width:100%;justify-content:center;padding:.75rem 1.25rem;font-size:.92rem;border-radius:var(--radius-md, .5rem);margin-top:.25rem}.guest-error-center{text-align:center;margin-top:1.25rem;font-size:.875rem}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 700px){.demo-roles{grid-template-columns:1fr}.demo-card{padding:2rem 1.25rem}.guest-demo-btns{flex-direction:column;width:100%}.btn-guest{width:100%;justify-content:center}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:5rem 1rem 3rem;position:relative;overflow:hidden}.auth-glow{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}.auth-glow-1{width:500px;height:500px;background:radial-gradient(circle,rgba(99,102,241,.2) 0%,transparent 70%);top:-100px;right:-80px}.auth-glow-2{width:350px;height:350px;background:radial-gradient(circle,rgba(139,92,246,.15) 0%,transparent 70%);bottom:-50px;left:-50px}.auth-card{width:100%;max-width:440px;padding:2.5rem;position:relative;z-index:1}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{font-size:2.5rem;margin-bottom:.75rem;display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(139,92,246,.15));border-radius:var(--radius-lg);border:1px solid rgba(99,102,241,.25)}.auth-logo.admin{background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(6,182,212,.15));border-color:#8b5cf640}.auth-header h1{font-size:1.6rem;font-weight:800;margin-bottom:.35rem}.auth-header p{color:var(--text-secondary);font-size:.9rem}.auth-form{margin-top:.5rem}.input-password-wrap{position:relative}.input-password-wrap .form-input{padding-right:3rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1rem;cursor:pointer;padding:.25rem;opacity:.6;transition:opacity var(--transition)}.password-toggle:hover{opacity:1}.role-indicator{margin-bottom:1.25rem}.auth-footer{text-align:center;margin-top:1.5rem;display:flex;flex-direction:column;gap:.4rem;font-size:.875rem;color:var(--text-secondary)}.auth-link{color:var(--primary-light);font-weight:600;transition:color var(--transition)}.auth-link:hover{color:var(--primary)}.guest-login-divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0 1rem;color:var(--text-secondary);font-size:.85rem}.guest-login-divider:before,.guest-login-divider:after{content:"";flex:1;border-bottom:1px solid rgba(255,255,255,.1)}.guest-login-divider span{padding:0 .75rem}.guest-login-group{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.guest-login-group .btn-guest{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:700;cursor:pointer;border:none;transition:all .2s ease;white-space:nowrap}.guest-login-group .btn-guest-admin{background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(139,92,246,.15));color:#fff;border:1px solid rgba(99,102,241,.3)}.guest-login-group .btn-guest-user{background:linear-gradient(135deg,rgba(14,165,233,.15),rgba(6,182,212,.15));color:#fff;border:1px solid rgba(14,165,233,.3)}.guest-login-group .btn-guest:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.guest-login-group .btn-guest-admin:hover:not(:disabled){background:linear-gradient(135deg,rgba(99,102,241,.25),rgba(139,92,246,.25))}.guest-login-group .btn-guest-user:hover:not(:disabled){background:linear-gradient(135deg,rgba(14,165,233,.25),rgba(6,182,212,.25))}.guest-login-group .btn-guest:disabled{opacity:.6;cursor:not-allowed}.guest-error{color:var(--error, #f87171);font-size:.85rem;width:100%}.resources-filters{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.75rem}.search-wrap{position:relative;max-width:520px}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1rem;pointer-events:none}.search-input{padding-left:2.75rem!important}.search-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:.2rem}.type-filters{display:flex;gap:.5rem;flex-wrap:wrap}.type-filter-btn{padding:.4rem 1rem;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.type-filter-btn:hover{border-color:var(--primary);color:var(--primary)}.type-filter-btn.active{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent}.results-count{font-size:.875rem;color:var(--text-muted);margin-bottom:1.25rem}.resources-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.resource-card{cursor:pointer;transition:all var(--transition);display:flex;flex-direction:column}.resource-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.resource-card-image{height:160px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.resource-card-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;position:absolute;top:0;right:0;bottom:0;left:0}.resource-card-placeholder{font-size:3.5rem}.resource-card-type-badge{position:absolute;top:.75rem;left:.75rem;padding:.2rem .65rem;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;border:1px solid;letter-spacing:.03em;text-transform:uppercase}.resource-card-body{padding:1.25rem;display:flex;flex-direction:column;flex:1}.resource-card-name{font-size:1.05rem;font-weight:700;margin-bottom:.35rem}.resource-card-desc{font-size:.85rem;color:var(--text-secondary);margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.resource-card-meta{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem;flex:1}.meta-item{font-size:.8rem;color:var(--text-secondary);display:flex;align-items:center;gap:.35rem}.resource-card-btn{align-self:flex-start}@media (max-width: 900px){.resources-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.resources-grid{grid-template-columns:1fr}}.back-btn{margin-bottom:1.5rem}.resource-header{display:flex;gap:0;margin-bottom:2rem;overflow:hidden}.resource-header-img{width:280px;flex-shrink:0;background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(139,92,246,.1));display:flex;align-items:center;justify-content:center;min-height:200px;overflow:hidden}.resource-header-img img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.resource-header-placeholder{font-size:5rem}.resource-header-info{flex:1}.resource-desc{color:var(--text-secondary);margin:.75rem 0 1.25rem;line-height:1.7}.resource-meta-grid{display:flex;flex-wrap:wrap;gap:.5rem}.meta-chip{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--text-secondary);background:var(--surface-2);border:1px solid var(--border);padding:.3rem .75rem;border-radius:var(--radius-full)}.slots-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem}.slots-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.slots-header h2{font-size:1.25rem;font-weight:700}.slots-count{font-size:.85rem;color:var(--text-secondary);background:var(--surface-2);border:1px solid var(--border);padding:.25rem .75rem;border-radius:var(--radius-full)}.date-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;overflow-x:auto;padding-bottom:.25rem}.date-tab{flex-shrink:0;padding:.6rem 1.25rem;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition);position:relative}.date-tab:hover{border-color:var(--primary);color:var(--primary)}.date-tab.active{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent}.date-tab-label{display:block}.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.slot-btn{display:flex;flex-direction:column;align-items:center;padding:1rem .75rem;border-radius:var(--radius);border:1.5px solid;cursor:pointer;transition:all var(--transition);font-weight:600}.slot-btn.available{background:rgba(16,185,129,.06);border-color:#10b9814d;color:var(--text)}.slot-btn.available:hover{background:rgba(16,185,129,.15);border-color:var(--success);transform:translateY(-2px);box-shadow:0 4px 16px #10b98133}.slot-btn.booked{background:var(--surface-2);border-color:var(--border);color:var(--text-muted);cursor:not-allowed;opacity:.6}.slot-time{font-size:1rem;font-weight:700}.slot-sep{font-size:.75rem;color:var(--text-muted);margin:.1rem 0}.slot-status-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem;color:var(--text-muted)}.slot-btn.available .slot-status-label{color:var(--success)}.booking-summary-item .value.highlight{color:var(--primary);font-size:1rem}@media (max-width: 768px){.resource-header{flex-direction:column}.resource-header-img{width:100%;height:200px}.slots-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.booking-filters{display:flex;gap:.5rem;margin-bottom:1.75rem;flex-wrap:wrap}.booking-filter-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem 1rem;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.booking-filter-btn:hover{border-color:var(--primary);color:var(--primary)}.booking-filter-btn.active{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent}.filter-count{background:rgba(255,255,255,.25);border-radius:var(--radius-full);padding:.05rem .45rem;font-size:.75rem}.booking-filter-btn:not(.active) .filter-count{background:var(--border);color:var(--text-secondary)}.bookings-list{display:flex;flex-direction:column;gap:1rem}.booking-card{display:flex;align-items:stretch;gap:0;overflow:hidden;transition:all var(--transition)}.booking-card:hover{transform:translate(4px);box-shadow:var(--shadow-lg)}.booking-card-left{width:180px;background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(139,92,246,.08));display:flex;align-items:center;justify-content:center;flex-shrink:0;border-right:1px solid var(--border);overflow:hidden}.booking-resource-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.booking-resource-icon{font-size:1.75rem}.booking-card-body{flex:1;padding:1.25rem}.booking-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.875rem}.booking-resource-name{font-size:1.05rem;font-weight:700;margin-bottom:.2rem}.booking-resource-type{font-size:.78rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.booking-details{display:flex;flex-direction:column;gap:.35rem}.booking-detail-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.detail-icon{font-size:.9rem}.booking-card-actions{display:flex;align-items:center;padding:1.25rem;border-left:1px solid var(--border)}.booking-summary{background:var(--surface-2);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.25rem}.booking-summary-item{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border)}.booking-summary-item:last-child{border-bottom:none}.booking-summary-item .label{font-size:.85rem;color:var(--text-secondary)}.booking-summary-item .value{font-size:.9rem;font-weight:600}@media (max-width: 600px){.booking-card-actions{padding:1rem;border-left:none;border-top:1px solid var(--border);width:100%}.booking-card{flex-wrap:wrap;flex-direction:column}.booking-card-left{width:100%;height:160px;border-right:none;border-bottom:1px solid var(--border)}}.admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:2rem}.admin-stat-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;transition:all var(--transition)}.admin-stat-card:hover{transform:translateY(-3px)}.admin-stat-icon{width:52px;height:52px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.admin-stat-value{font-size:2rem;font-weight:800;line-height:1}.admin-stat-label{font-size:.82rem;color:var(--text-secondary);font-weight:500;margin-top:.25rem}.admin-table-section{overflow:hidden}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{padding:.875rem 1rem;text-align:left;font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:1rem;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--surface-2)}.row-inactive td{opacity:.6}.table-resource-name{font-weight:600;margin-bottom:.2rem}.table-resource-loc{font-size:.78rem;color:var(--text-muted)}.table-time{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.table-actions{display:flex;gap:.4rem;flex-wrap:nowrap}.modal-close{background:none;border:none;font-size:1.1rem;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:all var(--transition)}.modal-close:hover{background:var(--surface-2);color:var(--text)}@media (max-width: 900px){.admin-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.admin-stats{grid-template-columns:1fr}.table-actions{flex-wrap:wrap}}.add-resource-form{display:flex;flex-direction:column;gap:0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.form-section-title{font-size:1rem;font-weight:700;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.time-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.toggle-label{display:flex;align-items:center;justify-content:space-between;cursor:pointer;gap:1rem}.toggle-switch{width:48px;height:26px;background:var(--border);border-radius:var(--radius-full);position:relative;cursor:pointer;transition:background var(--transition);flex-shrink:0}.toggle-switch.on{background:var(--success)}.toggle-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--transition);box-shadow:0 1px 4px #0003}.toggle-switch.on .toggle-knob{transform:translate(22px)}.slot-preview{background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(139,92,246,.08));border:1px solid rgba(99,102,241,.2);border-radius:var(--radius);padding:1rem;text-align:center;margin-top:.5rem}.slot-preview-label{font-size:.78rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.slot-preview-count{font-size:2.5rem;font-weight:900;color:var(--primary);line-height:1.1;margin:.25rem 0}.slot-preview-hint{font-size:.78rem;color:var(--text-muted)}.quick-add-dates{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.date-add-row{display:flex;gap:.75rem;align-items:center;margin-bottom:.75rem;flex-wrap:wrap}.dates-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.date-chip{display:inline-flex;align-items:center;gap:.5rem;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.25);color:var(--primary-light);border-radius:var(--radius-full);padding:.3rem .75rem;font-size:.82rem;font-weight:600}.date-chip-remove{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.75rem;padding:0 .1rem;opacity:.7;transition:opacity var(--transition)}.date-chip-remove:hover{opacity:1}.file-upload-wrap{position:relative;width:100%}.file-upload-label{display:block;border:2px dashed var(--border);border-radius:var(--radius);padding:1.25rem;text-align:center;cursor:pointer;background:var(--bg-card);transition:border-color var(--transition),background-color var(--transition)}.file-upload-label:hover{border-color:var(--primary);background:rgba(99,102,241,.04)}.file-upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem}.upload-icon{font-size:1.5rem}.file-upload-preview{display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:.9rem;color:var(--text-primary);flex-wrap:wrap}.file-name{font-weight:600;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:var(--text-muted)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@media (max-width: 768px){.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%;justify-content:center}}
