:root{--color-bg: #0d0d0d;--color-bg-elevated: #141414;--color-bg-card: #1a1a1a;--color-bg-card-hover: #1f1f1f;--color-bg-input: #0a0a0a;--color-gold: #c9a962;--color-gold-light: #e4d4a8;--color-gold-dark: #9f8347;--color-gold-glow: rgba(201, 169, 98, .15);--color-text: #f5f5f5;--color-text-secondary: #a0a0a0;--color-text-muted: #666666;--color-text-inverse: #0d0d0d;--color-success: #4ade80;--color-success-bg: rgba(74, 222, 128, .1);--color-warning: #fbbf24;--color-warning-bg: rgba(251, 191, 36, .1);--color-error: #f87171;--color-error-bg: rgba(248, 113, 113, .1);--color-info: #60a5fa;--color-info-bg: rgba(96, 165, 250, .1);--color-border: #2a2a2a;--color-border-light: #333333;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-display: "Cormorant Garamond", Georgia, serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.5rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-2xl: 32px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-gold: 0 0 30px rgba(201, 169, 98, .15);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:400;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);min-height:100vh;min-height:100dvh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:500;line-height:1.2;color:var(--color-text);letter-spacing:.02em}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}a{color:var(--color-gold);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-gold-light)}.material-symbols-rounded{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;vertical-align:middle}.icon-filled{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24}.icon-sm{font-size:20px}.icon-md{font-size:24px}.icon-lg{font-size:32px}.icon-xl{font-size:48px}.skeleton{background:linear-gradient(90deg,var(--color-bg-card) 0%,var(--color-bg-card-hover) 50%,var(--color-bg-card) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1em;margin-bottom:var(--space-2)}.skeleton-text-sm{height:.875em;width:60%}.skeleton-title{height:2em;width:40%;margin-bottom:var(--space-4)}.skeleton-avatar{width:48px;height:48px;border-radius:var(--radius-full)}.skeleton-card{height:100px;margin-bottom:var(--space-4)}.skeleton-stat{width:60px;height:2.5rem}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:var(--space-6);background:var(--color-bg)}.login-card{width:100%;max-width:420px;padding:var(--space-10);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--space-10)}.login-logo{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:500;letter-spacing:.15em;color:var(--color-gold);margin-bottom:var(--space-3)}.login-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);letter-spacing:.1em;text-transform:uppercase}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.login-footer{margin-top:var(--space-8);text-align:center}.login-footer p{font-size:var(--text-sm);color:var(--color-text-muted)}.login-footer a{color:var(--color-gold);text-decoration:none;font-weight:500}.login-footer a:hover{text-decoration:underline}.oauth-section{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}.oauth-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:500;color:var(--color-text);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.oauth-btn:hover{background:var(--color-bg-card);border-color:var(--color-gold)}.oauth-btn svg{flex-shrink:0}.login-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-4) 0;color:var(--color-text-muted);font-size:var(--text-sm)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-options{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-1)}.checkbox-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer}.checkbox-label input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.checkbox-custom{width:18px;height:18px;border:2px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);transition:all var(--transition-fast);position:relative}.checkbox-label input:checked+.checkbox-custom{background:var(--color-gold);border-color:var(--color-gold)}.checkbox-label input:checked+.checkbox-custom:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid var(--color-bg);border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-label input:focus+.checkbox-custom{box-shadow:0 0 0 3px var(--color-gold-glow)}.forgot-link{font-size:var(--text-sm);color:var(--color-gold);text-decoration:none}.forgot-link:hover{text-decoration:underline}.form-input-icon{position:relative;display:flex;align-items:center}.form-input-icon .material-symbols-rounded:first-child{position:absolute;left:var(--space-4);color:var(--color-text-muted);pointer-events:none;font-size:20px}.form-input-icon .form-input{padding-left:var(--space-12)}.password-toggle{position:absolute;right:var(--space-3);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:var(--space-2);display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--color-text)}.password-toggle .material-symbols-rounded{font-size:20px}.form-help{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-4);line-height:1.5}.back-link{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--color-text-muted);text-decoration:none;font-size:var(--text-sm)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);letter-spacing:.05em;text-transform:uppercase}.form-input{width:100%;padding:var(--space-4) var(--space-5);font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.form-input::placeholder{color:var(--color-text-muted)}.form-input:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 0 3px var(--color-gold-glow)}.form-input-icon{position:relative}.form-input-icon .form-input{padding-left:3rem}.form-input-icon .material-symbols-rounded{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);font-family:var(--font-sans);font-size:var(--text-base);font-weight:500;letter-spacing:.02em;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(rgba(255,255,255,.1),transparent);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:before{opacity:1}.btn-primary{color:var(--color-text-inverse);background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);box-shadow:var(--shadow-gold)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 40px #c9a96240}.btn-secondary{color:var(--color-text);background:var(--color-bg-card);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-card-hover);border-color:var(--color-border-light)}.btn-ghost{color:var(--color-text-secondary);background:transparent}.btn-ghost:hover{color:var(--color-text);background:var(--color-bg-card)}.btn-success{color:var(--color-bg);background:var(--color-success)}.btn-danger{color:#fff;background:var(--color-error)}.btn-large{padding:var(--space-5) var(--space-8);font-size:var(--text-lg);border-radius:var(--radius-xl)}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-icon{width:48px;height:48px;padding:0;border-radius:var(--radius-full)}.app-shell{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-left{display:flex;align-items:center;gap:var(--space-4)}.logo{font-family:var(--font-display);font-size:var(--text-xl);font-weight:500;letter-spacing:.1em;color:var(--color-gold)}.header-right{display:flex;align-items:center;gap:var(--space-3)}.main{flex:1;padding:var(--space-6);padding-bottom:calc(var(--space-6) + 90px);max-width:1200px;margin:0 auto;width:100%}.sync-status{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);background:var(--color-bg-card);border-radius:var(--radius-full)}.sync-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--color-text-muted);transition:background var(--transition-fast)}.sync-status.online .sync-dot{background:var(--color-success);box-shadow:0 0 8px var(--color-success)}.sync-status.offline .sync-dot{background:var(--color-warning);animation:pulse 2s ease-in-out infinite}.sync-status.syncing .sync-dot{background:var(--color-info);animation:pulse .5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.greeting-section{margin-bottom:var(--space-8)}.greeting-time{font-size:var(--text-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-2)}.greeting-name{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:500;color:var(--color-text);margin-bottom:var(--space-1)}.greeting-date{font-size:var(--text-base);color:var(--color-text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);margin-bottom:var(--space-8)}@media (min-width: 768px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{display:flex;flex-direction:column;padding:var(--space-5);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-gold),var(--color-gold-light));opacity:0;transition:opacity var(--transition-base)}.stat-card:hover{border-color:var(--color-border-light);transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-card:hover:before{opacity:1}.stat-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);background:var(--color-gold-glow);border-radius:var(--radius-lg);color:var(--color-gold)}.stat-label{font-size:var(--text-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.stat-value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:600;color:var(--color-text)}.stat-change{display:flex;align-items:center;gap:var(--space-1);margin-top:var(--space-2);font-size:var(--text-xs);color:var(--color-success)}.stat-change.negative{color:var(--color-error)}.clock-section{display:flex;flex-direction:column;align-items:center;padding:var(--space-8);margin-bottom:var(--space-8);background:linear-gradient(135deg,var(--color-bg-card) 0%,var(--color-bg-elevated) 100%);border:1px solid var(--color-border);border-radius:var(--radius-2xl);position:relative;overflow:hidden}.clock-section:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:200px;height:200px;background:radial-gradient(circle,var(--color-gold-glow) 0%,transparent 70%);pointer-events:none}.clock-time{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:300;color:var(--color-text);margin-bottom:var(--space-2);letter-spacing:.05em}.clock-status{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6)}.clock-status.clocked-in{color:var(--color-success)}.clock-btn{min-width:200px}.clock-btn.clock-in{background:linear-gradient(135deg,var(--color-success) 0%,#22c55e 100%);color:var(--color-bg)}.clock-btn.clock-out{background:linear-gradient(135deg,var(--color-error) 0%,#dc2626 100%);color:#fff}.section{margin-bottom:var(--space-8)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.section-title{font-family:var(--font-sans);font-size:var(--text-lg);font-weight:600;color:var(--color-text);display:flex;align-items:center;gap:var(--space-2)}.section-title .material-symbols-rounded{color:var(--color-gold)}.section-action{font-size:var(--text-sm);color:var(--color-gold);display:flex;align-items:center;gap:var(--space-1)}.rotation-queue{display:flex;flex-direction:column;gap:var(--space-3)}.queue-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base)}.queue-card:hover{border-color:var(--color-border-light);background:var(--color-bg-card-hover)}.queue-card.queue-next{background:linear-gradient(135deg,#c9a96233,#c9a9620d);border-color:var(--color-gold);box-shadow:var(--shadow-gold)}.queue-card.queue-me:not(.queue-next){border-color:var(--color-gold-dark);background:var(--color-gold-glow)}.queue-position{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-sm);background:var(--color-bg);border-radius:var(--radius-full);color:var(--color-text-secondary)}.queue-next .queue-position{background:var(--color-gold);color:var(--color-bg)}.queue-avatar{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);font-weight:600;background:var(--color-bg-elevated);border-radius:var(--radius-full);color:var(--color-text-secondary)}.queue-next .queue-avatar{background:var(--color-gold);color:var(--color-bg)}.queue-info{flex:1}.queue-name{font-weight:500;color:var(--color-text);margin-bottom:var(--space-1)}.queue-detail{font-size:var(--text-sm);color:var(--color-text-muted)}.queue-badge{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:500;text-transform:uppercase;letter-spacing:.05em;background:var(--color-bg);color:var(--color-text-muted);border-radius:var(--radius-full)}.queue-next .queue-badge{background:var(--color-gold);color:var(--color-bg)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;padding:var(--space-2) var(--space-4);padding-bottom:max(var(--space-2),env(safe-area-inset-bottom));background:var(--color-bg-elevated);border-top:1px solid var(--color-border);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);color:var(--color-text-muted);border-radius:var(--radius-lg);transition:all var(--transition-fast);min-width:64px}.nav-item:hover{color:var(--color-text-secondary)}.nav-item.active{color:var(--color-gold)}.nav-item.active .nav-icon-bg{background:var(--color-gold-glow)}.nav-icon-bg{display:flex;align-items:center;justify-content:center;width:48px;height:32px;border-radius:var(--radius-full);transition:background var(--transition-fast)}.nav-label{font-size:var(--text-xs);font-weight:500}.appointments-list{display:flex;flex-direction:column;gap:var(--space-3)}.appointment-card{display:flex;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base)}.appointment-card:hover{border-color:var(--color-border-light);background:var(--color-bg-card-hover)}.appointment-time{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:70px;padding:var(--space-3);background:var(--color-bg);border-radius:var(--radius-md)}.appointment-time-value{font-weight:600;font-size:var(--text-base);color:var(--color-text)}.appointment-time-duration{font-size:var(--text-xs);color:var(--color-text-muted)}.appointment-details{flex:1;display:flex;flex-direction:column;justify-content:center;gap:var(--space-1)}.appointment-service{font-weight:500;color:var(--color-text)}.appointment-client{font-size:var(--text-sm);color:var(--color-text-secondary)}.appointment-staff{font-size:var(--text-xs);color:var(--color-text-muted)}.appointment-status{display:flex;align-items:center}.status-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:500;text-transform:capitalize;border-radius:var(--radius-full);background:var(--color-bg);color:var(--color-text-muted)}.status-scheduled{background:var(--color-info-bg);color:var(--color-info)}.status-checked_in{background:var(--color-warning-bg);color:var(--color-warning)}.status-in_progress{background:var(--color-gold-glow);color:var(--color-gold)}.status-completed{background:var(--color-success-bg);color:var(--color-success)}.status-cancelled{background:var(--color-error-bg);color:var(--color-error)}.schedule-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-6);padding:var(--space-1);background:var(--color-bg-card);border-radius:var(--radius-lg)}.tab-btn{flex:1;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.tab-btn:hover{color:var(--color-text-secondary)}.tab-btn.active{color:var(--color-bg);background:var(--color-gold)}.checkin-list{display:flex;flex-direction:column;gap:var(--space-4)}.checkin-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-5);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:all var(--transition-base)}.checkin-card:hover{border-color:var(--color-border-light)}.checkin-avatar{width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:600;background:var(--color-gold-glow);color:var(--color-gold);border-radius:var(--radius-full)}.checkin-info{flex:1}.checkin-time{font-size:var(--text-xs);color:var(--color-gold);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.checkin-name{font-weight:600;font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-1)}.checkin-service{font-size:var(--text-sm);color:var(--color-text-secondary)}.checkin-provider{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.checkin-actions{display:flex;gap:var(--space-2)}.staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-4)}.staff-card{display:flex;flex-direction:column;align-items:center;padding:var(--space-5);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);text-align:center;transition:all var(--transition-base)}.staff-card:hover{border-color:var(--color-border-light);transform:translateY(-4px)}.staff-card.staff-me{border-color:var(--color-gold);background:var(--color-gold-glow)}.staff-avatar{width:64px;height:64px;display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);font-weight:600;background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);color:var(--color-bg);border-radius:var(--radius-full);margin-bottom:var(--space-4)}.staff-name{font-weight:500;color:var(--color-text);margin-bottom:var(--space-1)}.staff-role{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:capitalize}.staff-status-indicator{display:flex;align-items:center;gap:var(--space-1);margin-top:var(--space-3);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);background:var(--color-bg);border-radius:var(--radius-full)}.staff-status-indicator.available{color:var(--color-success)}.staff-status-indicator.busy{color:var(--color-warning)}.toast-container{position:fixed;bottom:100px;left:50%;transform:translate(-50%);z-index:1000;display:flex;flex-direction:column;gap:var(--space-2)}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);animation:toast-in .4s var(--transition-bounce)}.toast-icon{font-size:20px}.toast-message{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.toast-success{border-color:var(--color-success)}.toast-success .toast-icon{color:var(--color-success)}.toast-error{border-color:var(--color-error)}.toast-error .toast-icon{color:var(--color-error)}.toast-warning{border-color:var(--color-warning)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-fade{animation:toast-out .3s ease-out forwards}@keyframes toast-in{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-out{to{opacity:0;transform:translateY(-10px) scale(.95)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);text-align:center}.empty-state-icon{font-size:64px;color:var(--color-text-muted);margin-bottom:var(--space-4);opacity:.5}.empty-state-title{font-size:var(--text-lg);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.empty-state-desc{font-size:var(--text-sm);color:var(--color-text-muted)}.offline-notice{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-warning-bg);color:var(--color-warning);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-6)}.view-content{animation:view-enter .4s cubic-bezier(.4,0,.2,1)}@keyframes view-enter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-gold{color:var(--color-gold)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-muted{color:var(--color-text-muted)}.touch-device button,.touch-device .btn,.touch-device .nav-item,.touch-device input,.touch-device select{min-height:48px}.touch-device .nav-item{min-width:48px}.touch-device button,.touch-device .btn,.touch-device .nav-item{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}@supports (padding: max(0px)){.header{padding-top:max(var(--space-4),env(safe-area-inset-top));padding-left:max(var(--space-6),env(safe-area-inset-left));padding-right:max(var(--space-6),env(safe-area-inset-right))}.bottom-nav{padding-bottom:max(var(--space-2),env(safe-area-inset-bottom))}.main{padding-left:max(var(--space-6),env(safe-area-inset-left));padding-right:max(var(--space-6),env(safe-area-inset-right))}}.keyboard-open .bottom-nav{display:none}@media (min-width: 768px){.greeting-name{font-size:var(--text-4xl)}.clock-section{padding:var(--space-12)}.clock-time{font-size:4rem}}@media (orientation: landscape) and (max-height: 500px){.header{padding:var(--space-2) var(--space-4)}.bottom-nav{padding:var(--space-1) var(--space-4)}.clock-section{padding:var(--space-4)}}.pull-refresh-indicator{height:0;overflow:hidden;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s}.pull-refresh-indicator.active{height:60px;opacity:1}.pull-refresh-spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-gold);border-radius:50%}.pull-refresh-indicator.refreshing .pull-refresh-spinner{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ripple-container{position:relative;overflow:hidden}.ripple{position:absolute;border-radius:50%;background:#ffffff26;transform:scale(0);animation:ripple-effect .6s ease-out forwards;pointer-events:none}@keyframes ripple-effect{to{transform:scale(1);opacity:0}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}*{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-bg)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:var(--space-6);z-index:1000;opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.modal-overlay.active{opacity:1;visibility:visible}.modal{width:100%;max-width:480px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg),0 0 100px #c9a9621a;transform:scale(.9) translateY(20px);opacity:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.modal-overlay.active .modal{transform:scale(1) translateY(0);opacity:1}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border)}.modal-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:500;color:var(--color-text);display:flex;align-items:center;gap:var(--space-3)}.modal-title .material-symbols-rounded{color:var(--color-gold)}.modal-close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--color-text-muted);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;gap:var(--space-3);padding:var(--space-6);padding-top:0}.modal-footer .btn{flex:1}.modal-success .modal-title .material-symbols-rounded{color:var(--color-success)}.modal-warning .modal-title .material-symbols-rounded{color:var(--color-warning)}.modal-danger .modal-title .material-symbols-rounded{color:var(--color-error)}.modal-confirm-icon{width:80px;height:80px;margin:0 auto var(--space-6);display:flex;align-items:center;justify-content:center;background:var(--color-gold-glow);border-radius:var(--radius-full)}.modal-confirm-icon .material-symbols-rounded{font-size:40px;color:var(--color-gold)}.modal-confirm-text{text-align:center;margin-bottom:var(--space-6)}.modal-confirm-text h3{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-2)}.modal-confirm-text p{color:var(--color-text-secondary)}.btn-glow{position:relative}.btn-glow:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:linear-gradient(135deg,var(--color-gold),var(--color-gold-light),var(--color-gold));border-radius:inherit;z-index:-1;opacity:0;filter:blur(12px);transition:opacity var(--transition-base)}.btn-glow:hover:after{opacity:.6}.fab{position:fixed;bottom:100px;right:var(--space-6);width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);color:var(--color-bg);border:none;border-radius:var(--radius-full);box-shadow:var(--shadow-lg),var(--shadow-gold);cursor:pointer;z-index:50;transition:all var(--transition-base)}.fab:hover{transform:scale(1.1);box-shadow:var(--shadow-lg),0 0 40px #c9a96266}.fab:active{transform:scale(.95)}.fab .material-symbols-rounded{font-size:28px}.divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-6) 0;color:var(--color-text-muted);font-size:var(--text-sm)}.divider:before,.divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--color-border),transparent)}.gold-line{height:1px;background:linear-gradient(90deg,transparent,var(--color-gold),transparent);margin:var(--space-6) 0}.card-interactive{cursor:pointer;transition:all var(--transition-base)}.card-interactive:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-gold)}.card-interactive:active{transform:translateY(-2px)}.card-shine{position:relative;overflow:hidden}.card-shine:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(201,169,98,.1),transparent);transition:left .5s ease}.card-shine:hover:before{left:100%}.slide-in-right{animation:slideInRight .4s cubic-bezier(.4,0,.2,1)}.slide-in-left{animation:slideInLeft .4s cubic-bezier(.4,0,.2,1)}.slide-in-up{animation:slideInUp .4s cubic-bezier(.4,0,.2,1)}.slide-in-down{animation:slideInDown .4s cubic-bezier(.4,0,.2,1)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.fade-in{animation:fadeIn .3s ease-out}.fade-in-scale{animation:fadeInScale .4s cubic-bezier(.34,1.56,.64,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-gold);border-radius:50%;animation:spin .8s linear infinite}.spinner-lg{width:48px;height:48px;border-width:3px}.spinner-dots{display:flex;gap:var(--space-2)}.spinner-dots span{width:8px;height:8px;background:var(--color-gold);border-radius:50%;animation:bounce 1.4s ease-in-out infinite both}.spinner-dots span:nth-child(1){animation-delay:-.32s}.spinner-dots span:nth-child(2){animation-delay:-.16s}.spinner-dots span:nth-child(3){animation-delay:0s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.progress-bar{height:4px;background:var(--color-bg);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-gold),var(--color-gold-light));border-radius:var(--radius-full);transition:width .3s ease}.avatar{position:relative;display:flex;align-items:center;justify-content:center;font-weight:600;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-dark) 100%);color:var(--color-bg)}.avatar-sm{width:32px;height:32px;font-size:var(--text-sm)}.avatar-md{width:48px;height:48px;font-size:var(--text-lg)}.avatar-lg{width:64px;height:64px;font-size:var(--text-2xl)}.avatar-xl{width:96px;height:96px;font-size:var(--text-4xl)}.avatar-ring{box-shadow:0 0 0 3px var(--color-bg),0 0 0 5px var(--color-gold)}.avatar-status{position:absolute;bottom:0;right:0;width:14px;height:14px;background:var(--color-success);border:2px solid var(--color-bg);border-radius:50%}.avatar-status.offline{background:var(--color-text-muted)}.avatar-status.busy{background:var(--color-warning)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-2);font-size:11px;font-weight:600;color:var(--color-bg);background:var(--color-gold);border-radius:var(--radius-full)}.badge-dot{width:10px;height:10px;min-width:10px;padding:0}.badge-success{background:var(--color-success)}.badge-warning{background:var(--color-warning)}.badge-error{background:var(--color-error)}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:500;color:var(--color-text);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:100;pointer-events:none}[data-tooltip]:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(-4px)}.switch{position:relative;width:52px;height:28px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.switch:after{content:"";position:absolute;top:2px;left:2px;width:22px;height:22px;background:var(--color-text-muted);border-radius:50%;transition:all var(--transition-fast)}.switch.active{background:var(--color-gold-glow);border-color:var(--color-gold)}.switch.active:after{left:26px;background:var(--color-gold)}.glass-card{background:#1a1a1a99;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl)}.form-input:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 0 3px var(--color-gold-glow),0 0 20px #c9a9621a}.input-underline{position:relative;background:transparent;border:none;border-bottom:1px solid var(--color-border);border-radius:0;padding-left:0;padding-right:0}.input-underline:focus{border-bottom-color:var(--color-gold);box-shadow:none}.input-underline:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--color-gold);transition:all var(--transition-base)}.input-underline:focus:after{left:0;width:100%}.stagger-list>*{opacity:0;transform:translateY(20px);animation:staggerIn .4s ease-out forwards}.stagger-list>*:nth-child(1){animation-delay:.05s}.stagger-list>*:nth-child(2){animation-delay:.1s}.stagger-list>*:nth-child(3){animation-delay:.15s}.stagger-list>*:nth-child(4){animation-delay:.2s}.stagger-list>*:nth-child(5){animation-delay:.25s}.stagger-list>*:nth-child(6){animation-delay:.3s}.stagger-list>*:nth-child(7){animation-delay:.35s}.stagger-list>*:nth-child(8){animation-delay:.4s}@keyframes staggerIn{to{opacity:1;transform:translateY(0)}}.bg-pattern{position:absolute;top:0;left:0;right:0;bottom:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23c9a962' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none;z-index:-1}.back-btn{position:absolute;top:var(--space-2);left:var(--space-2);background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-full);transition:all var(--transition-fast)}.back-btn:hover{background:var(--color-bg-card);color:var(--color-text)}.section-desc{color:var(--color-text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-6)}.twofa-methods{display:flex;flex-direction:column;gap:var(--space-3)}.twofa-method-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.twofa-method-card:hover{background:var(--color-bg-card-hover);border-color:var(--color-border-light)}.twofa-method-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-gold-glow);border-radius:var(--radius-md);color:var(--color-gold);flex-shrink:0}.twofa-method-info{flex:1;min-width:0}.twofa-method-name{font-family:var(--font-sans);font-size:var(--text-base);font-weight:500;color:var(--color-text);margin-bottom:var(--space-1)}.twofa-method-desc{font-size:var(--text-sm);color:var(--color-text-secondary)}.twofa-method-status{flex-shrink:0}.passkeys-list{display:flex;flex-direction:column;gap:var(--space-3)}.passkey-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.passkey-card:hover{background:var(--color-bg-card-hover)}.passkey-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-bg-elevated);border-radius:var(--radius-sm);color:var(--color-text-secondary);flex-shrink:0}.passkey-info{flex:1;min-width:0}.passkey-name{font-family:var(--font-sans);font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.passkey-meta{font-size:var(--text-xs);color:var(--color-text-muted)}.passkey-delete{color:var(--color-text-muted);opacity:0;transition:opacity var(--transition-fast)}.passkey-card:hover .passkey-delete{opacity:1}.passkey-delete:hover{color:var(--color-error)}.backup-codes-info{padding:var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.backup-code-status{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.empty-state-sm{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);color:var(--color-text-muted);text-align:center}.empty-state-sm .material-symbols-rounded{font-size:32px;margin-bottom:var(--space-2);opacity:.5}.empty-state-sm p{font-size:var(--text-sm)}.status-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.status-badge.status-success{background:var(--color-success-bg);color:var(--color-success)}.status-badge.status-warning{background:var(--color-warning-bg);color:var(--color-warning)}.status-badge.status-error{background:var(--color-error-bg);color:var(--color-error)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);min-height:32px}.btn-block{width:100%;justify-content:center}.twofa-greeting{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--space-6)}.twofa-methods-select{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}.twofa-method-option{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.twofa-method-option:hover{background:var(--color-bg-card-hover);border-color:var(--color-border-light);color:var(--color-text)}.twofa-method-option.active{background:var(--color-gold-glow);border-color:var(--color-gold);color:var(--color-gold)}.twofa-method-option .material-symbols-rounded{font-size:18px}.twofa-code-input{text-align:center;font-size:var(--text-xl)!important;letter-spacing:.3em;font-family:monospace}.twofa-webauthn-prompt{display:flex;flex-direction:column;align-items:center;padding:var(--space-6);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;margin-bottom:var(--space-4)}.twofa-webauthn-prompt .twofa-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--color-gold-glow);border-radius:var(--radius-full);color:var(--color-gold);margin-bottom:var(--space-4)}.twofa-webauthn-prompt .twofa-icon .material-symbols-rounded{font-size:32px}.twofa-webauthn-prompt p{color:var(--color-text-secondary);font-size:var(--text-sm)}.back-link{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-text-secondary);font-size:var(--text-sm);text-decoration:none;transition:color var(--transition-fast)}.back-link:hover{color:var(--color-gold)}.back-link .material-symbols-rounded{font-size:18px}.pwa-install-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--color-primary, #1a1a2e) 0%,#2a2a4e 100%);color:var(--color-ivory, #faf8f5);border:none;border-radius:12px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #1a1a2e33}.pwa-install-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1a1a2e4d}.pwa-install-btn:active{transform:translateY(0)}.pwa-install-btn .material-symbols-rounded{font-size:1.25rem}.pwa-install-banner{position:fixed;top:-100%;left:0;right:0;z-index:9999;background:#fff;box-shadow:0 4px 20px #00000026;transition:top .4s cubic-bezier(.4,0,.2,1)}.pwa-install-banner.active{top:0}.pwa-install-banner-content{display:flex;align-items:center;gap:1rem;max-width:1200px;margin:0 auto;padding:1rem 1.5rem}.pwa-install-banner-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary, #1a1a2e) 0%,#2a2a4e 100%);border-radius:12px}.pwa-install-banner-icon .material-symbols-rounded{font-size:28px;color:var(--color-ivory, #faf8f5)}.pwa-install-banner-text{flex:1;min-width:0}.pwa-install-banner-text h3{font-size:1rem;font-weight:600;color:var(--color-primary, #1a1a2e);margin:0 0 .25rem}.pwa-install-banner-text p{font-size:.875rem;color:var(--color-text-secondary, #666);margin:0;line-height:1.4}.pwa-install-banner-actions{flex-shrink:0;display:flex;align-items:center;gap:.5rem}.pwa-install-banner-install{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--color-primary, #1a1a2e);color:var(--color-ivory, #faf8f5);border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.pwa-install-banner-install:hover{background:#2a2a4e;transform:translateY(-1px);box-shadow:0 2px 8px #1a1a2e33}.pwa-install-banner-install .material-symbols-rounded{font-size:1.125rem}.pwa-install-banner-dismiss{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--color-text-secondary, #666);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.pwa-install-banner-dismiss:hover{background:#0000000d;color:var(--color-primary, #1a1a2e)}.pwa-install-banner-dismiss .material-symbols-rounded{font-size:1.25rem}.pwa-install-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;background:#0000;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:all .3s ease}.pwa-install-modal-overlay.active{background:#00000080;opacity:1;pointer-events:all}.pwa-install-modal{background:#fff;border-radius:24px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;transform:scale(.9) translateY(20px);transition:transform .3s ease}.pwa-install-modal-overlay.active .pwa-install-modal{transform:scale(1) translateY(0)}.pwa-install-modal-header{text-align:center;padding:2rem 2rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.08)}.pwa-install-modal-icon{width:80px;height:80px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary, #1a1a2e) 0%,#2a2a4e 100%);border-radius:20px;box-shadow:0 8px 24px #1a1a2e33}.pwa-install-modal-icon .material-symbols-rounded{font-size:40px;color:var(--color-ivory, #faf8f5)}.pwa-install-modal-header h2{font-size:1.5rem;font-weight:600;color:var(--color-primary, #1a1a2e);margin:0 0 .5rem;letter-spacing:-.02em}.pwa-install-modal-header p{font-size:1rem;color:var(--color-text-secondary, #666);margin:0;line-height:1.5}.pwa-install-modal-body{padding:1.5rem 2rem}.pwa-install-modal-features{list-style:none;margin:0;padding:0}.pwa-install-modal-features li{display:flex;align-items:center;gap:1rem;padding:.75rem 0;font-size:.9375rem;color:var(--color-text, #2c2c2c);line-height:1.5}.pwa-install-modal-features li:not(:last-child){border-bottom:1px solid rgba(0,0,0,.05)}.pwa-install-modal-features li .material-symbols-rounded{font-size:1.5rem;color:#28a745;flex-shrink:0}.pwa-install-modal-footer{padding:1.5rem 2rem 2rem;display:flex;flex-direction:column;gap:.75rem}.pwa-install-modal-install{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 2rem;background:linear-gradient(135deg,var(--color-primary, #1a1a2e) 0%,#2a2a4e 100%);color:var(--color-ivory, #faf8f5);border:none;border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #1a1a2e33}.pwa-install-modal-install:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1a1a2e4d}.pwa-install-modal-install:active{transform:translateY(0)}.pwa-install-modal-install .material-symbols-rounded{font-size:1.25rem}.pwa-install-modal-cancel{width:100%;padding:.875rem 2rem;background:transparent;color:var(--color-text-secondary, #666);border:none;border-radius:12px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease}.pwa-install-modal-cancel:hover{background:#0000000d;color:var(--color-primary, #1a1a2e)}@media (max-width: 640px){.pwa-install-banner-content{flex-wrap:wrap;padding:1rem}.pwa-install-banner-text{flex-basis:100%;order:1}.pwa-install-banner-actions{flex-basis:100%;order:2;margin-top:.75rem;justify-content:flex-end}.pwa-install-banner-install{flex:1}.pwa-install-modal{border-radius:16px}.pwa-install-modal-header{padding:1.5rem 1.5rem 1rem}.pwa-install-modal-icon{width:64px;height:64px;border-radius:16px;margin-bottom:1rem}.pwa-install-modal-icon .material-symbols-rounded{font-size:32px}.pwa-install-modal-header h2{font-size:1.25rem}.pwa-install-modal-body{padding:1rem 1.5rem}.pwa-install-modal-footer{padding:1rem 1.5rem 1.5rem}}@supports (-webkit-touch-callout: none){.pwa-install-banner{padding-top:env(safe-area-inset-top)}}.pos-container{display:flex;height:100vh;height:100dvh;overflow:hidden;background:var(--color-charcoal);color:var(--color-ivory)}.pos-products-panel{flex:1;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.1)}.pos-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.pos-header-left{display:flex;align-items:center;gap:1rem}.pos-back-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--color-ivory);cursor:pointer;transition:all .2s}.pos-back-btn:hover{background:#ffffff26;border-color:var(--color-gold)}.pos-title{font-size:1.25rem;font-weight:600;color:var(--color-gold)}.pos-search{display:flex;align-items:center;gap:.5rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.5rem 1rem;width:280px}.pos-search .material-symbols-rounded{color:#ffffff80}.pos-search input{flex:1;background:transparent;border:none;color:var(--color-ivory);font-size:.9375rem;outline:none}.pos-search input::placeholder{color:#fff6}.pos-categories{display:flex;gap:.5rem;padding:1rem 1.5rem;overflow-x:auto;background:#0000001a;border-bottom:1px solid rgba(255,255,255,.1)}.pos-categories::-webkit-scrollbar{display:none}.pos-category-btn{flex-shrink:0;display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:25px;color:var(--color-ivory);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.pos-category-btn:hover{border-color:var(--color-gold)}.pos-category-btn.active{background:var(--color-gold);border-color:var(--color-gold);color:var(--color-charcoal)}.pos-category-btn .material-symbols-rounded{font-size:1.125rem}.pos-products-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;padding:1.5rem;overflow-y:auto;align-content:start}.pos-product-card{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;cursor:pointer;transition:all .2s}.pos-product-card:hover{border-color:var(--color-gold);transform:translateY(-2px)}.pos-product-card:active{transform:scale(.98)}.pos-product-card.out-of-stock{opacity:.4;pointer-events:none}.pos-product-image{width:100%;aspect-ratio:1;background:#0000004d;border-radius:8px;margin-bottom:.75rem;display:flex;align-items:center;justify-content:center;overflow:hidden}.pos-product-image img{width:100%;height:100%;object-fit:cover}.pos-product-image .material-symbols-rounded{font-size:2.5rem;color:#ffffff4d}.pos-product-name{font-size:.875rem;font-weight:500;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pos-product-price{font-size:1rem;font-weight:600;color:var(--color-gold)}.pos-product-stock{font-size:.75rem;color:#ffffff80;margin-top:.25rem}.pos-product-stock.low{color:var(--color-warning)}.pos-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#fff6}.pos-empty .material-symbols-rounded{font-size:4rem;margin-bottom:1rem}.pos-cart-panel{width:380px;display:flex;flex-direction:column;background:#0000004d}.pos-cart-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.pos-cart-header h2{font-size:1.125rem;font-weight:600;flex:1}.pos-cart-count{background:var(--color-gold);color:var(--color-charcoal);padding:.125rem .625rem;border-radius:12px;font-size:.8125rem;font-weight:600}.pos-clear-btn{padding:.375rem .75rem;background:transparent;border:1px solid var(--color-danger);border-radius:6px;color:var(--color-danger);font-size:.75rem;cursor:pointer;transition:all .2s}.pos-clear-btn:hover{background:var(--color-danger);color:#fff}.pos-cart-items{flex:1;overflow-y:auto;padding:1rem}.pos-cart-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff6;text-align:center}.pos-cart-empty .material-symbols-rounded{font-size:4rem;margin-bottom:.75rem;opacity:.5}.pos-cart-hint{font-size:.8125rem;margin-top:.25rem}.pos-cart-item{background:#ffffff0d;border-radius:10px;padding:1rem;margin-bottom:.75rem}.pos-cart-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.pos-cart-item-name{font-weight:500;font-size:.9375rem}.pos-cart-item-variant{font-size:.8125rem;color:#fff9}.pos-cart-item-remove{background:transparent;border:none;color:#fff6;cursor:pointer;padding:.25rem}.pos-cart-item-remove:hover{color:var(--color-danger)}.pos-cart-item-modifiers{font-size:.8125rem;color:var(--color-gold);margin-bottom:.5rem}.pos-cart-item-footer{display:flex;justify-content:space-between;align-items:center}.pos-qty-control{display:flex;align-items:center;gap:.5rem}.pos-qty-control button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:var(--color-ivory);font-size:1.25rem;cursor:pointer;transition:all .2s}.pos-qty-control button:hover{border-color:var(--color-gold);color:var(--color-gold)}.pos-qty-control span{min-width:24px;text-align:center;font-weight:600}.pos-cart-item-total{font-weight:600;font-size:1rem}.pos-cart-summary{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.pos-summary-row{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9375rem}.pos-summary-row:first-child span:first-child{color:#fff9}.pos-summary-row.pos-total{font-size:1.375rem;font-weight:700;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1);margin-top:.75rem;margin-bottom:0}.pos-discount-row{display:flex;gap:.5rem;margin:.75rem 0}.pos-discount-row input{flex:1;padding:.5rem .75rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--color-ivory);font-size:.875rem}.pos-discount-row select{padding:.5rem .75rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--color-ivory);font-size:.875rem;cursor:pointer}.pos-cart-actions{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.pos-pay-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background:var(--color-gold);border:none;border-radius:10px;color:var(--color-charcoal);font-size:1.125rem;font-weight:700;cursor:pointer;transition:all .2s}.pos-pay-btn:hover:not(:disabled){background:var(--color-gold-dark)}.pos-pay-btn:disabled{opacity:.5;cursor:not-allowed}.pos-pay-btn .material-symbols-rounded{font-size:1.375rem}.pos-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:all .3s}.pos-modal.active{opacity:1;visibility:visible}.pos-modal-content{background:var(--color-charcoal);border:1px solid rgba(255,255,255,.1);border-radius:16px;width:90%;max-width:480px;max-height:90vh;overflow:hidden;transform:scale(.95);transition:transform .3s}.pos-modal.active .pos-modal-content{transform:scale(1)}.pos-modal-wide{max-width:560px}.pos-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.pos-modal-header h3{font-size:1.125rem;font-weight:600}.pos-modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#ffffff80;cursor:pointer;border-radius:8px}.pos-modal-close:hover{background:#ffffff1a;color:var(--color-ivory)}.pos-modal-body{padding:1.5rem;max-height:60vh;overflow-y:auto}.pos-modal-footer{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.pos-variant-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.pos-variant-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem;background:#0000004d;border:2px solid rgba(255,255,255,.1);border-radius:10px;color:var(--color-ivory);cursor:pointer;transition:all .2s}.pos-variant-btn:hover{border-color:var(--color-gold)}.pos-variant-btn.active{border-color:var(--color-gold);background:#c9a9621a}.pos-variant-name{font-weight:500}.pos-variant-price{font-size:.8125rem;color:#ffffff80}.pos-variant-btn.active .pos-variant-price{color:var(--color-gold)}.pos-modifier-label{font-size:.875rem;color:#ffffff80;margin-bottom:.75rem}.pos-modifier-list{display:flex;flex-direction:column;gap:.5rem}.pos-modifier-btn{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#0000004d;border:2px solid rgba(255,255,255,.1);border-radius:10px;color:var(--color-ivory);cursor:pointer;transition:all .2s;text-align:left}.pos-modifier-btn:hover{border-color:var(--color-gold)}.pos-modifier-btn.active{border-color:var(--color-gold);background:#c9a9621a}.pos-modifier-check{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:6px;transition:all .2s}.pos-modifier-btn.active .pos-modifier-check{background:var(--color-gold);border-color:var(--color-gold)}.pos-modifier-check .material-symbols-rounded{font-size:.875rem;color:var(--color-charcoal);opacity:0}.pos-modifier-btn.active .pos-modifier-check .material-symbols-rounded{opacity:1}.pos-modifier-name{flex:1}.pos-modifier-price{font-weight:500;color:var(--color-gold)}.pos-payment-amount{text-align:center;padding:1.5rem 0;margin-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.pos-payment-amount p:first-child{font-size:.875rem;color:#ffffff80;margin-bottom:.5rem}.pos-payment-total{font-size:2.5rem;font-weight:700;color:var(--color-gold)}.pos-payment-methods{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem}.pos-payment-method{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:#0000004d;border:2px solid rgba(255,255,255,.1);border-radius:10px;color:#fff9;cursor:pointer;transition:all .2s}.pos-payment-method:hover{border-color:var(--color-gold)}.pos-payment-method.active{border-color:var(--color-gold);background:#c9a9621a;color:var(--color-gold)}.pos-payment-method .material-symbols-rounded{font-size:1.75rem}.pos-tip-section{padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.pos-tip-section>p{font-size:.875rem;color:#ffffff80;margin-bottom:.75rem}.pos-tip-options{display:flex;gap:.5rem;margin-bottom:.75rem}.pos-tip-btn{flex:1;padding:.75rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--color-ivory);font-size:.875rem;cursor:pointer;transition:all .2s}.pos-tip-btn:hover{border-color:var(--color-gold)}.pos-tip-btn.active{border-color:var(--color-gold);background:#c9a9621a;color:var(--color-gold)}.pos-tip-section input{width:100%;padding:.75rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--color-ivory);font-size:.875rem}.pos-success-content{text-align:center;padding:2.5rem 1.5rem}.pos-success-icon{width:80px;height:80px;margin:0 auto 1.5rem;background:#7fb06926;border-radius:50%;display:flex;align-items:center;justify-content:center}.pos-success-icon .material-symbols-rounded{font-size:3rem;color:var(--color-success)}.pos-success-content h3{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.pos-success-order{color:#ffffff80;margin-bottom:1.5rem}.pos-success-amount{font-size:2.5rem;font-weight:700;color:var(--color-gold);margin-bottom:2rem}.pos-success-actions{display:flex;flex-direction:column;gap:.75rem}.pos-btn-primary{flex:1;padding:.875rem 1.5rem;background:var(--color-gold);border:none;border-radius:10px;color:var(--color-charcoal);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.pos-btn-primary:hover{background:var(--color-gold-dark)}.pos-btn-primary.pos-btn-large{padding:1rem 1.5rem;font-size:1.125rem}.pos-btn-secondary{padding:.875rem 1.5rem;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:10px;color:var(--color-ivory);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.pos-btn-secondary:hover{border-color:var(--color-gold)}@media (max-width: 768px){.pos-container{flex-direction:column}.pos-products-panel{flex:1;border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}.pos-cart-panel{width:100%;height:50vh;max-height:50vh}.pos-search{width:auto;flex:1;max-width:200px}.pos-products-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));padding:1rem;gap:.75rem}.pos-variant-grid,.pos-payment-methods{grid-template-columns:repeat(2,1fr)}}@media (min-width: 769px) and (max-height: 600px){.pos-products-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.pos-cart-panel{width:320px}}
