@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.auth-layout{background:var(--bg);min-height:100vh;display:flex;position:relative;overflow:hidden}.auth-layout:before{content:"";pointer-events:none;background:radial-gradient(circle,#ff6b350f 0%,#0000 70%);width:600px;height:600px;position:absolute;top:-200px;right:-200px}.auth-layout:after{content:"";pointer-events:none;background:radial-gradient(circle,#f7c9480a 0%,#0000 70%);width:400px;height:400px;position:absolute;bottom:-100px;left:-100px}.auth-left{border-right:1px solid var(--glass-border);background:linear-gradient(135deg,#ff6b3508 0%,#f7c94805 100%);flex-direction:column;flex:1.5;justify-content:center;align-items:center;padding:3rem;display:flex;position:relative;overflow:hidden}.auth-left-bg{position:absolute;inset:0;overflow:hidden}.auth-floating-circle{background:#ff6b350d;border:1px solid #ff6b3514;border-radius:50%;position:absolute}.auth-floating-circle:first-child{width:300px;height:300px;animation:8s ease-in-out infinite float;top:10%;left:-50px}.auth-floating-circle:nth-child(2){background:#f7c9480d;border-color:#f7c94814;width:200px;height:200px;animation:6s ease-in-out infinite reverse float;bottom:15%;right:10%}.auth-floating-circle:nth-child(3){width:150px;height:150px;animation:10s ease-in-out infinite float;top:50%;right:30%}.auth-branding{z-index:1;text-align:center;max-width:480px;position:relative}.auth-brand-logo{margin-bottom:1.5rem;font-size:4rem;animation:4s ease-in-out infinite float;display:block}.auth-brand-name{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.75rem;font-size:2.5rem;font-weight:700}.auth-brand-tagline{color:var(--text-secondary);margin-bottom:2.5rem;font-size:1.15rem;line-height:1.7}.auth-floating-emojis{flex-wrap:wrap;justify-content:center;gap:1.5rem;display:flex}.auth-emoji{animation:float var(--duration) ease-in-out infinite;animation-delay:var(--delay);filter:drop-shadow(0 4px 8px #0000004d);cursor:default;font-size:2rem;transition:transform .3s}.auth-emoji:hover{transform:scale(1.3)rotate(10deg)}.auth-right{z-index:1;flex:1;justify-content:center;align-items:center;padding:2rem;display:flex;position:relative}.auth-form-container{background:var(--glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);width:100%;max-width:420px;box-shadow:var(--shadow);border-radius:16px;padding:2.5rem;animation:.5s ease-out scaleIn}.auth-form-header{margin-bottom:2rem}.auth-form-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.auth-form-subtitle{color:var(--text-secondary);font-size:.95rem}.auth-form-body{flex-direction:column;gap:1.25rem;display:flex}.auth-form-footer{text-align:center;margin-top:1.5rem}.auth-form-footer p{color:var(--text-muted);font-size:.9rem}.auth-form-footer a{color:var(--primary);margin-left:.25rem;font-weight:500}.auth-form-footer a:hover{text-decoration:underline}.auth-error{background:var(--error-bg);border-radius:var(--radius-input);color:var(--error);border:1px solid #ef444433;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.875rem;animation:.3s ease-out slideDown;display:flex}.auth-success{border-radius:var(--radius-input);color:var(--success);background:#34d3991a;border:1px solid #34d39933;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.875rem;animation:.3s ease-out slideDown;display:flex}@media (width<=768px){.auth-layout{flex-direction:column}.auth-left{display:none}.auth-right{flex:1;min-height:100vh;padding:1.5rem}.auth-form-container{max-width:100%;padding:2rem 1.5rem}}@media (width<=1024px) and (width>=769px){.auth-left{flex:1}.auth-brand-name{font-size:2rem}.auth-brand-tagline{font-size:1rem}}.input-group{flex-direction:column;gap:.4rem;width:100%;display:flex}.input-label{color:var(--text-secondary);transition:var(--transition);font-size:.875rem;font-weight:500}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);transition:var(--transition);pointer-events:none;z-index:1;justify-content:center;align-items:center;display:flex;position:absolute;left:.875rem}.input-field{background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--radius-input);width:100%;color:var(--text-primary);transition:var(--transition);outline:none;padding:.75rem .875rem;font-size:.95rem}.input-field.has-icon{padding-left:2.75rem}.input-field::placeholder{color:var(--text-muted)}.input-field:hover:not(:disabled){border-color:var(--text-muted)}.input-field:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px #ff6b351a,0 0 15px #ff6b350d}.input-field:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:var(--primary)}.input-field:disabled{opacity:.5;cursor:not-allowed}.input-field.input-error{border-color:var(--error);box-shadow:0 0 0 3px var(--error-bg)}.input-error-text{color:var(--error);align-items:center;gap:.25rem;font-size:.8rem;animation:.2s ease-out slideDown;display:flex}.input-suffix{z-index:1;align-items:center;display:flex;position:absolute;right:.875rem}.input-toggle-password{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;align-items:center;padding:.25rem;display:flex}.input-toggle-password:hover{color:var(--text-secondary)}.btn{border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);letter-spacing:.01em;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:before{content:"";background:linear-gradient(90deg,#0000,#ffffff1a,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.btn:hover:before{left:100%}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn:disabled:before{display:none}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);color:#fff;box-shadow:0 4px 15px #ff6b354d}.btn-primary:hover:not(:disabled){transform:translateY(-1px)scale(1.02);box-shadow:0 8px 25px #ff6b3566}.btn-primary:active:not(:disabled){transform:translateY(0)scale(.98)}.btn-secondary{color:var(--primary);border:1.5px solid var(--primary);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--primary-light);transform:translateY(-1px)scale(1.02);box-shadow:0 4px 15px #ff6b3526}.btn-ghost{color:var(--text-secondary);border:1.5px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--glass);color:var(--text-primary);border-color:var(--glass-border)}.btn-full{width:100%}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.btn-secondary .btn-spinner{border-color:#ff6b354d;border-top-color:var(--primary)}.login-form{flex-direction:column;gap:1.25rem;display:flex}.login-remember-row{justify-content:space-between;align-items:center;display:flex}.login-remember{cursor:pointer;align-items:center;gap:.5rem;display:flex}.login-remember input[type=checkbox]{appearance:none;border:1.5px solid var(--input-border);background:var(--input-bg);cursor:pointer;width:18px;height:18px;transition:var(--transition);border-radius:4px;flex-shrink:0;position:relative}.login-remember input[type=checkbox]:checked{background:var(--primary);border-color:var(--primary)}.login-remember input[type=checkbox]:checked:after{content:"✓";color:#fff;font-size:.7rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-remember span{color:var(--text-secondary);font-size:.875rem}.login-forgot{color:var(--primary);cursor:pointer;transition:var(--transition);background:0 0;border:none;padding:0;font-size:.875rem}.login-forgot:hover{color:var(--primary-hover);text-decoration:underline}.login-divider{align-items:center;gap:1rem;margin:.5rem 0;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.login-divider span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.register-form{flex-direction:column;gap:1.1rem;display:flex}.register-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=480px){.register-row{grid-template-columns:1fr}}.password-strength{flex-direction:column;gap:.35rem;display:flex}.password-strength-bars{gap:4px;display:flex}.password-strength-bar{background:var(--border);height:3px;transition:var(--transition);border-radius:2px;flex:1}.password-strength-bar.active{background:var(--error)}.password-strength-bar.active.medium{background:var(--secondary)}.password-strength-bar.active.strong{background:var(--success)}.password-strength-label{transition:var(--transition);font-size:.75rem;font-weight:500}.password-strength-label.weak{color:var(--error)}.password-strength-label.medium{color:var(--secondary)}.password-strength-label.strong{color:var(--success)}.role-selector{flex-direction:column;gap:.4rem;display:flex}.role-selector-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.role-options{gap:.75rem;display:flex}.role-option{border-radius:var(--radius-input);border:1.5px solid var(--input-border);background:var(--input-bg);color:var(--text-secondary);cursor:pointer;transition:var(--transition);flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.65rem .75rem;font-size:.875rem;font-weight:500;display:flex}.role-option:hover{border-color:var(--text-muted)}.role-option.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.role-option input{display:none}.otp-form{flex-direction:column;align-items:center;gap:1.5rem;display:flex}.otp-email-badge{background:var(--primary-light);color:var(--primary);border:1px solid #ff6b3533;border-radius:20px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;animation:.3s ease-out scaleIn;display:inline-flex}.otp-inputs{justify-content:center;gap:.75rem;display:flex}.otp-input{text-align:center;background:var(--input-bg);border:2px solid var(--input-border);border-radius:var(--radius-input);width:52px;height:60px;color:var(--text-primary);transition:var(--transition);caret-color:var(--primary);outline:none;font-size:1.5rem;font-weight:700}.otp-input:focus{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 0 0 3px #ff6b3526,0 0 20px #ff6b3514}.otp-input.filled{border-color:var(--primary);background:#ff6b350d}.otp-input.error{border-color:var(--error);animation:.3s ease-out shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.otp-timer{flex-direction:column;align-items:center;gap:.5rem;display:flex}.otp-countdown{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:1.1rem;font-weight:600}.otp-countdown.expiring{color:var(--error);animation:1s ease-in-out infinite pulse}.otp-resend{color:var(--primary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:4px;padding:.25rem .5rem;font-size:.9rem;font-weight:500}.otp-resend:hover:not(:disabled){background:var(--primary-light);text-decoration:underline}.otp-resend:disabled{color:var(--text-muted);cursor:not-allowed}.otp-actions{flex-direction:column;gap:.75rem;width:100%;display:flex}@media (width<=480px){.otp-inputs{gap:.5rem}.otp-input{width:44px;height:52px;font-size:1.25rem}}.home-page{background:var(--bg);min-height:100vh;animation:.5s ease-out fadeIn}.home-container{max-width:1100px;margin:0 auto;padding:0 24px}.home-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 0;display:flex}.home-brand{align-items:center;gap:10px;display:flex}.home-brand-emoji{font-size:1.8rem}.home-brand-name{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700}.home-logout-btn{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);background:0 0;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:500;display:flex}.home-logout-btn:hover{border-color:var(--error);color:var(--error);background:var(--error-bg)}.home-welcome{padding:48px 0 32px}.welcome-card{text-align:center;background:var(--surface);border-radius:var(--radius-card);border:1px solid var(--border);padding:40px;animation:.6s ease-out slideUp}.welcome-avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 16px;font-size:1.8rem;font-weight:700;display:flex;box-shadow:0 0 24px #ff6b354d}.welcome-title{color:var(--text-primary);margin-bottom:8px;font-size:1.6rem;font-weight:600}.welcome-name{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.welcome-subtitle{color:var(--text-secondary);margin-bottom:16px;font-size:1rem}.welcome-role-badge{background:var(--primary-light);color:var(--primary);text-transform:capitalize;border-radius:20px;padding:4px 16px;font-size:.8rem;font-weight:600;display:inline-block}.home-features{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:20px;padding-bottom:48px;display:grid}.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);text-align:center;transition:var(--transition);color:inherit;cursor:pointer;padding:28px;text-decoration:none;animation:.6s ease-out backwards slideUp;display:block;position:relative;overflow:hidden}.feature-card:first-child{animation-delay:.1s}.feature-card:nth-child(2){animation-delay:.2s}.feature-card:nth-child(3){animation-delay:.3s}.feature-card:nth-child(4){animation-delay:.4s}.feature-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm);transform:translateY(-4px)}.feature-card:hover .active-badge{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.cart-count-badge{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important;font-weight:600!important}.feature-icon{margin-bottom:12px;font-size:2.4rem;display:block}.feature-card h3{color:var(--text-primary);margin-bottom:6px;font-size:1.1rem;font-weight:600}.feature-card p{color:var(--text-muted);margin-bottom:12px;font-size:.85rem;line-height:1.5}.feature-badge{border:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;background:#ffffff0d;border-radius:12px;padding:3px 12px;font-size:.7rem;font-weight:500;display:inline-block}.home-footer{text-align:center;border-top:1px solid var(--border);color:var(--text-muted);padding:24px 0;font-size:.85rem}@media (width<=768px){.home-header{padding:16px 0}.home-brand-name{font-size:1.2rem}.home-logout-btn{padding:8px 14px;font-size:.85rem}.home-welcome{padding:32px 0 24px}.welcome-card{padding:28px 20px}.welcome-title{font-size:1.3rem}.home-features{grid-template-columns:repeat(2,1fr);gap:14px}.feature-card{padding:20px}.feature-icon{font-size:2rem}}@media (width<=480px){.home-features{grid-template-columns:1fr}}.loading-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.loading-screen:before{content:"";background:radial-gradient(circle,#ff6b3514 0%,#0000 70%);width:400px;height:400px;animation:3s ease-in-out infinite pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.loading-content{z-index:1;flex-direction:column;align-items:center;gap:2rem;animation:.6s ease-out fadeIn;display:flex}.loading-logo{flex-direction:column;align-items:center;gap:.75rem;display:flex}.loading-emoji{font-size:3rem;animation:3s ease-in-out infinite float}.loading-title{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:700}.loading-spinner-container{width:48px;height:48px;position:relative}.spinner-ring-2{border-top-color:var(--secondary);animation-duration:.8s;animation-direction:reverse;inset:6px}.canteen-layout{background:var(--bg);min-height:100vh;color:var(--text-primary);display:flex}.canteen-sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:260px;height:100vh;padding:24px;display:flex;position:fixed;top:0;left:0}.canteen-sidebar-brand{align-items:center;gap:10px;margin-bottom:32px;display:flex}.canteen-sidebar-brand h2{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:700}.portal-badge{text-transform:uppercase;color:var(--primary);letter-spacing:.5px;background:#ff6b3526;border:1px solid #ff6b354d;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:700}.canteen-owner-profile{border:1px solid var(--border);border-radius:var(--radius-card);background:#ffffff05;align-items:center;gap:12px;margin-bottom:24px;padding:16px;display:flex}.canteen-logo-container{background:var(--input-bg);border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;width:44px;height:44px;display:flex;overflow:hidden}.canteen-sidebar-logo{object-fit:cover;width:100%;height:100%}.canteen-owner-info{flex-direction:column;gap:4px;min-width:0;display:flex}.canteen-name-sidebar{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.canteen-status-badge{text-transform:uppercase;letter-spacing:.5px;align-self:flex-start;font-size:.7rem;font-weight:700;display:inline-block}.canteen-status-active{color:var(--success)}.canteen-status-inactive{color:var(--text-muted)}.canteen-status-pending{color:var(--secondary)}.canteen-sidebar-nav{flex-direction:column;flex-grow:1;gap:8px;display:flex}.sidebar-nav-item{color:var(--text-secondary);border-radius:var(--radius-input);transition:var(--transition);cursor:pointer;align-items:center;gap:12px;padding:12px 16px;font-size:.95rem;font-weight:500;display:flex}.sidebar-nav-item:hover{color:var(--text-primary);background:#ffffff08}.sidebar-nav-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}.canteen-sidebar-footer{border-top:1px solid var(--border);padding-top:16px}.sidebar-logout-btn{width:100%;color:var(--text-secondary);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:12px 16px;font-size:.95rem;font-weight:500;display:flex}.sidebar-logout-btn:hover{background:var(--error-bg);color:var(--error)}.canteen-main-content{flex-direction:column;flex-grow:1;min-height:100vh;margin-left:260px;display:flex}.canteen-content-header{border-bottom:1px solid var(--border);background:var(--bg);z-index:90;justify-content:space-between;align-items:center;height:70px;padding:0 40px;display:flex;position:sticky;top:0}.header-breadcrumbs{align-items:center;gap:8px;font-size:.85rem;font-weight:500;display:flex}.breadcrumb-separator{color:var(--border)}.header-user-info{align-items:center;gap:10px;font-size:.9rem;display:flex}.user-avatar{border:1px solid var(--border);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.user-name-text{color:var(--text-primary);font-weight:550}.canteen-content-body{background:linear-gradient(180deg, var(--bg) 0%, #0f1419cc 100%);flex-grow:1;padding:40px}.canteen-reg-container{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:40px 24px;display:flex}.canteen-reg-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);width:100%;max-width:520px;box-shadow:var(--shadow);padding:40px;animation:.4s cubic-bezier(.16,1,.3,1) scaleIn}.canteen-reg-header{text-align:center;margin-bottom:32px}.canteen-reg-logo-emoji{filter:drop-shadow(0 0 10px #ff6b3533);margin-bottom:16px;font-size:3rem;display:block}.canteen-reg-header h2{color:var(--text-primary);margin-bottom:8px;font-size:1.6rem;font-weight:700}.canteen-reg-header p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.canteen-reg-form{flex-direction:column;gap:20px;display:flex}.canteen-reg-error{background:var(--error-bg);border:1px solid var(--error);color:var(--error);border-radius:var(--radius-input);padding:12px;font-size:.85rem;font-weight:500}.canteen-reg-form .form-group{flex-direction:column;gap:8px;display:flex}.canteen-reg-form label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.canteen-reg-form input,.canteen-reg-form textarea{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-input);width:100%;color:var(--text-primary);transition:var(--transition);padding:12px 16px}.canteen-reg-form input:focus,.canteen-reg-form textarea:focus{border-color:var(--primary);box-shadow:var(--shadow-glow);outline:none}.canteen-reg-buttons{gap:16px;margin-top:10px;display:flex}.btn-primary-custom{background:var(--primary);color:#fff;border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);border:none;flex-grow:1;padding:12px;font-weight:600}.btn-primary-custom:hover:not(:disabled){background:var(--primary-hover)}.btn-primary-custom:disabled{opacity:.6;cursor:not-allowed}.btn-secondary-custom{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);background:0 0;padding:12px 24px;font-weight:600}.btn-secondary-custom:hover{color:var(--text-primary);background:#ffffff0d}.loading-screen{background:var(--bg);z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-content{text-align:center}.loading-spinner-container{justify-content:center;margin-bottom:20px;display:flex}.loading-spinner{width:50px;height:50px;position:relative}.spinner-ring{border:3px solid #0000;border-top-color:var(--primary);border-radius:50%;animation:1s linear infinite spin;position:absolute;inset:0}.spinner-ring-2{border-top-color:#0000;border-bottom-color:var(--secondary);animation-duration:1.5s}.loading-text{color:var(--text-secondary);font-size:.9rem;font-weight:500;animation:1.5s infinite pulse}@media (width<=992px){.canteen-sidebar{align-items:center;width:80px;padding:16px 8px}.canteen-sidebar-brand h2,.portal-badge,.canteen-owner-info,.sidebar-nav-item span:not(.nav-item-icon),.sidebar-logout-btn span:not(.nav-item-icon){display:none}.canteen-sidebar-brand{margin-bottom:24px}.canteen-owner-profile{background:0 0;border:none;margin-bottom:16px;padding:8px}.canteen-logo-container{width:40px;height:40px}.sidebar-nav-item{justify-content:center;padding:12px}.canteen-main-content{margin-left:80px}.canteen-content-header{padding:0 24px}.canteen-content-body{padding:24px}}.dashboard-page{animation:.4s ease-out fadeIn}.dashboard-welcome{margin-bottom:32px}.dashboard-welcome h2{color:var(--text-primary);margin-bottom:6px;font-size:1.8rem;font-weight:700}.dashboard-welcome p{color:var(--text-secondary);font-size:.95rem}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:32px;display:grid}.metric-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.metric-icon{border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;font-size:2rem;display:flex}.revenue-icon{color:var(--success);background:#34d3991a}.orders-icon{color:var(--secondary);background:#f7c9481a}.completion-icon{color:var(--primary);background:#ff6b351a}.cancellations-icon{color:var(--error);background:#ef44441a}.metric-details{flex-grow:1;min-width:0}.metric-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:.8rem;font-weight:600;display:block}.metric-value{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:1.4rem;font-weight:700;overflow:hidden}.metric-trend{color:var(--text-secondary);font-size:.75rem}.metric-trend.positive{color:var(--success)}.metric-trend.negative{color:var(--error)}.completion-bar-container{background:var(--border);border-radius:2px;height:4px;margin-top:6px;overflow:hidden}.completion-bar{background:var(--primary);border-radius:2px;height:100%;transition:width .5s ease-out}.dashboard-row{align-items:flex-start;gap:24px;display:flex}.col-main{flex:2;min-width:0}.col-side{flex:1;min-width:0}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:24px}.section-card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-card-header h3{color:var(--text-primary);font-size:1.1rem;font-weight:600}.section-header-link{color:var(--primary);transition:var(--transition);font-size:.85rem;font-weight:600}.section-header-link:hover{text-decoration:underline}.table-responsive{width:100%;overflow-x:auto}.dashboard-table{border-collapse:collapse;text-align:left;width:100%}.dashboard-table th{border-bottom:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;font-size:.75rem;font-weight:600}.dashboard-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle;padding:16px;font-size:.9rem}.dashboard-table tr:last-child td{border-bottom:none}.order-id-link{color:var(--primary);font-weight:600}.order-id-link:hover{text-decoration:underline}.customer-info-cell{flex-direction:column;gap:2px;display:flex}.customer-name{color:var(--text-primary);font-weight:550}.customer-phone{color:var(--text-muted);font-size:.75rem}.status-badge-custom{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:4px 8px;font-size:.75rem;font-weight:700;display:inline-block}.order-badge-pending{color:var(--secondary);background:#f7c9481a}.order-badge-confirmed{color:#60a5fa;background:#3b82f61a}.order-badge-preparing{color:#c084fc;background:#a855f71a}.order-badge-ready{color:#fb923c;background:#fb923c1a}.order-badge-completed{color:var(--success);background:#34d3991a}.order-badge-cancelled{color:var(--error);background:#ef44441a}.period-toggle-buttons{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);padding:2px;display:flex}.period-toggle-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:6px;padding:4px 10px;font-size:.75rem;font-weight:600}.period-toggle-btn.active{background:var(--surface-hover);color:var(--primary)}.revenue-history-list{flex-direction:column;gap:16px;display:flex}.revenue-history-item{border-bottom:1px solid #ffffff05;justify-content:space-between;align-items:center;padding:12px;display:flex}.revenue-history-item:last-child{border-bottom:none}.rev-item-left{flex-direction:column;gap:4px;display:flex}.rev-item-period{color:var(--text-primary);font-size:.9rem;font-weight:600}.rev-item-count{color:var(--text-muted);font-size:.75rem}.rev-item-value{color:var(--success);font-size:.95rem;font-weight:700}.empty-state{text-align:center;color:var(--text-muted);padding:40px 20px}.empty-state-emoji{margin-bottom:12px;font-size:2.5rem;display:block}.dashboard-loading{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 0;display:flex}.dashboard-loading .spinner{border:3px solid #0000;border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@media (width<=1200px){.dashboard-row{flex-direction:column}.col-main,.col-side{flex:none;width:100%}}.food-page{animation:.4s ease-out fadeIn}.food-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.food-title-section h2{color:var(--text-primary);margin-bottom:6px;font-size:1.8rem;font-weight:700}.food-title-section p{color:var(--text-secondary);font-size:.95rem}.btn-add-food{background:var(--primary);color:#fff;border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);border:none;align-items:center;gap:8px;padding:12px 24px;font-weight:600;display:flex}.btn-add-food:hover{background:var(--primary-hover);box-shadow:var(--shadow-glow)}.food-filters-bar{align-items:center;gap:20px;margin-bottom:32px;display:flex}.search-box-container{flex-grow:1;position:relative}.search-icon{color:var(--text-muted);position:absolute;top:50%;left:16px;transform:translateY(-50%)}.search-input-field{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-input);width:100%;color:var(--text-primary);transition:var(--transition);padding:12px 16px 12px 44px}.search-input-field:focus{border-color:var(--primary);box-shadow:var(--shadow-glow);outline:none}.category-filter-select{white-space:nowrap;align-items:center;gap:10px;display:flex}.category-filter-select label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.category-filter-select select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-input);color:var(--text-primary);cursor:pointer;transition:var(--transition);padding:12px 20px}.category-filter-select select:focus{border-color:var(--primary);outline:none}.menu-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;display:grid}.food-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);transition:var(--transition);flex-direction:column;display:flex;overflow:hidden}.food-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm);transform:translateY(-4px)}.food-unavailable{opacity:.6}.food-card-image-box{background:var(--input-bg);border-bottom:1px solid var(--border);justify-content:center;align-items:center;height:180px;display:flex;position:relative;overflow:hidden}.food-card-img{object-fit:cover;width:100%;height:100%;transition:var(--transition)}.food-card:hover .food-card-img{transform:scale(1.05)}.food-card-img-placeholder{font-size:3.5rem}.food-img-upload-overlay{color:#fff;opacity:0;transition:var(--transition);cursor:pointer;background:#0f1419bf;border:none;justify-content:center;align-items:center;gap:8px;font-size:.9rem;font-weight:600;display:flex;position:absolute;inset:0}.food-card-image-box:hover .food-img-upload-overlay{opacity:1}.food-card-cat-badge{border:1px solid var(--border);color:var(--secondary);text-transform:uppercase;background:#0f1419d9;border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:700;position:absolute;top:12px;left:12px}.food-card-body{flex-direction:column;flex-grow:1;padding:20px;display:flex}.food-title-row{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px;display:flex}.food-card-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:1.1rem;font-weight:600;overflow:hidden}.food-card-price{color:var(--primary);white-space:nowrap;font-size:1.05rem;font-weight:700}.food-card-desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;height:2.46rem;margin-bottom:16px;font-size:.82rem;line-height:1.5;display:-webkit-box;overflow:hidden}.food-card-stock{color:var(--text-muted);margin-bottom:16px;font-size:.8rem}.stock-count{color:var(--text-secondary);font-weight:600}.food-card-controls{border-top:1px solid #ffffff08;justify-content:space-between;align-items:center;margin-top:auto;padding-top:14px;display:flex}.availability-switch{align-items:center;gap:8px;display:flex}.availability-label{color:var(--text-muted);font-size:.75rem;font-weight:600}.switch{width:38px;height:20px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:var(--border);transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;width:14px;height:14px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:var(--primary)}input:focus+.slider{box-shadow:0 0 1px var(--primary)}input:checked+.slider:before{transform:translate(18px)}.slider.round{border-radius:20px}.slider.round:before{border-radius:50%}.food-action-buttons{gap:8px;display:flex}.btn-edit-item,.btn-delete-item{border:1px solid var(--border);cursor:pointer;width:32px;height:32px;transition:var(--transition);background:0 0;border-radius:6px;justify-content:center;align-items:center;display:flex}.btn-edit-item:hover{border-color:var(--text-secondary);background:#ffffff0d}.btn-delete-item:hover{background:var(--error-bg);border-color:var(--error)}.modal-backdrop-custom{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f1419cc;justify-content:center;align-items:center;padding:24px;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.food-modal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);width:100%;max-width:500px;box-shadow:var(--shadow);padding:32px;animation:.3s cubic-bezier(.16,1,.3,1) scaleIn}.food-modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.food-modal-header h3{color:var(--text-primary);font-size:1.3rem;font-weight:700}.btn-close-modal{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.8rem;line-height:1}.btn-close-modal:hover{color:var(--text-primary)}.food-modal-form{flex-direction:column;gap:16px;display:flex}.food-form-error{background:var(--error-bg);border:1px solid var(--error);color:var(--error);border-radius:var(--radius-input);padding:10px;font-size:.8rem}.food-modal-form .form-group{flex-direction:column;gap:6px;display:flex}.food-modal-form .form-group-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.food-modal-form label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.food-modal-form input,.food-modal-form select,.food-modal-form textarea{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-input);color:var(--text-primary);transition:var(--transition);padding:10px 14px}.food-modal-form input:focus,.food-modal-form select:focus,.food-modal-form textarea:focus{border-color:var(--primary);outline:none}.food-modal-buttons{justify-content:flex-end;gap:12px;margin-top:12px;display:flex}.menu-loading{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:100px 0;display:flex}.menu-loading .spinner{border:3px solid #0000;border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.menu-empty-state{text-align:center;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-card);padding:80px 40px}.menu-empty-state h3{color:var(--text-primary);margin-bottom:6px;font-size:1.2rem;font-weight:600}.menu-empty-state p{color:var(--text-secondary);font-size:.9rem}@media (width<=768px){.food-header{flex-direction:column;align-items:stretch;gap:16px}.food-filters-bar{flex-direction:column;align-items:stretch;gap:14px}}.orders-page{animation:.4s ease-out fadeIn}.orders-header{margin-bottom:32px}.orders-header h2{color:var(--text-primary);margin-bottom:6px;font-size:1.8rem;font-weight:700}.orders-header p{color:var(--text-secondary);font-size:.95rem}.orders-tabs{border-bottom:1px solid var(--border);gap:16px;margin-bottom:32px;display:flex}.tab-button{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 16px;font-size:.95rem;font-weight:600}.tab-button:hover{color:var(--text-primary)}.tab-button.active{border-bottom-color:var(--primary);color:var(--primary)}.tab-button span{border:1px solid var(--border);color:var(--text-muted);background:#ffffff0d;border-radius:10px;margin-left:6px;padding:2px 8px;font-size:.8rem}.tab-button.active span{background:var(--primary-light);color:var(--primary);border-color:#ff6b354d}.orders-list{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;display:grid}.order-item-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);transition:var(--transition);flex-direction:column;display:flex;overflow:hidden}.order-item-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.order-card-header{border-bottom:1px solid var(--border);background:#ffffff03;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.order-id-section{align-items:center;gap:6px;display:flex}.order-id-label{color:var(--text-muted);text-transform:uppercase;font-size:.75rem;font-weight:600}.order-id-number{color:var(--text-primary);font-size:1.05rem;font-weight:700}.order-card-body{flex-direction:column;flex-grow:1;gap:12px;padding:20px;display:flex}.order-info-row{justify-content:space-between;align-items:center;font-size:.9rem;display:flex}.info-label{color:var(--text-muted);font-weight:550}.info-value{color:var(--text-primary);font-weight:600}.info-value.price-text{color:var(--primary);font-size:1rem}.order-card-note,.order-card-cancel-reason{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);margin-top:6px;padding:10px 14px;font-size:.8rem;line-height:1.5}.order-card-note{color:var(--text-secondary)}.order-card-cancel-reason{color:#f87171;background:#ef444408;border-color:#ef444433}.order-card-footer{border-top:1px solid var(--border);background:#ffffff03;justify-content:space-between;align-items:center;margin-top:auto;padding:16px 20px;display:flex}.btn-view-details-custom{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border-radius:6px;padding:8px 16px;font-size:.8rem;font-weight:600}.btn-view-details-custom:hover{color:var(--text-primary);border-color:var(--text-secondary);background:#ffffff0d}.order-action-controls{gap:8px;display:flex}.btn-confirm-custom,.btn-prepare-custom,.btn-ready-custom,.btn-complete-custom,.btn-cancel-custom{cursor:pointer;transition:var(--transition);border:none;border-radius:6px;padding:8px 14px;font-size:.8rem;font-weight:700}.btn-confirm-custom{color:#fff;background:#3b82f6}.btn-confirm-custom:hover{background:#2563eb}.btn-prepare-custom{color:#fff;background:#a855f7}.btn-prepare-custom:hover{background:#9333ea}.btn-ready-custom{color:#fff;background:#fb923c}.btn-ready-custom:hover{background:#ea580c}.btn-complete-custom{background:var(--success);color:#fff}.btn-complete-custom:hover{background:#059669}.btn-cancel-custom{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.btn-cancel-custom:hover{background:var(--error-bg);color:var(--error);border-color:var(--error)}.order-details-modal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);width:100%;max-width:600px;box-shadow:var(--shadow);padding:32px;animation:.3s cubic-bezier(.16,1,.3,1) scaleIn}.details-modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.details-modal-header h3{color:var(--text-primary);font-size:1.3rem;font-weight:700}.details-modal-body{flex-direction:column;gap:20px;max-height:400px;padding-right:8px;display:flex;overflow-y:auto}.details-customer-section,.details-items-section,.details-note-section{border-bottom:1px solid var(--border);padding-bottom:16px}.details-note-section{border-bottom:none}.details-modal-body h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:.9rem;font-weight:700}.details-grid-two{grid-template-columns:1fr 1fr;gap:16px;display:grid}.details-label{color:var(--text-muted);margin-bottom:4px;font-size:.75rem;display:block}.details-value{color:var(--text-primary);font-size:.95rem;font-weight:600}.details-items-list{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.detail-food-item{justify-content:space-between;align-items:center;font-size:.9rem;display:flex}.item-name-col{gap:10px;display:flex}.item-qty{color:var(--primary);font-weight:700}.detail-total-row{border-top:1px dashed var(--border);justify-content:space-between;align-items:center;padding-top:12px;font-size:1.05rem;font-weight:700;display:flex}.total-val{color:var(--primary)}.details-note-p{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);color:var(--text-secondary);padding:10px 14px;font-size:.85rem;line-height:1.5}.details-modal-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;display:flex}.modal-footer-actions{gap:12px;display:flex}.cancel-modal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);width:100%;max-width:440px;box-shadow:var(--shadow);padding:28px}.cancel-modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.cancel-modal-header h3{color:var(--text-primary);font-size:1.2rem;font-weight:700}.cancel-modal-form{flex-direction:column;gap:16px;display:flex}.cancel-modal-form textarea{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);width:100%;color:var(--text-primary);padding:12px;font-size:.85rem}.cancel-modal-form textarea:focus{border-color:var(--error);outline:none}.cancel-modal-buttons{justify-content:flex-end;gap:12px;margin-top:10px;display:flex}.btn-cancel-submit{background:var(--error);color:#fff;cursor:pointer;transition:var(--transition);border:none;border-radius:6px;padding:10px 18px;font-size:.8rem;font-weight:700}.btn-cancel-submit:hover{background:#dc2626}.orders-loading{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:100px 0;display:flex}.orders-loading .spinner{border:3px solid #0000;border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.orders-empty-state{text-align:center;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-card);padding:80px 40px}@media (width<=576px){.orders-tabs{gap:8px}.tab-button{padding:8px 10px;font-size:.8rem}}.settings-page{animation:.4s ease-out fadeIn}.settings-header{margin-bottom:32px}.settings-header h2{color:var(--text-primary);margin-bottom:6px;font-size:1.8rem;font-weight:700}.settings-header p{color:var(--text-secondary);font-size:.95rem}.settings-grid{grid-template-columns:1.4fr 1fr;align-items:flex-start;gap:24px;display:grid}.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:32px}.settings-card h3{color:var(--text-primary);border-bottom:1px solid #ffffff08;margin-bottom:24px;padding-bottom:12px;font-size:1.15rem;font-weight:700}.settings-form{flex-direction:column;gap:20px;display:flex}.settings-success-alert,.settings-error-alert{border-radius:var(--radius-input);border:1px solid #0000;padding:12px 16px;font-size:.85rem;font-weight:550}.settings-success-alert{border-color:var(--success);color:var(--success);background:#34d3991a}.settings-error-alert{background:var(--error-bg);border-color:var(--error);color:var(--error)}.settings-form .form-group{flex-direction:column;gap:8px;display:flex}.settings-form .form-group-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}.settings-form label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.settings-form input,.settings-form textarea{background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-input);color:var(--text-primary);transition:var(--transition);padding:12px 16px}.settings-form input:focus,.settings-form textarea:focus{border-color:var(--primary);box-shadow:var(--shadow-glow);outline:none}.logo-upload-section{text-align:center;border-bottom:1px solid #ffffff08;flex-direction:column;align-items:center;gap:20px;margin-bottom:24px;padding-bottom:32px;display:flex}.logo-preview-box{background:var(--input-bg);border:2px dashed var(--border);border-radius:16px;justify-content:center;align-items:center;width:140px;height:140px;display:flex;position:relative;overflow:hidden}.preview-logo-img{object-fit:cover;width:100%;height:100%}.preview-logo-placeholder{font-size:3.5rem}.logo-upload-spinner{background:#0f1419b3;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.logo-upload-spinner .spinner{border:3px solid #0000;border-top-color:var(--primary);border-radius:50%;width:28px;height:28px;animation:1s linear infinite spin}.logo-upload-details h4{color:var(--text-primary);margin-bottom:6px;font-size:.95rem;font-weight:600}.logo-upload-details p{color:var(--text-muted);max-width:280px;margin-bottom:16px;font-size:.8rem;line-height:1.5}.btn-upload-logo-custom{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border-radius:8px;padding:10px 20px;font-size:.85rem;font-weight:600}.btn-upload-logo-custom:hover:not(:disabled){color:var(--text-primary);border-color:var(--text-secondary);background:#ffffff08}.btn-upload-logo-custom:disabled{opacity:.6;cursor:not-allowed}.store-status-info h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;font-size:.9rem;font-weight:700}.status-row{border:1px solid var(--border);border-radius:var(--radius-input);background:#ffffff03;justify-content:space-between;align-items:center;margin-bottom:12px;padding:12px 16px;display:flex}.status-label{color:var(--text-secondary);font-size:.85rem;font-weight:550}.status-val-badge{letter-spacing:.5px;border-radius:4px;padding:4px 10px;font-size:.75rem;font-weight:700}.status-val-badge.active{color:var(--success);background:#34d39926}.status-val-badge.inactive{color:var(--text-muted);background:#ffffff0d}.status-val-badge.pending{color:var(--secondary);background:#f7c94826}.status-notes{color:var(--text-muted);font-size:.75rem;line-height:1.5}@media (width<=992px){.settings-grid{grid-template-columns:1fr}}.student-home{color:#333;max-width:1200px;min-height:calc(100vh - 100px);margin:0 auto;padding:24px}.canteens-view,.menu-view{flex-direction:column;gap:24px;display:flex}.section-header h2{color:var(--primary,#e28743);margin-bottom:8px;font-size:2rem}.section-header p{color:#666;font-size:1.1rem}.canteens-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;display:grid}.canteen-card{cursor:pointer;background:#fff;border:1px solid #f0f0f0;border-radius:12px;transition:transform .2s,box-shadow .2s;overflow:hidden;box-shadow:0 4px 15px #0000000d}.canteen-card:hover{border-color:#ffd8b3;transform:translateY(-5px);box-shadow:0 10px 20px #0000001a}.canteen-card-image{background:#f7f7f7;border-bottom:1px solid #f0f0f0;justify-content:center;align-items:center;height:180px;display:flex;overflow:hidden}.canteen-card-image img{object-fit:cover;width:100%;height:100%}.canteen-logo-placeholder{font-size:4rem}.canteen-card-info{flex-direction:column;gap:8px;padding:20px;display:flex}.canteen-card-info h3{color:#222;margin:0;font-size:1.25rem}.canteen-addr{color:#666;white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;overflow:hidden}.canteen-hours{color:var(--primary,#e28743);font-size:.9rem;font-weight:500}.canteen-desc{color:#888;-webkit-line-clamp:2;-webkit-box-orient:vertical;height:2.8em;font-size:.85rem;line-height:1.4;display:-webkit-box;overflow:hidden}.canteen-browse-btn{color:var(--primary,#e28743);cursor:pointer;text-align:center;background:#fef4ec;border:none;border-radius:8px;margin-top:8px;padding:10px;font-weight:600;transition:background .2s,color .2s}.canteen-card:hover .canteen-browse-btn{background:var(--primary,#e28743);color:#fff}.menu-header{flex-direction:column;gap:16px;display:flex}.back-btn{color:#555;cursor:pointer;background:0 0;border:none;align-self:flex-start;align-items:center;gap:4px;padding:0;font-size:1rem;font-weight:600;display:flex}.menu-canteen-meta h2{margin:0 0 4px;font-size:1.8rem}.menu-canteen-sub{color:#666}.quick-cart-bar{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2c3e50,#34495e);border-radius:12px;justify-content:space-between;align-items:center;padding:16px 24px;transition:transform .2s;display:flex;box-shadow:0 8px 25px #00000026}.quick-cart-bar:hover{transform:scale(1.01)}.quick-cart-info{align-items:center;gap:24px;font-size:1.1rem;display:flex}.quick-cart-subtotal{border-left:1px solid #fff3;padding-left:24px}.quick-cart-btn{background:var(--primary,#e28743);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-weight:600;transition:background .2s}.quick-cart-btn:hover{background:#cf7735}.categories-tab-bar{gap:12px;padding-bottom:8px;display:flex;overflow-x:auto}.category-tab-btn{cursor:pointer;white-space:nowrap;color:#555;background:#f0f0f0;border:none;border-radius:20px;padding:8px 18px;font-weight:500;transition:background .2s,color .2s}.category-tab-btn.active{background:var(--primary,#e28743);color:#fff}.foods-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;display:grid}.food-item-card{background:#fff;border:1px solid #f0f0f0;border-radius:12px;flex-direction:column;display:flex;overflow:hidden;box-shadow:0 4px 15px #00000008}.food-item-image{background:#f7f7f7;border-bottom:1px solid #f0f0f0;justify-content:center;align-items:center;height:200px;display:flex;overflow:hidden}.food-item-image img{object-fit:cover;width:100%;height:100%}.food-image-placeholder{font-size:5rem}.food-item-body{flex-direction:column;flex-grow:1;gap:12px;padding:20px;display:flex}.food-item-title-row{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.food-item-title-row h3{color:#222;margin:0;font-size:1.2rem}.food-item-category{color:#666;white-space:nowrap;background:#f0f0f0;border-radius:12px;padding:4px 8px;font-size:.75rem;font-weight:600}.food-item-desc{color:#777;flex-grow:1;margin:0;font-size:.85rem;line-height:1.4}.food-item-price-stock{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.food-item-price{color:var(--primary,#e28743);font-size:1.25rem;font-weight:700}.food-item-stock{color:#666;font-size:.85rem}.food-item-actions{gap:12px;margin-top:8px;display:flex}.qty-picker{border:1px solid #dcdcdc;border-radius:8px;align-items:center;display:flex;overflow:hidden}.qty-picker button{cursor:pointer;background:#f7f7f7;border:none;width:36px;height:36px;font-weight:700;transition:background .2s}.qty-picker button:hover{background:#e8e8e8}.qty-picker button:disabled{color:#ccc;cursor:not-allowed;background:#f0f0f0}.qty-display{text-align:center;width:40px;font-weight:600}.add-to-cart-btn{background:var(--primary,#e28743);color:#fff;cursor:pointer;border:none;border-radius:8px;flex-grow:1;font-weight:600;transition:background .2s}.add-to-cart-btn:hover{background:#cf7735}.animate-fade-in{animation:.3s ease-out forwards fadeIn}.animate-slide-in{animation:.3s ease-out forwards slideIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-15px)}to{opacity:1;transform:translateY(0)}}.student-loading{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:calc(100vh - 200px);display:flex}.student-spinner{border:4px solid #f3f3f3;border-top:4px solid var(--primary,#e28743);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{text-align:center;background:#fff;border:1px solid #f0f0f0;border-radius:12px;width:100%;margin:20px 0;padding:48px;box-shadow:0 4px 15px #00000005}.empty-emoji{margin-bottom:16px;font-size:3rem;display:block}.empty-state h3{color:#333;margin:0 0 8px}.empty-state p{color:#777;margin:0}.student-cart{max-width:1200px;min-height:calc(100vh - 100px);margin:0 auto;padding:24px}.cart-header-title h2{color:var(--primary,#e28743);margin:0 0 8px;font-size:2rem}.cart-header-title p{color:#666;margin:0}.cart-tabs{gap:12px;margin:20px 0;padding-bottom:8px;display:flex;overflow-x:auto}.cart-tab-btn{cursor:pointer;white-space:nowrap;color:#555;background:#fff;border:1px solid #ddd;border-radius:8px;padding:10px 20px;font-weight:600;transition:all .2s}.cart-tab-btn.active{background:var(--primary,#e28743);color:#fff;border-color:var(--primary,#e28743);box-shadow:0 4px 10px #e2874333}.cart-container{grid-template-columns:2fr 1fr;gap:32px;margin-top:24px;display:grid}@media (width<=900px){.cart-container{grid-template-columns:1fr}}.cart-items-section{background:#fff;border:1px solid #f0f0f0;border-radius:12px;padding:24px;box-shadow:0 4px 15px #00000008}.cart-section-title{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.cart-section-title h3{color:#222;margin:0;font-size:1.3rem}.clear-cart-btn{color:#e74c3c;cursor:pointer;background:0 0;border:none;font-size:.95rem;font-weight:600}.clear-cart-btn:hover{text-decoration:underline}.cart-table-wrapper{overflow-x:auto}.cart-table{border-collapse:collapse;text-align:left;width:100%}.cart-table th{color:#777;border-bottom:2px solid #f0f0f0;padding:12px 16px;font-size:.9rem;font-weight:600}.cart-table td{vertical-align:middle;border-bottom:1px solid #f0f0f0;padding:20px 16px}.item-td{min-width:250px}.cart-item-info{align-items:center;gap:16px;display:flex}.cart-item-img{background:#f7f7f7;border:1px solid #eee;border-radius:8px;justify-content:center;align-items:center;width:60px;height:60px;font-size:1.8rem;display:flex;overflow:hidden}.cart-item-img img{object-fit:cover;width:100%;height:100%}.cart-item-name{color:#222;font-weight:600;display:block}.stock-warning{color:#e74c3c;margin-top:4px;font-size:.8rem;display:block}.subtotal-td{color:#222;font-weight:600}.delete-item-btn{color:#999;cursor:pointer;background:0 0;border:none;padding:4px;transition:color .2s}.delete-item-btn:hover{color:#e74c3c}.cart-summary-section{flex-direction:column;gap:20px;display:flex}.summary-card{background:#fff;border:1px solid #f0f0f0;border-radius:12px;flex-direction:column;gap:16px;padding:24px;display:flex;box-shadow:0 4px 15px #00000008}.summary-card h3{color:#222;margin:0 0 8px;font-size:1.3rem}.summary-row{color:#555;justify-content:space-between;font-size:1rem;display:flex}.free-badge{color:#2ecc71;font-weight:700}.total-row{color:#222;font-size:1.2rem;font-weight:700}.total-price{color:var(--primary,#e28743);font-size:1.4rem}.summary-card hr{border:none;border-top:1px solid #eee;margin:8px 0}.checkout-form{flex-direction:column;gap:16px;margin-top:12px;display:flex}.checkout-form .form-group{flex-direction:column;gap:8px;display:flex}.checkout-form label{color:#555;font-size:.9rem;font-weight:600}.checkout-form textarea{resize:vertical;border:1px solid #ccc;border-radius:8px;width:100%;padding:12px;font-family:inherit;font-size:.95rem}.checkout-form textarea:focus{border-color:var(--primary,#e28743);outline:none}.checkout-btn{background:var(--primary,#e28743);color:#fff;cursor:pointer;text-align:center;border:none;border-radius:8px;padding:14px;font-size:1.1rem;font-weight:700;transition:background .2s}.checkout-btn:hover{background:#cf7735}.checkout-btn:disabled{cursor:not-allowed;background:#ccc}.student-cart.empty-view{justify-content:center;align-items:center;min-height:calc(100vh - 200px);display:flex}.explore-btn{background:var(--primary,#e28743);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:16px;padding:12px 24px;font-weight:600;transition:background .2s}.explore-btn:hover{background:#cf7735}.student-orders{max-width:800px;min-height:calc(100vh - 100px);margin:0 auto;padding:24px}.orders-header h2{color:var(--primary,#e28743);margin:0 0 8px;font-size:2rem}.orders-header p{color:#666;margin:0}.orders-tabs{border-bottom:2px solid #f0f0f0;gap:16px;margin:24px 0;display:flex}.orders-tab-btn{color:#777;cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;padding:12px 8px;font-size:1.1rem;font-weight:600;transition:all .2s}.orders-tab-btn:hover{color:var(--primary,#e28743)}.orders-tab-btn.active{color:var(--primary,#e28743);border-bottom-color:var(--primary,#e28743)}.orders-list{flex-direction:column;gap:20px;display:flex}.order-summary-card{cursor:pointer;background:#fff;border:1px solid #f0f0f0;border-radius:12px;flex-direction:column;gap:12px;padding:20px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 15px #00000008}.order-summary-card:hover{border-color:#ffd8b3;transform:translateY(-2px);box-shadow:0 8px 20px #00000014}.order-summary-header{justify-content:space-between;align-items:center;display:flex}.order-num-canteen{align-items:center;gap:12px;display:flex}.order-num{color:#222;font-size:1.1rem;font-weight:700}.order-canteen{color:#555;font-weight:500}.status-badge{text-align:center;border-radius:20px;padding:6px 12px;font-size:.75rem;font-weight:700}.status-pending{color:#f90;background:#fff5e6}.status-confirmed{color:#1890ff;background:#e6f7ff}.status-preparing{color:#722ed1;background:#f9f0ff}.status-ready{color:#52c41a;background:#f6ffed}.status-delivering{color:#13c2c2;background:#e6fffb}.status-completed{color:#2ecc71;background:#ebfbee}.status-cancelled{color:#eb2f96;background:#fff0f6}.order-summary-body{color:#666;border-bottom:1px solid #f9f9f9;justify-content:space-between;padding-bottom:12px;font-size:.95rem;display:flex}.order-total strong{color:var(--primary,#e28743);font-size:1.1rem}.order-summary-footer{justify-content:space-between;align-items:center;gap:16px;display:flex}.order-note-preview{color:#888;white-space:nowrap;text-overflow:ellipsis;max-width:70%;margin:0;font-size:.85rem;overflow:hidden}.view-details-btn{color:var(--primary,#e28743);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;font-weight:600}.view-details-btn:hover{text-decoration:underline}.student-order-detail{max-width:1200px;min-height:calc(100vh - 100px);margin:0 auto;padding:24px}.detail-header-row{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.back-btn{color:#555;cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-size:1rem;font-weight:600;display:flex}.back-btn:hover{color:var(--primary,#e28743)}.header-meta{align-items:center;gap:16px;display:flex}.header-meta h2{color:#222;margin:0;font-size:1.6rem}.detail-container{grid-template-columns:2fr 1fr;gap:32px;display:grid}@media (width<=900px){.detail-container{grid-template-columns:1fr}}.detail-main,.detail-sidebar{flex-direction:column;gap:24px;display:flex}.detail-card{background:#fff;border:1px solid #f0f0f0;border-radius:12px;padding:24px;box-shadow:0 4px 15px #00000008}.detail-card h3{color:#222;border-bottom:1px solid #f9f9f9;margin:0 0 16px;padding-bottom:8px;font-size:1.2rem}.canteen-details p{color:#555;margin:6px 0;font-size:1.05rem}.order-items-container{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.order-item-row{justify-content:space-between;align-items:center;display:flex}.order-item-left{align-items:center;gap:12px;display:flex}.item-qty{color:var(--primary,#e28743);font-size:1.05rem;font-weight:700}.item-name{color:#333;font-weight:500}.item-subtotal{color:#222;font-weight:600}.order-total-summary{background:#fdfdfd;border:1px solid #f3f3f3;border-radius:8px;padding:16px}.order-total-summary hr{border:none;border-top:1px solid #eee;margin:12px 0}.total-val{color:var(--primary,#e28743);font-size:1.3rem;font-weight:700}.order-note-text{color:#555;background:#fcfcfc;border-left:3px solid #ddd;border-radius:8px;margin:0;padding:12px;font-style:italic}.no-note-text{color:#999;margin:0;font-style:italic}.delivery-staff-info{color:#14532d;background:#f0fdf4;border:1px solid #dcfce7;border-radius:8px;margin-top:20px;padding:16px}.delivery-staff-info h4{margin:0 0 8px;font-size:1rem}.delivery-staff-info p{margin:4px 0;font-size:.95rem}.cancel-info-box{color:#991b1b;background:#fef2f2;border:1px solid #fee2e2;border-radius:8px;margin-top:20px;padding:16px}.cancel-info-box h4{margin:0 0 8px;font-size:1rem}.cancel-info-box p{margin:4px 0;font-size:.95rem}.cancel-order-trigger-btn{color:#e74c3c;cursor:pointer;background:0 0;border:1px solid #e74c3c;border-radius:8px;margin-top:16px;padding:10px 20px;font-weight:600;transition:all .2s}.cancel-order-trigger-btn:hover{color:#fff;background:#e74c3c}.cancelled-timeline-state{text-align:center;padding:24px}.cancel-timeline-emoji{margin-bottom:12px;font-size:2.5rem;display:block}.cancelled-timeline-state h4{color:#333;margin:0 0 8px}.cancelled-timeline-state p{color:#777;margin:0;font-size:.9rem}.timeline{flex-direction:column;padding-left:20px;display:flex;position:relative}.timeline-item{gap:16px;padding-bottom:24px;display:flex;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-item:after{content:"";z-index:1;background:#e0e0e0;width:2px;position:absolute;top:22px;bottom:0;left:10px}.timeline-item:last-child:after{display:none}.timeline-item.completed:after{background:#2ecc71}.timeline-marker{z-index:2;background:#fff;border:2px solid #e0e0e0;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;margin-left:-1px;transition:all .3s;display:flex}.timeline-item.completed .timeline-marker{background:#2ecc71;border-color:#2ecc71}.timeline-item.active .timeline-marker{border-color:#2ecc71;box-shadow:0 0 0 4px #2ecc7133}.marker-dot{background:#e0e0e0;border-radius:50%;width:8px;height:8px}.timeline-item.active .marker-dot{background:#2ecc71}.marker-check{color:#fff;font-size:.75rem;font-weight:700;line-height:1}.timeline-content{flex-direction:column;gap:4px;display:flex}.timeline-label{color:#777;font-size:.95rem;font-weight:600}.timeline-item.completed .timeline-label{color:#222}.timeline-item.active .timeline-label{color:#2ecc71;font-weight:700}.timeline-time{color:#999;font-size:.8rem}.timeline-note{color:#666;background:#f9f9f9;border-left:2px solid #ccc;border-radius:4px;margin:4px 0 0;padding:6px 10px;font-size:.85rem}.modal-overlay{z-index:100;background:#0006;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background:#fff;border-radius:12px;flex-direction:column;gap:16px;width:90%;max-width:450px;padding:24px;display:flex;box-shadow:0 10px 30px #0003}.modal-content h3{color:#222;margin:0;font-size:1.3rem}.modal-content p{color:#666;margin:0;font-size:.95rem;line-height:1.4}.modal-content textarea{resize:vertical;border:1px solid #ccc;border-radius:8px;width:100%;padding:12px;font-family:inherit;font-size:.95rem}.modal-content textarea:focus{border-color:#e74c3c;outline:none}.modal-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.modal-cancel-btn{color:#555;cursor:pointer;background:#f0f0f0;border:none;border-radius:8px;padding:10px 18px;font-weight:600}.modal-cancel-btn:hover{background:#e0e0e0}.modal-submit-btn{color:#fff;cursor:pointer;background:#e74c3c;border:none;border-radius:8px;padding:10px 18px;font-weight:600}.modal-submit-btn:hover{background:#c0392b}.modal-submit-btn:disabled{cursor:not-allowed;background:#ccc}.student-profile{max-width:600px;min-height:calc(100vh - 100px);margin:0 auto;padding:24px}.profile-header h2{color:var(--primary,#e28743);margin:0 0 8px;font-size:2rem}.profile-header p{color:#666;margin:0}.profile-card{background:#fff;border:1px solid #f0f0f0;border-radius:12px;flex-direction:column;align-items:center;gap:24px;margin-top:24px;padding:32px;display:flex;box-shadow:0 4px 15px #00000008}.profile-avatar-large{background:var(--primary,#e28743);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:90px;height:90px;font-size:3rem;font-weight:700;display:flex;box-shadow:0 4px 10px #e287434d}.profile-details-grid{flex-direction:column;gap:16px;width:100%;display:flex}.profile-detail-item{border-bottom:1px solid #f9f9f9;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.profile-detail-item:last-child{border-bottom:none}.detail-value.role-badge{text-transform:capitalize;color:#555;background:#f0f0f0;border-radius:12px;padding:4px 10px;font-size:.85rem;font-weight:600}.detail-value.status-badge{border-radius:12px;padding:4px 10px;font-size:.8rem;font-weight:700}.customer-support-view{flex-direction:column;gap:24px;height:calc(100vh - 140px);display:flex}.support-header-section{justify-content:space-between;align-items:center;gap:24px;margin-bottom:8px;display:flex}.header-meta h3{margin-bottom:4px;font-size:1.4rem;font-weight:700}.header-meta p{color:var(--text-secondary);margin:0;font-size:.95rem}.new-ticket-btn{white-space:nowrap;padding:12px 24px;font-size:.88rem}.new-ticket-form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;gap:24px;width:100%;max-width:800px;margin:0 auto;padding:32px;display:flex;overflow-y:auto}.new-ticket-form-card h4{color:var(--text-primary);margin:0;font-size:1.2rem;font-weight:700}.form-group-custom{flex-direction:column;flex:1;gap:6px;display:flex}.form-group-custom label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.form-group-custom input,.form-group-custom select,.form-group-custom textarea{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);color:var(--text-primary);transition:var(--transition);padding:12px 14px;font-size:.88rem}.form-group-custom input:focus,.form-group-custom select:focus,.form-group-custom textarea:focus{border-color:var(--primary);outline:none}.form-group-row{gap:20px;display:flex}.form-actions-row{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.support-split-workspace{flex:1;gap:24px;min-height:0;display:flex}.customer-tickets-pane{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;width:320px;display:flex;overflow:hidden}.customer-tickets-pane h5{border-bottom:1px solid var(--border);color:var(--text-primary);background:#ffffff03;margin:0;padding:18px 20px;font-size:.95rem;font-weight:700}.tickets-cards-container{flex-direction:column;flex:1;gap:10px;padding:12px;display:flex;overflow-y:auto}.pane-loader,.pane-empty{text-align:center;color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px 16px;font-size:.88rem;display:flex}.status-badge-custom.open{color:#fbbf24;background:#fbbf241a;border:1px solid #fbbf2433}.status-badge-custom.in_progress{color:var(--primary);background:#3b82f626;border:1px solid #3b82f633}.status-badge-custom.escalated{color:var(--error);background:#ef44441a;border:1px solid #ef444433}.status-badge-custom.resolved{color:var(--success);background:#34d39926;border:1px solid #34d39933}.card-date{color:var(--text-muted);font-size:.72rem}.customer-details-pane{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;flex:1;display:flex;overflow:hidden}.empty-emoji{font-size:3rem}.ticket-details-workspace{flex-direction:column;height:100%;min-height:0;display:flex}.details-header{border-bottom:1px solid var(--border);background:#ffffff03;flex-direction:column;gap:16px;padding:24px;display:flex}.details-header .title-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.details-header .title-row h4{color:var(--text-primary);margin:0;font-size:1.15rem;font-weight:700}.details-meta-bar{color:var(--text-secondary);border-radius:var(--radius-input);border:1px solid var(--border);background:#ffffff05;justify-content:space-between;padding:12px 16px;font-size:.8rem;display:flex}.original-complaint-box{border:1px solid var(--border);border-radius:var(--radius-input);background:#ffffff03;padding:12px 16px;font-size:.85rem}.original-complaint-box strong{color:var(--text-muted);margin-bottom:6px;font-size:.75rem;display:block}.original-complaint-box p{color:var(--text-primary);margin:0;line-height:1.5}.chat-feed-box{flex-direction:column;flex:1;min-height:0;padding:24px;display:flex}.chat-feed-box h5{color:var(--text-secondary);margin:0 0 12px;font-size:.9rem}.no-comments-msg{color:var(--text-muted);font-size:.85rem;font-style:italic}.comment-bubble{border-radius:var(--radius-input);max-width:80%;padding:12px 16px}.comment-bubble.customer{background:#3b82f61a;border:1px solid #3b82f640;align-self:flex-end}.comment-bubble.agent{border:1px solid var(--border);background:#ffffff05;align-self:flex-start}.comment-bubble.customer .comment-bubble-meta{justify-content:flex-end}.role-label,.comment-time{color:var(--text-muted)}.comment-reply-form{border-top:1px solid var(--border);align-items:flex-end;gap:12px;padding-top:16px;display:flex}.comment-reply-form textarea{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);color:var(--text-primary);resize:none;flex:1;padding:12px;font-size:.85rem}.comment-reply-form textarea:focus{border-color:var(--primary);outline:none}.send-reply-btn{height:46px;padding:12px 24px;font-size:.85rem}.resolved-ticket-notification{color:var(--success);border-radius:var(--radius-input);text-align:center;background:#34d3991a;border:1px solid #34d39933;padding:12px 16px;font-size:.85rem;font-weight:600}@media (width<=900px){.support-split-workspace{flex-direction:column}.customer-tickets-pane{width:100%;height:250px}.form-group-row{flex-direction:column;gap:16px}}.student-feedback{max-width:800px;margin:2rem auto;padding:0 1rem}.feedback-header{text-align:center;margin-bottom:2rem}.feedback-header h2{color:var(--text-color,#333);margin-bottom:.5rem;font-size:2.2rem;font-weight:700}.feedback-header p{color:var(--text-muted,#666);font-size:1.1rem}.feedback-content-card{-webkit-backdrop-filter:blur(16px);background:#ffffff14;border:1px solid #ffffff1a;border-radius:16px;padding:2.5rem;box-shadow:0 8px 32px #1f268712}.form-group-feedback{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.form-group-feedback label{color:var(--text-color,#444);font-size:.95rem;font-weight:600}.feedback-input{color:inherit;background:#ffffff0d;border:1px solid #ffffff26;border-radius:8px;outline:none;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:all .2s}.feedback-input:focus{border-color:var(--primary-color,#ff4757);box-shadow:0 0 0 3px #ff475726}.feedback-textarea{resize:vertical;min-height:120px}.rating-stars{gap:.5rem;display:flex}.star-button{color:#fff3;cursor:pointer;background:0 0;border:none;font-size:2rem;transition:transform .1s,color .1s}.star-button.active{color:#ffb800;text-shadow:0 0 10px #ffb8004d}.star-button:hover{transform:scale(1.15)}.feedback-submit-btn{background:var(--primary-color,#ff4757);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:1rem;padding:.85rem;font-size:1.1rem;font-weight:600;transition:background .2s,transform .1s}.feedback-submit-btn:hover{background:var(--primary-hover,#e03747)}.feedback-submit-btn:active{transform:scale(.98)}.feedback-submit-btn:disabled{opacity:.6;cursor:not-allowed}.zoho-iframe-container{background:#fff;border-radius:12px;overflow:hidden}.admin-layout{background:var(--bg);min-height:100vh;color:var(--text-primary);display:flex}.admin-sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:260px;height:100vh;padding:24px;display:flex;position:fixed;top:0;left:0}.admin-sidebar-brand{align-items:center;gap:10px;margin-bottom:32px;display:flex}.admin-sidebar-brand h2{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:700}.admin-portal-badge{text-transform:uppercase;color:var(--primary);letter-spacing:.5px;background:#ff6b3526;border:1px solid #ff6b354d;border-radius:4px;padding:2px 8px;font-size:.65rem;font-weight:700}.admin-profile-sidebar{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-card);align-items:center;gap:12px;margin-bottom:28px;padding:16px;display:flex}.admin-avatar-placeholder{background:var(--primary-light);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.5rem;display:flex}.admin-info-sidebar{overflow:hidden}.admin-name-sidebar{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.9rem;font-weight:600;overflow:hidden}.admin-role-tag{color:var(--primary);text-transform:capitalize;font-size:.75rem}.admin-sidebar-nav{flex-direction:column;flex:1;gap:6px;display:flex}.admin-nav-item{color:var(--text-secondary);border-radius:var(--radius-input);transition:var(--transition);align-items:center;gap:12px;padding:12px 16px;font-size:.9rem;font-weight:500;text-decoration:none;display:flex}.admin-nav-item:hover{background:var(--glass);color:var(--text-primary)}.admin-nav-item.active{background:var(--primary);color:#fff}.nav-item-icon{font-size:1.1rem}.admin-sidebar-footer{border-top:1px solid var(--border);padding-top:16px}.admin-logout-btn{width:100%;color:var(--text-secondary);border-radius:var(--radius-input);cursor:pointer;text-align:left;transition:var(--transition);background:0 0;border:1px solid #0000;align-items:center;gap:12px;padding:12px 16px;font-size:.9rem;font-weight:500;display:flex}.admin-logout-btn:hover{background:var(--error-bg);color:var(--error)}.admin-main-content{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;padding:0 40px 40px;display:flex;overflow-x:hidden}.admin-content-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:24px;padding:24px 0;display:flex}.admin-header-breadcrumbs{align-items:center;gap:8px;font-size:.85rem;display:flex}.breadcrumb-root,.breadcrumb-separator{color:var(--text-muted)}.breadcrumb-current{color:var(--primary);font-weight:600}.admin-user-info{align-items:center;gap:8px;font-size:.9rem;font-weight:500;display:flex}.admin-avatar{background:var(--glass);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:1.1rem;display:flex}.admin-content-body{flex:1;animation:.4s ease-out fadeIn}@media (width<=1024px){.admin-sidebar{align-items:center;width:80px;padding:16px 8px}.admin-sidebar-brand h2,.admin-portal-badge,.admin-info-sidebar,.admin-nav-item text,.admin-logout-btn text{display:none}.admin-profile-sidebar{padding:8px}.admin-sidebar-nav{align-items:center;width:100%}.admin-nav-item{justify-content:center;width:48px;height:48px;padding:0}.admin-main-content{margin-left:80px;padding:0 24px 24px}}.admin-dashboard-view{flex-direction:column;gap:32px;display:flex}.dashboard-intro h3{margin-bottom:4px;font-size:1.4rem;font-weight:700}.dashboard-intro p{color:var(--text-secondary);font-size:.95rem}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;display:grid}.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);transition:var(--transition);align-items:center;gap:16px;padding:20px;display:flex}.metric-card:hover{border-color:var(--primary);transform:translateY(-2px)}.metric-icon{background:var(--glass);border-radius:8px;padding:8px;font-size:2.2rem}.metric-info{flex-direction:column;display:flex}.metric-value{color:var(--text-primary);font-size:1.6rem;font-weight:700}.metric-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem}.highlight-metric{background:linear-gradient(135deg,#ff6b3526,#f7c9480d);border-color:#ff6b354d}.highlight-metric .metric-value{color:var(--primary)}.dashboard-content-split{grid-template-columns:2fr 1fr;gap:24px;display:grid}.revenue-trends-card,.snapshot-controls-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:28px}.revenue-trends-card h4,.snapshot-controls-card h4{border-left:3px solid var(--primary);margin-bottom:20px;padding-left:10px;font-size:1.15rem;font-weight:600}.trends-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}.trend-item{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);text-align:center;flex-direction:column;gap:4px;padding:16px;display:flex}.trend-lbl{color:var(--text-muted);text-transform:uppercase;font-size:.75rem}.trend-val{color:var(--text-primary);font-size:1.15rem;font-weight:700}.bars-chart{flex-direction:column;gap:14px;margin-top:16px;display:flex}.chart-bar-row{align-items:center;gap:16px;font-size:.85rem;display:flex}.bar-date{width:90px;color:var(--text-secondary)}.bar-wrapper{background:var(--input-bg);border-radius:6px;flex:1;height:12px;overflow:hidden}.bar-fill{background:linear-gradient(90deg, var(--primary), var(--secondary));border-radius:6px;height:100%;transition:width .6s ease-out}.bar-val{text-align:right;width:170px;color:var(--text-primary);font-weight:600}.no-data-msg{color:var(--text-muted);text-align:center;padding:20px 0;font-size:.9rem}.snap-desc{color:var(--text-secondary);margin-bottom:24px;font-size:.9rem;line-height:1.5}.snapshot-form{flex-direction:column;gap:16px;display:flex}.snapshot-msg{margin-top:16px;font-size:.9rem;font-weight:500}.admin-loading-container{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 0;display:flex}.admin-spinner{border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@media (width<=992px){.dashboard-content-split{grid-template-columns:1fr}}.dashboard-tabs{border-bottom:1px solid var(--border);gap:16px;margin-top:-16px;padding-bottom:12px;display:flex}.tab-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:8px;padding:8px 16px;font-size:.95rem;font-weight:600}.tab-btn:hover{background:var(--input-bg);color:var(--text-primary)}.tab-btn.active{background:var(--primary);color:#fff}.zoho-analytics-container{flex-direction:column;gap:20px;display:flex}.zoho-analytics-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:12px;box-shadow:0 8px 32px #0000000d}.zoho-placeholder-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;gap:20px;max-width:800px;margin:0 auto;padding:32px;display:flex;box-shadow:0 8px 32px #0000000d}.zoho-placeholder-card h4{color:var(--text-primary);border-left:3px solid var(--primary);padding-left:12px;font-size:1.25rem;font-weight:700}.zoho-placeholder-card p{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.zoho-setup-steps{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);padding:24px}.zoho-setup-steps h5{color:var(--text-primary);margin-bottom:16px;font-size:1rem;font-weight:600}.zoho-setup-steps ol{color:var(--text-secondary);flex-direction:column;gap:12px;padding-left:20px;font-size:.9rem;line-height:1.5;display:flex}.env-code-block{color:#a9feab;background:#1e1e1e;border:1px solid #ffffff1a;border-radius:6px;margin-top:8px;padding:12px 16px;font-family:Consolas,Courier New,Courier,monospace;font-size:.85rem;overflow-x:auto}.btn-primary-custom,.btn-secondary-custom{background:var(--primary);color:#fff;border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-weight:600;display:flex}.btn-primary-custom:hover{background:var(--primary-hover)}.btn-secondary-custom{border:1px solid var(--primary);color:var(--primary);background:0 0}.btn-secondary-custom:hover:not(:disabled){background:var(--primary-light)}.btn-primary-custom:disabled,.btn-secondary-custom:disabled{opacity:.6;cursor:not-allowed}.admin-users-view{flex-direction:column;gap:28px;display:flex}.users-header h3{margin-bottom:4px;font-size:1.4rem;font-weight:700}.users-header p{color:var(--text-secondary);font-size:.95rem}.users-table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.users-data-table{border-collapse:collapse;text-align:left;width:100%;font-size:.85rem}.users-data-table th{color:var(--text-secondary);border-bottom:1px solid var(--border);background:#ffffff05;padding:16px 24px;font-weight:600}.users-data-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:16px 24px}.users-data-table tr:last-child td{border-bottom:none}.user-cell-profile{align-items:center;gap:12px;display:flex}.user-cell-avatar{background:var(--primary-light);width:36px;height:36px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.user-cell-nameinfo{flex-direction:column;display:flex}.user-cell-nameinfo strong{color:var(--text-primary);font-size:.9rem}.user-cell-nameinfo span{color:var(--text-muted);font-size:.75rem}.user-cell-contact{color:var(--text-secondary);flex-direction:column;gap:2px;display:flex}.role-selection-dropdown{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);color:var(--text-primary);cursor:pointer;width:150px;padding:8px 12px;font-size:.8rem}.role-display-badge{text-transform:capitalize;border-radius:4px;padding:4px 10px;font-size:.75rem;font-weight:700;display:inline-block}.role-display-badge.super-admin{color:var(--error);background:#ef44441a;border:1px solid #ef444433}.status-badge-custom{text-transform:capitalize;border-radius:12px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-block}.status-badge-custom.verified{color:var(--success);background:#34d3991a}.status-badge-custom.unverified{color:var(--text-muted);background:#ffffff0d}.status-badge-custom.active{color:var(--success);background:#34d39926}.status-badge-custom.suspended{background:var(--error-bg);color:var(--error);border:1px solid #ef444433}.btn-action-unsuspend{color:var(--success);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);background:0 0;border:1px solid #34d3994d;padding:8px 14px;font-size:.8rem;font-weight:500}.btn-action-unsuspend:hover{background:#34d3991a}.admin-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.3s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.admin-modal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;gap:20px;width:480px;padding:32px;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleIn;display:flex}.admin-modal-card h4{color:var(--text-primary);margin:0;font-size:1.2rem;font-weight:600}.admin-modal-card p{color:var(--text-secondary);margin:0;font-size:.88rem;line-height:1.5}.admin-modal-card label{color:var(--text-secondary);margin-bottom:6px;font-size:.8rem;font-weight:500;display:block}.admin-modal-card textarea{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);width:100%;color:var(--text-primary);resize:none;padding:12px;font-size:.88rem}.admin-modal-card textarea:focus{border-color:var(--primary);outline:none}.admin-modal-buttons{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.btn-secondary-custom{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);background:0 0;padding:10px 20px;font-size:.85rem;font-weight:600}.btn-secondary-custom:hover{border-color:var(--text-muted);color:var(--text-primary)}.btn-primary-custom{background:var(--primary);border:1px solid var(--primary);color:#fff;border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);padding:10px 20px;font-size:.85rem;font-weight:600}.btn-primary-custom:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-danger-custom{background:var(--error);border-color:var(--error)}.btn-danger-custom:hover{background:#dc2626;border-color:#dc2626}@media (width<=768px){.filters-bar{flex-direction:column;align-items:stretch}.select-filters{justify-content:space-between}}.admin-canteens-view{flex-direction:column;gap:28px;display:flex}.canteens-header h3{margin-bottom:4px;font-size:1.4rem;font-weight:700}.canteens-header p{color:var(--text-secondary);font-size:.95rem}.filters-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);justify-content:space-between;align-items:center;gap:24px;padding:16px 24px;display:flex}.search-input-wrapper{flex:1;position:relative}.search-input-icon{color:var(--text-muted);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-input-wrapper input{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);width:100%;color:var(--text-primary);transition:var(--transition);padding:12px 16px 12px 42px;font-size:.9rem}.search-input-wrapper input:focus{border-color:var(--primary);outline:none}.select-filters{gap:16px;display:flex}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-group label{color:var(--text-secondary);font-size:.75rem;font-weight:500}.filter-group select{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);color:var(--text-primary);cursor:pointer;padding:10px 16px;font-size:.85rem}.filter-group select:focus{border-color:var(--primary);outline:none}.canteens-table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden}.canteens-data-table{border-collapse:collapse;text-align:left;width:100%;font-size:.85rem}.canteens-data-table th{color:var(--text-secondary);border-bottom:1px solid var(--border);background:#ffffff05;padding:16px 24px;font-weight:600}.canteens-data-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:16px 24px}.canteens-data-table tr:last-child td{border-bottom:none}.canteen-cell-profile{align-items:center;gap:16px;display:flex}.canteen-cell-logo{border:1px solid var(--border);background:#ffffff0d;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex}.canteen-cell-info{flex-direction:column;display:flex}.canteen-cell-info strong{color:var(--text-primary);font-size:.95rem}.canteen-cell-info span{color:var(--text-secondary);font-size:.8rem}.owner-cell-info{flex-direction:column;gap:2px;display:flex}.owner-cell-info strong{color:var(--text-primary);font-size:.88rem}.owner-cell-info span{color:var(--text-secondary);font-size:.78rem}.status-badge-custom{text-align:center;border-radius:12px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-block}.status-badge-custom.pending{color:#fbbf24;background:#fbbf241a;border:1px solid #fbbf2433}.status-badge-custom.active{color:var(--success);background:#34d3991a;border:1px solid #34d39933}.status-badge-custom.suspended{color:var(--error);background:#ef44441a;border:1px solid #ef444433}.contract-cell-status{flex-direction:column;gap:4px;display:flex}.contract-badge{text-transform:capitalize;border-radius:4px;width:fit-content;padding:3px 8px;font-size:.7rem;font-weight:700;display:inline-block}.contract-badge.pending{color:#fbbf24;background:#fbbf241a;border:1px solid #fbbf2426}.contract-badge.signed{color:var(--success);background:#34d3991a;border:1px solid #34d39926}.contract-date{color:var(--text-muted);font-size:.7rem}.no-contract-badge{color:var(--text-muted);font-size:.75rem}.empty-results-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);text-align:center;color:var(--text-muted);padding:48px}.btn-action-approve{color:var(--success);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);background:0 0;border:1px solid #34d3994d;padding:8px 14px;font-size:.8rem;font-weight:600}.btn-action-approve:hover{background:#34d39926}.btn-action-suspend{color:var(--error);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);background:0 0;border:1px solid #ef44444d;padding:8px 14px;font-size:.8rem;font-weight:600}.btn-action-suspend:hover{background:#ef444426}@media (width<=768px){.filters-bar{flex-direction:column;align-items:stretch}.select-filters{justify-content:space-between}}.admin-support-view{flex-direction:column;gap:24px;height:calc(100vh - 120px);display:flex}.support-header-bar h3{margin-bottom:4px;font-size:1.4rem;font-weight:700}.support-header-bar p{color:var(--text-secondary);margin:0;font-size:.95rem}.support-workspace-layout{flex:1;gap:24px;min-height:0;display:flex}.support-tickets-pane{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;width:320px;display:flex;overflow:hidden}.pane-filters{border-bottom:1px solid var(--border);background:#ffffff03;gap:12px;padding:16px;display:flex}.pane-filters .filter-group{flex-direction:column;flex:1;gap:4px;display:flex}.pane-filters .filter-group label{color:var(--text-secondary);font-size:.7rem;font-weight:600}.pane-filters .filter-group select{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);color:var(--text-primary);cursor:pointer;padding:8px;font-size:.8rem}.pane-loading{color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:48px 16px;display:flex}.pane-empty{color:var(--text-muted);flex:1;justify-content:center;align-items:center;padding:48px 16px;font-size:.88rem;display:flex}.tickets-cards-list{flex-direction:column;flex:1;gap:10px;padding:12px;display:flex;overflow-y:auto}.ticket-summary-card{border:1px solid var(--border);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);background:#ffffff05;flex-direction:column;gap:8px;padding:16px;display:flex}.ticket-summary-card:hover{border-color:var(--text-muted);background:#ffffff0a}.ticket-summary-card.active{border-color:var(--primary);background:#ffffff0d;box-shadow:0 0 12px #3b82f626}.card-top-row{justify-content:space-between;align-items:center;display:flex}.priority-tag{border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:700}.priority-tag.low{color:var(--primary);background:#3b82f61a;border:1px solid #3b82f626}.priority-tag.medium{color:#fbbf24;background:#fbbf241a;border:1px solid #fbbf2426}.priority-tag.high{color:var(--error);background:#ef44441a;border:1px solid #ef444426}.card-subject{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;overflow:hidden}.card-meta{color:var(--text-muted);justify-content:space-between;font-size:.72rem;display:flex}.support-details-pane{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;flex:1;display:flex;overflow:hidden}.workspace-empty-selection{text-align:center;color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:48px;display:flex}.workspace-empty-emoji{font-size:3rem}.details-pane-loading{color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.ticket-workspace{flex-direction:column;height:100%;min-height:0;display:flex}.ticket-workspace-header{border-bottom:1px solid var(--border);background:#ffffff03;flex-direction:column;gap:16px;padding:24px;display:flex}.ticket-workspace-header .title-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.ticket-workspace-header .title-row h4{color:var(--text-primary);margin:0;font-size:1.15rem;font-weight:700}.header-status-badge{align-items:center;gap:8px;display:flex}.meta-grid{border:1px solid var(--border);border-radius:var(--radius-input);background:#ffffff05;grid-template-columns:repeat(2,1fr);gap:12px;padding:14px 18px;display:grid}.meta-item{color:var(--text-secondary);flex-direction:column;font-size:.8rem;display:flex}.meta-label{color:var(--text-muted);margin-bottom:2px;font-size:.72rem}.order-status-subtag{color:var(--text-muted);text-transform:capitalize;margin-left:4px;font-size:.75rem}.ticket-description-box{border:1px solid var(--border);border-radius:var(--radius-input);background:#ffffff03;padding:12px 16px;font-size:.85rem}.ticket-description-box strong{color:var(--text-muted);margin-bottom:6px;font-size:.75rem;display:block}.ticket-description-box p{color:var(--text-primary);margin:0;line-height:1.5}.ticket-ops-buttons{justify-content:flex-end;gap:12px;display:flex}.btn-action-escalate{color:#fbbf24;border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);background:0 0;border:1px solid #fbbf244d;padding:8px 16px;font-size:.8rem;font-weight:600}.btn-action-escalate:hover{background:#fbbf2426}.btn-action-resolve{background:var(--primary);border:1px solid var(--primary);color:#fff;border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);padding:8px 16px;font-size:.8rem;font-weight:600}.btn-action-resolve:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.ticket-chat-feed{flex-direction:column;flex:1;min-height:0;padding:24px;display:flex}.ticket-chat-feed h5{color:var(--text-secondary);margin:0 0 12px;font-size:.9rem}.comments-scroll-area{flex-direction:column;flex:1;gap:14px;margin-bottom:16px;padding-right:8px;display:flex;overflow-y:auto}.comment-bubble{border:1px solid var(--border);border-radius:var(--radius-input);background:#ffffff05;align-self:flex-start;max-width:85%;padding:12px 16px}.comment-bubble.internal-admin{background:#fbbf240a;border-color:#fbbf2440;align-self:flex-end}.comment-bubble-meta{color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:6px;font-size:.72rem;display:flex}.role-bubble-tag{color:var(--text-muted);text-transform:capitalize}.internal-badge-indicator{color:#fbbf24;background:#fbbf2426;border-radius:4px;padding:1px 6px;font-size:.65rem;font-weight:700}.comment-time{color:var(--text-muted);margin-left:auto}.comment-message{color:var(--text-primary);white-space:pre-wrap;margin:0;font-size:.85rem;line-height:1.45}.comment-compose-form{border-top:1px solid var(--border);flex-direction:column;gap:12px;padding-top:16px;display:flex}.comment-compose-form textarea{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);width:100%;color:var(--text-primary);resize:none;padding:12px;font-size:.85rem}.comment-compose-form textarea:focus{border-color:var(--primary);outline:none}.compose-bottom-controls{justify-content:space-between;align-items:center;display:flex}.checkbox-internal-wrapper{cursor:pointer;color:var(--text-secondary);align-items:center;gap:8px;font-size:.8rem;display:flex}.checkbox-internal-wrapper input{cursor:pointer}@media (width<=900px){.support-workspace-layout{flex-direction:column}.support-tickets-pane{width:100%;height:250px}}.admin-reports-view{flex-direction:column;gap:28px;display:flex}.reports-header-section h3{margin-bottom:4px;font-size:1.4rem;font-weight:700}.reports-header-section p{color:var(--text-secondary);font-size:.95rem}.reports-tabs-nav{border-bottom:1px solid var(--border);gap:12px;padding-bottom:1px;display:flex}.tab-nav-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 20px;font-size:.9rem;font-weight:600}.tab-nav-btn:hover{color:var(--text-primary)}.tab-nav-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.health-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.health-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;gap:20px;padding:24px;display:flex}.health-card h4{color:var(--text-primary);margin:0 0 4px;font-size:1.1rem;font-weight:600}.health-node-list{flex-direction:column;gap:16px;display:flex}.health-node-item{border:1px solid var(--border);border-radius:var(--radius-input);background:#ffffff05;align-items:center;gap:16px;padding:12px 16px;display:flex}.node-icon{font-size:1.5rem}.node-detail{flex-direction:column;flex:1;display:flex}.node-detail strong{color:var(--text-primary);font-size:.9rem}.node-detail span{color:var(--text-secondary);font-size:.78rem}.node-status-tag{text-transform:uppercase;border-radius:4px;padding:4px 10px;font-size:.7rem;font-weight:700;display:inline-block}.node-status-tag.healthy,.node-status-tag.OK{color:var(--success);background:#34d3991a}.node-status-tag.unhealthy,.node-status-tag.ERROR{color:var(--error);background:#ef44441a}.metrics-indicators-list{flex-direction:column;gap:12px;display:flex}.metric-indicator-box{border:1px solid var(--border);border-radius:var(--radius-input);background:#ffffff05;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.metric-indicator-label{color:var(--text-secondary);font-size:.85rem}.metric-indicator-value{color:var(--text-primary);font-size:1.05rem;font-weight:700}.refresh-health-btn{width:100%;margin-top:8px;padding:12px;font-size:.88rem}.settings-list-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:24px}.settings-list-header{margin-bottom:24px}.settings-list-header h4{margin:0;font-size:1.1rem;font-weight:600}.settings-list-header p{color:var(--text-secondary);margin:4px 0 0;font-size:.85rem}.settings-items-container{flex-direction:column;gap:16px;display:flex}.setting-item-row{border:1px solid var(--border);border-radius:var(--radius-input);background:#ffffff03;justify-content:space-between;align-items:center;gap:24px;padding:16px 20px;display:flex}.setting-item-meta{flex-direction:column;flex:1;gap:4px;display:flex}.setting-item-meta strong{color:var(--text-primary);font-size:.88rem}.setting-item-meta span{color:var(--text-secondary);font-size:.8rem}.setting-item-control{align-items:center;gap:12px;display:flex}.setting-item-input{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);width:220px;color:var(--text-primary);text-align:right;transition:var(--transition);padding:8px 12px;font-size:.88rem}.setting-item-input:focus{border-color:var(--primary);background:#ffffff08;outline:none}.setting-saving-spinner{font-size:1rem}.audit-timestamp{white-space:nowrap;color:var(--text-secondary)}.audit-admin-info{flex-direction:column;display:flex}.audit-admin-info strong{color:var(--text-primary)}.audit-admin-info span{color:var(--text-secondary);font-size:.75rem}.audit-action-tag{text-transform:capitalize;border-radius:4px;padding:3px 8px;font-size:.72rem;font-weight:700;display:inline-block}.audit-action-tag.user-suspend,.audit-action-tag.user-status{color:var(--error);background:#ef44441a;border:1px solid #ef444433}.audit-action-tag.canteen-approve{color:var(--success);background:#34d3991a;border:1px solid #34d39933}.audit-action-tag.setting-update{color:var(--primary);background:#3b82f61a;border:1px solid #3b82f633}.audit-target-info{color:var(--text-secondary);flex-direction:column;font-size:.78rem;display:flex}.audit-client-info{flex-direction:column;gap:2px;display:flex}.audit-ua{color:var(--text-muted);word-break:break-all;font-size:.72rem}.audit-details-json{max-width:250px;overflow:auto}.audit-details-json pre{border:1px solid var(--border);color:var(--text-secondary);background:#0000004d;border-radius:4px;margin:0;padding:8px;font-family:monospace;font-size:.72rem}.audit-pagination-bar{justify-content:space-between;align-items:center;margin-top:16px;padding:0 4px;display:flex}.audit-page-display{color:var(--text-secondary);font-size:.88rem}@media (width<=1024px){.health-grid{grid-template-columns:1fr}}.feedback-tab-view{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:24px}.feedback-reports-container{margin-top:12px}.feedback-date{white-space:nowrap;color:var(--text-secondary);font-size:.85rem}.feedback-rating-display{color:#f59e0b;letter-spacing:2px;white-space:nowrap;font-size:1.1rem}.feedback-comments-text{color:var(--text-primary);word-break:break-word;max-width:450px;font-size:.88rem;line-height:1.5}.feedback-email{color:var(--text-secondary);word-break:break-all;font-size:.85rem}.source-badge{text-align:center;border-radius:6px;padding:4px 8px;font-size:.75rem;font-weight:600;display:inline-block}.source-badge.direct{color:var(--primary);background:#ff6b3526;border:1px solid #ff6b354d}.source-badge.zoho_forms{color:#10b981;background:#10b98126;border:1px solid #10b9814d}.delivery-layout{background:var(--bg);min-height:100vh;color:var(--text-primary);display:flex}.delivery-sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:260px;height:100vh;padding:24px;display:flex;position:fixed;top:0;left:0}.delivery-sidebar-brand{align-items:center;gap:10px;margin-bottom:32px;display:flex}.sidebar-brand-emoji{font-size:1.8rem}.delivery-sidebar-brand h2{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:700}.delivery-portal-badge{text-transform:uppercase;color:var(--secondary);letter-spacing:.5px;background:#f7c94826;border:1px solid #f7c9484d;border-radius:4px;padding:2px 8px;font-size:.65rem;font-weight:700}.delivery-profile-sidebar{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-card);align-items:center;gap:12px;margin-bottom:28px;padding:16px;display:flex}.delivery-avatar-placeholder{background:#f7c9481a;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.5rem;display:flex}.delivery-info-sidebar{overflow:hidden}.delivery-name-sidebar{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.9rem;font-weight:600;overflow:hidden}.delivery-role-tag{color:var(--secondary);font-size:.75rem}.delivery-sidebar-nav{flex-direction:column;flex:1;gap:6px;display:flex}.delivery-nav-item{color:var(--text-secondary);border-radius:var(--radius-input);transition:var(--transition);align-items:center;gap:12px;padding:12px 16px;font-size:.9rem;font-weight:500;text-decoration:none;display:flex}.delivery-nav-item:hover{background:var(--glass);color:var(--text-primary)}.delivery-nav-item.active{background:var(--primary);color:#fff}.delivery-sidebar-footer{border-top:1px solid var(--border);padding-top:16px}.delivery-logout-btn{width:100%;color:var(--text-secondary);border-radius:var(--radius-input);cursor:pointer;text-align:left;transition:var(--transition);background:0 0;border:1px solid #0000;align-items:center;gap:12px;padding:12px 16px;font-size:.9rem;font-weight:500;display:flex}.delivery-logout-btn:hover{background:var(--error-bg);color:var(--error)}.delivery-main-content{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;padding:0 40px 40px;display:flex;overflow-x:hidden}.delivery-content-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:24px;padding:24px 0;display:flex}.delivery-header-breadcrumbs{align-items:center;gap:8px;font-size:.85rem;display:flex}.delivery-user-info{align-items:center;gap:8px;font-size:.9rem;font-weight:500;display:flex}.delivery-avatar{background:var(--glass);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:1.1rem;display:flex}.delivery-content-body{flex:1;animation:.4s ease-out fadeIn}@media (width<=1024px){.delivery-sidebar{align-items:center;width:80px;padding:16px 8px}.delivery-sidebar-brand h2,.delivery-portal-badge,.delivery-info-sidebar,.delivery-nav-item text,.delivery-logout-btn text{display:none}.delivery-profile-sidebar{padding:8px}.delivery-sidebar-nav{align-items:center;width:100%}.delivery-nav-item{justify-content:center;width:48px;height:48px;padding:0}.delivery-main-content{margin-left:80px;padding:0 24px 24px}}.delivery-dashboard-view{flex-direction:column;gap:24px;height:calc(100vh - 120px);display:flex}.rider-stats-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.rider-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);align-items:center;gap:16px;padding:16px 20px;display:flex}.rider-stat-icon{font-size:2rem}.rider-stat-info{flex-direction:column;display:flex}.rider-stat-value{color:var(--text-primary);font-size:1.35rem;font-weight:700;line-height:1.2}.rider-stat-label{color:var(--text-secondary);font-size:.78rem}.delivery-tabs-nav{border-bottom:1px solid var(--border);gap:12px;display:flex}.delivery-tab-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 20px;font-size:.9rem;font-weight:600}.delivery-tab-btn:hover{color:var(--text-primary)}.delivery-tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.delivery-workspace-split{flex:1;gap:24px;min-height:0;display:flex}.delivery-orders-list-pane{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;gap:12px;width:330px;padding:16px;display:flex;overflow-y:auto}.pane-loader{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 16px;display:flex}.pane-empty-card{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 16px;display:flex}.pane-empty-card .empty-emoji{font-size:2.5rem}.delivery-cards-stack{flex-direction:column;gap:12px;display:flex}.delivery-order-card{border:1px solid var(--border);border-radius:var(--radius-input);cursor:pointer;transition:var(--transition);background:#ffffff05;flex-direction:column;gap:12px;padding:16px;display:flex}.delivery-order-card:hover{border-color:var(--text-muted);background:#ffffff0a}.delivery-order-card.active{border-color:var(--primary);background:#ffffff0d;box-shadow:0 0 12px #3b82f626}.card-top{justify-content:space-between;align-items:center;display:flex}.card-top strong{color:var(--text-primary);font-size:.9rem}.card-route-info{border-top:1px solid #ffffff08;border-bottom:1px solid #ffffff08;flex-direction:column;gap:8px;padding:8px 0;display:flex}.route-stop{align-items:flex-start;gap:8px;display:flex}.stop-icon{margin-top:2px;font-size:.9rem}.stop-detail{color:var(--text-secondary);flex-direction:column;font-size:.78rem;display:flex}.stop-detail span{color:var(--text-muted);font-size:.68rem}.stop-detail strong{color:var(--text-primary)}.address-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:230px;font-size:.72rem;overflow:hidden}.card-bottom{justify-content:space-between;align-items:center;font-size:.78rem;display:flex}.amount-label{color:var(--text-muted)}.amount-value{color:var(--primary);font-weight:700}.delivery-details-pane{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;flex:1;display:flex;overflow-y:auto}.empty-details-view{text-align:center;color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:48px;display:flex}.empty-rider-emoji{font-size:3rem}.details-loader{color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.delivery-details-workspace{flex-direction:column;gap:20px;height:100%;padding:24px;display:flex}.delivery-details-workspace h4{color:var(--text-primary);margin:0;font-size:1.15rem;font-weight:700}.details-route-card{border:1px solid var(--border);border-radius:var(--radius-input);background:#ffffff05;flex-direction:column;gap:20px;padding:20px;display:flex;position:relative}.details-route-card:before{content:"";background:dashed var(--border);z-index:1;width:2px;position:absolute;top:36px;bottom:36px;left:29px}.route-step{z-index:2;align-items:flex-start;gap:16px;display:flex;position:relative}.bullet{border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.65rem;font-weight:800;display:flex}.bullet.start{background:var(--primary);color:#fff}.bullet.end{background:var(--success);color:#fff}.step-content{color:var(--text-secondary);flex-direction:column;gap:2px;font-size:.82rem;display:flex}.step-content strong{color:var(--text-primary);font-size:.9rem}.address-highlight{color:var(--success);margin-top:4px;font-weight:600}.order-items-box{border:1px solid var(--border);border-radius:var(--radius-input);background:#ffffff03;padding:16px}.order-items-box h5{color:var(--text-muted);text-transform:uppercase;margin:0 0 12px;font-size:.85rem}.items-list-container{flex-direction:column;gap:8px;max-height:150px;margin-bottom:12px;padding-right:4px;display:flex;overflow-y:auto}.item-row-rider{justify-content:space-between;font-size:.85rem;display:flex}.item-qty{color:var(--primary);width:32px;font-weight:700}.item-name{color:var(--text-primary);flex:1}.item-price{color:var(--text-secondary)}.items-box-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:12px;font-size:.88rem;display:flex}.items-box-footer span{color:var(--text-secondary)}.items-box-footer strong{color:var(--primary);font-size:1rem}.rider-note-card{border-radius:var(--radius-input);background:#fbbf240a;border:1px solid #fbbf2433;padding:12px 16px;font-size:.85rem}.rider-note-card strong{color:#fbbf24;margin-bottom:4px;font-size:.75rem;display:block}.rider-note-card p{color:var(--text-primary);margin:0;font-style:italic}.rider-action-footer{margin-top:auto}.btn-rider-action{border-radius:var(--radius-input);cursor:pointer;width:100%;transition:var(--transition);border:none;padding:14px;font-size:.95rem;font-weight:700}.btn-rider-action.claim{background:var(--primary);color:#fff}.btn-rider-action.claim:hover{background:var(--primary-hover)}.btn-rider-action.complete{background:var(--success);color:#fff}.btn-rider-action.complete:hover{background:#059669}@media (width<=900px){.delivery-workspace-split{flex-direction:column}.delivery-orders-list-pane{width:100%;height:250px}.rider-stats-grid{grid-template-columns:1fr;gap:12px}}.delivery-profile-view{flex-direction:column;gap:24px;display:flex}.profile-header-section h3{margin-bottom:4px;font-size:1.4rem;font-weight:700}.profile-header-section p{color:var(--text-secondary);margin:0;font-size:.95rem}.profile-workspace-grid{grid-template-columns:280px 1fr;align-items:start;gap:24px;display:grid}.profile-card-left{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);text-align:center;flex-direction:column;align-items:center;padding:32px 24px;display:flex}.profile-avatar-large{border:2px solid var(--border);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;width:90px;height:90px;margin-bottom:16px;font-size:3rem;display:flex}.profile-card-left h4{color:var(--text-primary);margin:0 0 4px;font-size:1.15rem;font-weight:700}.rider-status-role{color:var(--primary);background:var(--primary-light);border-radius:12px;margin-bottom:24px;padding:3px 10px;font-size:.72rem;font-weight:800}.duty-status-toggle{border-top:1px solid var(--border);flex-direction:column;align-items:center;gap:12px;width:100%;padding-top:20px;display:flex}.duty-label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.btn-duty-toggle{border:1px solid var(--border);border-radius:var(--radius-input);cursor:pointer;width:100%;transition:var(--transition);padding:12px;font-size:.85rem;font-weight:700}.btn-duty-toggle.active{color:var(--success);background:#34d3991a;border-color:#34d3994d}.btn-duty-toggle.inactive{color:var(--error);background:#ef44441a;border-color:#ef44444d}.duty-help-text{color:var(--text-muted);margin:0;font-size:.72rem;line-height:1.4}.profile-card-right{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-direction:column;gap:32px;padding:32px;display:flex}.profile-details-section h5{color:var(--text-primary);border-bottom:1px solid var(--border);margin:0 0 16px;padding-bottom:8px;font-size:1rem;font-weight:700}.profile-details-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.profile-detail-item{flex-direction:column;gap:4px;display:flex}.detail-label{color:var(--text-secondary);font-size:.75rem;font-weight:500}.detail-value{color:var(--text-primary);font-size:.95rem;font-weight:600}.detail-value.status-badge{border-radius:4px;width:fit-content;padding:2px 8px;font-size:.72rem;font-weight:800;display:inline-block}.detail-value.status-badge.verified{color:var(--success);background:#34d3991a}.detail-value.status-badge.unverified{color:var(--text-muted);background:#ffffff0d}.form-grid-vehicle{grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px;display:grid}.form-group-vehicle{flex-direction:column;gap:6px;display:flex}.form-group-vehicle label{color:var(--text-secondary);font-size:.75rem;font-weight:500}.form-group-vehicle select,.form-group-vehicle input{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-input);color:var(--text-primary);transition:var(--transition);padding:10px 14px;font-size:.88rem}.form-group-vehicle select:focus,.form-group-vehicle input:focus{border-color:var(--primary);outline:none}.save-vehicle-btn{width:fit-content;padding:10px 24px;font-size:.88rem}@media (width<=768px){.profile-workspace-grid,.profile-details-grid,.form-grid-vehicle{grid-template-columns:1fr}}:root{--primary:#ff6b35;--primary-hover:#e85d2c;--primary-light:#ff6b351a;--secondary:#f7c948;--bg:#0f1419;--surface:#1a1f2e;--surface-hover:#242938;--glass:#ffffff0d;--glass-border:#ffffff1a;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--success:#34d399;--error:#ef4444;--error-bg:#ef44441a;--border:#2d3348;--input-bg:#141824;--input-border:#2d3348;--input-focus-border:#ff6b35;--shadow:0 25px 50px #00000080;--shadow-sm:0 4px 12px #0000004d;--shadow-glow:0 0 20px #ff6b354d;--radius-card:12px;--radius-input:8px;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{color:var(--text-primary);background:#ff6b354d}input,button,textarea,select{font-family:inherit;font-size:inherit}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}a{color:var(--primary);transition:var(--transition);text-decoration:none}a:hover{color:var(--primary-hover)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes glow{0%,to{box-shadow:0 0 5px #ff6b3533}50%{box-shadow:0 0 20px #ff6b3566}}.text-center{text-align:center}.text-error{color:var(--error);font-size:.85rem}.text-success{color:var(--success);font-size:.85rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.fade-in{animation:.5s ease-out fadeIn}.slide-up{animation:.5s ease-out slideUp}.toast-container-global{z-index:9999;pointer-events:none;flex-direction:column;gap:12px;display:flex;position:fixed;top:24px;right:24px}.toast-message-card{pointer-events:auto;border-radius:var(--radius-card);-webkit-backdrop-filter:blur(12px)saturate(180%);min-width:300px;max-width:450px;color:var(--text-primary);animation:.3s cubic-bezier(.16,1,.3,1) toastSlideIn,.35s forwards fadeOut;animation-delay:0s, var(--toast-delay,2.7s);background:#1a1f2ebf;border:1px solid #ffffff14;align-items:center;gap:12px;padding:16px 20px;transition:transform .2s,opacity .2s;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 30px #0006}.toast-message-card:before{content:"";background:var(--toast-status-color,var(--primary));width:4px;position:absolute;top:0;bottom:0;left:0}.toast-message-card.success{--toast-status-color:#34d399;border-color:#34d39926}.toast-message-card.error{--toast-status-color:#ef4444;border-color:#ef444426}.toast-message-card.warning{--toast-status-color:#fbbf24;border-color:#fbbf2426}.toast-message-card.info{--toast-status-color:#60a5fa;border-color:#60a5fa26}.toast-card-icon{justify-content:center;align-items:center;font-size:1.2rem;display:flex}.toast-card-text{flex:1;font-size:.88rem;font-weight:500;line-height:1.4}.toast-card-close{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;font-size:1.1rem;display:flex}.toast-card-close:hover{color:var(--text-primary)}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)translateY(-10px)}to{opacity:1;transform:translate(0)translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}.confirm-overlay-global{-webkit-backdrop-filter:blur(8px);z-index:10000;background:#000000a6;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.25s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.confirm-card-global{-webkit-backdrop-filter:blur(16px)saturate(180%);border-radius:var(--radius-card);background:#1a1f2ed9;border:1px solid #ffffff14;flex-direction:column;gap:20px;width:420px;padding:28px;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleIn;display:flex;box-shadow:0 20px 50px #00000080}.confirm-card-title{color:var(--text-primary);margin:0;font-size:1.15rem;font-weight:700}.confirm-card-msg{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.5}.confirm-card-buttons{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}#root{flex-direction:column;min-height:100vh;display:flex}
