body,html{height:100%;overflow-x:hidden}body{background:var(--bg-page);background-attachment:fixed;background-image:var(--gradient-mesh);background-size:cover;color:var(--text-primary);transition:background .3s ease,color .3s ease}#root{min-height:100%;position:relative}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}h1{font-size:clamp(24px,5vw,36px);font-weight:700;line-height:1.2}h2{font-size:clamp(20px,4vw,30px);line-height:1.3}h2,h3{font-weight:600}h3{font-size:clamp(18px,3.5vw,24px);line-height:1.4}p{font-size:clamp(14px,2.5vw,18px);line-height:1.6}button{border:none;cursor:pointer;font-family:inherit;outline:none;transition:all var(--transition-base)}button:active{transform:scale(.98)}button:disabled{cursor:not-allowed;opacity:.6}input,select,textarea{backdrop-filter:blur(var(--blur-sm));-webkit-backdrop-filter:blur(var(--blur-sm));background:var(--glass-white-lighter);border:1px solid var(--border-glass);border-radius:var(--radius-lg);color:var(--text-primary);font-family:inherit;font-size:16px;padding:var(--space-3) var(--space-4);transition:all var(--transition-base)}input:focus,select:focus,textarea:focus{background:var(--glass-white);border-color:var(--color-primary);box-shadow:0 0 0 3px var(--glass-primary),var(--shadow-glow-primary);outline:none}a{color:var(--color-primary);text-decoration:none;transition:all var(--transition-base)}a:hover{color:var(--color-primary-light);text-shadow:0 0 8px var(--color-primary-glow)}img{display:block;height:auto;max-width:100%}*{-webkit-overflow-scrolling:touch}body{overscroll-behavior-y:contain}@supports (padding-top:env(safe-area-inset-top)){body{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}}.container{margin:0 auto;max-width:1200px;padding:0 16px;width:100%}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.hidden{display:none!important}.visible-mobile{display:block}.visible-desktop{display:none}@media (min-width:768px){.visible-mobile{display:none}.visible-desktop{display:block}}.loading-spinner-container{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center}.loading-spinner{border:4px solid #0000001a;border-left-color:#6366f1}.loading-spinner-container.small .loading-spinner{border-width:2px;height:20px;width:20px}.loading-spinner-container.medium .loading-spinner{border-width:4px;height:40px;width:40px}.loading-spinner-container.large .loading-spinner{border-width:6px;height:60px;width:60px}.loading-message{color:#6b7280;font-size:.875rem;margin:0}[data-theme=dark] .loading-spinner{border-color:#ffffff1a #ffffff1a #ffffff1a #818cf8}[data-theme=dark] .loading-message{color:#9ca3af}.notification-bell-container{position:relative}.notification-bell-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:var(--radius-full);cursor:pointer;display:flex;height:40px;justify-content:center;position:relative;transition:all var(--transition-base);width:40px}.notification-bell-btn:hover{background:#ffffff4d;border-color:#fff9;box-shadow:0 4px 16px #0003;transform:scale(1.1)}.notification-bell-btn:active{transform:scale(1.05)}.bell-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));font-size:22px}@keyframes bellRing{0%,to{transform:rotate(0deg)}10%,30%{transform:rotate(14deg)}20%,40%{transform:rotate(-14deg)}50%{transform:rotate(0deg)}}.notification-badge{align-items:center;animation:bounceIn .5s var(--ease-spring);background:#f44;border-radius:var(--radius-full);box-shadow:0 0 0 3px #ffffff4d,0 2px 8px #0000004d;color:#fff;display:flex;font-size:10px;font-weight:var(--font-weight-bold);height:20px;justify-content:center;min-width:20px;padding:0 4px;position:absolute;right:-4px;top:-4px}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.1)}to{transform:scale(1)}}.notification-dropdown{animation:dropdownSlideIn .3s var(--ease-out-quad);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);max-height:500px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:380px;z-index:1000}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{align-items:center;background:var(--bg-page);border-bottom:2px solid var(--border-color);display:flex;justify-content:space-between;padding:var(--space-4)}.dropdown-header h3{color:var(--text-primary);font-size:var(--font-size-lg);margin:0}.dropdown-header h3,.unread-count{font-weight:var(--font-weight-bold)}.unread-count{background:var(--color-primary);border-radius:var(--radius-full);color:#fff;font-size:var(--font-size-xs);padding:var(--space-1) var(--space-2)}.dropdown-content{max-height:360px;overflow-y:auto}.dropdown-notifications{display:flex;flex-direction:column}.dropdown-notification-item{align-items:flex-start;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);position:relative;transition:background var(--transition-base)}.dropdown-notification-item:last-child{border-bottom:none}.dropdown-notification-item:hover{background:var(--bg-hover)}.dropdown-notification-item.unread{background:#6366f10d}.unread-indicator{background:var(--color-primary);border-radius:50%;height:8px;left:var(--space-2);position:absolute;top:50%;transform:translateY(-50%);width:8px}.notification-icon{align-items:center;background:var(--bg-page);border-radius:var(--radius-lg);display:flex;flex-shrink:0;font-size:20px;height:40px;justify-content:center;width:40px}.notification-info{flex:1;min-width:0}.notification-title{color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);white-space:nowrap}.notification-message,.notification-title{margin:0 0 var(--space-1) 0;overflow:hidden;text-overflow:ellipsis}.notification-message{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-secondary);display:-webkit-box;font-size:var(--font-size-xs);line-height:1.4}.notification-time{color:var(--text-tertiary);font-size:var(--font-size-xs)}.dropdown-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:var(--space-8) var(--space-4);text-align:center}.empty-icon{font-size:48px;margin-bottom:var(--space-2);opacity:.3}.dropdown-empty p{color:var(--text-secondary);font-size:var(--font-size-sm);margin:0}.dropdown-footer{background:var(--bg-page);border-top:2px solid var(--border-color);padding:var(--space-3)}.view-all-btn{background:#0000;border:none;border-radius:var(--radius-lg);color:var(--color-primary);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);padding:var(--space-2);transition:all var(--transition-base);width:100%}.view-all-btn:hover{background:#6366f11a}.dropdown-content::-webkit-scrollbar{width:8px}.dropdown-content::-webkit-scrollbar-track{background:var(--bg-page)}.dropdown-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.dropdown-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}[data-theme=dark] .notification-bell-btn,[data-theme=dark] .notification-dropdown{background:var(--bg-card-dark);border-color:var(--border-color-dark)}[data-theme=dark] .dropdown-footer,[data-theme=dark] .dropdown-header{background:var(--bg-page-dark)}[data-theme=dark] .dropdown-notification-item{border-color:var(--border-color-dark)}[data-theme=dark] .dropdown-notification-item.unread{background:#6366f11a}[data-theme=dark] .notification-icon{background:var(--bg-page-dark)}@media (max-width:768px){.notification-dropdown{left:8px;position:fixed;right:8px;top:60px;width:auto}.dropdown-content{max-height:calc(100vh - 200px)}}.floating-app-badges{animation:slideInLeft .6s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #ffffff80;border-radius:var(--radius-xl);box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014;display:flex;flex-direction:column;gap:var(--space-2);left:var(--space-3);max-width:200px;padding:var(--space-3);position:fixed;top:var(--space-3);z-index:200}.floating-app-badges.minimized{animation:minimizeBadges .3s ease;padding:var(--space-2)}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-120px) scale(.8)}to{opacity:1;transform:translateX(0) scale(1)}}@keyframes minimizeBadges{0%{max-height:400px}to{max-height:60px}}.badge-controls{display:flex;gap:var(--space-1);justify-content:flex-end;margin-bottom:var(--space-2)}.badge-control-btn{align-items:center;background:#0000000d;border:1px solid #0000001a;border-radius:var(--radius-full);color:#666;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;padding:0;transition:all .2s ease;width:24px}.badge-control-btn:hover{background:#0000001a;transform:scale(1.1)}.badge-control-btn.close-btn:hover{background:#ff3b30;border-color:#ff3b30;color:#fff}.badge-control-btn.minimize-btn:hover{background:#007aff;border-color:#007aff;color:#fff}.badges-container{animation:fadeIn .3s ease;display:flex;flex-direction:column;gap:var(--space-2)}.store-badge-floating{align-items:center;border-radius:var(--radius-lg);cursor:pointer;display:flex;overflow:hidden;padding:var(--space-2) var(--space-3);position:relative;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.store-badge-floating:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.store-badge-floating:hover:before{left:100%}.store-badge-floating.app-store{background:linear-gradient(135deg,#000,#1a1a1a);box-shadow:0 4px 12px #00000040;color:#fff}.store-badge-floating.app-store:hover{box-shadow:0 8px 24px #00000059;transform:translateY(-3px) scale(1.02)}.store-badge-floating.google-play{background:linear-gradient(135deg,#000,#2c2c2c);box-shadow:0 4px 12px #00000040;color:#fff}.store-badge-floating.google-play:hover{box-shadow:0 8px 24px #00000059;transform:translateY(-3px) scale(1.02)}.badge-content{gap:var(--space-2);width:100%}.badge-content,.badge-icon{align-items:center;display:flex}.badge-icon{flex-shrink:0;height:28px;justify-content:center;width:28px}.badge-icon svg{height:100%;width:100%}.badge-text{display:flex;flex:1;flex-direction:column;gap:2px}.badge-label{font-size:9px;font-weight:400;letter-spacing:.3px;line-height:1;opacity:.9;text-transform:uppercase}.badge-title{font-size:16px;font-weight:600;letter-spacing:-.3px;line-height:1}.download-prompt{align-items:center;animation:pulse 2s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--radius-lg);color:#fff;display:flex;font-size:11px;font-weight:600;gap:var(--space-2);margin-top:var(--space-1);padding:var(--space-2);text-align:center}.prompt-icon{animation:rotate 3s linear infinite;font-size:16px}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.prompt-text{flex:1;line-height:1.3}[data-theme=dark] .floating-app-badges{background:#1e1e1ef2;border-color:#ffffff1a}[data-theme=dark] .badge-control-btn{background:#ffffff1a;border-color:#ffffff26;color:#ccc}@media (max-width:768px){.floating-app-badges{left:var(--space-2);max-width:160px;padding:var(--space-2);top:var(--space-2)}.badge-content{gap:8px}.badge-icon{height:22px;width:22px}.badge-label{font-size:8px}.badge-title{font-size:13px}.store-badge-floating{padding:8px 10px}.download-prompt{font-size:9px;padding:6px 8px}.prompt-icon{font-size:14px}}@media (min-width:769px) and (max-width:1024px){.floating-app-badges{max-width:180px}}.top-bar{backdrop-filter:blur(var(--blur-xl));-webkit-backdrop-filter:blur(var(--blur-xl));background:#fffffffa;border-bottom:1px solid var(--border-glass);box-shadow:var(--shadow-glass),var(--shadow-glass-inset);height:var(--top-bar-height);left:0;position:-webkit-sticky;position:sticky;right:0;top:0;transition:all var(--transition-base);z-index:100}.top-bar:before{background:var(--gradient-primary);bottom:0;content:"";left:0;opacity:.15;position:absolute;right:0;top:0;z-index:-1}[data-theme=dark] .top-bar{background:var(--bg-glass-card);border-bottom-color:var(--border-glass-dark);box-shadow:var(--shadow-glass-lg)}[data-theme=dark] .top-bar:before{opacity:.25}.top-bar-content{align-items:center;display:flex;gap:var(--space-4);height:100%;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 var(--space-4)}.top-bar-left{flex-shrink:0}.app-logo{align-items:center;cursor:pointer;display:flex;gap:var(--space-2);transition:transform var(--transition-base);-webkit-user-select:none;user-select:none}.app-logo:hover{transform:scale(1.05)}.app-logo:active{transform:scale(.95)}.logo-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));font-size:28px;line-height:1}.logo-text{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:var(--color-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);letter-spacing:.5px;text-shadow:0 0 10px var(--color-primary-glow);white-space:nowrap}.top-bar-center{display:none;flex:1;justify-content:center}.page-title{color:var(--text-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:.5px;margin:0;text-shadow:0 0 8px var(--color-primary-glow)}.top-bar-right{align-items:center;display:flex;flex-shrink:0;gap:var(--space-3)}.profile-avatar-btn{align-items:center;backdrop-filter:blur(var(--blur-md));-webkit-backdrop-filter:blur(var(--blur-md));background:var(--glass-white);border:2px solid var(--border-glass);border-radius:var(--radius-full);box-shadow:var(--shadow-glass),var(--shadow-glass-inset);cursor:pointer;display:flex;height:40px;justify-content:center;overflow:hidden;padding:0;transition:all var(--transition-base);width:40px}.profile-avatar-btn:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-glass-lg),var(--shadow-glow-primary);transform:scale(1.1)}.profile-avatar-btn:active{transform:scale(1.05)}.avatar-img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background:var(--color-primary);color:#fff;display:flex;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);height:100%;justify-content:center;width:100%}@media (max-width:768px){.top-bar{height:56px}.top-bar-content{padding:0 var(--space-3)}.logo-text{display:none}.logo-icon{font-size:24px}.top-bar-center{display:flex}.page-title{font-size:var(--font-size-lg)}.profile-avatar-btn{height:36px;width:36px}.avatar-placeholder{font-size:var(--font-size-base)}}@media (min-width:769px) and (max-width:1024px){.top-bar-content{max-width:100%}}@media (min-width:1024px){.top-bar{border-radius:0 0 var(--radius-2xl) var(--radius-2xl);left:50%;margin-left:-300px;max-width:600px;right:auto}.top-bar-content{max-width:100%}}@media (min-width:1440px){.top-bar{margin-left:-350px;max-width:700px}}.top-bar{animation:slideDown .3s var(--ease-out-quad)}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.quick-actions-overlay{animation:fadeIn .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);background:radial-gradient(circle at center,#0009,#000c);bottom:0;left:0;position:fixed;right:0;top:0;z-index:998}.quick-actions-menu{bottom:calc(var(--bottom-nav-height) + 60px);display:flex;flex-direction:column;gap:16px;left:50%;max-height:70vh;overflow-y:auto;padding:0 8px;position:fixed;transform:translateX(-50%);z-index:999}.bookings-menu{bottom:calc(var(--bottom-nav-height) + 80px);max-width:500px;width:90vw}.quick-action-item{align-items:center;animation:slideUp .5s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(30px) saturate(200%);-webkit-backdrop-filter:blur(30px) saturate(200%);background:linear-gradient(145deg,#fffffff2,#ffffffd9);border:1px solid #fff6;border-radius:50px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014,inset 0 1px 1px #fffc,inset 0 -1px 1px #0000000d;cursor:pointer;display:flex;gap:16px;min-width:240px;overflow:hidden;padding:14px 24px;position:relative;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.quick-action-item:before{background:linear-gradient(90deg,#0000,#fff9,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.quick-action-item:hover:before{left:100%}.quick-action-item:hover{border-color:#fff9;box-shadow:0 16px 48px #00000029,0 4px 16px #0000001f,0 0 40px #6366f14d,inset 0 2px 2px #ffffffe6,inset 0 -2px 2px #00000014;transform:translateY(-4px) scale(1.05)}.quick-action-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 4px 16px #667eea66,inset 0 1px 2px #ffffff4d,inset 0 -1px 2px #0003;display:flex;font-size:28px;height:52px;justify-content:center;position:relative;width:52px}.quick-action-icon:after{background:linear-gradient(135deg,#ffffff4d,#0000);border-radius:50%;bottom:2px;content:"";left:2px;position:absolute;right:2px;top:2px}.quick-action-label{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1a1a1a,#333);-webkit-background-clip:text;background-clip:text;font-size:16px;font-weight:700;text-shadow:0 1px 2px #ffffff80;white-space:nowrap}.bottom-navigation{align-items:center;backdrop-filter:blur(40px) saturate(200%);-webkit-backdrop-filter:blur(40px) saturate(200%);background:linear-gradient(180deg,#fffffffa,#fafafcf2 50%,#f8f8fafa);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;border-top:1px solid #fff9;bottom:0;box-shadow:0 -8px 32px #00000014,0 -2px 8px #0000000a,0 -1px 0 #fffc,inset 0 1px 1px #ffffffe6,inset 0 -1px 1px #00000005;display:flex;height:auto;justify-content:center;left:50%;max-width:600px;min-height:80px;overflow:visible;padding:12px 16px calc(16px + var(--safe-area-bottom)) 16px;pointer-events:auto;position:fixed;transform:translateX(-50%);transition:all .4s cubic-bezier(.4,0,.2,1);width:100%;z-index:100}.bottom-navigation:before{background:linear-gradient(90deg,#0000,#6366f166 20%,#3b82f666 50%,#6366f166 80%,#0000);content:"";height:2px;left:0;opacity:.8;position:absolute;right:0;top:0}.bottom-navigation:after{background:radial-gradient(ellipse at center,#6366f114 0,#0000 70%);bottom:0;content:"";filter:blur(20px);height:60%;left:10%;position:absolute;right:10%;z-index:-1}[data-theme=dark] .bottom-navigation{background:linear-gradient(180deg,#1a1a1efa,#141418f2 50%,#121216fa);border-top-color:#ffffff1a;box-shadow:0 -8px 32px #0006,0 -2px 8px #0000004d,0 -1px 0 #ffffff0d,inset 0 1px 1px #ffffff0d}.nav-items-container{gap:4px;height:100%;justify-content:space-around;margin:0 auto;max-width:600px;width:100%}.nav-item,.nav-items-container{align-items:center;display:flex;position:relative}.nav-item{background:#0000;border:none;border-radius:16px;cursor:pointer;flex:1;flex-direction:column;gap:6px;justify-content:center;max-width:90px;padding:10px 8px;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-item:before{background:linear-gradient(145deg,#ffffff1a,#fff0);border-radius:20px;content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease}.nav-item:hover:before{opacity:1}.nav-item:not(.fab-button):hover{background:linear-gradient(145deg,#fff9,#f0f0f566);box-shadow:0 8px 24px #00000014,0 2px 8px #0000000a,inset 0 1px 1px #ffffffe6,inset 0 -1px 1px #0000000d;transform:translateY(-4px)}.nav-item:not(.fab-button):active{box-shadow:0 4px 12px #0000000f,0 1px 4px #0000000a,inset 0 2px 4px #00000014;transform:translateY(-2px) scale(.98)}.nav-icon-container{align-items:center;background:linear-gradient(145deg,#fff6,#f0f0f533);border-radius:16px;box-shadow:0 4px 12px #0000000f,inset 0 1px 1px #fffc,inset 0 -1px 1px #0000000d;display:flex;height:52px;justify-content:center;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:52px}.nav-item.active .nav-icon-container{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 8px 24px #667eea66,0 4px 12px #764ba24d,inset 0 1px 2px #fff6,inset 0 -1px 2px #0003;transform:scale(1.1)}.nav-item:hover .nav-icon-container{box-shadow:0 6px 20px #0000001a,inset 0 2px 2px #ffffffe6,inset 0 -1px 2px #00000014;transform:scale(1.05)}.nav-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:26px;position:relative;transition:all .3s cubic-bezier(.34,1.56,.64,1);z-index:1}.nav-item.active .nav-icon{animation:iconBounce .6s cubic-bezier(.34,1.56,.64,1);filter:drop-shadow(0 4px 8px rgba(0,0,0,.2)) drop-shadow(0 0 20px rgba(255,255,255,.4));font-size:30px}.nav-label{color:#666;font-size:12px;font-weight:600;letter-spacing:.3px;text-align:center;text-shadow:0 1px 2px #fffc;transition:all .3s ease}.nav-item.active .nav-label{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:13px;font-weight:800;text-shadow:0 2px 4px #667eea33}.badge{background:linear-gradient(135deg,#f44,#c00);border:2px solid #ffffffe6;border-radius:20px;box-shadow:0 4px 12px #ff444480,0 2px 6px #0000004d,inset 0 1px 1px #fff6,inset 0 -1px 1px #0000004d;font-weight:800;min-width:22px;padding:3px 7px;right:-6px;text-align:center;top:-6px}.badge,.nav-badge{animation:badgePulse 2s ease-in-out infinite;color:#fff;font-size:11px;position:absolute}.nav-badge{align-items:center;background:#ef4444;border:1.5px solid #ffffffd9;border-radius:10px;box-shadow:0 2px 6px #ef444480;display:flex;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 4px;pointer-events:none;right:2px;top:2px}.fab-button,.fab-container{position:relative}.fab-container{margin-bottom:28px}.fab{align-items:center;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:linear-gradient(135deg,#667eea,#764ba2);border:3px solid #ffffff80;border-radius:50%;bottom:0;box-shadow:0 12px 40px #667eea80,0 6px 20px #764ba266,0 2px 8px #0000004d,inset 0 2px 4px #fff6,inset 0 -2px 4px #0000004d,0 0 0 8px #667eea1a;cursor:pointer;display:flex;height:68px;justify-content:center;left:50%;position:absolute;transform:translateX(-50%);transition:all .4s cubic-bezier(.34,1.56,.64,1);width:68px}.fab:before{background:linear-gradient(145deg,#ffffff4d,#0000);inset:4px;opacity:.6}.fab:after,.fab:before{border-radius:50%;content:"";position:absolute}.fab:after{background:radial-gradient(circle,#667eea33,#0000 70%);filter:blur(12px);inset:-16px;opacity:0;transition:opacity .4s ease;z-index:-1}.fab:hover{box-shadow:0 20px 60px #667eea99,0 10px 30px #764ba280,0 4px 12px #0006,inset 0 3px 6px #ffffff80,inset 0 -3px 6px #0006,0 0 0 12px #667eea26;transform:translateX(-50%) scale(1.15) translateY(-4px)}.fab:hover:after{opacity:1}.fab.rotated{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 12px 40px #f093fb80,0 6px 20px #f5576c66,inset 0 2px 4px #fff6,inset 0 -2px 4px #0000004d;transform:translateX(-50%) rotate(135deg)}.fab-button.active .fab{animation:fabGlow 1.5s ease-in-out infinite}.fab-icon{color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));font-size:34px;font-weight:900;position:relative;transition:all .3s ease;z-index:1}@media (max-width:768px){.nav-items-container{gap:4px;padding:0 4px}.nav-item{gap:4px;max-width:72px;padding:8px 4px}.nav-icon-container{height:48px;width:48px}.nav-icon{font-size:24px}.nav-item.active .nav-icon{font-size:28px}.nav-label{font-size:10px}.nav-item.active .nav-label{font-size:11px}.fab{height:64px;width:64px}.fab-icon{font-size:32px}.quick-action-item{min-width:200px;padding:12px 20px}.quick-action-icon{font-size:24px;height:48px;width:48px}.quick-action-label{font-size:14px}}@media (min-width:1024px){.bottom-navigation{border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;max-width:600px}.nav-items-container{max-width:600px}}@media (min-width:1440px){.bottom-navigation,.nav-items-container{max-width:700px}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes iconBounce{0%,to{transform:scale(1)}25%{transform:scale(1.2)}50%{transform:scale(.95)}75%{transform:scale(1.05)}}@keyframes badgePulse{0%,to{box-shadow:0 4px 12px #ff444480,0 2px 6px #0000004d,inset 0 1px 1px #fff6,inset 0 -1px 1px #0000004d;transform:scale(1)}50%{box-shadow:0 6px 20px #ff4444b3,0 3px 10px #0006,inset 0 1px 1px #ffffff80,inset 0 -1px 1px #0006;transform:scale(1.15)}}@keyframes fabGlow{0%,to{box-shadow:0 12px 40px #667eea80,0 6px 20px #764ba266,0 2px 8px #0000004d,inset 0 2px 4px #fff6,inset 0 -2px 4px #0000004d,0 0 0 8px #667eea1a}50%{box-shadow:0 20px 60px #667eeab3,0 10px 30px #764ba299,0 4px 12px #0006,inset 0 3px 6px #ffffff80,inset 0 -3px 6px #0006,0 0 0 16px #667eea33}}[data-theme=dark] .nav-icon-container{background:linear-gradient(145deg,#28282dcc,#1e1e2399);box-shadow:0 4px 12px #0000004d,inset 0 1px 1px #ffffff0d,inset 0 -1px 1px #0000004d}[data-theme=dark] .nav-label{color:#aaa;text-shadow:0 1px 2px #00000080}[data-theme=dark] .quick-action-item{background:linear-gradient(145deg,#28282df2,#1e1e23e6);border-color:#ffffff1a}[data-theme=dark] .quick-action-label{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#ddd);-webkit-background-clip:text;background-clip:text}.bookings-header{align-items:center;backdrop-filter:blur(30px) saturate(200%);-webkit-backdrop-filter:blur(30px) saturate(200%);background:linear-gradient(145deg,#fffffffa,#ffffffeb);border:1px solid #fff6;border-radius:20px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014,inset 0 1px 1px #ffffffe6;display:flex;justify-content:space-between;margin-bottom:8px;padding:16px 20px}.bookings-header h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:800;margin:0}.view-all-bookings-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:13px;font-weight:700;padding:8px 16px;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.view-all-bookings-btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.bookings-loading{align-items:center;-webkit-backdrop-filter:blur(30px) saturate(200%);backdrop-filter:blur(30px) saturate(200%);background:linear-gradient(145deg,#fffffff2,#ffffffd9);border:1px solid #fff6;border-radius:20px;box-shadow:0 8px 32px #0000001f;display:flex;flex-direction:column;gap:12px;padding:40px 20px}.spinner-small{animation:spin .8s linear infinite;border:3px solid #667eea33;border-radius:50%;border-top-color:#667eea;height:32px;width:32px}.bookings-loading span{color:#666;font-size:14px;font-weight:600}.no-bookings{align-items:center;-webkit-backdrop-filter:blur(30px) saturate(200%);backdrop-filter:blur(30px) saturate(200%);background:linear-gradient(145deg,#fffffff2,#ffffffd9);border:1px solid #fff6;border-radius:20px;box-shadow:0 8px 32px #0000001f;display:flex;flex-direction:column;gap:12px;padding:40px 20px;text-align:center}.no-bookings-icon{font-size:48px;margin-bottom:8px}.no-bookings-title{color:#333;font-size:18px;font-weight:800;margin:0}.no-bookings-subtitle{color:#666;font-size:14px;font-weight:500;margin:0;max-width:280px}.browse-properties-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:16px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:14px;font-weight:700;margin-top:8px;padding:12px 24px;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.browse-properties-btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px) scale(1.03)}.booking-card{animation:slideUp .5s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(30px) saturate(200%);-webkit-backdrop-filter:blur(30px) saturate(200%);background:linear-gradient(145deg,#fffffffa,#ffffffeb);border:1px solid #fff6;border-radius:20px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014,inset 0 1px 1px #ffffffe6;cursor:pointer;padding:16px;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.booking-card:hover{border-color:#fff9;box-shadow:0 16px 48px #00000029,0 4px 16px #0000001f,0 0 40px #667eea33;transform:translateY(-4px) scale(1.02)}.booking-card-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.booking-property-info{flex:1;min-width:0}.booking-property-title{color:#1a1a1a;font-size:16px;font-weight:800;margin:0 0 4px}.booking-property-address,.booking-property-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.booking-property-address{color:#666;font-size:13px;font-weight:500;margin:0}.booking-status-badge{border-radius:12px;box-shadow:0 2px 8px #00000026;color:#fff;font-size:11px;font-weight:800;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase;white-space:nowrap}.booking-card-details{display:flex;gap:12px;margin-bottom:12px}.booking-detail-item{align-items:center;background:#667eea14;border-radius:12px;display:flex;flex:1;gap:8px;padding:10px}.booking-detail-icon{font-size:18px}.booking-detail-text{display:flex;flex-direction:column;gap:2px}.booking-detail-label{color:#666;font-size:11px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.booking-detail-value{color:#1a1a1a;font-size:13px;font-weight:800}.booking-card-footer{align-items:center;border-top:1px solid #00000014;display:flex;justify-content:space-between;padding-top:12px}.booking-guests{align-items:center;color:#666;display:flex;font-size:13px;font-weight:600;gap:6px}.booking-guests-icon{font-size:16px}.booking-total{align-items:center;display:flex}.booking-total-amount{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:900}.booking-guest-info{align-items:center;border-top:1px solid #00000014;display:flex;font-size:13px;gap:6px;margin-top:12px;padding-top:12px}.booking-guest-label{color:#666;font-weight:600}.booking-guest-name{color:#1a1a1a;font-weight:800}[data-theme=dark] .booking-card,[data-theme=dark] .bookings-header,[data-theme=dark] .bookings-loading,[data-theme=dark] .no-bookings{background:linear-gradient(145deg,#28282df2,#1e1e23e6);border-color:#ffffff1a}[data-theme=dark] .booking-detail-value,[data-theme=dark] .booking-guest-name,[data-theme=dark] .booking-property-title,[data-theme=dark] .bookings-header h3,[data-theme=dark] .no-bookings-title{color:#fff}[data-theme=dark] .booking-detail-label,[data-theme=dark] .booking-guest-label,[data-theme=dark] .booking-guests,[data-theme=dark] .booking-property-address,[data-theme=dark] .bookings-loading span,[data-theme=dark] .no-bookings-subtitle{color:#aaa}[data-theme=dark] .booking-detail-item{background:#667eea26}@media (max-width:480px){.bookings-menu{width:95vw}.bookings-header{padding:14px 16px}.bookings-header h3{font-size:16px}.view-all-bookings-btn{font-size:12px;padding:6px 12px}.booking-card{padding:14px}.booking-property-title{font-size:15px}.booking-card-details{flex-direction:column;gap:8px}}.offline-banner{align-items:center;animation:offlineBannerSlideIn .3s ease-out forwards;background:#f59e0b;box-shadow:0 2px 8px #00000026;color:#1c1917;display:flex;font-size:.875rem;font-weight:500;gap:8px;justify-content:center;left:0;line-height:1.25;padding:8px 16px;position:fixed;right:0;text-align:center;top:0;z-index:calc(var(--z-fixed, 1030) + 10)}@keyframes offlineBannerSlideIn{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.offline-banner-icon{align-items:center;display:flex;flex-shrink:0}.offline-banner-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}[data-theme=dark] .offline-banner{background:#d97706;color:#fff}@media (max-width:360px){.offline-banner{font-size:.75rem;padding:6px 12px}.offline-banner-text{white-space:normal}}.notification-prompt{align-items:center;animation:notificationPromptSlideIn .4s var(--ease-spring,cubic-bezier(.68,-.55,.265,1.55)) forwards;backdrop-filter:blur(var(--blur-xl,24px));-webkit-backdrop-filter:blur(var(--blur-xl,24px));background:var(--bg-glass-card,#fffffff7);border:1px solid var(--border-glass,#ffffff4d);border-radius:var(--radius-2xl,1.5rem);bottom:calc(var(--bottom-nav-height, 100px) + 12px);box-shadow:var(--shadow-glass-lg,0 8px 32px #1f268740),0 4px 16px #0000001a;display:flex;gap:12px;left:50%;max-width:480px;padding:14px 16px;position:fixed;transform:translateX(-50%) translateY(0);width:calc(100% - 32px);z-index:calc(var(--z-fixed, 1030) + 5)}@keyframes notificationPromptSlideIn{0%{opacity:0;transform:translateX(-50%) translateY(120%)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.notification-prompt-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--radius-xl,1rem);color:#fff;display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.notification-prompt-body{flex:1;min-width:0}.notification-prompt-title{color:var(--text-primary,#111827);font-size:var(--font-size-sm,.875rem);font-weight:var(--font-weight-bold,700);line-height:1.3;margin:0 0 2px}.notification-prompt-message{color:var(--text-secondary,#6b7280);font-size:var(--font-size-xs,.75rem);line-height:1.4;margin:0}.notification-prompt-actions{display:flex;flex-direction:column;flex-shrink:0;gap:6px}.notification-prompt-btn{border:none;border-radius:var(--radius-full,9999px);cursor:pointer;font-size:var(--font-size-xs,.75rem);font-weight:var(--font-weight-semibold,600);padding:7px 14px;transition:all var(--transition-base,.2s ease);white-space:nowrap}.notification-prompt-btn:disabled{cursor:not-allowed;opacity:.6}.notification-prompt-btn--primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea66;color:#fff}.notification-prompt-btn--primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea80;transform:translateY(-1px)}.notification-prompt-btn--secondary{background:var(--bg-hover,#f3f4f6);color:var(--text-secondary,#6b7280)}.notification-prompt-btn--secondary:hover:not(:disabled){background:var(--bg-active,#e5e7eb);color:var(--text-primary,#111827)}[data-theme=dark] .notification-prompt{background:var(--bg-glass-card,#1f2937e6);border-color:var(--border-glass,#ffffff1a);box-shadow:0 8px 32px #00000080,0 4px 16px #0000004d}[data-theme=dark] .notification-prompt-btn--secondary{background:var(--bg-hover,#374151);color:var(--text-secondary,#d1d5db)}[data-theme=dark] .notification-prompt-btn--secondary:hover:not(:disabled){background:var(--bg-active,#4b5563);color:var(--text-primary,#f9fafb)}@media (min-width:400px){.notification-prompt-actions{align-items:center;flex-direction:row}}@media (max-width:360px){.notification-prompt{border-radius:var(--radius-xl,1rem);gap:8px;padding:12px}.notification-prompt-icon{height:36px;width:36px}.notification-prompt-btn{font-size:11px;padding:6px 10px}}.pwa-install-prompt{align-items:center;animation:pwaPromptSlideIn .4s var(--ease-spring,cubic-bezier(.68,-.55,.265,1.55)) forwards;backdrop-filter:blur(var(--blur-xl,24px));-webkit-backdrop-filter:blur(var(--blur-xl,24px));background:var(--bg-glass-card,#fffffff7);border:1px solid var(--border-glass,#ffffff4d);border-radius:var(--radius-2xl,1.5rem);bottom:calc(var(--bottom-nav-height, 64px) + 80px);box-shadow:var(--shadow-glass-lg,0 8px 32px #1f268740),0 4px 16px #0000001a;display:flex;gap:12px;left:50%;max-width:480px;padding:14px 16px;position:fixed;transform:translateX(-50%) translateY(0);width:calc(100% - 32px);z-index:calc(var(--z-fixed, 1030) + 4)}@keyframes pwaPromptSlideIn{0%{opacity:0;transform:translateX(-50%) translateY(120%)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.pwa-install-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--radius-xl,1rem);display:flex;flex-shrink:0;font-size:22px;height:44px;justify-content:center;line-height:1;width:44px}.pwa-install-body{flex:1;min-width:0}.pwa-install-title{color:var(--text-primary,#111827);font-size:var(--font-size-sm,.875rem);font-weight:var(--font-weight-bold,700);line-height:1.3;margin:0 0 2px}.pwa-install-message{color:var(--text-secondary,#6b7280);font-size:var(--font-size-xs,.75rem);line-height:1.4;margin:0}.pwa-install-actions{display:flex;flex-direction:column;flex-shrink:0;gap:6px}.pwa-install-btn{border:none;border-radius:var(--radius-full,9999px);cursor:pointer;font-size:var(--font-size-xs,.75rem);font-weight:var(--font-weight-semibold,600);padding:7px 14px;transition:all var(--transition-base,.2s ease);white-space:nowrap}.pwa-install-btn:disabled{cursor:not-allowed;opacity:.6}.pwa-install-btn--primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea66;color:#fff}.pwa-install-btn--primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea80;transform:translateY(-1px)}.pwa-install-btn--secondary{background:var(--bg-hover,#f3f4f6);color:var(--text-secondary,#6b7280)}.pwa-install-btn--secondary:hover:not(:disabled){background:var(--bg-active,#e5e7eb);color:var(--text-primary,#111827)}[data-theme=dark] .pwa-install-prompt{background:var(--bg-glass-card,#1f2937e6);border-color:var(--border-glass,#ffffff1a);box-shadow:0 8px 32px #00000080,0 4px 16px #0000004d}[data-theme=dark] .pwa-install-btn--secondary{background:var(--bg-hover,#374151);color:var(--text-secondary,#d1d5db)}[data-theme=dark] .pwa-install-btn--secondary:hover:not(:disabled){background:var(--bg-active,#4b5563);color:var(--text-primary,#f9fafb)}@media (min-width:400px){.pwa-install-actions{align-items:center;flex-direction:row}}@media (max-width:360px){.pwa-install-prompt{border-radius:var(--radius-xl,1rem);gap:8px;padding:12px}.pwa-install-icon{font-size:18px;height:36px;width:36px}.pwa-install-btn{font-size:11px;padding:6px 10px}}.mini-player{align-items:center;animation:miniPlayerSlideUp .35s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(24px) saturate(200%) brightness(105%);-webkit-backdrop-filter:blur(24px) saturate(200%) brightness(105%);background:#ffffffd1;border-bottom:1px solid #764ba21f;border-top:1px solid #ffffff73;bottom:64px;box-shadow:0 -6px 24px #764ba22e,0 -2px 8px #0000000f;display:flex;gap:.625rem;left:0;padding:.625rem 1rem;position:fixed;right:0;z-index:999}@keyframes miniPlayerSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mini-player:before{animation:miniProgressShimmer 2s linear infinite;background:linear-gradient(90deg,#f6c90e,#764ba2 50%,#f6c90e);background-size:200% 100%;content:"";height:2px;left:0;position:absolute;right:0;top:0}@keyframes miniProgressShimmer{0%{background-position:0 0}to{background-position:200% 0}}.mini-player-art-btn{background:none;border:none;border-radius:.625rem;cursor:pointer;flex-shrink:0;overflow:hidden;padding:0;position:relative;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.mini-player-art-btn:hover{transform:scale(1.05)}.mini-player-art{border-radius:.625rem;box-shadow:0 2px 8px #0000002e;display:block;height:40px;object-fit:cover;width:40px}.mini-art-playing-indicator{align-items:flex-end;background:#764ba273;border-radius:.625rem;display:flex;gap:2px;inset:0;justify-content:center;padding-bottom:6px;position:absolute}.mini-art-playing-indicator span{animation:miniBarBounce .8s ease-in-out infinite alternate;background:#fff;border-radius:2px;display:block;width:3px}.mini-art-playing-indicator span:first-child{animation-delay:0s;height:8px}.mini-art-playing-indicator span:nth-child(2){animation-delay:.15s;height:14px}.mini-art-playing-indicator span:nth-child(3){animation-delay:.3s;height:6px}@keyframes miniBarBounce{0%{transform:scaleY(.5)}to{transform:scaleY(1)}}.mini-player-info-btn{background:none;border:none;cursor:pointer;flex:1;min-width:0;padding:0;text-align:left;transition:opacity .2s ease}.mini-player-info-btn:hover{opacity:.8}.mini-player-title{color:#1f2937;font-size:.875rem;font-weight:700;margin:0 0 .1rem}.mini-player-artist,.mini-player-title{line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mini-player-artist{color:#1f293799;font-size:.75rem;margin:0}.mini-player-earning{align-items:center;animation:earningFadeIn .4s ease;background:#f6c90e26;border:1px solid #f6c90e59;border-radius:2rem;display:flex;flex-shrink:0;gap:.25rem;padding:.2rem .5rem}@keyframes earningFadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.mini-token-icon{animation:tokenSpin 1.5s ease-in-out infinite;font-size:.875rem}@keyframes tokenSpin{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.mini-player-toggle{align-items:center;background:linear-gradient(135deg,#f6c90e,#764ba2);border:none;border-radius:50%;box-shadow:0 4px 12px #764ba259,0 2px 6px #0000001a;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:all .3s cubic-bezier(.34,1.56,.64,1);width:40px}.mini-player-toggle:hover{box-shadow:0 6px 18px #764ba273,0 3px 8px #0000001f;transform:scale(1.1)}.mini-player-toggle:active{transform:scale(.95)}.mini-player-close{align-items:center;background:#ffffff26;border:1px solid #ffffff4d;border-radius:50%;color:#1f29378c;cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .3s cubic-bezier(.34,1.56,.64,1);width:32px}.mini-player-close:hover{background:#ef44441f;border-color:#ef44444d;color:#ef4444;transform:rotate(90deg) scale(1.1)}.mini-player-close:active{transform:rotate(90deg) scale(.9)}.mini-player-art-btn:focus-visible,.mini-player-close:focus-visible,.mini-player-info-btn:focus-visible,.mini-player-toggle:focus-visible{outline:3px solid #764ba280;outline-offset:2px}@media (max-width:480px){.mini-player{bottom:56px;gap:.5rem;padding:.5rem .875rem}.mini-player-art,.mini-player-toggle{height:36px;width:36px}.mini-player-close{height:28px;width:28px}}@media (min-width:768px){.mini-player{border:1px solid #fff6;border-bottom:none;border-radius:1rem 1rem 0 0;left:50%;max-width:720px;right:auto;transform:translateX(-50%)}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.main-layout{background:#0000;min-height:100vh;overflow-x:hidden;position:relative;width:100%}.anonymous-banner{backdrop-filter:blur(var(--blur-xl))!important;-webkit-backdrop-filter:blur(var(--blur-xl))!important;background:var(--glass-primary)!important;border:1px solid #fff3!important;border-radius:var(--radius-xl)!important;bottom:calc(var(--bottom-nav-height, 100px) + 280px)!important;box-shadow:var(--shadow-glass-lg),var(--shadow-glow-primary)!important;color:#fff!important;display:block!important;left:var(--space-4,16px)!important;max-width:180px!important;pointer-events:auto!important;position:fixed!important;right:auto!important;top:auto!important;transform:none!important;width:180px!important;z-index:10001!important}.banner-close-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:20px;justify-content:center;line-height:1;padding:0;position:absolute;right:8px;top:8px;transition:all .3s ease;width:20px;z-index:1}.banner-close-btn:hover{background:#fff6;transform:scale(1.1)}.anonymous-banner-content{align-items:flex-start;display:flex;flex-direction:column;gap:8px;max-width:100%;padding:12px}.banner-icon{align-self:center;flex-shrink:0;font-size:20px;margin-bottom:4px}.banner-text{display:flex;flex-direction:column;gap:4px;width:100%}.banner-text strong{font-size:12px;font-weight:700;line-height:1.3}.banner-text span{font-size:10px;line-height:1.4;opacity:.9}.banner-button{background:#fff;border:none;border-radius:12px;color:#2196f3;cursor:pointer;font-size:11px;font-weight:700;padding:6px 12px;transition:all .3s ease;white-space:nowrap;width:100%}.banner-button:hover{box-shadow:0 2px 8px #0003;transform:translateY(-1px)}.main-content{background:#0000;min-height:100vh;overflow-x:hidden;position:relative;transition:padding var(--transition-base);width:100%}.main-content.with-nav{padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom))}.main-content.with-banner,.main-content.with-topbar{padding-top:calc(var(--top-bar-height) + var(--safe-area-top))}.main-content.full-screen{padding:0}.page-container{backdrop-filter:blur(var(--blur-lg));-webkit-backdrop-filter:blur(var(--blur-lg));background:#fffffffa;border:1px solid var(--border-glass);margin:0 auto;max-width:100%;position:relative;width:100%;z-index:1}.main-content.with-banner .page-container,.page-container{min-height:calc(100vh - var(--total-nav-overhead) - var(--safe-area-top) - var(--safe-area-bottom))}@media (max-width:480px){.anonymous-banner{max-width:160px!important;width:160px!important}.anonymous-banner-content{gap:6px;padding:10px}.banner-icon{font-size:18px}.banner-text strong{font-size:11px}.banner-text span{font-size:9px}.banner-button{font-size:10px;padding:5px 10px}.main-content.with-banner{padding-top:calc(var(--top-bar-height) + var(--safe-area-top))}}@media (min-width:768px){.page-container{box-shadow:0 0 20px #0000001a;max-width:768px}.anonymous-banner{bottom:calc(var(--bottom-nav-height, 100px) + 300px)!important;max-width:200px!important;width:200px!important}.banner-text strong{font-size:13px!important}.banner-text span{font-size:11px!important}.banner-button{font-size:12px!important}}@media (min-width:1024px){.main-layout{align-items:flex-start;background:var(--gradient-primary);background-attachment:fixed;background-image:var(--gradient-mesh);display:flex;justify-content:center;min-height:100vh}.main-content,.page-container{background:var(--bg-page);margin:0;max-width:100%;min-height:100vh;width:100%}.page-container{border:none}.anonymous-banner{bottom:calc(var(--bottom-nav-height, 100px) + 320px)!important;max-width:200px!important;width:200px!important}.main-content.with-banner .page-container,.main-content.with-nav .page-container{min-height:calc(100vh - var(--total-nav-overhead) - var(--safe-area-top) - var(--safe-area-bottom))}}@media (min-width:1440px){.main-content{max-width:100%}.page-container{max-width:100%;width:100%}.anonymous-banner{max-width:220px!important;width:220px!important}}html{scroll-behavior:smooth}body{margin:0;overflow-x:hidden;padding:0}.page-container{-webkit-overflow-scrolling:touch;overflow-x:hidden;overflow-y:auto}@supports (padding-top:env(safe-area-inset-top)){.anonymous-banner{padding-top:var(--safe-area-top)}}.page-container.loading{align-items:center;display:flex;justify-content:center;min-height:100vh}.page-container>*{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.error-boundary-container{align-items:center;background:linear-gradient(135deg,#6366f10d,#8b5cf60d 50%,#ec48990d);display:flex;justify-content:center;min-height:100vh;padding:var(--space-8)}.error-boundary-content{animation:fadeInUp .6s ease;backdrop-filter:blur(var(--blur-lg));-webkit-backdrop-filter:blur(var(--blur-lg));background:var(--bg-glass-card);border:1px solid var(--border-glass);border-radius:var(--radius-2xl);box-shadow:var(--shadow-glass-lg);max-width:600px;padding:var(--space-12);text-align:center;width:100%}.error-icon{animation:bounce 1.5s ease-in-out infinite;font-size:80px;margin-bottom:var(--space-6)}.error-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--color-primary),var(--color-purple));-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-4)}.error-message{color:var(--text-secondary);font-size:var(--font-size-lg);line-height:1.6;margin-bottom:var(--space-8)}.error-details{background:#ef44440d;border:1px solid #ef444433;border-radius:var(--radius-lg);margin:var(--space-6) 0;padding:var(--space-4);text-align:left}.error-details summary{color:var(--color-error);cursor:pointer;font-weight:var(--font-weight-semibold);margin-bottom:var(--space-3);-webkit-user-select:none;user-select:none}.error-details summary:hover{text-decoration:underline}.error-stack{color:var(--text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-3)}.error-stack p{margin-bottom:var(--space-2);word-break:break-word}.error-stack pre{word-wrap:break-word;background:#0000000d;border-radius:var(--radius-md);font-size:var(--font-size-xs);line-height:1.5;overflow-x:auto;padding:var(--space-3);white-space:pre-wrap}.error-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;margin-bottom:var(--space-6)}.btn-error-primary,.btn-error-secondary{border:none;border-radius:var(--radius-xl);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);overflow:hidden;padding:var(--space-3) var(--space-6);position:relative;transition:all .3s ease}.btn-error-primary{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);box-shadow:var(--shadow-md);color:#fff}.btn-error-primary:hover{box-shadow:var(--shadow-lg),var(--shadow-glow-primary);transform:translateY(-2px)}.btn-error-primary:active{transform:scale(.96)}.btn-error-secondary{-webkit-backdrop-filter:blur(var(--blur-sm));backdrop-filter:blur(var(--blur-sm));background:var(--glass-white);border:1px solid var(--border-glass);color:var(--text-primary)}.btn-error-secondary:hover{background:var(--glass-white-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-error-secondary:active{transform:scale(.96)}.error-help{color:var(--text-tertiary);font-size:var(--font-size-sm);margin-top:var(--space-4)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@media (max-width:640px){.error-boundary-content{padding:var(--space-8)}.error-icon{font-size:64px}.error-title{font-size:var(--font-size-2xl)}.error-message{font-size:var(--font-size-base)}.error-actions{flex-direction:column;width:100%}.btn-error-primary,.btn-error-secondary{width:100%}}.offline-indicator{left:50%;max-width:90%;pointer-events:none;position:fixed;transform:translateX(-50%) translateY(-100%);transition:transform .4s cubic-bezier(.4,0,.2,1);width:auto;z-index:var(--z-toast,10000)}.offline-indicator.top{top:var(--space-4)}.offline-indicator.bottom{bottom:calc(var(--bottom-nav-height) + var(--space-4));top:auto;transform:translateX(-50%) translateY(200%)}.offline-indicator.visible{pointer-events:auto;transform:translateX(-50%) translateY(0)}.offline-indicator-content{align-items:center;animation:slideInBounce .5s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(var(--blur-xl));-webkit-backdrop-filter:blur(var(--blur-xl));background:var(--bg-glass-card);border:1px solid var(--border-glass);border-radius:var(--radius-full);box-shadow:var(--shadow-glass-lg),0 8px 32px #00000026;display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-5)}@keyframes slideInBounce{0%{opacity:0;transform:scale(.9) translateY(-20px)}50%{transform:scale(1.02) translateY(0)}to{opacity:1;transform:scale(1) translateY(0)}}.indicator-icon{flex-shrink:0;height:24px;width:24px}.offline-indicator.offline .indicator-icon{color:#f59e0b}.offline-indicator.online .indicator-icon{color:#10b981}.indicator-icon.pulse{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.indicator-text{display:flex;flex-direction:column;gap:2px;min-width:0}.indicator-text strong{color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);white-space:nowrap}.indicator-text span{color:var(--text-secondary);font-size:var(--font-size-xs);white-space:nowrap}.offline-indicator.offline .offline-indicator-content{background:linear-gradient(135deg,#f59e0b1a,#fbbf240d);border-color:#f59e0b4d}.offline-indicator.online .offline-indicator-content{background:linear-gradient(135deg,#10b9811a,#34d3990d);border-color:#10b9814d}@media (max-width:768px){.offline-indicator{max-width:calc(100% - var(--space-4)*2)}.offline-indicator.top{top:var(--space-3)}.offline-indicator.bottom{bottom:calc(var(--bottom-nav-height) + var(--space-3))}.offline-indicator-content{gap:var(--space-2);padding:var(--space-2) var(--space-4)}.indicator-icon{height:20px;width:20px}.indicator-text strong{font-size:13px}.indicator-text span{font-size:11px}}@media (max-width:480px){.offline-indicator-content{padding:10px var(--space-3)}.indicator-text strong{font-size:12px}.indicator-text span{display:none}}@media (prefers-color-scheme:dark){.offline-indicator.offline .offline-indicator-content{background:linear-gradient(135deg,#f59e0b26,#fbbf2414)}.offline-indicator.online .offline-indicator-content{background:linear-gradient(135deg,#10b98126,#34d39914)}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{background:var(--gradient-primary);background-attachment:fixed;min-height:100vh;position:relative}.App:before{background:var(--gradient-mesh);bottom:0;content:"";left:0;opacity:.2;pointer-events:none;position:fixed;right:0;top:0;z-index:0}.loading-container{align-items:center;color:#fff;display:flex;flex-direction:column;height:100vh;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:5px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.hero-section{align-items:center;color:#fff;display:flex;justify-content:center;min-height:100vh;padding:var(--space-8);text-align:center}.hero-content,.hero-section{position:relative;z-index:1}.hero-content h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e7ff);-webkit-background-clip:text;background-clip:text;font-size:clamp(2.5rem,6vw,3.5rem);font-weight:var(--font-weight-bold);margin-bottom:var(--space-6);text-shadow:0 4px 20px #0006}.hero-content p{font-size:clamp(1.125rem,2.5vw,1.375rem);margin-bottom:var(--space-8);opacity:.95;text-shadow:0 2px 10px #0000004d}.auth-buttons{display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:center}.auth-btn{align-items:center;border:none;border-radius:var(--radius-full);cursor:pointer;display:inline-flex;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);justify-content:center;min-width:180px;overflow:hidden;padding:var(--space-4) var(--space-8);position:relative;text-decoration:none;transition:all var(--transition-base)}.auth-btn.primary{backdrop-filter:blur(var(--blur-md));-webkit-backdrop-filter:blur(var(--blur-md));background:var(--glass-white);border:1px solid var(--border-glass);box-shadow:var(--shadow-glass);color:var(--color-primary)}.auth-btn.primary:hover{background:#fffffff2;box-shadow:var(--shadow-glass-lg),var(--shadow-glow-primary)}.auth-btn.secondary{backdrop-filter:blur(var(--blur-md));-webkit-backdrop-filter:blur(var(--blur-md));background:#ffffff26;border:2px solid #ffffff4d;box-shadow:var(--shadow-glass);color:#fff}.auth-btn.secondary:hover{background:#ffffff40;border-color:#ffffff80}.auth-btn:hover{box-shadow:0 12px 24px #00000040;transform:translateY(-3px)}.user-welcome h2{font-size:2rem;margin-bottom:1rem}.sign-out-btn{backdrop-filter:blur(var(--blur-md));-webkit-backdrop-filter:blur(var(--blur-md));background:#ffffff26;border:2px solid #ffffff4d;border-radius:var(--radius-full);box-shadow:var(--shadow-glass);color:#fff;cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);padding:var(--space-3) var(--space-6);transition:all var(--transition-base)}.sign-out-btn:hover{background:var(--glass-white);border-color:var(--border-glass);box-shadow:var(--shadow-glass-lg);color:var(--color-primary);transform:translateY(-2px)}@media (max-width:768px){.hero-content h1{font-size:2.5rem}.auth-buttons{align-items:center;flex-direction:column}.auth-btn{width:200px}}