@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--success-50: #ecfdf5;--success-500: #10b981;--success-600: #059669;--warning-50: #fffbeb;--warning-500: #f59e0b;--warning-600: #d97706;--danger-50: #fef2f2;--danger-500: #ef4444;--danger-600: #dc2626;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-success: linear-gradient(135deg, #11998e 0%, #38ef7d 100%);--gradient-danger: linear-gradient(135deg, #eb3349 0%, #f45c43 100%);--gradient-dark: linear-gradient(135deg, #1e3a8a 0%, #312e81 100%);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-glow: 0 0 20px rgba(59, 130, 246, .3);--radius-sm: .375rem;--radius: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--gradient-dark);min-height:100vh;color:var(--gray-100);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{display:flex;min-height:100vh}.main-content{flex:1;padding:2rem;margin-left:280px;min-height:100vh}@media (max-width: 768px){.main-content{margin-left:0;padding:1rem 1rem 5rem}}.sidebar{position:fixed;left:0;top:0;width:280px;height:100vh;background:#1e293bf2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.1);padding:2rem 1.5rem;display:flex;flex-direction:column;z-index:100}.sidebar-logo{display:flex;align-items:center;gap:.75rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:2rem}.sidebar-logo-icon{width:48px;height:48px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.sidebar-logo h1{font-size:1.25rem;font-weight:700;color:#fff}.sidebar-logo span{font-size:.75rem;color:var(--gray-400)}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;padding-right:.5rem;min-height:0}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:var(--radius-full)}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius-md);color:var(--gray-300);text-decoration:none;font-weight:500;transition:all var(--transition)}.sidebar-link:hover{background:#ffffff0d;color:#fff}.sidebar-link.active{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow)}.sidebar-link-icon{font-size:1.25rem;width:24px;text-align:center}.sidebar-user{padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:.75rem}.sidebar-user-avatar{width:44px;height:44px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem}.sidebar-user-info{flex:1}.sidebar-user-name{font-weight:600;font-size:.9rem;color:#fff}.sidebar-user-role{font-size:.75rem;color:var(--gray-400)}.sidebar-logout{background:none;border:none;color:var(--gray-400);cursor:pointer;padding:.5rem;border-radius:var(--radius);transition:all var(--transition)}.sidebar-logout:hover{color:var(--danger-500);background:#ef44441a}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#1e293bfa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:.75rem;border-top:1px solid rgba(255,255,255,.1);z-index:100}@media (max-width: 768px){.sidebar{display:none}.mobile-nav{display:flex;justify-content:space-around}}.mobile-nav-link{display:flex;flex-direction:column;align-items:center;gap:.25rem;color:var(--gray-400);text-decoration:none;font-size:.65rem;padding:.5rem;border-radius:var(--radius);transition:all var(--transition)}.mobile-nav-link.active{color:var(--primary-400)}.mobile-nav-link-icon{font-size:1.25rem}.card{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:1.5rem}.card-glass{background:#ffffff14;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.card-title{font-size:1.25rem;font-weight:700;color:#fff}.card-subtitle{font-size:.875rem;color:var(--gray-400);margin-top:.25rem}.status-card{display:flex;align-items:center;gap:1rem;padding:1.25rem}.status-card-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.status-card-icon.success{background:#10b98133;color:var(--success-500)}.status-card-icon.warning{background:#f59e0b33;color:var(--warning-500)}.status-card-icon.danger{background:#ef444433;color:var(--danger-500)}.status-card-icon.primary{background:#3b82f633;color:var(--primary-400)}.status-card-content h3{font-size:.875rem;color:var(--gray-400);font-weight:500;margin-bottom:.25rem}.status-card-content p{font-size:1.5rem;font-weight:700;color:#fff}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:600;font-size:.9rem;cursor:pointer;border:none;transition:all var(--transition);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-success{background:var(--gradient-success);color:#fff;box-shadow:0 4px 15px #11998e66}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #11998e80}.btn-danger{background:var(--gradient-danger);color:#fff;box-shadow:0 4px 15px #eb334966}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #eb334980}.btn-outline{background:transparent;border:2px solid rgba(255,255,255,.2);color:#fff}.btn-outline:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff4d}.btn-lg{padding:1rem 2rem;font-size:1rem;border-radius:var(--radius-lg)}.btn-block{width:100%}.btn-icon{font-size:1.25rem}.attendance-btn{width:100%;padding:2rem;border-radius:var(--radius-xl);font-size:1.25rem;font-weight:700;display:flex;flex-direction:column;align-items:center;gap:.75rem}.attendance-btn-icon{font-size:3rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--gray-300);margin-bottom:.5rem}.form-input{width:100%;padding:.875rem 1rem;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:#fff;font-size:1rem;font-family:inherit;transition:all var(--transition)}.form-input::placeholder{color:var(--gray-500)}.form-input:focus{outline:none;border-color:var(--primary-500);background:#ffffff14;box-shadow:0 0 0 3px #3b82f633}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-error{color:var(--danger-500);font-size:.8rem;margin-top:.5rem}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:1rem;padding-right:2.5rem;background-color:#1e293b}.form-select option{background-color:#1e293b;color:#fff}.camera-container{position:relative;width:100%;max-width:400px;margin:0 auto}.camera-video{width:100%;border-radius:var(--radius-xl);background:var(--gray-800);transform:scaleX(-1)}.camera-preview{width:100%;border-radius:var(--radius-xl)}.camera-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:180px;height:220px;border:3px dashed rgba(255,255,255,.5);border-radius:var(--radius-xl);pointer-events:none}.camera-controls{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.camera-btn{width:64px;height:64px;border-radius:var(--radius-full);border:4px solid white;background:transparent;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.camera-btn:hover{background:#fff3}.camera-btn-inner{width:48px;height:48px;border-radius:var(--radius-full);background:#fff}.camera-btn-retake{background:#ffffff1a;border-color:var(--gray-400)}.location-info{display:flex;align-items:center;gap:1rem;padding:1rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-lg);margin-bottom:1rem}.location-info-icon{font-size:1.5rem;color:var(--primary-400)}.location-info-content{flex:1}.location-info-label{font-size:.75rem;color:var(--gray-400)}.location-info-value{font-weight:600;color:#fff}.location-distance{padding:.5rem 1rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:600}.location-distance.valid{background:#10b98133;color:var(--success-500)}.location-distance.invalid{background:#f59e0b33;color:var(--warning-500)}.table-container{overflow-x:auto;border-radius:var(--radius-lg)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:1rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.1)}.table th{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);font-weight:600;background:#ffffff0d}.table td{font-size:.9rem;color:var(--gray-200)}.table tbody tr:hover{background:#ffffff08}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.badge-success{background:#10b98133;color:var(--success-500)}.badge-warning{background:#f59e0b33;color:var(--warning-500)}.badge-danger{background:#ef444433;color:var(--danger-500)}.badge-primary{background:#3b82f633;color:var(--primary-400)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--gradient-dark)}.login-container{width:100%;max-width:420px}.login-card{background:#ffffff14;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-xl);padding:2.5rem}.login-logo{text-align:center;margin-bottom:2rem}.login-logo-icon{width:72px;height:72px;background:var(--gradient-primary);border-radius:var(--radius-xl);display:inline-flex;align-items:center;justify-content:center;font-size:2rem;margin-bottom:1rem}.login-logo h1{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.25rem}.login-logo p{color:var(--gray-400);font-size:.9rem}.alert{padding:1rem 1.25rem;border-radius:var(--radius-lg);margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}.alert-icon{font-size:1.25rem}.alert-success{background:#10b98126;border:1px solid rgba(16,185,129,.3);color:var(--success-500)}.alert-warning{background:#f59e0b26;border:1px solid rgba(245,158,11,.3);color:var(--warning-500)}.alert-danger{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:var(--danger-500)}.alert-info{background:#3b82f626;border:1px solid rgba(59,130,246,.3);color:var(--primary-400)}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.1);border-top-color:var(--primary-500);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172acc;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:200;animation:fadeIn var(--transition-fast)}.modal{background:var(--gray-800);border-radius:var(--radius-xl);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp var(--transition)}.modal-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.25rem;font-weight:700;color:#fff}.modal-close{background:none;border:none;color:var(--gray-400);font-size:1.5rem;cursor:pointer;padding:.25rem;transition:color var(--transition)}.modal-close:hover{color:#fff}.modal-body{padding:1.5rem}.modal-footer{padding:1.5rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:flex-end;gap:.75rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.text-center{text-align:center}.text-right{text-align:right}.text-success{color:var(--success-500)}.text-warning{color:var(--warning-500)}.text-danger{color:var(--danger-500)}.text-muted{color:var(--gray-400)}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.hidden{display:none}.page-header{margin-bottom:2rem}.page-title{font-size:1.75rem;font-weight:800;color:#fff;margin-bottom:.5rem}.page-subtitle{color:var(--gray-400);font-size:1rem}.empty-state{text-align:center;padding:3rem 2rem}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state-text{color:var(--gray-400);font-size:1rem}.photo-thumb{width:48px;height:48px;border-radius:var(--radius);object-fit:cover}.photo-thumb-lg{width:80px;height:80px;border-radius:var(--radius-md);object-fit:cover}.dashboard-watermark{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(1.5);z-index:0;opacity:.08;pointer-events:none;width:100%;height:100%;object-fit:contain;max-width:none;padding:0;filter:grayscale(100%)}@media (max-width: 768px){.grid-2{grid-template-columns:1fr 1fr;gap:.75rem}.status-card{flex-direction:column;text-align:center;padding:1rem .5rem;gap:.5rem;height:100%;justify-content:center}.status-card-icon{width:40px;height:40px;font-size:1.2rem;margin:0 auto}.status-card-content h3{font-size:.75rem;margin-bottom:0}.status-card-content p{font-size:.9rem}html{font-size:14px}.page-header{margin-bottom:1rem}.page-title{font-size:1.5rem}.page-subtitle{font-size:.875rem}.card{padding:1rem;border-radius:var(--radius-lg)}.card-header{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.card-header .btn{width:100%}.card-title{font-size:1rem}.form-group{margin-bottom:1rem}.form-input{padding:.75rem;font-size:16px}.form-select{font-size:16px}.btn{padding:.875rem 1.25rem;font-size:.9rem;width:100%}.btn-lg{padding:1rem 1.5rem}.table-container{margin:0 -1rem;border-radius:0}.table th,.table td{padding:.75rem .5rem;font-size:.8rem}.status-card{padding:1rem}.status-card-icon{width:48px;height:48px;font-size:1.25rem}.status-card-content p{font-size:1.25rem}.modal-overlay{padding:0;align-items:flex-end}.modal{max-width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:85vh}.modal-header,.modal-body,.modal-footer{padding:1rem}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}.camera-container{max-width:100%;margin-bottom:0}.camera-view-wrapper{position:relative;width:fit-content;margin:0 auto .5rem}.camera-video{width:260px;height:340px;object-fit:cover;display:block;border-radius:var(--radius-lg);margin:0}.camera-overlay{width:180px;height:240px;border-width:2px;border-radius:var(--radius-lg);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.camera-controls{margin-top:.5rem;gap:1.5rem;display:flex;flex-direction:column;justify-content:center;align-items:center}.camera-controls .btn{width:auto;padding:.5rem 1rem}.camera-btn{width:60px;height:60px;border-width:3px;background:#ffffff1a}.camera-btn-inner{width:44px;height:44px}.photo-thumb-lg{width:60px;height:60px}.attendance-btn{padding:1.5rem;font-size:1rem}.attendance-btn-icon{font-size:2.5rem}.location-info{flex-direction:column;text-align:center}.location-distance{width:100%;text-align:center}.badge{font-size:.7rem;padding:.2rem .5rem}.login-page{padding:1rem}.login-card{padding:1.5rem}.login-logo-icon{width:60px;height:60px;font-size:1.5rem}.login-logo h1{font-size:1.25rem}.empty-state{padding:2rem 1rem}.empty-state-icon{font-size:2.5rem}.alert{padding:.875rem;font-size:.875rem}.card.mb-3>div{gap:.75rem!important}.card.mb-3>div>div{flex-direction:column!important;align-items:flex-start!important}}.attendance-container{max-width:480px;margin:0 auto;width:100%;padding-bottom:5rem}@media (max-width: 480px){html{font-size:13px}.main-content{padding:.75rem .75rem 5rem}.page-title{font-size:1.35rem}.card{padding:.875rem}.table th,.table td{padding:.5rem .25rem;font-size:.75rem}.status-card-icon{width:40px;height:40px;font-size:1rem}.status-card-content h3{font-size:.75rem}.status-card-content p{font-size:1.1rem}.photo-thumb-lg{width:50px;height:50px}.mobile-nav{padding:.5rem}.mobile-nav-link{font-size:.6rem;padding:.375rem}.mobile-nav-link-icon{font-size:1.1rem}}html,body{overflow-x:hidden}@media (pointer: coarse){.btn,.sidebar-link,.mobile-nav-link{min-height:44px}.form-input,.form-select,.table tbody tr{min-height:48px}.sidebar-logout{min-width:44px;min-height:44px}}@supports (padding: env(safe-area-inset-bottom)){.mobile-nav{padding-bottom:calc(.75rem + env(safe-area-inset-bottom))}.main-content{padding-bottom:calc(5rem + env(safe-area-inset-bottom))}}@media (max-height: 500px) and (orientation: landscape){.camera-container{max-width:60%}.modal{max-height:95vh}.login-logo-icon{width:48px;height:48px;margin-bottom:.5rem}.login-logo{margin-bottom:1rem}}@media (max-width: 768px){.card form[style*=flex]{flex-direction:column!important}.card form[style*=flex] .form-group,.card form[style*=flex] .btn{width:100%}}.attendance-action-grid{display:grid;grid-template-columns:1fr 1fr}.btn-attendance-compact{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:var(--radius-lg);text-decoration:none;position:relative;overflow:hidden;transition:all var(--transition);border:1px solid rgba(255,255,255,.1);background:#ffffff0d}.btn-attendance-compact.primary{background:var(--gradient-success);box-shadow:0 4px 12px #10b9814d}.btn-attendance-compact.danger{background:var(--gradient-danger);box-shadow:0 4px 12px #ef44444d}.btn-attendance-compact.disabled{background:#ffffff0d;opacity:.6;filter:grayscale(1);cursor:not-allowed}.btn-attendance-compact:hover:not(.disabled){transform:translateY(-2px);filter:brightness(1.1)}.btn-attendance-compact .icon-wrapper{width:42px;height:42px;background:#fff3;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:1.25rem}.btn-attendance-compact .text-wrapper{flex:1;display:flex;flex-direction:column}.btn-attendance-compact .label{color:#fff;font-weight:700;font-size:1rem;line-height:1.2}.btn-attendance-compact .sub-label{color:#fffc;font-size:.75rem}.btn-attendance-compact .status-badge{background:#fff;color:var(--success-600);width:24px;height:24px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}@media (max-width: 640px){.btn-attendance-compact{padding:.75rem;gap:.5rem}.btn-attendance-compact .icon-wrapper{width:32px;height:32px;font-size:1rem}.btn-attendance-compact .label{font-size:.85rem}.btn-attendance-compact .sub-label{font-size:.65rem}.btn-attendance-compact .status-badge{width:18px;height:18px;font-size:.6rem}}.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.menu-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;text-decoration:none;padding:.75rem .5rem;border-radius:var(--radius-lg);transition:background-color var(--transition)}.menu-item:hover{background:#ffffff0d}.menu-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:#ffffff1a;color:#fff;transition:transform var(--transition)}.menu-item:hover .menu-icon{transform:scale(1.1)}.menu-icon.bg-blue-100{background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:#0284c7}.menu-icon.bg-green-100{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}.menu-icon.bg-purple-100{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);color:#9333ea}.menu-icon.bg-orange-100{background:linear-gradient(135deg,#ffedd5,#fed7aa);color:#ea580c}.menu-label{color:var(--gray-300);font-size:.8rem;font-weight:500;text-align:center;line-height:1.2}.menu-item:hover .menu-label{color:#fff}@media (max-width: 640px){.menu-grid{grid-template-columns:repeat(4,1fr);gap:.5rem}.menu-icon{width:40px;height:40px;font-size:1.25rem}.menu-label{font-size:.7rem}}.image-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:2rem;animation:fadeIn .3s ease}.image-modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;animation:zoomIn .3s cubic-bezier(.34,1.56,.64,1)}.image-modal-img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:var(--radius-lg);box-shadow:0 20px 50px #00000080;border:4px solid rgba(255,255,255,.1)}.image-modal-close{position:absolute;top:-40px;right:0;background:#fff;color:#000;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;transition:all .2s;border:none;z-index:10001}.image-modal-close:hover{transform:scale(1.1) rotate(90deg);background:var(--danger-500);color:#fff}.image-modal-caption{color:#fff;margin-top:1rem;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.5);background:#00000080;padding:.5rem 1.5rem;border-radius:var(--radius-full);font-size:.9rem}.photo-thumb-lg{cursor:pointer;transition:transform .2s,box-shadow .2s}.photo-thumb-lg:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000004d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width: 640px){.image-modal-overlay{padding:1rem}.image-modal-close{top:-40px;right:0}}
