:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#faf8f5;color:#1a1625}a{font-weight:500;color:#7c3aed;text-decoration:none;transition:color .2s}a:hover{color:#5b21b6}button{font-family:inherit;cursor:pointer}img{max-width:100%;height:auto;display:block}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#faf8f5}::-webkit-scrollbar-thumb{background:#7c3aed4d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#7c3aed80}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:300px;animation:slideIn .3s ease-out;cursor:pointer;transition:transform .2s,opacity .2s;border-left:4px solid}.toast:hover{transform:translate(-5px);box-shadow:0 6px 16px #0003}.toast-success{border-left-color:#00b894}.toast-error{border-left-color:#d63031}.toast-warning{border-left-color:#fdcb6e}.toast-info{border-left-color:#0984e3}.toast-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.toast-success .toast-icon{background:#00b894;color:#fff}.toast-error .toast-icon{background:#d63031;color:#fff}.toast-warning .toast-icon{background:#fdcb6e;color:#333}.toast-info .toast-icon{background:#0984e3;color:#fff}.toast-message{flex:1;color:#333;font-size:.95rem;line-height:1.4}.toast-close{background:none;border:none;color:#999;font-size:24px;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s;flex-shrink:0}.toast-close:hover{color:#333}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.toast-container{left:10px;right:10px;max-width:none}.toast{min-width:auto}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);padding:2rem}.error-content{background:#fff;border-radius:12px;padding:3rem;max-width:500px;text-align:center;box-shadow:0 10px 40px #0003}.error-icon{font-size:4rem;margin-bottom:1rem}.error-content h1{color:#333;margin-bottom:.5rem;font-size:1.5rem}.error-content p{color:#666;margin-bottom:1.5rem}.error-details{text-align:left;margin:1.5rem 0;padding:1rem;background:#f5f5f5;border-radius:8px;cursor:pointer}.error-details summary{font-weight:600;color:#06c;margin-bottom:.5rem}.error-details pre{margin:.5rem 0 0;padding:.5rem;background:#fff;border-radius:4px;overflow-x:auto;font-size:.85rem;color:#d63031}.error-content .btn-primary{margin-top:1rem}.notification-bell{position:relative}.bell-button{position:relative;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;transition:transform .2s}.bell-button:hover{transform:scale(1.1)}.notification-badge{position:absolute;top:0;right:0;background:#dc2626;color:#fff;font-size:.7rem;font-weight:700;padding:.15rem .4rem;border-radius:10px;min-width:18px;text-align:center}.notification-overlay{position:fixed;inset:0;z-index:999}.notification-dropdown{position:absolute;top:calc(100% + .5rem);right:0;width:380px;max-height:500px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;z-index:1000;display:flex;flex-direction:column;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e5e7eb}.notification-header h3{margin:0;font-size:1.1rem;color:#1f2937}.mark-all-btn{background:none;border:none;color:#06c;font-size:.85rem;cursor:pointer;padding:.25rem .5rem}.mark-all-btn:hover{text-decoration:underline}.notification-list{flex:1;overflow-y:auto;max-height:400px}.no-notifications{padding:3rem 2rem;text-align:center;color:#9ca3af}.notification-item{display:flex;gap:1rem;padding:1rem;border-bottom:1px solid #f3f4f6;cursor:pointer;transition:background-color .2s;position:relative}.notification-item:hover{background-color:#f9fafb}.notification-item.unread{background-color:#eff6ff}.notif-icon{font-size:1.5rem;flex-shrink:0}.notif-content{flex:1;min-width:0}.notif-title{font-weight:600;color:#1f2937;margin-bottom:.25rem}.notif-message{font-size:.9rem;color:#6b7280;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-time{font-size:.8rem;color:#9ca3af}.unread-dot{position:absolute;top:50%;right:1rem;transform:translateY(-50%);width:8px;height:8px;background:#06c;border-radius:50%}.view-all-notif{display:block;text-align:center;padding:.75rem;color:#06c;font-weight:600;text-decoration:none;border-top:1px solid #e5e7eb;transition:background-color .2s}.view-all-notif:hover{background-color:#f9fafb}@media(max-width:480px){.notification-dropdown{width:calc(100vw - 2rem);right:-100px}}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:#faf8f5d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);transition:background .3s,box-shadow .3s}.navbar-scrolled{background:#faf8f5f5;box-shadow:var(--shadow-sm)}.nav-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:76px;display:flex;align-items:center;gap:1.5rem}.nav-logo{display:flex;align-items:center;gap:.4rem;text-decoration:none;flex-shrink:0}.nav-logo-full{height:80px;width:auto;display:block}.nav-logo-icon{height:44px;width:auto;display:none}.nav-links{display:flex;align-items:center;gap:.25rem;flex:1}.nav-link{padding:.4rem .75rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:var(--transition);white-space:nowrap}.nav-link:hover{color:var(--color-text);background:var(--color-surface-alt)}.nav-link-active{color:var(--color-primary);background:var(--color-primary-soft);font-weight:600}.nav-link-active:hover{color:var(--color-primary-dark);background:var(--color-primary-soft)}.nav-actions{display:flex;align-items:center;gap:.625rem;flex-shrink:0;margin-left:auto}.btn-sm{padding:.45rem 1rem;font-size:.83rem}.user-menu-wrap{position:relative}.user-avatar-btn{display:flex;align-items:center;gap:.5rem;background:var(--color-surface);border:1.5px solid var(--color-border-strong);border-radius:var(--radius-full);padding:.3rem .75rem .3rem .3rem;cursor:pointer;transition:var(--transition);font-family:inherit}.user-avatar-btn:hover{border-color:var(--color-primary);background:var(--color-primary-soft)}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--gradient-primary);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}.user-name{font-size:.85rem;font-weight:600;color:var(--color-text);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chevron{color:var(--color-text-light);transition:transform .2s}.chevron-up{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:220px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:.5rem;z-index:200;animation:dropIn .18s ease}@keyframes dropIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-item{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;border-radius:var(--radius-lg);font-size:.875rem;font-weight:500;color:var(--color-text);text-decoration:none;transition:var(--transition);cursor:pointer;width:100%;text-align:left;background:none;border:none;font-family:inherit}.dropdown-item:hover{background:var(--color-surface-alt);color:var(--color-text)}.dropdown-item-special{color:var(--color-primary);font-weight:600}.dropdown-item-danger{color:var(--color-error)}.dropdown-item-danger:hover{background:#ef444414;color:var(--color-error)}.dropdown-divider{height:1px;background:var(--color-border);margin:.375rem 0}.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:8px;border:1.5px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;transition:var(--transition)}.hamburger:hover{border-color:var(--color-primary);background:var(--color-primary-soft)}.hamburger span{display:block;width:100%;height:1.5px;background:var(--color-text);border-radius:2px;transition:var(--transition);transform-origin:center}.hamburger-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.hamburger-open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.mobile-menu{border-top:1px solid var(--color-border);background:var(--color-surface);padding:.75rem 1rem 1.25rem;display:flex;flex-direction:column;gap:.25rem;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.mobile-link{padding:.625rem .875rem;border-radius:var(--radius-lg);font-size:.95rem;font-weight:500;color:var(--color-text);text-decoration:none;transition:var(--transition);display:block;background:none;border:none;font-family:inherit;text-align:left;cursor:pointer;width:100%}.mobile-link:hover{background:var(--color-surface-alt)}.mobile-link-active{color:var(--color-primary);background:var(--color-primary-soft);font-weight:600}.mobile-link-danger{color:var(--color-error)}.mobile-menu-divider{height:1px;background:var(--color-border);margin:.5rem 0}.mobile-auth-btns{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}@media(max-width:900px){.nav-links{display:none}.hamburger{display:flex}.user-name{display:none}}@media(max-width:480px){.nav-inner{padding:0 1rem}.nav-logo-full{display:none}.nav-logo-icon{display:block}}.footer{background:var(--color-text);color:var(--color-text-light);margin-top:auto;padding-top:var(--spacing-2xl)}.footer-container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--spacing-2xl);padding-bottom:var(--spacing-2xl);border-bottom:1px solid rgba(255,255,255,.07)}.footer-logo{display:inline-flex;align-items:center;gap:.4rem;margin-bottom:.875rem}.footer-logo-img{height:28px;width:auto;display:block;filter:brightness(0) invert(1)}.footer-tagline{font-size:.9rem;line-height:1.65;color:var(--color-text-light);margin-bottom:var(--spacing-md);max-width:260px}.footer-social{display:flex;gap:.5rem}.social-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#ffffff12;border-radius:var(--radius-md);color:var(--color-text-light);text-decoration:none;transition:var(--transition)}.social-btn:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px)}.footer-col-title{font-size:.8rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem;display:block}.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.625rem}.footer-col ul li a{font-size:.9rem;color:var(--color-text-light);text-decoration:none;transition:var(--transition)}.footer-col ul li a:hover{color:#fff}.footer-content,.footer-column{display:none}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) 0;font-size:.83rem;color:#ffffff59;flex-wrap:wrap;gap:.75rem}.footer-bottom-links{display:flex;gap:1.25rem}.footer-bottom-links a{color:#ffffff59;text-decoration:none;transition:var(--transition);font-size:.83rem}.footer-bottom-links a:hover{color:#fff}@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr;gap:var(--spacing-xl)}.footer-brand{grid-column:1 / -1}.footer-tagline{max-width:100%}}@media(max-width:480px){.footer-top{grid-template-columns:1fr;gap:var(--spacing-lg)}.footer-bottom{flex-direction:column;align-items:center;text-align:center}}.home{width:100%}.hero{position:relative;background:var(--color-bg);padding:2rem 0 3rem;overflow:hidden}.hero-glow{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}.hero-glow-1{width:500px;height:500px;top:-150px;right:-100px;background:#7c3aed1f}.hero-glow-2{width:400px;height:400px;bottom:-120px;left:-80px;background:#f9731614}.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative}.hero-tag{display:inline-block;padding:.35rem .875rem;background:var(--color-primary-soft);color:var(--color-primary);border-radius:var(--radius-full);font-size:.8rem;font-weight:700;letter-spacing:.02em;margin-bottom:1.25rem;text-transform:uppercase}.hero-title{font-size:3.5rem;font-weight:900;line-height:1.1;letter-spacing:-.04em;color:var(--color-text);margin-bottom:1.25rem}.hero-subtitle{font-size:1.1rem;color:var(--color-text-secondary);line-height:1.65;margin-bottom:2rem;max-width:480px}.hero-actions{display:flex;gap:.875rem;flex-wrap:wrap}.hero-benefits{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:2rem;max-width:480px}.hero-benefit{display:flex;align-items:flex-start;gap:.625rem;background:#ffffff8c;border:1px solid rgba(124,58,237,.1);border-radius:var(--radius-lg);padding:.75rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hero-benefit-icon{font-size:1.25rem;flex-shrink:0;margin-top:1px}.hero-benefit-title{font-size:.82rem;font-weight:700;color:var(--color-text);line-height:1.3}.hero-benefit-desc{font-size:.74rem;color:var(--color-text-secondary);margin-top:1px;line-height:1.3}.hero-visual{position:relative;height:320px}.hero-card{position:absolute;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:.875rem 1rem;display:flex;align-items:center;gap:.75rem;box-shadow:var(--shadow-lg);font-size:1.5rem}.hero-card-1{top:0;left:0;right:0}.hero-card-2{top:90px;left:20px;right:20px}.hero-card-3{top:180px;left:40px;right:0}.hc-title{font-size:.9rem;font-weight:700;color:var(--color-text)}.hc-sub{font-size:.78rem;color:var(--color-text-secondary);margin-top:2px}.hc-badge{margin-left:auto;background:var(--color-primary-soft);color:var(--color-primary);font-size:.7rem;font-weight:700;padding:.2rem .5rem;border-radius:var(--radius-full);white-space:nowrap}.hc-price{margin-left:auto;font-size:1rem;font-weight:800;color:var(--color-text);letter-spacing:-.03em}.quick-actions{padding:2.5rem 0}.qa-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.875rem}.qa-card{display:flex;align-items:center;gap:.875rem;padding:1.125rem 1.25rem;background:var(--qa-bg, var(--color-surface));border-radius:var(--radius-xl);border:1px solid var(--color-border);text-decoration:none;color:var(--color-text);transition:var(--transition)}.qa-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);color:var(--color-text)}.qa-icon{font-size:1.5rem;flex-shrink:0}.qa-label{font-size:.9rem;font-weight:700;color:var(--color-text)}.qa-desc{font-size:.78rem;color:var(--color-text-secondary);margin-top:2px}.qa-arrow{margin-left:auto;color:var(--color-text-light);flex-shrink:0}.events-section{background:var(--color-bg)}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.event-card{display:flex;flex-direction:column;text-decoration:none;color:var(--color-text)}.event-img{position:relative;height:180px;overflow:hidden;background:var(--color-surface-alt);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.event-img img{width:100%;height:100%;object-fit:cover}.img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem}.event-type-badge{position:absolute;top:10px;right:10px;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em}.event-body{padding:1rem 1.125rem 1.125rem;flex:1;display:flex;flex-direction:column;gap:.625rem}.event-name{font-size:1rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em;line-height:1.35;margin:0}.event-meta{display:flex;flex-direction:column;gap:.2rem;font-size:.82rem;color:var(--color-text-secondary)}.event-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.625rem;border-top:1px solid var(--color-border);margin-top:auto}.event-price{font-size:1.1rem;font-weight:800;color:var(--color-primary);letter-spacing:-.03em}.event-avail{font-size:.8rem;color:var(--color-text-secondary)}.event-avail.sold-out{color:var(--color-error);font-weight:600}.est-section{background:var(--color-surface-alt)}.est-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}.est-card{display:flex;flex-direction:column;text-decoration:none;color:var(--color-text);background:var(--color-surface)}.est-img{position:relative;height:160px;overflow:hidden;display:flex;align-items:center;justify-content:center}.est-img img{width:100%;height:100%;object-fit:cover}.est-emoji{font-size:3.5rem;opacity:.45}.open-pill{position:absolute;top:10px;left:10px;display:flex;align-items:center;gap:5px;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.open-pill-open{background:#10b98126;color:#059669}.open-pill-closed{background:#ef44441f;color:#dc2626}.open-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.est-body{padding:1rem 1.125rem 1.125rem}.est-logo-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.est-logo{width:40px;height:40px;border-radius:var(--radius-md);object-fit:contain;border:1px solid var(--color-border)}.est-logo-placeholder{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-primary-soft);display:flex;align-items:center;justify-content:center;font-size:1.25rem}.est-name{font-size:.95rem;font-weight:700;color:var(--color-text);margin:0 0 2px;letter-spacing:-.02em}.est-type{font-size:.75rem;color:var(--color-text-light);text-transform:capitalize}.est-desc{font-size:.82rem;color:var(--color-text-secondary);line-height:1.55;margin-bottom:.75rem}.est-meta{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--color-text-secondary)}.est-rating{display:flex;align-items:center;gap:3px;font-weight:700;color:var(--color-text)}.home-skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.skeleton-card{height:300px;border-radius:var(--radius-xl);background:linear-gradient(90deg,var(--color-surface-alt) 25%,var(--color-surface) 50%,var(--color-surface-alt) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{display:flex;flex-direction:column;align-items:center;padding:3rem 1rem;gap:.75rem;color:var(--color-text-secondary);font-size:.95rem}.empty-state>span{font-size:3rem}.cta-banner{background:var(--gradient-hero);padding:4rem 0;margin-top:var(--spacing-xl)}.cta-inner{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.cta-text h2{font-size:2rem;font-weight:800;color:#fff;letter-spacing:-.04em;margin-bottom:.5rem}.cta-text p{font-size:1rem;color:#fffc}.cta-actions{display:flex;gap:.75rem;flex-wrap:wrap}.cta-actions .btn-secondary{background:#ffffff26;border-color:#ffffff59;color:#fff}.cta-actions .btn-secondary:hover{background:#ffffff40;color:#fff}.welcome-banner,.quick-actions-legacy{display:none}@media(max-width:900px){.hero-inner{grid-template-columns:1fr;gap:2rem}.hero-visual{display:none}.hero-title{font-size:2.75rem}.cta-inner{flex-direction:column;text-align:center}.cta-actions{justify-content:center}}@media(max-width:640px){.hero{padding:3rem 0 2.5rem}.hero-title{font-size:2.25rem}.hero-benefits{grid-template-columns:1fr;max-width:100%}.events-grid,.est-grid{grid-template-columns:1fr}.qa-grid{grid-template-columns:1fr 1fr}}@media(max-width:400px){.qa-grid{grid-template-columns:1fr}.hero-title{font-size:2rem}}.ad-banner{border-radius:var(--radius-xl);padding:var(--spacing-xl);margin:var(--spacing-xl) 0;box-shadow:var(--shadow-lg);transition:var(--transition);position:relative}.ad-banner:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.ad-background-image{position:absolute;inset:0;background-size:cover;background-position:center;pointer-events:none;z-index:1}.ad-content{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xl)}.ad-text{flex:1}.ad-title{font-size:1.75rem;font-weight:800;color:var(--color-white);margin-bottom:var(--spacing-sm);text-shadow:0 2px 4px rgba(0,0,0,.2)}.ad-description{font-size:1.1rem;color:#fffffff2;margin-bottom:var(--spacing-md);line-height:1.6;text-shadow:0 1px 2px rgba(0,0,0,.1)}.ad-cta-button{padding:.875rem 1.75rem;background:var(--color-white);color:var(--color-dark);border:none;border-radius:var(--radius-lg);font-weight:700;font-size:1rem;cursor:pointer;display:inline-flex;align-items:center;gap:var(--spacing-xs);transition:var(--transition);box-shadow:0 4px 12px #00000026}.ad-cta-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003}.ad-side-image{flex-shrink:0;width:250px;height:250px;position:relative;z-index:2}.ad-side-image img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}.ad-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--color-white);padding:.25rem .75rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;z-index:3}.ad-banner-loading{background:linear-gradient(135deg,#e0e0e0,#f0f0f0);min-height:200px;display:flex;align-items:center;justify-content:center}.ad-skeleton{width:100%;max-width:600px}.skeleton-title,.skeleton-description,.skeleton-button{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-title{height:2rem;width:70%;margin-bottom:var(--spacing-sm)}.skeleton-description{height:1rem;width:90%;margin-bottom:var(--spacing-xs)}.skeleton-button{height:2.5rem;width:150px;margin-top:var(--spacing-md);border-radius:var(--radius-lg)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media(max-width:768px){.ad-banner{padding:var(--spacing-md)}.ad-content{flex-direction:column;text-align:center}.ad-title{font-size:1.5rem}.ad-description{font-size:1rem}.ad-side-image{width:200px;height:200px}.ad-cta-button{width:100%;justify-content:center}}@media(max-width:480px){.ad-side-image{width:150px;height:150px}.ad-title{font-size:1.25rem}}.page-hero{background:var(--gradient-primary);padding:var(--spacing-2xl) 0;text-align:center;margin-bottom:var(--spacing-xl)}.page-title{font-size:3rem;font-weight:900;color:var(--color-white);margin-bottom:var(--spacing-md)}.page-subtitle{font-size:1.25rem;color:#ffffffe6;max-width:600px;margin:0 auto}.events-filters{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);flex-wrap:wrap;justify-content:center}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-xl)}.event-card{background:var(--color-white);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);transition:var(--transition);border:2px solid transparent}.event-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--color-primary)}.event-image{background:var(--gradient-primary);height:200px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.event-flyer{width:100%;height:100%;object-fit:cover}.event-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary)}.placeholder-icon,.event-emoji{font-size:5rem;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}.event-badge{position:absolute;top:var(--spacing-md);right:var(--spacing-md);padding:.5rem 1rem;border-radius:var(--radius-lg);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.event-badge.available{background:#fffffff2;color:var(--color-primary)}.event-badge.sold-out{background:#000000b3;color:var(--color-white)}.event-content{padding:var(--spacing-lg)}.event-category{display:inline-block;padding:.3rem .75rem;background:var(--color-primary-soft);color:var(--color-primary);border-radius:var(--radius-full);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--spacing-sm)}.event-title{font-size:1.5rem;font-weight:700;color:var(--color-dark);margin-bottom:var(--spacing-md)}.event-info{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.event-detail{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-gray);font-size:.95rem}.event-detail .icon{font-size:1.1rem}.event-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-md);border-top:1px solid var(--color-light)}.event-price{font-size:1.5rem;font-weight:800;color:var(--color-primary)}.btn-sm{padding:.625rem 1.25rem;font-size:.9rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}@media(max-width:768px){.page-title{font-size:2rem}.events-grid{grid-template-columns:1fr}}.event-detail-page{background:var(--color-light);min-height:100vh}.event-hero-banner{position:relative;width:100%;height:520px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#0a0a0a}.event-hero-backdrop{position:absolute;inset:-20px;background-size:cover;background-position:center;filter:blur(28px) brightness(.35) saturate(1.4)}.event-hero-flyer{position:relative;z-index:1;max-height:440px;width:auto;max-width:min(380px,55%);object-fit:contain;border-radius:10px;box-shadow:0 24px 64px #000000b3}.event-hero-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(to bottom,transparent 30%,rgba(0,0,0,.75) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:2rem 2.5rem;pointer-events:none}.event-hero-overlay .event-type-badge{display:inline-block;background:var(--color-primary);color:#fff;padding:.3rem .9rem;border-radius:20px;font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.75rem;width:fit-content;pointer-events:auto}.event-hero-overlay h1{font-size:clamp(1.6rem,3.5vw,2.5rem);font-weight:900;color:#fff;margin:0 0 .4rem;line-height:1.15;text-shadow:0 2px 10px rgba(0,0,0,.6)}.event-hero-overlay .event-availability{font-size:.88rem;font-weight:600;color:#ffffffd9}.event-hero-emoji-banner{display:flex;align-items:center;justify-content:center;font-size:6rem;width:100%;height:100%;background:var(--gradient-primary)}.event-detail-body{max-width:1200px;margin:0 auto;padding:2rem 1.5rem;display:grid;grid-template-columns:1fr 380px;gap:2rem;align-items:start}.event-meta-strip{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2rem}.meta-chip{display:flex;align-items:center;gap:.75rem;padding:.9rem 1.25rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014,0 0 0 1px #0000000a;flex:1 1 160px;min-width:0;transition:box-shadow .2s ease,transform .2s ease}.meta-chip:hover{box-shadow:0 4px 16px #0000001f,0 0 0 1px #0000000d;transform:translateY(-1px)}.meta-chip-icon{font-size:1.4rem;flex-shrink:0}.meta-chip-content{display:flex;flex-direction:column;min-width:0}.meta-chip-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-light);margin-bottom:.2rem}.meta-chip-value{font-size:.95rem;font-weight:600;color:var(--color-dark)}.event-section-card{background:#fff;border-radius:12px;padding:1.75rem;box-shadow:0 2px 12px #00000012;margin-bottom:1.5rem}.event-section-card h2{font-size:1.25rem;font-weight:700;color:var(--color-dark);margin:0 0 1rem}.event-section-card p{font-size:1rem;line-height:1.75;color:var(--color-gray);margin:0}.social-share{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.share-label{font-weight:600;color:var(--color-text-light);font-size:.9rem}.social-share-buttons{display:flex;gap:.5rem}.share-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s;text-decoration:none}.share-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.share-btn svg{width:18px;height:18px}.share-btn.facebook{background:#1877f2;color:#fff}.share-btn.twitter{background:#1da1f2;color:#fff}.share-btn.whatsapp{background:#25d366;color:#fff}.share-btn.copy{background:#6c757d;color:#fff}.info-box{background:linear-gradient(135deg,#00a5500d,#ffd70014);padding:1.25rem 1.5rem;border-radius:10px;border-left:4px solid var(--color-primary)}.info-box h4{font-size:1rem;font-weight:700;color:var(--color-dark);margin:0 0 .75rem}.info-box ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.info-box li{color:var(--color-gray);font-size:.9rem;padding-left:1rem;position:relative}.info-box li:before{content:"•";position:absolute;left:0;color:var(--color-primary);font-weight:900}.event-sidebar{position:sticky;top:calc(70px + 1.5rem)}.booking-card{background:#fff;padding:1.75rem;border-radius:16px;box-shadow:0 8px 32px #0000001f}.booking-card h3{font-size:1.25rem;font-weight:700;color:var(--color-dark);margin:0 0 1.25rem;padding-bottom:1rem;border-bottom:2px solid var(--color-light)}.price-types-section,.packs-section{margin-bottom:1.25rem}.section-label{display:block;font-weight:600;color:#555;margin-bottom:.75rem;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em}.price-types-grid,.packs-grid{display:flex;flex-direction:column;gap:.6rem}.price-type-option,.pack-option{padding:.9rem 1rem;border:2px solid var(--color-border);border-radius:10px;cursor:pointer;transition:all .2s;background:#fff}.price-type-option:hover,.pack-option:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #00a55026}.price-type-option.selected,.pack-option.selected{border-color:var(--color-primary);background:#00a5500f}.price-type-header{display:flex;justify-content:space-between;align-items:center}.price-type-name{font-weight:600;color:#333;font-size:1rem}.price-type-price{font-weight:700;color:var(--color-primary);font-size:1.1rem}.price-type-description{font-size:.85rem;color:#666;margin:.4rem 0 0;line-height:1.4}.price-type-availability,.pack-availability{margin-top:.5rem;font-size:.82rem;font-weight:600}.price-type-availability .available,.pack-availability .available{color:#10b981}.price-type-availability .low-stock,.pack-availability .low-stock{color:#f97316;animation:pulse 2s infinite}.price-type-availability .sold-out,.pack-availability .sold-out{color:#ef4444;text-transform:uppercase}.pack-option{position:relative;padding:1rem}.pack-badge{position:absolute;top:-8px;right:12px;background:#f97316;color:#fff;padding:.2rem .65rem;border-radius:10px;font-size:.75rem;font-weight:700}.pack-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.pack-header h4{margin:0;color:#333;font-size:1rem;font-weight:600}.pack-price{font-weight:700;color:var(--color-primary);font-size:1.15rem}.pack-description{font-size:.85rem;color:#666;margin:0 0 .75rem;line-height:1.4}.pack-includes{background:var(--color-light);padding:.6rem .75rem;border-radius:6px}.pack-item{font-size:.88rem;color:#333;padding:.2rem 0}.pack-goods{margin-top:.4rem;padding-top:.4rem;border-top:1px dashed #ddd}.pack-availability{text-align:right;margin-top:.6rem}.price-display{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:2px solid var(--color-light);margin-bottom:1.25rem}.price-label{color:var(--color-gray);font-weight:500}.price-value{font-size:1.75rem;font-weight:900;color:var(--color-primary)}.quantity-selector{margin-bottom:1.25rem}.quantity-selector label{display:block;font-weight:600;color:var(--color-dark);margin-bottom:.5rem;font-size:.9rem}.quantity-controls{display:flex;align-items:center;justify-content:center;gap:.75rem}.quantity-controls button{width:42px;height:42px;border:2px solid var(--color-primary);background:#fff;color:var(--color-primary);border-radius:8px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;flex-shrink:0}.quantity-controls button:hover:not(:disabled){background:var(--color-primary);color:#fff}.quantity-controls button:disabled{opacity:.3;cursor:not-allowed}.quantity-controls span{font-size:1.2rem;font-weight:700;color:var(--color-dark);min-width:40px;text-align:center}.pack-quantity-info{background:var(--color-light);padding:1rem;border-radius:8px;margin-bottom:1rem}.pack-quantity-info .info-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.92rem}.pack-quantity-info .info-item span{color:#666}.pack-quantity-info .info-item strong{color:var(--color-primary);font-size:1.05rem}.pack-quantity-info .quantity-selector{margin-bottom:0}.total-display{display:flex;justify-content:space-between;align-items:center;padding:.9rem 1rem;background:var(--color-light);border-radius:8px;margin-bottom:1rem}.total-display span:first-child{font-weight:600;color:var(--color-dark)}.total-value{font-size:1.6rem;font-weight:900;color:var(--color-primary)}.auth-message{text-align:center;margin-top:.75rem;color:var(--color-gray);font-size:.88rem}.auth-message a{color:var(--color-primary);font-weight:600;text-decoration:none}.auth-message a:hover{text-decoration:underline}@media(max-width:968px){.event-hero-banner{height:280px}.event-hero-overlay{padding:1.25rem}.event-detail-body{grid-template-columns:1fr;padding:1rem;gap:1.25rem}.event-sidebar{position:static}.event-meta-strip{gap:.6rem}.meta-chip{flex:1 1 130px}}@media(max-width:480px){.event-hero-banner{height:220px}.event-hero-overlay h1{font-size:1.5rem}.meta-chip{flex:1 1 100%}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.event-checkout-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:2rem 1rem}.event-checkout-content{max-width:1200px;margin:0 auto}.checkout-header{margin-bottom:2rem}.back-button{background:#fff;border:1px solid #e2e8f0;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;color:#64748b;transition:all .2s;margin-bottom:1rem}.back-button:hover{background:#f8fafc;border-color:#cbd5e1;transform:translate(-2px)}.checkout-header h1{font-size:2.5rem;color:#1e293b;margin:0}.checkout-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.order-summary{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 6px #00000012}.order-summary h2{font-size:1.5rem;color:#1e293b;margin:0 0 1.5rem}.event-card{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border-radius:12px;padding:1.5rem;color:#fff;margin-bottom:1.5rem;display:flex;gap:1.5rem;align-items:flex-start}.checkout-event-card{display:flex!important;flex-direction:row!important;gap:1.5rem!important;align-items:flex-start!important}.event-image{width:100%;height:200px;object-fit:cover;border-radius:8px;margin-bottom:1rem}.event-info{flex:1}.event-info h3{font-size:1.5rem;margin:0 0 .5rem;color:#fff}.event-date,.event-location{margin:.5rem 0;font-size:.95rem;opacity:.95}.event-flyer-container{width:180px;flex-shrink:0}.event-flyer-image{width:100%;height:auto;border-radius:8px;object-fit:cover;box-shadow:0 2px 8px #00000026}.price-breakdown{border-top:1px solid #e2e8f0;padding-top:1.5rem;margin-top:1.5rem}.price-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;font-size:1rem;color:#475569}.price-row.total{border-top:2px solid #e2e8f0;margin-top:.5rem;padding-top:1rem;font-weight:600;font-size:1.25rem;color:#1e293b}.total-amount{color:var(--color-primary);font-size:1.5rem}.summary-footer{background:#f8fafc;border-radius:8px;padding:1.5rem;margin-top:1.5rem}.summary-footer p{margin:.5rem 0;color:#475569;font-size:.95rem}.payment-section{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 6px #00000012;position:sticky;top:2rem}.payment-section h2{font-size:1.5rem;color:#1e293b;margin:0 0 .5rem}.payment-description{color:#64748b;font-size:.95rem;margin-bottom:2rem}.event-checkout-form{margin-top:1.5rem}.card-element-container{margin-bottom:1.5rem}.card-label{display:block;font-weight:600;color:#1e293b;margin-bottom:.5rem;font-size:.95rem}.card-element{padding:1rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;transition:border-color .2s}.card-element:focus{border-color:var(--color-primary);outline:none}.error-message{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.error-icon{font-size:1.2rem}.checkout-button{width:100%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}.checkout-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #667eea4d}.checkout-button:disabled{opacity:.6;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.secure-payment-badge{text-align:center;color:#64748b;font-size:.9rem;margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.lock-icon{font-size:1.2rem}.payment-info{margin-top:2rem;padding-top:2rem;border-top:1px solid #e2e8f0}.secure-text{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.9rem}.shield-icon{font-size:1.2rem}.loading{text-align:center;padding:4rem 2rem;font-size:1.2rem;color:#64748b}@media(max-width:968px){.checkout-grid{grid-template-columns:1fr}.payment-section{position:static}.checkout-header h1{font-size:2rem}.event-card{padding:1rem}.event-info h3{font-size:1.2rem}}@media(max-width:640px){.event-checkout-container{padding:1rem .5rem}.order-summary,.payment-section{padding:1.5rem}.checkout-header h1{font-size:1.75rem}.total-amount{font-size:1.25rem}}.establishments-page{width:100%}.establishments-filters{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap;justify-content:center}.filter-btn{padding:.5rem 1.125rem;border:1.5px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-text-secondary);border-radius:var(--radius-full);font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition)}.filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-soft)}.filter-btn.active{background:var(--gradient-primary);color:#fff;border-color:transparent;box-shadow:var(--shadow-primary)}.establishments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;align-items:stretch;width:100%}.establishment-card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);overflow:hidden;transition:var(--transition);display:flex;flex-direction:column;height:100%}.establishment-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-border-strong)}.establishment-header{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--color-surface-alt);border-bottom:1px solid var(--color-border)}.establishment-logo{width:64px;height:64px;object-fit:contain;border-radius:var(--radius-md);background:var(--color-surface);padding:.375rem;border:1px solid var(--color-border);flex-shrink:0}.establishment-logo-placeholder{width:64px;height:64px;border-radius:var(--radius-md);background:var(--color-primary-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}.establishment-emoji{font-size:2rem}.establishment-header-info{flex:1;display:flex;flex-direction:column;gap:.375rem;min-width:0}.establishment-name{font-size:1rem;font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:.2rem .6rem;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;width:fit-content}.status-open{background:#10b9811f;color:#059669}.status-closed{background:#ef44441a;color:#dc2626}.establishment-content{padding:1.125rem 1.25rem 1.25rem;display:flex;flex-direction:column;flex:1;gap:.75rem}.establishment-meta{display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}.meta-left{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.type-tag{display:inline-block;padding:.25rem .625rem;background:var(--color-primary-soft);color:var(--color-primary);border-radius:var(--radius-full);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.convention-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .75rem;background:#d1fae5;color:#065f46;border-radius:var(--radius-full);font-size:.78rem;font-weight:700;margin-top:.5rem}.cuisine-tag{display:inline-block;padding:.25rem .625rem;background:var(--color-orange-soft);color:var(--color-orange);border-radius:var(--radius-full);font-weight:600;font-size:.72rem}.rating{display:flex;align-items:center;gap:.25rem}.star{font-size:.9rem}.rating-value{font-weight:700;color:var(--color-text);font-size:.875rem}.review-count{font-size:.78rem;color:var(--color-text-light)}.establishment-description{font-size:.82rem;color:var(--color-text-secondary);line-height:1.55;flex:1;margin:0}.establishment-schedule{background:var(--color-primary-soft);border-radius:var(--radius-md);padding:.75rem}.schedule-title{font-size:.75rem;font-weight:700;color:var(--color-primary);margin-bottom:.375rem;text-transform:uppercase;letter-spacing:.06em}.schedule-row{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.8rem;border-bottom:1px solid rgba(124,58,237,.1)}.schedule-row:last-child{border-bottom:none}.schedule-day{font-weight:600;color:var(--color-text)}.schedule-hours{color:var(--color-text-secondary)}.establishment-location,.establishment-contact{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--color-text-secondary)}.location-icon,.contact-icon{font-size:1rem}.establishment-image{width:100%;height:180px;overflow:hidden;background:var(--color-surface-alt)}.establishment-image img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}.establishment-card:hover .establishment-image img{transform:scale(1.04)}.image-overlay{position:relative;display:flex;justify-content:flex-end;padding:.75rem;margin-top:-180px;z-index:10;pointer-events:none}.image-overlay .establishment-type{background:#7c3aede6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:.3rem .75rem;border-radius:var(--radius-full);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}.establishment-header-fallback{background:var(--gradient-primary);padding:1.5rem;display:flex;justify-content:space-between;align-items:center;min-height:120px;position:relative}.establishment-header-fallback .establishment-emoji{font-size:3rem;opacity:.7}.establishment-header-fallback .establishment-type{position:absolute;top:.75rem;right:.75rem;background:#ffffffe6;color:var(--color-primary);padding:.25rem .625rem;border-radius:var(--radius-full);font-weight:700;font-size:.72rem;text-transform:uppercase}.spinner{width:40px;height:40px;border:3px solid var(--color-surface-alt);border-top:3px solid var(--color-primary);border-radius:50%;animation:spin .9s linear infinite}.empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-md);background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border)}.empty-state h3{font-size:1.25rem;font-weight:700;color:var(--color-text);margin-bottom:.5rem}.empty-state p{color:var(--color-text-secondary);margin-bottom:1.25rem;font-size:.9rem}@media(max-width:768px){.establishments-grid{grid-template-columns:1fr}}@media(max-width:480px){.establishments-filters{justify-content:flex-start}}.establishment-detail-page{padding:var(--spacing-xl) 0}.establishment-hero{background:var(--gradient-primary);padding:2.5rem;border-radius:var(--radius-2xl);margin-bottom:2rem;box-shadow:var(--shadow-primary);color:#fff}.hero-content{display:flex;flex-direction:column;gap:1.25rem}.hero-header{display:flex;align-items:center;gap:1.25rem;flex-wrap:nowrap}.establishment-hero-logo{width:88px;height:88px;object-fit:contain;border-radius:var(--radius-xl);background:#fffffff2;padding:.625rem;border:2px solid rgba(255,255,255,.3);flex-shrink:0}.establishment-hero-emoji{font-size:3rem;opacity:.85;flex-shrink:0}.hero-header h1{font-size:1.875rem;font-weight:800;color:#fff!important;margin:0;letter-spacing:-.04em;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rating-display{padding:.5rem .875rem;background:#fffffff2;border-radius:var(--radius-lg);font-weight:700;font-size:1rem;display:flex;align-items:center;gap:.375rem;color:var(--color-text);flex-shrink:0}.establishment-details{display:flex;gap:1.5rem;flex-wrap:wrap}.establishment-detail-item{display:flex;align-items:center;gap:.5rem;color:#ffffffe6;font-size:.9rem}.establishment-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag-badge{padding:.3rem .75rem;background:#ffffff2e;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:var(--radius-full);font-weight:600;font-size:.8rem;text-transform:capitalize}.detail-item{display:flex;align-items:center;gap:.625rem;color:#ffffffe6!important;font-size:.9rem;padding:.25rem 0}.hero-actions{display:flex;align-items:center;gap:.875rem;flex-wrap:wrap}.favorite-btn{background:#ffffff26;border:1.5px solid rgba(255,255,255,.35);color:#fff;padding:.5rem 1rem;border-radius:var(--radius-full);cursor:pointer;font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:.5rem;transition:var(--transition);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.favorite-btn:hover{background:#ffffff40}.favorite-btn.favorited{background:#ef4444b3;border-color:#ffffff80}.establishment-detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem;align-items:start}.establishment-description,.establishment-schedule-section,.click-collect-section,.amenities-section,.image-gallery-section,.reviews-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:1.75rem;margin-bottom:1.5rem}.establishment-description h2,.establishment-schedule-section h2,.amenities-section h2,.image-gallery-section h2{font-size:1.25rem;font-weight:700;color:var(--color-text);margin-bottom:1rem;letter-spacing:-.03em;display:flex;align-items:center;gap:.5rem}.establishment-description p{font-size:.95rem;line-height:1.7;color:var(--color-text-secondary);margin:0}.schedule-list{display:grid;gap:.375rem}.schedule-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--color-surface-alt);border-radius:var(--radius-md);font-size:.9rem;transition:var(--transition)}.schedule-row:hover{background:var(--color-primary-soft);transform:translate(4px)}.schedule-day{font-weight:700;color:var(--color-text);min-width:90px}.schedule-hours{color:var(--color-text-secondary);font-weight:500}.click-collect-section{border:2px solid var(--color-primary);background:var(--color-primary-soft);text-align:center}.click-collect-btn{width:100%;padding:1rem 1.5rem;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:.625rem;margin-bottom:.75rem}.click-collect-info{color:var(--color-text-secondary);font-size:.875rem;margin:0}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.875rem}.gallery-image{aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);transition:var(--transition);cursor:pointer}.gallery-image:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.gallery-image img{width:100%;height:100%;object-fit:cover}.amenities-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.amenity-item{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;background:var(--color-surface-alt);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text-secondary)}.amenity-item span:first-child{color:var(--color-primary);font-weight:900}.reservation-card{background:var(--color-surface);border:1px solid var(--color-border);padding:1.75rem;border-radius:var(--radius-xl);margin-bottom:1.25rem;box-shadow:var(--shadow-md)}.reservation-card h3{font-size:1.2rem;font-weight:700;color:var(--color-text);margin-bottom:1.25rem;letter-spacing:-.03em}.reservation-form{display:flex;flex-direction:column;gap:.875rem}.reservation-form .form-group{display:flex;flex-direction:column;gap:.375rem}.reservation-form .form-group label{font-size:.82rem;font-weight:600;color:var(--color-text)}.reservation-form .form-group input,.reservation-form .form-group select,.reservation-form textarea{padding:.75rem 1rem;border:1.5px solid var(--color-border-strong);border-radius:var(--radius-lg);font-size:.9rem;font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:var(--transition);outline:none}.reservation-form .form-group input:focus,.reservation-form .form-group select:focus,.reservation-form textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #7c3aed1a}.reservation-form textarea{resize:vertical;min-height:80px}.reservation-notice{background:var(--color-primary-soft);border-left:3px solid var(--color-primary);padding:.75rem 1rem;border-radius:var(--radius-md);margin-top:.25rem}.reservation-notice p{margin:0;color:var(--color-text-secondary);font-size:.82rem;line-height:1.55}.time-slots-hint{display:block;margin-top:.375rem;font-size:.8rem;color:var(--color-primary);font-style:italic}.auth-required{display:flex;flex-direction:column;gap:.875rem;text-align:center}.auth-required p{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:.5rem}.reservations-disabled{background:#f9731614;border:1.5px solid rgba(249,115,22,.25);border-radius:var(--radius-lg);padding:1.25rem;text-align:center;color:#92400e}.info-box{background:var(--color-primary-soft);border:1.5px solid rgba(124,58,237,.2);border-radius:var(--radius-lg);padding:1.25rem;margin-top:.625rem}.info-box h4{font-size:.95rem;font-weight:700;color:var(--color-text);margin-bottom:.75rem}.info-box ul{list-style:none;padding:0;margin:0}.info-box li{padding:.5rem 0 .5rem 1rem;color:var(--color-text-secondary);font-size:.875rem;line-height:1.55;position:relative}.info-box li:before{content:"•";color:var(--color-primary);font-weight:900;position:absolute;left:0}.reviews-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.reviews-header h2{font-size:1.25rem;font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.03em}.review-form{background:var(--color-surface-alt);padding:1.25rem;border-radius:var(--radius-lg);margin-bottom:1.5rem}.review-form label{display:block;font-weight:600;font-size:.82rem;color:var(--color-text);margin-bottom:.375rem}.star-rating{display:flex;gap:.25rem}.star-btn{background:none;border:none;font-size:1.75rem;cursor:pointer;padding:0;transition:transform .15s}.star-btn:hover{transform:scale(1.2)}.reviews-list{display:flex;flex-direction:column;gap:1.125rem}.review-card{background:var(--color-surface-alt);padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.review-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.875rem}.review-user{display:flex;gap:.75rem;align-items:center}.user-avatar{width:38px;height:38px;border-radius:50%;background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}.user-name{font-weight:600;color:var(--color-text);font-size:.9rem}.review-date{font-size:.78rem;color:var(--color-text-light);margin-top:.2rem}.review-rating{font-size:1rem}.review-title{font-size:.95rem;font-weight:600;color:var(--color-text);margin-bottom:.375rem}.review-comment{font-size:.875rem;color:var(--color-text-secondary);line-height:1.6;margin:0}.no-reviews{text-align:center;color:var(--color-text-light);padding:1.5rem;font-style:italic;font-size:.9rem}.review-count{font-size:.875rem;opacity:.8}@media(max-width:968px){.establishment-detail-grid{grid-template-columns:1fr}.reservation-card{position:static}.amenities-grid{grid-template-columns:1fr}.hero-header h1{font-size:1.5rem}}.convention-badge{display:inline-flex;align-items:center;padding:.3rem .75rem;background:#d1fae5;color:#065f46;border-radius:9999px;font-size:.82rem;font-weight:700}@media(max-width:640px){.establishment-hero{padding:1.5rem}.hero-header{flex-wrap:wrap}}.menu-page{width:100%;min-height:100vh;background-color:var(--color-light)}.menu-header{background:var(--gradient-primary);color:var(--color-white);padding:var(--spacing-xl) 0;margin-bottom:var(--spacing-lg)}.back-button{background:#fff3;color:var(--color-white);border:none;padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.95rem;font-weight:600;cursor:pointer;transition:var(--transition);margin-bottom:var(--spacing-md)}.back-button:hover{background:#ffffff4d}.establishment-info h1{font-size:2.5rem;font-weight:800;margin-bottom:var(--spacing-sm)}.status-badge{display:inline-block;padding:.5rem 1rem;border-radius:var(--radius-full);font-size:.95rem;font-weight:600;margin-bottom:var(--spacing-sm);background:#fff3}.status-open{background:#10b98133;color:#10b981;border:2px solid rgba(16,185,129,.3)}.status-closed{background:#ef444433;color:#ef4444;border:2px solid rgba(239,68,68,.3)}.closed-notice{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#fef2f2;border:2px solid #fecaca;border-radius:var(--radius-md);margin:1rem 0}.closed-notice .notice-icon{font-size:2rem}.closed-notice strong{display:block;color:#dc2626;margin-bottom:.25rem}.closed-notice p{margin:0;color:#991b1b;font-size:.9rem}.establishment-meta{display:flex;gap:var(--spacing-md);flex-wrap:wrap;margin-bottom:var(--spacing-sm);opacity:.95}.establishment-meta span{font-size:1rem}.establishment-description{font-size:1.1rem;opacity:.9;max-width:800px}.category-filter{background:var(--color-white);border-bottom:2px solid var(--color-light);padding:var(--spacing-md) 0;margin-bottom:var(--spacing-xl);position:sticky;top:70px;z-index:10;box-shadow:var(--shadow-sm)}.category-tabs{display:flex;gap:var(--spacing-sm);overflow-x:auto;scrollbar-width:thin;padding-bottom:.5rem}.category-tabs::-webkit-scrollbar{height:4px}.category-tabs::-webkit-scrollbar-track{background:var(--color-light)}.category-tabs::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:2px}.category-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:2px solid var(--color-light);background:var(--color-white);border-radius:var(--radius-lg);font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap;color:var(--color-dark)}.category-tab:hover{border-color:var(--color-primary);background:#7c3aed0d}.category-tab.active{background:var(--gradient-primary);color:var(--color-white);border-color:var(--color-primary)}.category-icon{font-size:1.25rem}.menu-content{padding-bottom:100px}.menu-category-section{margin-bottom:var(--spacing-2xl)}.category-title{font-size:1.75rem;font-weight:800;color:var(--color-dark);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm)}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.product-card{background:var(--color-white);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);transition:var(--transition);display:flex;flex-direction:column}.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.product-image{width:100%;height:200px;position:relative;overflow:hidden;background:linear-gradient(135deg,gold,#ffc107)}.product-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem}.unavailable-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:#ef4444f2;color:#fff;padding:.4rem .8rem;border-radius:var(--radius-lg);font-size:.75rem;font-weight:700;text-transform:uppercase}.product-info{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1}.product-name{font-size:1.25rem;font-weight:700;color:var(--color-dark);margin:0}.product-description{font-size:.9rem;color:var(--color-gray);line-height:1.5;margin:0}.product-allergens{font-size:.8rem;color:#d97706;background:#d977061a;padding:.35rem .6rem;border-radius:var(--radius-md);margin:0}.product-prep-time{font-size:.85rem;color:var(--color-gray);margin:0}.product-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:var(--spacing-sm);border-top:1px solid var(--color-light)}.product-price{font-size:1.5rem;font-weight:800;color:var(--color-primary)}.add-to-cart-btn{background:var(--gradient-primary);color:var(--color-white);border:none;padding:.75rem 1.5rem;border-radius:var(--radius-lg);font-weight:700;cursor:pointer;transition:var(--transition);font-size:.95rem}.add-to-cart-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.add-to-cart-btn:disabled{background:var(--color-gray-light);cursor:not-allowed;opacity:.6}.empty-menu{text-align:center;padding:var(--spacing-2xl);color:var(--color-gray);font-size:1.1rem}.floating-cart-button{position:fixed;bottom:var(--spacing-xl);right:var(--spacing-xl);background:var(--gradient-primary);color:var(--color-white);border:none;padding:1rem 1.5rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);cursor:pointer;display:flex;align-items:center;gap:var(--spacing-sm);font-weight:700;font-size:1rem;z-index:100;transition:var(--transition)}.floating-cart-button:hover{transform:translateY(-4px);box-shadow:0 20px 30px #7c3aed4d}.floating-cart-button.pulse{animation:pulse-animation .6s ease-out}@keyframes pulse-animation{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.cart-icon{font-size:1.5rem}.cart-count{background:var(--color-white);color:var(--color-primary);padding:.25rem .6rem;border-radius:50%;font-size:.9rem;font-weight:800;min-width:2rem;text-align:center}.cart-text{font-size:1rem}.loading,.error{text-align:center;padding:var(--spacing-2xl);font-size:1.1rem;color:var(--color-gray)}.error{color:#dc2626}@media(max-width:768px){.menu-header{padding:var(--spacing-lg) 0}.establishment-info h1{font-size:2rem}.establishment-meta{flex-direction:column;gap:var(--spacing-xs)}.category-filter{top:60px}.products-grid{grid-template-columns:1fr}.floating-cart-button{bottom:var(--spacing-md);right:var(--spacing-md);left:var(--spacing-md);justify-content:center}.cart-text{flex:1;text-align:center}}@media(max-width:480px){.establishment-info h1{font-size:1.5rem}.category-tab{padding:.6rem 1rem;font-size:.9rem}.product-price{font-size:1.25rem}.add-to-cart-btn{padding:.6rem 1rem;font-size:.85rem}}.checkout-page{width:100%;min-height:calc(100vh - 70px);background-color:var(--color-light);padding:var(--spacing-xl) 0}.checkout-header{margin-bottom:var(--spacing-xl)}.checkout-header h1{font-size:2.5rem;font-weight:800;color:var(--color-dark);margin:var(--spacing-md) 0}.establishment-name{font-size:1.1rem;color:var(--color-gray);font-weight:600}.checkout-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:var(--spacing-xl)}.order-summary-section,.pickup-details-section{background:var(--color-white);padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.order-summary-section h2,.pickup-details-section h2{font-size:1.5rem;font-weight:700;color:#1a1a1a!important;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-light)}.cart-items{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.checkout-page .checkout-cart-item{display:grid!important;grid-template-columns:1fr auto auto!important;gap:var(--spacing-md)!important;align-items:center!important;padding:var(--spacing-md)!important;border:2px solid var(--color-light)!important;border-radius:var(--radius-lg)!important;transition:var(--transition)!important;background:#fff!important}.checkout-page .checkout-cart-item:hover{border-color:var(--color-primary)!important;background:#7c3aed05!important}.checkout-page .checkout-cart-item *{color:inherit!important}.checkout-page .checkout-cart-item .item-info h3{font-size:1.1rem!important;font-weight:700!important;color:#1a1a1a!important;margin-bottom:.25rem!important}.checkout-page .checkout-cart-item .item-description{font-size:.85rem!important;color:#666!important;margin:.25rem 0!important}.checkout-page .checkout-cart-item .item-price{font-size:.9rem!important;color:#00a550!important;font-weight:600!important;margin:.25rem 0 0!important}.checkout-page .checkout-cart-item .item-controls{display:flex!important;align-items:center!important;gap:var(--spacing-sm)!important}.checkout-page .checkout-cart-item .quantity-controls{display:flex!important;align-items:center!important;gap:.5rem!important;background:var(--color-light)!important;padding:.5rem!important;border-radius:var(--radius-md)!important}.checkout-page .checkout-cart-item .qty-btn{background:var(--color-white)!important;border:none!important;width:2rem!important;height:2rem!important;border-radius:var(--radius-md)!important;font-size:1.2rem!important;font-weight:700!important;cursor:pointer!important;transition:var(--transition)!important;color:var(--color-primary)!important}.checkout-page .checkout-cart-item .qty-btn:hover{background:var(--color-primary)!important;color:var(--color-white)!important}.checkout-page .checkout-cart-item .quantity{font-weight:700!important;min-width:2rem!important;text-align:center!important;color:#1a1a1a!important}.checkout-page .checkout-cart-item .remove-btn{background:transparent!important;border:none!important;font-size:1.5rem!important;cursor:pointer!important;opacity:.6!important;transition:var(--transition)!important;padding:.25rem!important}.checkout-page .checkout-cart-item .remove-btn:hover{opacity:1!important;transform:scale(1.1)!important}.checkout-page .checkout-cart-item .item-subtotal{font-size:1.25rem!important;font-weight:800!important;color:#1a1a1a!important}.order-totals{border-top:2px solid var(--color-light);padding-top:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.total-row{display:flex;justify-content:space-between;align-items:center;font-size:1rem;color:#1a1a1a!important}.total-row span{color:#1a1a1a!important}.total-final{font-size:1.5rem;font-weight:800;padding-top:var(--spacing-md);border-top:2px solid var(--color-primary);margin-top:var(--spacing-sm);color:#00a550!important}.total-final span{color:#00a550!important}.pickup-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.customer-info{background:var(--color-light);padding:var(--spacing-md);border-radius:var(--radius-lg)}.customer-info h3{font-size:1.1rem;font-weight:700;color:#1a1a1a!important;margin-bottom:var(--spacing-sm)}.customer-info p{margin:.5rem 0;color:#1a1a1a!important}.customer-info strong{color:#00a550!important;margin-right:.5rem}.btn-large{width:100%;padding:1.25rem;font-size:1.1rem}.payment-notice{text-align:center;color:var(--color-gray);font-size:.9rem;margin:0}.auth-required,.empty-cart{text-align:center;padding:var(--spacing-2xl);background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.auth-required h2,.empty-cart h2{font-size:2rem;font-weight:800;color:var(--color-dark);margin-bottom:var(--spacing-md)}.auth-required p,.empty-cart p{color:var(--color-gray);font-size:1.1rem;margin-bottom:var(--spacing-xl)}.card-element-wrapper{padding:.75rem 1rem;border:1.5px solid var(--color-border-strong);border-radius:var(--radius-lg);background:var(--color-surface);transition:var(--transition)}.card-element-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft)}.payment-step-actions{display:flex;gap:var(--spacing-sm)}.payment-step-actions .btn{flex:1;justify-content:center}@media(max-width:1024px){.checkout-grid{grid-template-columns:1fr}.pickup-details-section{order:2}.order-summary-section{order:1}}@media(max-width:768px){.checkout-header h1{font-size:2rem}.cart-item{grid-template-columns:1fr;gap:var(--spacing-sm)}.item-controls{justify-content:space-between}.item-subtotal{text-align:right}.order-summary-section,.pickup-details-section{padding:var(--spacing-lg)}}@media(max-width:480px){.checkout-page{padding:var(--spacing-md) 0}.checkout-header h1{font-size:1.5rem}.order-summary-section h2,.pickup-details-section h2{font-size:1.25rem}.item-info h3{font-size:1rem}.total-final{font-size:1.25rem}}.about-content{max-width:900px;margin:0 auto}.about-section{margin-bottom:var(--spacing-2xl)}.about-section h2{font-size:2rem;font-weight:900;color:var(--color-dark);margin-bottom:var(--spacing-md);text-align:center}.about-section p{font-size:1.15rem;color:var(--color-gray);line-height:1.8;text-align:center}.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg);margin:var(--spacing-2xl) 0}.value-card{background:var(--color-white);padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);text-align:center;transition:var(--transition);border:2px solid transparent}.value-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--color-primary)}.value-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-md)}.value-card h3{font-size:1.25rem;font-weight:700;color:var(--color-dark);margin-bottom:var(--spacing-sm)}.value-card p{font-size:1rem;color:var(--color-gray);line-height:1.6}.features-list{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-top:var(--spacing-xl)}.feature-item{display:flex;gap:var(--spacing-md);align-items:flex-start;background:var(--color-white);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition)}.feature-item:hover{box-shadow:var(--shadow-md);transform:translate(8px)}.feature-check{font-size:1.5rem;flex-shrink:0}.feature-item h4{font-size:1.15rem;font-weight:700;color:var(--color-dark);margin-bottom:var(--spacing-xs)}.feature-item p{font-size:1rem;color:var(--color-gray);line-height:1.6;text-align:left}.cta-box{background:var(--gradient-primary);padding:var(--spacing-2xl);border-radius:var(--radius-xl);text-align:center;margin-top:var(--spacing-2xl)}.cta-box h2{font-size:2rem;font-weight:900;color:var(--color-white);margin-bottom:var(--spacing-md)}.cta-box p{font-size:1.15rem;color:#ffffffe6;margin-bottom:var(--spacing-xl)}@media(max-width:768px){.values-grid{grid-template-columns:1fr}.about-section h2,.cta-box h2{font-size:1.75rem}}.auth-page{min-height:100vh;background:var(--color-bg);display:flex;align-items:center;justify-content:center;padding:2rem 1rem;position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;width:600px;height:600px;top:-200px;right:-200px;border-radius:50%;background:#7c3aed12;filter:blur(80px);pointer-events:none}.auth-page:after{content:"";position:absolute;width:400px;height:400px;bottom:-150px;left:-100px;border-radius:50%;background:#f973160f;filter:blur(80px);pointer-events:none}.auth-container{width:100%;max-width:480px;position:relative;z-index:1}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:2.5rem;box-shadow:0 4px 40px #1a162514}.auth-header{margin-bottom:2rem}.auth-logo{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;text-decoration:none}.auth-logo-mark{width:36px;height:36px;background:var(--gradient-primary);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;font-weight:800}.auth-logo-text{font-size:1.25rem;font-weight:800;color:var(--color-text);letter-spacing:-.04em}.auth-header h1{font-size:1.75rem;font-weight:800;color:var(--color-text);letter-spacing:-.04em;margin:0 0 .375rem}.auth-header p{font-size:.9rem;color:var(--color-text-secondary);margin:0}.back-button{display:inline-flex;align-items:center;gap:.375rem;background:none;border:none;cursor:pointer;padding:0;font-size:.875rem;color:var(--color-text-secondary);margin-bottom:1.25rem;transition:var(--transition)}.back-button:hover{color:var(--color-primary)}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.875rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.82rem;font-weight:600;color:var(--color-text)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;border:1.5px solid var(--color-border-strong);border-radius:var(--radius-lg);background:var(--color-surface);color:var(--color-text);font-size:.9rem;font-family:inherit;transition:var(--transition);outline:none;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #7c3aed1a}.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%235A5468' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.form-group textarea{resize:vertical;min-height:90px}.form-divider{display:flex;align-items:center;gap:.75rem;margin:.5rem 0}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.form-divider span{font-size:.78rem;font-weight:600;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.alert{padding:.75rem 1rem;border-radius:var(--radius-lg);font-size:.875rem;font-weight:500}.alert-error{background:#ef444414;border:1px solid rgba(239,68,68,.2);color:#b91c1c}.alert-success{background:#10b98114;border:1px solid rgba(16,185,129,.2);color:#065f46}.auth-footer{margin-top:1.5rem;text-align:center}.auth-footer p{font-size:.875rem;color:var(--color-text-secondary);margin:0}.auth-footer a{color:var(--color-primary);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.role-selection{display:grid;grid-template-columns:1fr 1fr;gap:.875rem;margin-bottom:1.5rem}.role-card{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;padding:1.375rem 1.25rem;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;text-align:left;transition:var(--transition)}.role-card:hover{border-color:var(--color-primary);background:var(--color-primary-soft);transform:translateY(-2px);box-shadow:var(--shadow-primary)}.role-icon{font-size:2rem;margin-bottom:.25rem}.role-card h3{font-size:.95rem;font-weight:700;color:var(--color-text);margin:0;letter-spacing:-.02em}.role-card p{font-size:.78rem;color:var(--color-text-secondary);margin:0;line-height:1.5}.role-features{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem}.role-features span{font-size:.75rem;color:var(--color-text-secondary)}@media(max-width:520px){.auth-card{padding:1.75rem 1.25rem}.form-row,.role-selection{grid-template-columns:1fr}}.dashboard-page{padding:var(--spacing-xl) 0}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.dashboard-header h1{font-size:2.5rem;font-weight:900;color:var(--color-dark);margin-bottom:var(--spacing-xs)}.dashboard-header p{font-size:1.15rem;color:var(--color-gray)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-card{background:var(--color-white);padding:var(--spacing-lg);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:var(--spacing-md);transition:var(--transition);border:2px solid transparent}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--color-primary)}.stat-icon{font-size:3rem;width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-lg);flex-shrink:0}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:2rem;font-weight:900;color:var(--color-dark)}.stat-label{color:var(--color-gray);font-size:.95rem;font-weight:500}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.dashboard-card{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden}.card-header{padding:var(--spacing-lg);border-bottom:2px solid var(--color-light);display:flex;justify-content:space-between;align-items:center}.card-header h2{font-size:1.5rem;font-weight:700;color:var(--color-dark)}.view-all{color:var(--color-primary);font-weight:600;text-decoration:none;transition:var(--transition)}.view-all:hover{color:var(--color-primary-dark)}.card-content{padding:var(--spacing-lg)}.empty-state{text-align:center;color:var(--color-gray);padding:var(--spacing-xl)}.items-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.list-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-light);border-radius:var(--radius-lg);transition:var(--transition)}.list-item:hover{background:var(--color-primary-soft)}.item-content{flex:1}.item-content h4{font-size:1.05rem;font-weight:600;color:var(--color-dark);margin-bottom:.25rem}.item-content p{font-size:.9rem;color:var(--color-gray)}.status-badge{padding:.375rem .75rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-pending{background:#ffc10733;color:#f59e0b}.status-confirmed{background:#7c3aed33;color:var(--color-primary)}.status-completed{background:#10b98133;color:#10b981}.status-cancelled{background:#ef444433;color:#dc2626}.quick-actions{margin-top:var(--spacing-2xl)}.quick-actions h2{font-size:2rem;font-weight:900;color:var(--color-dark);margin-bottom:var(--spacing-lg);text-align:center}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.action-card{background:var(--color-white);padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);text-align:center;transition:var(--transition);text-decoration:none;border:2px solid transparent}.action-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--color-primary)}.action-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-md)}.action-card h3{font-size:1.25rem;font-weight:700;color:var(--color-dark);margin-bottom:var(--spacing-xs)}.action-card p{color:var(--color-text-secondary)}.loading-container{min-height:400px;display:flex;align-items:center;justify-content:center}.spinner{width:50px;height:50px;border:4px solid var(--color-light);border-top:4px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.dashboard-grid,.stats-grid,.actions-grid{grid-template-columns:1fr}.dashboard-header h1{font-size:2rem}}.loading-fullscreen{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fffffff2;z-index:9999}.loading-inline{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.loading-spinner{display:inline-block}.spinner{border:3px solid #f3f3f3;border-top:3px solid #0066cc;border-radius:50%;animation:spin .8s linear infinite}.spinner-small .spinner{width:20px;height:20px;border-width:2px}.spinner-medium .spinner{width:40px;height:40px}.spinner-large .spinner{width:60px;height:60px;border-width:4px}.loading-message{margin-top:1rem;color:#666;font-size:.95rem}.btn-loading{position:relative;pointer-events:none;opacity:.7}.btn-loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid #ffffff;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.my-orders-page{padding:var(--spacing-xl) 0;min-height:calc(100vh - 70px)}.page-header{margin-bottom:var(--spacing-xl)}.page-header h1{font-size:2.5rem;font-weight:900;color:var(--color-dark);margin-bottom:var(--spacing-xs)}.page-header p{font-size:1.15rem;color:var(--color-gray)}.orders-filters{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.filters-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.filter-input,.filter-select{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.95rem;transition:border-color .2s}.filter-input:focus,.filter-select:focus{outline:none;border-color:#06c}.search-input{flex:1;min-width:200px}.filter-select,.date-input{min-width:150px}.results-count{color:#666;font-size:.9rem;margin-bottom:1rem;padding:.5rem 0}.empty-state-box{background:var(--color-white);padding:var(--spacing-2xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);text-align:center;max-width:500px;margin:var(--spacing-2xl) auto}.empty-icon{font-size:5rem;display:block;margin-bottom:var(--spacing-lg)}.empty-state-box h3{font-size:1.5rem;font-weight:700;color:var(--color-dark);margin-bottom:var(--spacing-sm)}.empty-state-box p{color:var(--color-gray);margin-bottom:var(--spacing-xl)}.orders-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.order-card{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;transition:var(--transition)}.order-card:hover{box-shadow:var(--shadow-xl)}.order-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);background:linear-gradient(135deg,#7c3aed0d,#ffd70014);border-bottom:2px solid var(--color-light)}.order-header h3{font-size:1.25rem;font-weight:700;color:var(--color-dark);margin-bottom:.25rem}.order-date{font-size:.9rem;color:var(--color-gray)}.status-badge{padding:.5rem 1rem;border-radius:var(--radius-lg);color:var(--color-white);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.order-items{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.order-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--color-light);border-radius:var(--radius-md)}.item-info{display:flex;align-items:center;gap:var(--spacing-md)}.item-icon{font-size:2rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--color-white);border-radius:var(--radius-md);flex-shrink:0}.item-info h4{font-size:1.05rem;font-weight:600;color:var(--color-dark);margin-bottom:.25rem}.item-info p{font-size:.9rem;color:var(--color-gray)}.item-total{font-size:1.25rem;font-weight:700;color:var(--color-primary)}.order-footer{padding:var(--spacing-lg);background:var(--color-light);display:flex;justify-content:space-between;align-items:center}.order-total{display:flex;flex-direction:column}.order-total span:first-child{font-size:.9rem;color:var(--color-gray);margin-bottom:.25rem}.total-amount{font-size:1.75rem;font-weight:900;color:var(--color-primary)}.order-actions{display:flex;gap:var(--spacing-sm)}@media(max-width:768px){.order-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.order-footer{flex-direction:column;gap:var(--spacing-md);align-items:flex-start}.order-actions{width:100%}.order-actions button{flex:1}}.order-status-tracker{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #00000014}.current-status-card{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;border-left:4px solid;margin-bottom:2rem}.status-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:#fff;flex-shrink:0}.status-info h3{margin:0 0 .5rem;font-size:1.5rem;color:#1e293b}.status-info p{margin:0;color:#64748b;font-size:.95rem}.progress-container{margin-bottom:2rem}.progress-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.9rem;color:#64748b;font-weight:500}.progress-percentage{font-weight:600;color:#1e293b}.progress-bar{height:8px;background:#e5e7eb;border-radius:10px;overflow:hidden}.progress-fill{height:100%;transition:width .5s ease,background-color .3s ease;border-radius:10px}.status-timeline{display:flex;justify-content:space-between;align-items:flex-start;position:relative;margin:2rem 0}.timeline-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.step-marker{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;border:3px solid transparent;transition:all .3s ease;z-index:2;background-color:#e5e7eb}.timeline-step.active .step-marker{transform:scale(1.1)}.timeline-step.current .step-marker{border-width:4px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1.1);box-shadow:0 0 #667eeab3}50%{transform:scale(1.15);box-shadow:0 0 0 10px #667eea00}}.step-label{margin-top:.75rem;font-size:.85rem;font-weight:500;color:#64748b;text-align:center;max-width:80px}.timeline-step.active .step-label{color:#1e293b;font-weight:600}.step-connector{position:absolute;top:25px;left:50%;right:-50%;height:3px;background-color:#e5e7eb;transition:background-color .3s ease;z-index:1}.timeline-step:last-child .step-connector{display:none}.estimated-time{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fef3c7;border:1px solid #fde68a;border-radius:8px;margin-top:2rem}.time-icon{font-size:1.5rem}.estimated-time strong{color:#92400e;display:block;margin-bottom:.25rem}.estimated-time p{margin:0;color:#78350f;font-size:.95rem}@media(max-width:768px){.order-status-tracker{padding:1.5rem}.current-status-card{flex-direction:column;text-align:center;gap:1rem}.status-timeline{flex-direction:column;align-items:stretch}.timeline-step{flex-direction:row;align-items:center;margin-bottom:1.5rem}.step-marker{width:40px;height:40px;font-size:1.2rem;flex-shrink:0}.step-label{margin-top:0;margin-left:1rem;text-align:left;max-width:none}.step-connector{top:20px;left:20px;right:auto;bottom:-1.5rem;width:3px;height:auto}.timeline-step:last-child{margin-bottom:0}.timeline-step:last-child .step-connector{display:none}}@media(max-width:480px){.status-info h3{font-size:1.25rem}.status-icon{width:50px;height:50px;font-size:1.5rem}}.order-detail-page{padding:2rem 0;min-height:calc(100vh - 70px);background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.order-date{color:#64748b;font-size:1rem}.detail-full-width{grid-column:1 / -1}.items-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.order-item{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0;transition:all .3s ease}.order-item:hover{box-shadow:0 4px 12px #7c3aed1a;transform:translateY(-2px)}.item-main{display:flex;gap:1rem;flex:1}.item-icon{font-size:2.5rem;line-height:1}.item-info{flex:1}.item-info h3{font-size:1.1rem;color:#1e293b;margin-bottom:.5rem}.item-description{color:#64748b;font-size:.9rem;margin-bottom:.75rem}.item-details{display:flex;gap:1.5rem;font-size:.9rem;color:#475569}.item-quantity,.item-price{display:flex;align-items:center;gap:.5rem}.item-total{font-size:1.2rem;color:var(--color-primary);font-weight:700;min-width:100px;text-align:right}.order-summary{padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:12px;border:2px solid #e2e8f0}.summary-row{display:flex;justify-content:space-between;padding:.75rem 0;font-size:1rem;color:#475569}.summary-row.total{border-top:2px solid #cbd5e1;margin-top:.75rem;padding-top:1rem}.total-amount{font-size:1.5rem;color:var(--color-primary)}.info-list{display:flex;flex-direction:column;gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-label{font-size:.85rem;color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.info-value{font-size:1rem;color:#1e293b;font-weight:500}.info-badge{padding:.5rem 1rem;border-radius:50px;color:#fff;font-weight:600;font-size:.85rem;text-transform:capitalize;display:inline-block;width:fit-content}.establishment-info{text-align:center}.establishment-info h3{font-size:1.2rem;color:#1e293b;margin-bottom:.75rem}.establishment-info p{color:#64748b;margin-bottom:.5rem;font-size:.95rem}.establishment-info .btn{margin-top:1rem}.tickets-card{background:linear-gradient(135deg,var(--color-primary) 0%,#008040 100%);color:#fff}.tickets-card h2{color:#fff;border-bottom-color:#fff3}.tickets-card p{color:#ffffffe6;margin-bottom:1.5rem}@media(max-width:968px){.detail-grid{grid-template-columns:1fr}.detail-sidebar{position:static}.detail-header{flex-direction:column;gap:1rem}.detail-header h1{font-size:1.5rem}}@media(max-width:640px){.order-detail-page{padding:1rem 0}.detail-card{padding:1.5rem}.order-item{flex-direction:column;gap:1rem}.item-main{flex-direction:column;width:100%}.item-total{text-align:left;width:100%}.item-details{flex-direction:column;gap:.5rem}}.status-history-list{display:flex;flex-direction:column;gap:.75rem}.status-history-item{display:flex;align-items:flex-start;gap:.75rem}.status-history-dot{width:10px;height:10px;border-radius:50%;margin-top:5px;flex-shrink:0}.status-history-info{display:flex;flex-direction:column;gap:.125rem}.status-history-label{font-weight:600;font-size:.9rem;color:var(--color-text);text-transform:capitalize}.status-history-date{font-size:.8rem;color:var(--color-text-light)}.status-history-note{font-size:.85rem;color:var(--color-text-secondary);font-style:italic}.my-reservations-page{padding:2rem 0;min-height:calc(100vh - 70px)}.reservations-page-header{text-align:center;margin-bottom:3rem;padding:0 1rem}.reservations-page-title{font-size:2.5rem;color:var(--text-dark);margin-bottom:.5rem;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reservations-page-subtitle{color:var(--text-light);font-size:1.1rem;margin:0;line-height:1.5}.reservations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.reservation-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px #0000001a;overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column}.reservation-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px #00000026}.reservation-header{padding:1.5rem;display:flex;justify-content:space-between;align-items:center;min-height:100px;gap:1rem}.establishment-info{display:flex;align-items:center;gap:1rem;flex:1}.establishment-logo{width:60px;height:60px;object-fit:contain;border-radius:8px;background:#fff;padding:.5rem;box-shadow:0 2px 8px #00000026}.establishment-icon{font-size:3rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.2))}.establishment-name{color:#fff;font-size:1.5rem;font-weight:700;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.2)}.status-badge{padding:.5rem 1rem;border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;box-shadow:0 2px 8px #0003}.reservation-content{padding:1.5rem;flex:1}.reservation-content h3{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin-bottom:1rem}.reservation-details{display:flex;flex-direction:column;gap:.75rem}.reservation-detail-item{display:flex;align-items:center;gap:.5rem;color:#1a1a1a!important;font-size:.95rem}.reservation-text{color:#1a1a1a!important;font-weight:500}.reservation-icon{font-size:1.1rem;color:#1a1a1a!important}.reservation-footer{padding:1rem 1.5rem;background:#f5f5f5;display:flex;justify-content:flex-start;align-items:center;gap:1rem;flex-wrap:wrap}.reservation-footer .btn{flex:0 0 auto;min-width:120px}.reservation-note{color:#666;font-size:.9rem;font-weight:500;margin-left:auto}@media(max-width:768px){.my-reservations-page{padding:1rem 0}.reservations-page-header{margin-bottom:2rem}.reservations-page-title{font-size:2rem;line-height:1.3;white-space:normal}.reservations-page-subtitle{font-size:1rem}.reservations-grid{grid-template-columns:1fr}.reservation-header{flex-direction:column;align-items:flex-start;min-height:auto}.establishment-info{width:100%}.status-badge{align-self:flex-start}.reservation-footer{flex-direction:column;gap:.75rem}.reservation-footer .btn{width:100%}}.reservation-detail-page{padding:2rem 0;min-height:calc(100vh - 70px);background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.back-btn{background:none;border:none;color:var(--color-primary);font-size:1rem;cursor:pointer;padding:.5rem 0;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;transition:all .3s ease}.back-btn:hover{color:#008040;transform:translate(-5px)}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e2e8f0}.detail-header h1{font-size:2rem;color:#1e293b;margin-bottom:.5rem}.reservation-date{color:#64748b;font-size:1.1rem;font-weight:500}.status-badge{padding:.5rem 1.5rem;border-radius:50px;color:#fff;font-weight:600;font-size:.9rem;text-transform:capitalize;box-shadow:0 2px 8px #0000001a}.detail-grid{display:grid;grid-template-columns:1fr 400px;gap:2rem;align-items:start}.detail-card{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:1.5rem}.detail-card h2{font-size:1.5rem;color:#1e293b;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.main-card{min-height:400px}.reservation-hero{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:linear-gradient(135deg,var(--color-primary) 0%,#008040 100%);border-radius:12px;color:#fff;margin-bottom:2rem}.hero-logo{width:80px;height:80px;object-fit:contain;border-radius:8px;background:#fff;padding:.5rem;box-shadow:0 4px 12px #0003;flex-shrink:0}.hero-icon{font-size:4rem;line-height:1;flex-shrink:0}.hero-info h3{font-size:1.8rem;margin-bottom:.5rem}.establishment-type{opacity:.9;font-size:1.1rem}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.info-box{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0;transition:all .3s ease}.info-box:hover{box-shadow:0 4px 12px #7c3aed1a;transform:translateY(-2px)}.info-icon{font-size:2rem;line-height:1}.info-box>div{display:flex;flex-direction:column;gap:.3rem}.info-label{font-size:.8rem;color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.info-value{font-size:1.1rem;color:#1e293b;font-weight:600}.info-badge{padding:.4rem 1rem;border-radius:50px;color:#fff;font-weight:600;font-size:.85rem;text-transform:capitalize;display:inline-block;width:fit-content}.special-requests{padding:1.5rem;background:#fef3c7;border-left:4px solid #F59E0B;border-radius:8px}.special-requests h3{font-size:1.1rem;color:#92400e;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.special-requests h3:before{content:"📝"}.cancel-section{margin-top:2rem;padding:1.5rem;background:#fee;border:2px solid #DC2626;border-radius:12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.btn-danger{background:#dc2626;color:#fff;border:none;font-weight:600;transition:all .3s ease;padding:.75rem 2rem;border-radius:8px;font-size:1rem;cursor:pointer;max-width:300px}.btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.cancel-info{font-size:.9rem;color:#991b1b}.special-requests p{color:#78350f;line-height:1.6}.detail-sidebar{position:sticky;top:2rem}.establishment-card{text-align:center}.establishment-details h3{font-size:1.3rem;color:#1e293b;margin-bottom:1rem}.establishment-contact{margin-bottom:1.5rem}.establishment-contact p{color:#64748b;margin-bottom:.5rem;font-size:.95rem}.establishment-card .btn{width:100%}.user-info{display:flex;flex-direction:column;gap:1rem}.user-info p{color:#475569;font-size:.95rem}.user-info strong{color:#1e293b;margin-right:.5rem}.tips-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #93C5FD}.tips-card h2{color:#1e40af;border-bottom-color:#93c5fd}.tips-list{list-style:none;padding:0;margin:0}.tips-list li{padding:.75rem;margin-bottom:.75rem;background:#fff;border-radius:8px;color:#1e40af;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.tips-list li:before{content:"✓";display:inline-block;width:24px;height:24px;background:var(--color-primary);color:#fff;border-radius:50%;text-align:center;line-height:24px;font-weight:700;flex-shrink:0}.error-box{background:#fff;padding:3rem;border-radius:16px;text-align:center;box-shadow:0 4px 20px #00000014;margin:2rem 0}.spinner{width:50px;height:50px;border:4px solid #f3f4f6;border-top:4px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:968px){.detail-grid{grid-template-columns:1fr}.detail-sidebar{position:static}.info-grid{grid-template-columns:1fr}.detail-header{flex-direction:column;gap:1rem}.detail-header h1{font-size:1.5rem}}@media(max-width:640px){.reservation-detail-page{padding:1rem 0}.detail-card{padding:1.5rem}.reservation-hero{flex-direction:column;text-align:center;padding:1.5rem}.hero-info h3{font-size:1.4rem}.info-box{padding:1rem}}.my-tickets{padding:40px 20px;min-height:calc(100vh - 200px)}.my-tickets .container{max-width:1200px;margin:0 auto}.my-tickets .page-header{text-align:center;margin-bottom:40px}.my-tickets .page-header h1{font-size:2.5rem;color:#1a1a2e;margin-bottom:10px}.my-tickets .page-header p{color:#64748b;font-size:1.1rem}.empty-state p{color:#64748b;font-size:1.1rem;margin-bottom:30px}.tickets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(500px,1fr));gap:30px}@media(max-width:768px){.tickets-grid{grid-template-columns:1fr}}.ticket-card{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.ticket-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #0000001f}.ticket-header{padding:20px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;justify-content:space-between;align-items:flex-start;gap:15px}.ticket-event-info{display:flex;gap:15px;align-items:flex-start;flex:1}.ticket-event-image{width:80px;height:80px;object-fit:cover;border-radius:12px}.ticket-event-info h3{color:#1a1a2e;font-size:1.2rem;margin:0 0 8px}.ticket-event-date,.ticket-event-location{color:#64748b;font-size:.9rem;margin:4px 0}.ticket-status{padding:8px 16px;border-radius:20px;font-size:.85rem;font-weight:600;white-space:nowrap}.ticket-status.valid{background-color:#d1fae5;color:#065f46}.ticket-status.used{background-color:#e0e7ff;color:#3730a3}.ticket-status.cancelled{background-color:#fee2e2;color:#991b1b}.ticket-body{padding:30px 20px;display:flex;gap:30px;align-items:center}@media(max-width:576px){.ticket-body{flex-direction:column}}.ticket-qr{flex-shrink:0}.ticket-qr img{width:150px;height:150px;border-radius:12px;border:3px solid var(--color-primary)}.qr-placeholder{width:150px;height:150px;background:linear-gradient(135deg,var(--color-primary) 0%,#FFD700 100%);border-radius:12px;display:flex;align-items:center;justify-content:center}.qr-code-visual{width:120px;height:120px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center}.qr-pattern{width:100px;height:100px;background-image:repeating-linear-gradient(90deg,#1A1A2E 0px,#1A1A2E 10px,transparent 10px,transparent 20px),repeating-linear-gradient(0deg,#1A1A2E 0px,#1A1A2E 10px,transparent 10px,transparent 20px)}.ticket-details{flex:1}.detail-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #f1f5f9}.detail-label{color:#64748b;font-size:.9rem}.detail-value{color:#1a1a2e;font-weight:600;font-size:.95rem}.ticket-footer{padding:20px;background-color:#fef3c7;display:flex;justify-content:space-between;align-items:center;gap:15px}@media(max-width:576px){.ticket-footer{flex-direction:column;align-items:flex-start}}.ticket-instructions{color:#92400e;font-size:.9rem;margin:0;flex:1}.btn-link{color:var(--color-primary);text-decoration:none;font-weight:600;transition:color .3s ease;white-space:nowrap}.btn-link:hover{color:#008040}.ticket-detail-page{padding:2rem 0;min-height:calc(100vh - 70px);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%)}.back-btn{background:none;border:none;color:#fff;font-size:1rem;cursor:pointer;padding:.5rem 0;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;transition:all .3s ease}.back-btn:hover{transform:translate(-5px)}.ticket-container{display:grid;grid-template-columns:1fr 350px;gap:2rem;align-items:start}.ticket-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.ticket-header{background:linear-gradient(135deg,var(--color-primary) 0%,#008040 100%);color:#fff;padding:3rem 2rem;text-align:center;position:relative}.ticket-logo{font-size:4rem;margin-bottom:1rem}.ticket-header h1{font-size:2rem;margin-bottom:1rem}.status-badge{display:inline-block;padding:.5rem 1.5rem;border-radius:50px;color:#fff;font-weight:600;font-size:.9rem;text-transform:uppercase;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.event-section{padding:2rem;text-align:center;border-bottom:2px dashed #e2e8f0}.event-section h2{font-size:1.8rem;color:#1e293b;margin-bottom:1.5rem}.event-details{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:500px;margin:0 auto}.event-detail-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8fafc;border-radius:12px}.detail-icon{font-size:2rem;line-height:1}.event-detail-item>div{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.detail-label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.detail-value{font-size:1rem;color:#1e293b;font-weight:600;margin-top:.25rem}.qr-section{padding:3rem 2rem;text-align:center;background:#f8fafc;border-bottom:2px dashed #e2e8f0}.qr-container{display:inline-block;padding:1.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000001a;margin-bottom:1.5rem}.qr-code{display:block;max-width:300px;width:100%;height:auto}.qr-code-text{font-family:Courier New,monospace;font-size:1.1rem;color:#475569;margin-bottom:.5rem;font-weight:600}.qr-instruction{color:#64748b;font-size:.95rem;margin-bottom:1.5rem}.ticket-info-section{padding:2rem;display:flex;flex-direction:column;gap:1rem}.info-row{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8fafc;border-radius:8px}.info-label{font-size:.9rem;color:#64748b;font-weight:600}.info-value{font-size:1rem;color:#1e293b;font-weight:600}.ticket-footer{padding:2rem;background:#f1f5f9;border-top:2px dashed #e2e8f0}.footer-section{margin-bottom:1.5rem}.footer-section h3{font-size:1.1rem;color:#1e293b;margin-bottom:1rem}.footer-section ul{list-style:none;padding:0;margin:0}.footer-section li{padding:.5rem 0;color:#475569;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.footer-section li:before{content:"•";color:var(--color-primary);font-weight:700;font-size:1.2rem}.ticket-footer .btn{width:100%}.ticket-sidebar{position:sticky;top:2rem}.sidebar-card{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 20px #0000001a;margin-bottom:1.5rem}.sidebar-card h3{font-size:1.2rem;color:#1e293b;margin-bottom:1rem}.organizer-info h4{font-size:1.1rem;color:#1e293b;margin-bottom:.5rem}.organizer-info p{color:#64748b;font-size:.9rem;margin-bottom:.5rem}.organizer-info .btn{width:100%;margin-top:1rem}.help-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #FCD34D}.help-card h3{color:#92400e}.help-card p{color:#78350f;font-size:.9rem;margin-bottom:1rem;line-height:1.6}.tips-card{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #93C5FD}.tips-card h3{color:#1e40af}.tips-card ul{list-style:none;padding:0;margin:0}.tips-card li{padding:.75rem;margin-bottom:.5rem;background:#fff;border-radius:8px;color:#1e40af;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.tips-card li:before{content:"✓";display:inline-block;width:20px;height:20px;background:var(--color-primary);color:#fff;border-radius:50%;text-align:center;line-height:20px;font-weight:700;flex-shrink:0;font-size:.75rem}.error-box{background:#fff;padding:3rem;border-radius:16px;text-align:center;box-shadow:0 4px 20px #0000004d;margin:2rem 0}.error-box h2{color:#dc2626;margin-bottom:1rem}.error-box p{color:#64748b;margin-bottom:2rem}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:968px){.ticket-container{grid-template-columns:1fr}.ticket-sidebar{position:static}.event-details{grid-template-columns:1fr}}@media(max-width:640px){.ticket-detail-page{padding:1rem 0}.ticket-header{padding:2rem 1.5rem}.ticket-header h1{font-size:1.5rem}.event-section h2{font-size:1.4rem}.qr-section{padding:2rem 1rem}.sidebar-card,.ticket-info-section,.ticket-footer{padding:1.5rem}}.favorite-btn{background:#fff;border:2px solid var(--color-secondary);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;position:relative;box-shadow:0 2px 8px #0000001a}.favorite-btn:hover{transform:scale(1.1);border-color:var(--color-primary);box-shadow:0 4px 12px #00000026}.favorite-btn.favorited{background:var(--color-accent);border-color:var(--color-primary);animation:heartBeat .5s ease}.favorite-btn:disabled{opacity:.6;cursor:not-allowed}.favorite-btn.loading{animation:pulse 1.5s infinite}.heart-icon{font-size:1.3rem;line-height:1;transition:transform .2s}.favorite-btn:active .heart-icon{transform:scale(.9)}.favorite-count{position:absolute;top:-6px;right:-6px;background:var(--color-primary);color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}@keyframes heartBeat{0%{transform:scale(1)}25%{transform:scale(1.2)}50%{transform:scale(1)}75%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.my-favorites-page{padding:2rem 0;min-height:80vh}.favorites-page-header{text-align:center;margin-bottom:3rem;padding:0 1rem}.favorites-page-title{font-size:2.5rem;color:var(--text-dark);margin-bottom:.5rem;font-weight:700;line-height:1.2;display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.favorites-page-subtitle{color:var(--text-light);font-size:1.1rem;margin:0;line-height:1.5}.empty-state{text-align:center;padding:4rem 2rem;max-width:600px;margin:0 auto}.empty-icon{font-size:5rem;margin-bottom:1rem;opacity:.5}.empty-state h2{font-size:1.8rem;color:var(--text-dark);margin-bottom:1rem}.empty-state p{color:var(--text-light);font-size:1.1rem;margin-bottom:2rem}.favorites-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid var(--border-color);padding-bottom:0;overflow-x:auto}.tab-btn{background:none;border:none;padding:1rem 1.5rem;font-size:1rem;font-weight:600;color:var(--text-light);cursor:pointer;transition:all .3s;border-bottom:3px solid transparent;margin-bottom:-2px;white-space:nowrap}.tab-btn:hover{color:var(--primary-color);background:var(--background-light)}.tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.favorites-section{margin-bottom:3rem}.favorites-section h2{font-size:1.8rem;color:var(--text-dark);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--border-color)}.favorites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.favorite-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:all .3s;display:flex;flex-direction:column}.favorite-card:hover{transform:translateY(-5px);box-shadow:0 4px 16px #00000026}.card-image{position:relative;width:100%;height:200px;overflow:hidden}.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.favorite-card:hover .card-image img{transform:scale(1.05)}.favorite-badge{position:absolute;top:10px;right:10px;z-index:10}.card-content{padding:1.5rem;flex:1;display:flex;flex-direction:column}.card-content h3{font-size:1.3rem;color:var(--text-dark);margin-bottom:.75rem;line-height:1.3}.card-description{color:var(--text-light);font-size:.95rem;line-height:1.5;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.card-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:1rem 0;border-top:1px solid var(--border-color)}.detail-item{display:flex;align-items:center;font-size:.9rem;color:var(--text-light)}.detail-item:before{margin-right:.5rem}.card-content .btn{width:100%;justify-content:center;margin-top:auto}@media(max-width:768px){.my-favorites-page{padding:1rem 0}.favorites-page-header{margin-bottom:2rem}.favorites-page-title{font-size:2rem;line-height:1.3}.favorites-page-subtitle{font-size:1rem}.favorites-grid{grid-template-columns:1fr;gap:1.5rem}.empty-actions{flex-direction:column}.empty-actions .btn{width:100%}.favorites-tabs{gap:.5rem}.tab-btn{padding:.75rem 1rem;font-size:.9rem}}.my-waitlist-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);padding:2rem 0}.my-waitlist-page .container{max-width:1200px;margin:0 auto;padding:0 1rem}.page-header{text-align:center;margin-bottom:2rem}.page-header h1{font-size:2.5rem;color:#333;margin-bottom:.5rem}.page-header p{font-size:1.1rem;color:#666}.filter-tabs{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.filter-tabs .tab{padding:.75rem 1.5rem;border:2px solid #e0e7ff;background:#fff;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.filter-tabs .tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-tabs .tab.active{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;border-color:transparent}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000001a}.waitlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.waitlist-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:transform .3s;border-left:4px solid #e0e7ff}.waitlist-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026}.waitlist-card.status-waiting{border-left-color:#f59e0b}.waitlist-card.status-notified{border-left-color:#10b981;animation:pulse 2s infinite}.waitlist-card.status-seated{border-left-color:#6b7280}.waitlist-card.status-cancelled{border-left-color:#ef4444;opacity:.7}.waitlist-card.status-expired{border-left-color:#9ca3af;opacity:.6}@keyframes pulse{0%,to{box-shadow:0 2px 8px #0000001a}50%{box-shadow:0 4px 16px #10b9814d}}.card-header{display:flex;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.establishment-image{width:60px;height:60px;border-radius:8px;object-fit:cover}.establishment-info h3{font-size:1.25rem;color:#333;margin:0 0 .25rem}.establishment-info .address{font-size:.9rem;color:#666;margin:0}.card-status{margin-bottom:1rem}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--badge-color, var(--color-primary));color:#fff;border-radius:999px;font-weight:600;font-size:.9rem}.badge-icon{font-size:1.1rem}.card-details{margin-bottom:1rem}.detail-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;font-size:.95rem;color:#333}.detail-row .icon{font-size:1.1rem;width:24px}.position-info{background:linear-gradient(135deg,#fff7ed,#fef3c7);border-radius:8px;padding:1rem;margin-bottom:1rem;text-align:center}.position-badge{font-weight:700;color:#f59e0b;font-size:1.1rem;margin-bottom:.5rem}.wait-time{font-size:.9rem;color:#92400e;margin:0}.expiration-warning{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:2px solid #fca5a5;border-radius:8px;padding:.75rem;margin-bottom:1rem;text-align:center;color:#dc2626;font-weight:600;font-size:.9rem}.special-requests{background:#f8f9fa;border-radius:8px;padding:1rem;margin-bottom:1rem}.special-requests strong{display:block;color:#333;font-size:.9rem;margin-bottom:.5rem}.special-requests p{color:#666;font-size:.9rem;margin:0;line-height:1.5}.card-actions{display:flex;gap:.75rem}.btn{flex:1;padding:.75rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s;font-size:.95rem}.btn-success:hover{background:#059669;transform:translateY(-2px)}.success-message{width:100%;text-align:center;padding:.75rem;background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border-radius:8px;font-weight:600}@media(max-width:768px){.waitlist-grid{grid-template-columns:1fr}.page-header h1{font-size:2rem}.filter-tabs{flex-direction:column}.filter-tabs .tab{width:100%}.card-actions{flex-direction:column}}.notifications-page{padding:40px 20px;min-height:calc(100vh - 200px)}.notifications-page .container{max-width:900px;margin:0 auto}.notifications-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;gap:20px;flex-wrap:wrap}.notifications-page .page-header h1{font-size:2.5rem;color:#1a1a2e;margin:0 0 5px}.notifications-page .page-header p{color:#64748b;font-size:1.1rem;margin:0}.filter-tabs{display:flex;gap:10px;margin-bottom:30px;border-bottom:2px solid #f1f5f9;overflow-x:auto}.filter-tab{background:none;border:none;padding:15px 25px;font-size:1rem;font-weight:600;color:#64748b;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s ease;white-space:nowrap}.filter-tab:hover{color:var(--color-primary)}.filter-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.empty-state{text-align:center;padding:80px 20px}.empty-icon{font-size:5rem;margin-bottom:20px;opacity:.5}.empty-state h2{font-size:1.8rem;color:#1a1a2e;margin-bottom:10px}.empty-state p{color:#64748b;font-size:1.1rem}.notifications-list{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;overflow:hidden}.notification-item{display:flex;align-items:flex-start;gap:15px;padding:20px;border-bottom:1px solid #f1f5f9;transition:background-color .2s ease;cursor:pointer;position:relative}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:#f8fafc}.notification-item.unread{background-color:#f0fdf4}.notification-item.unread:hover{background-color:#dcfce7}.notification-icon{font-size:2rem;flex-shrink:0;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:12px}.notification-item.unread .notification-icon{background:linear-gradient(135deg,var(--color-primary) 0%,#FFD700 100%)}.notification-content{flex:1}.notification-content h3{color:#1a1a2e;font-size:1.1rem;margin:0 0 5px;font-weight:600}.notification-content p{color:#64748b;font-size:.95rem;margin:0 0 8px;line-height:1.5}.notification-time{color:#94a3b8;font-size:.85rem}.unread-badge{width:10px;height:10px;background-color:var(--color-primary);border-radius:50%;flex-shrink:0;margin-top:5px}@media(max-width:576px){.notifications-page .page-header{flex-direction:column;align-items:flex-start}.notification-icon{width:40px;height:40px;font-size:1.5rem}.notification-content h3{font-size:1rem}.notification-content p{font-size:.9rem}}.loyalty-enhanced-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);padding:2rem 0}.loyalty-enhanced-page .container{max-width:1200px;margin:0 auto;padding:0 1rem}.loyalty-header{background:#fff;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.tier-badge{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #f0f0f0}.tier-icon{font-size:4rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.tier-info h1{font-size:2rem;font-weight:700;color:var(--tier-color, #333);margin:0 0 .5rem}.tier-info p{font-size:1.1rem;color:#666;margin:0}.points-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.points-card{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:1.5rem;border-radius:12px;text-align:center;box-shadow:0 4px 12px #667eea4d;transition:transform .2s}.points-card:hover{transform:translateY(-4px)}.points-card h3{font-size:.9rem;font-weight:500;text-transform:uppercase;letter-spacing:1px;opacity:.9;margin:0 0 .5rem}.points-value{font-size:2.5rem;font-weight:700;margin:0}.tier-progress-section{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.progress-header{display:flex;justify-content:space-between;margin-bottom:1rem;font-size:.9rem;color:#666}.progress-bar{height:12px;background:#e0e7ff;border-radius:999px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border-radius:999px;transition:width .5s ease;box-shadow:0 0 10px #667eea80}.loyalty-tabs{display:flex;gap:.5rem;background:#fff;border-radius:12px;padding:.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.tab-btn{flex:1;min-width:120px;padding:.75rem 1.5rem;border:none;background:transparent;color:#666;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s;white-space:nowrap}.tab-btn:hover{background:#f8f9fa;color:#333}.tab-btn.active{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;box-shadow:0 2px 8px #667eea4d}.tab-content{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 2px 8px #0000001a;min-height:400px}.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.benefit-card{background:linear-gradient(135deg,#f5f7fa,#e8ecf1);border-radius:12px;padding:1.5rem;text-align:center;border:2px solid transparent;transition:all .3s}.benefit-card:hover{border-color:var(--color-primary);transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.benefit-icon{font-size:3rem;display:block;margin-bottom:1rem}.benefit-card h3{font-size:1rem;font-weight:600;color:#333;margin:0 0 .5rem}.benefit-value{font-size:2rem;font-weight:700;color:var(--color-primary);margin:.5rem 0}.benefit-desc{font-size:.9rem;color:#666;margin:.5rem 0 1rem}.quick-actions h2{font-size:1.5rem;margin-bottom:1.5rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.action-card{background:#fff;border:2px solid #e0e7ff;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;transition:all .3s;font-size:1rem;font-weight:600;color:#333}.action-card:hover{border-color:var(--color-primary);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;transform:translateY(-4px)}.action-icon{font-size:2rem}.tiers-comparison{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:2rem}.tier-card{border:2px solid #e0e7ff;border-radius:12px;overflow:hidden;transition:all .3s}.tier-card:hover{transform:translateY(-8px);box-shadow:0 12px 24px #00000026}.tier-card.current{border-color:var(--tier-color);box-shadow:0 8px 16px #00000026}.tier-header{background:var(--tier-color);color:#fff;padding:1.5rem;text-align:center;position:relative}.tier-icon-large{font-size:3rem;display:block;margin-bottom:.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.tier-header h3{margin:0;font-size:1.5rem;font-weight:700}.current-badge{position:absolute;top:.5rem;right:.5rem;background:#ffffff4d;padding:.25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tier-features{padding:1.5rem}.feature{padding:.75rem 0;border-bottom:1px solid #f0f0f0;font-size:.95rem;color:#333}.feature:last-child{border-bottom:none}.referral-section{margin-bottom:3rem}.referral-section h2{font-size:1.5rem;margin-bottom:1rem}.referral-code-box{display:flex;gap:1rem;align-items:center;margin:1.5rem 0}.code-display{flex:1;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:1.5rem;border-radius:12px;font-size:2rem;font-weight:700;text-align:center;letter-spacing:4px;font-family:monospace;box-shadow:0 4px 12px #667eea4d}.referral-desc{color:#666;font-size:1rem;line-height:1.6}.referral-stats{background:linear-gradient(135deg,#f5f7fa,#e8ecf1);border-radius:12px;padding:2rem;margin-bottom:3rem}.referral-stats h3{font-size:1.25rem;margin-bottom:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;text-align:center;box-shadow:0 2px 8px #0000000d}.stat-value{font-size:2.5rem;font-weight:700;color:var(--color-primary);margin:0 0 .5rem}.stat-label{font-size:.9rem;color:#666;margin:0;text-transform:uppercase;letter-spacing:1px}.apply-referral-section h3{font-size:1.25rem;margin-bottom:1rem}.referral-input-group{display:flex;gap:1rem}.referral-input-group input{flex:1;padding:.875rem 1rem;border:2px solid #e0e7ff;border-radius:8px;font-size:1rem;text-transform:uppercase;font-weight:600;letter-spacing:2px;font-family:monospace;transition:border-color .3s}.referral-input-group input:focus{outline:none;border-color:var(--color-primary)}.history-tab h2{font-size:1.5rem;margin-bottom:1.5rem}.empty-history{text-align:center;padding:3rem;color:#666}.history-list{display:flex;flex-direction:column;gap:.75rem}.history-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid transparent;transition:all .2s}.history-item:hover{background:#f0f0f0}.history-item.earned{border-left-color:#10b981}.history-item.redeemed{border-left-color:#ef4444}.history-item.bonus{border-left-color:#f59e0b}.history-item.expired{border-left-color:#6b7280}.history-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%}.history-details{flex:1}.history-reason{font-weight:600;color:#333;margin:0 0 .25rem}.history-date{font-size:.85rem;color:#666;margin:0}.history-points{font-size:1.25rem;font-weight:700;min-width:100px;text-align:right}.history-points.positive{color:#10b981}.history-points.negative{color:#ef4444}.empty-state{text-align:center;padding:4rem 2rem}.empty-icon{font-size:5rem;margin-bottom:1.5rem}.empty-state h2{font-size:2rem;margin-bottom:1rem;color:#333}.empty-state p{font-size:1.1rem;color:#666;margin-bottom:2rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-sm{padding:.5rem 1rem;font-size:.875rem}@media(max-width:768px){.loyalty-enhanced-page{padding:1rem 0}.loyalty-header{padding:1.5rem}.tier-badge{flex-direction:column;text-align:center}.tier-info h1{font-size:1.5rem}.points-summary,.benefits-grid,.tiers-comparison{grid-template-columns:1fr}.referral-code-box{flex-direction:column}.code-display{font-size:1.5rem;padding:1rem}.referral-input-group{flex-direction:column}.tab-content{padding:1rem}.loyalty-tabs{overflow-x:scroll;scrollbar-width:none}.loyalty-tabs::-webkit-scrollbar{display:none}}.profile-page{padding:var(--spacing-xl) 0;min-height:calc(100vh - 70px)}.profile-header{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.profile-avatar{width:120px;height:120px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:900;color:var(--color-white);text-transform:uppercase;position:relative;overflow:hidden;cursor:default;transition:all .3s ease}.profile-avatar.editable{cursor:pointer}.profile-avatar.editable:hover{transform:scale(1.05)}.profile-avatar img{width:100%;height:100%;object-fit:cover}.avatar-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;font-size:2rem;opacity:0;transition:opacity .3s}.profile-avatar.editable:hover .avatar-overlay{opacity:1}.user-bio{font-style:italic;color:var(--color-gray);margin-top:var(--spacing-xs)}.profile-header h1{font-size:2.5rem;font-weight:900;color:var(--color-dark);margin-bottom:var(--spacing-xs)}.profile-header p{font-size:1.15rem;color:var(--color-gray)}.profile-grid{display:flex;flex-direction:column;gap:var(--spacing-xl);max-width:800px}.profile-card{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden}.profile-card .card-header{padding:var(--spacing-lg);border-bottom:2px solid var(--color-light);display:flex;justify-content:space-between;align-items:center}.profile-card .card-header h2{font-size:1.5rem;font-weight:700;color:var(--color-dark)}.profile-form{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.profile-form input:disabled,.profile-form textarea:disabled{background:var(--color-light);cursor:not-allowed}.profile-form textarea{width:100%;min-height:100px;padding:var(--spacing-sm);border:1px solid #ddd;border-radius:var(--radius-md);font-family:inherit;font-size:1rem;line-height:1.5;resize:vertical;transition:border-color .3s}.profile-form textarea:focus{outline:none;border-color:var(--color-primary)}.profile-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.danger-zone{border:2px solid #DC2626}.danger-zone .card-header h2{color:#dc2626}.danger-zone p{padding:var(--spacing-lg);color:var(--color-gray);margin:0}.btn-danger{margin:0 var(--spacing-lg) var(--spacing-lg);background:#dc2626;color:var(--color-white);padding:.75rem 1.5rem;border:none;border-radius:var(--radius-lg);font-weight:600;cursor:pointer;transition:var(--transition)}.btn-danger:hover{background:#b91c1c;transform:translateY(-2px)}@media(max-width:768px){.profile-header{flex-direction:column;text-align:center}.profile-header h1{font-size:2rem}}.preferences-page{min-height:100vh;background:var(--color-background, #f8f9fa);padding:var(--spacing-xl, 2rem) var(--spacing-md, 1rem)}.preferences-container{max-width:900px;margin:0 auto}.preferences-header{margin-bottom:var(--spacing-xl, 2rem)}.preferences-header h1{font-size:2rem;font-weight:800;color:var(--color-dark, #1a1a1a);margin-bottom:var(--spacing-xs, .5rem)}.preferences-header p{color:var(--color-gray, #666);font-size:1rem}.preferences-grid{display:flex;flex-direction:column;gap:var(--spacing-lg, 1.5rem)}.preference-card{background:var(--color-white, #fff);border-radius:var(--radius-xl, 12px);box-shadow:var(--shadow-md, 0 4px 6px rgba(0, 0, 0, .1));overflow:hidden}.preference-card .card-header{padding:var(--spacing-lg, 1.5rem);border-bottom:2px solid var(--color-light, #f0f0f0)}.preference-card .card-header h2{font-size:1.25rem;font-weight:700;color:var(--color-dark, #1a1a1a);margin-bottom:var(--spacing-xs, .5rem)}.preference-card .card-header p{color:var(--color-gray, #666);font-size:.9rem}.preference-content{padding:var(--spacing-lg, 1.5rem);display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.preference-item{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md, 1rem);padding:var(--spacing-sm, .75rem) 0}.preference-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem)}.preference-info strong{color:var(--color-dark, #1a1a1a);font-weight:600;font-size:.95rem}.preference-info span{color:var(--color-gray, #666);font-size:.85rem}.preference-divider{height:1px;background:var(--color-light, #f0f0f0);margin:var(--spacing-sm, .5rem) 0}.preference-select{display:flex;flex-direction:column;gap:var(--spacing-xs, .5rem)}.preference-select label{color:var(--color-dark, #1a1a1a);font-weight:600;font-size:.95rem}.preference-select select{padding:var(--spacing-sm, .75rem);border:1px solid #ddd;border-radius:var(--radius-md, 8px);font-size:1rem;color:var(--color-dark, #1a1a1a);background:var(--color-white, #fff);cursor:pointer;transition:border-color .3s}.preference-select select:focus{outline:none;border-color:var(--color-primary, var(--color-primary));box-shadow:0 0 0 3px #667eea1a}.preferences-actions{margin-top:var(--spacing-xl, 2rem);display:flex;justify-content:center}.preferences-actions .btn{padding:var(--spacing-sm, .75rem) var(--spacing-xl, 2rem);font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-lg, 10px);cursor:pointer;transition:all .3s}.preferences-actions .btn-primary{background:var(--gradient-primary, linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%));color:var(--color-white, #fff)}.preferences-actions .btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.preferences-actions .btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media(max-width:768px){.preferences-page{padding:var(--spacing-md, 1rem) var(--spacing-sm, .5rem)}.preferences-header h1{font-size:1.5rem}.preference-item{flex-direction:column;align-items:flex-start}.toggle-switch{align-self:flex-end}}.settings-page{min-height:100vh;background:var(--color-background, #f8f9fa);padding:var(--spacing-xl, 2rem) var(--spacing-md, 1rem)}.settings-container{max-width:900px;margin:0 auto}.settings-header{margin-bottom:var(--spacing-xl, 2rem)}.settings-header h1{font-size:2rem;font-weight:800;color:var(--color-dark, #1a1a1a);margin-bottom:var(--spacing-xs, .5rem)}.settings-header p{color:var(--color-gray, #666);font-size:1rem}.settings-grid{display:flex;flex-direction:column;gap:var(--spacing-lg, 1.5rem)}.settings-card{background:var(--color-white, #fff);border-radius:var(--radius-xl, 12px);box-shadow:var(--shadow-md, 0 4px 6px rgba(0, 0, 0, .1));overflow:hidden}.settings-card.danger-card{border:2px solid #ff4444}.settings-card .card-header{padding:var(--spacing-lg, 1.5rem);border-bottom:2px solid var(--color-light, #f0f0f0)}.danger-card .card-header{background:#fff5f5;border-bottom-color:#fcc}.settings-card .card-header h2{font-size:1.25rem;font-weight:700;color:var(--color-dark, #1a1a1a);margin-bottom:var(--spacing-xs, .5rem)}.settings-card .card-header p{color:var(--color-gray, #666);font-size:.9rem}.settings-content{padding:var(--spacing-lg, 1.5rem);display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.setting-item{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md, 1rem);padding:var(--spacing-sm, .75rem) 0}.setting-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem)}.setting-info strong{color:var(--color-dark, #1a1a1a);font-weight:600;font-size:.95rem}.setting-info span{color:var(--color-gray, #666);font-size:.85rem}.setting-divider{height:1px;background:var(--color-light, #f0f0f0);margin:var(--spacing-sm, .5rem) 0}.setting-select{padding:var(--spacing-xs, .5rem) var(--spacing-sm, .75rem);border:1px solid #ddd;border-radius:var(--radius-md, 8px);font-size:.95rem;color:var(--color-dark, #1a1a1a);background:var(--color-white, #fff);cursor:pointer;transition:border-color .3s}.setting-select:focus{outline:none;border-color:var(--color-primary, var(--color-primary));box-shadow:0 0 0 3px #667eea1a}.toggle-switch{position:relative;display:inline-block;width:50px;height:26px;flex-shrink:0;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background:var(--gradient-primary, linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%))}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 0 3px #667eea33}.danger-item{padding:var(--spacing-md, 1rem);background:#fff5f5;border:1px solid #ffcccc;border-radius:var(--radius-md, 8px)}.danger-info{margin-bottom:var(--spacing-md, 1rem)}.danger-info strong{display:block;color:#c00;font-weight:700;font-size:1.1rem;margin-bottom:var(--spacing-xs, .5rem)}.danger-info p{color:#666;font-size:.9rem;line-height:1.5}.btn-danger{background:#f44;color:#fff;padding:var(--spacing-sm, .75rem) var(--spacing-md, 1rem);border:none;border-radius:var(--radius-md, 8px);font-weight:600;cursor:pointer;transition:all .3s}.btn-danger:hover:not(:disabled){background:#c00;transform:translateY(-2px);box-shadow:0 4px 12px #f446}.btn-danger:disabled{opacity:.6;cursor:not-allowed;transform:none}.settings-actions{margin-top:var(--spacing-xl, 2rem);display:flex;justify-content:center}.settings-actions .btn{padding:var(--spacing-sm, .75rem) var(--spacing-xl, 2rem);font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-lg, 10px);cursor:pointer;transition:all .3s}.settings-actions .btn-primary{background:var(--gradient-primary, linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%));color:var(--color-white, #fff)}.settings-actions .btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.settings-actions .btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md, 1rem)}.modal-content{background:var(--color-white, #fff);border-radius:var(--radius-xl, 12px);padding:var(--spacing-xl, 2rem);max-width:500px;width:100%;box-shadow:0 10px 40px #0000004d}.modal-content h3{font-size:1.5rem;font-weight:700;color:#c00;margin-bottom:var(--spacing-md, 1rem)}.modal-content p{color:var(--color-gray, #666);margin-bottom:var(--spacing-sm, .75rem);line-height:1.5}.confirm-input{width:100%;padding:var(--spacing-sm, .75rem);border:2px solid #ddd;border-radius:var(--radius-md, 8px);font-size:1rem;margin-top:var(--spacing-sm, .75rem);margin-bottom:var(--spacing-md, 1rem)}.confirm-input:focus{outline:none;border-color:#f44;box-shadow:0 0 0 3px #ff44441a}.modal-actions{display:flex;gap:var(--spacing-md, 1rem);justify-content:flex-end}.btn-secondary{background:var(--color-light, #f0f0f0);color:var(--color-dark, #1a1a1a);padding:var(--spacing-sm, .75rem) var(--spacing-md, 1rem);border:none;border-radius:var(--radius-md, 8px);font-weight:600;cursor:pointer;transition:all .3s}@media(max-width:768px){.settings-page{padding:var(--spacing-md, 1rem) var(--spacing-sm, .5rem)}.settings-header h1{font-size:1.5rem}.setting-item{flex-direction:column;align-items:flex-start}.toggle-switch,.setting-select{align-self:flex-end}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}.referral-page{min-height:100vh;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);padding:var(--spacing-xl, 2rem) var(--spacing-md, 1rem)}.referral-container{max-width:1000px;margin:0 auto}.referral-header{text-align:center;color:#fff;margin-bottom:var(--spacing-xl, 2rem)}.referral-header h1{font-size:2.5rem;font-weight:900;margin-bottom:var(--spacing-sm, .75rem);text-shadow:0 2px 10px rgba(0,0,0,.2)}.referral-header p{font-size:1.2rem;opacity:.95}.referral-code-card{background:#fff;border-radius:var(--radius-xl, 16px);padding:var(--spacing-xl, 2rem);margin-bottom:var(--spacing-xl, 2rem);box-shadow:0 10px 40px #00000026}.referral-code-card .card-header{text-align:center;margin-bottom:var(--spacing-lg, 1.5rem)}.referral-code-card .card-header h2{font-size:1.5rem;font-weight:700;color:var(--color-dark, #1a1a1a);margin-bottom:var(--spacing-xs, .5rem)}.referral-code-card .card-header p{color:var(--color-gray, #666);font-size:.95rem}.code-display{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md, 1rem);margin-bottom:var(--spacing-lg, 1.5rem)}.code-badge{font-size:2.5rem;font-weight:900;color:var(--color-primary);letter-spacing:4px;padding:var(--spacing-md, 1rem) var(--spacing-xl, 2rem);background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:var(--radius-lg, 12px);border:3px dashed var(--color-primary)}.btn-copy{padding:var(--spacing-sm, .75rem) var(--spacing-lg, 1.5rem);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md, 8px);font-weight:600;cursor:pointer;transition:all .3s}.btn-copy:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-copy.copied{background:#28a745}.share-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md, 1rem);margin-bottom:var(--spacing-md, 1rem)}.btn-share{padding:var(--spacing-sm, .75rem);border:none;border-radius:var(--radius-md, 8px);font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs, .5rem)}.btn-share span{font-size:1.2rem}.btn-share.whatsapp{background:#25d366;color:#fff}.btn-share.facebook{background:#1877f2;color:#fff}.btn-share.twitter{background:#1da1f2;color:#fff}.btn-share.email{background:#ea4335;color:#fff}.btn-share:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn-copy-link{width:100%;padding:var(--spacing-sm, .75rem);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;border:none;border-radius:var(--radius-md, 8px);font-weight:600;cursor:pointer;transition:all .3s}.btn-copy-link:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md, 1rem);margin-bottom:var(--spacing-xl, 2rem)}.stat-card{background:#fff;border-radius:var(--radius-xl, 16px);padding:var(--spacing-lg, 1.5rem);text-align:center;box-shadow:0 4px 12px #0000001a;transition:transform .3s}.stat-card:hover{transform:translateY(-4px)}.stat-card.highlight{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff}.stat-icon{font-size:2.5rem;margin-bottom:var(--spacing-sm, .75rem)}.stat-value{font-size:2rem;font-weight:900;margin-bottom:var(--spacing-xs, .5rem)}.stat-label{font-size:.9rem;opacity:.8}.how-it-works{background:#fff;border-radius:var(--radius-xl, 16px);padding:var(--spacing-xl, 2rem);margin-bottom:var(--spacing-xl, 2rem);box-shadow:0 4px 12px #0000001a}.how-it-works h3{font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:var(--spacing-lg, 1.5rem)}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg, 1.5rem)}.step{text-align:center;padding:var(--spacing-md, 1rem)}.step-number{width:60px;height:60px;margin:0 auto var(--spacing-md, 1rem);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:900}.step h4{font-size:1.1rem;font-weight:700;margin-bottom:var(--spacing-xs, .5rem)}.step p{color:var(--color-gray, #666);font-size:.9rem}.referrals-list-card{background:#fff;border-radius:var(--radius-xl, 16px);padding:var(--spacing-xl, 2rem);box-shadow:0 4px 12px #0000001a}.referrals-list-card .card-header{margin-bottom:var(--spacing-lg, 1.5rem);padding-bottom:var(--spacing-md, 1rem);border-bottom:2px solid var(--color-light, #f0f0f0)}.referrals-list-card .card-header h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-xs, .5rem)}.referrals-list-card .card-header p{color:var(--color-gray, #666)}.referrals-list{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.referral-item{display:flex;align-items:center;gap:var(--spacing-md, 1rem);padding:var(--spacing-md, 1rem);background:var(--color-light, #f8f9fa);border-radius:var(--radius-lg, 12px);transition:all .3s}.referral-item:hover{background:#e9ecef;transform:translate(4px)}.referral-avatar{width:60px;height:60px;border-radius:50%;overflow:hidden;flex-shrink:0}.referral-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700}.referral-info{flex:1}.referral-name{font-weight:600;font-size:1rem;margin-bottom:var(--spacing-xs, .25rem)}.referral-email{color:var(--color-gray, #666);font-size:.85rem;margin-bottom:var(--spacing-xs, .25rem)}.referral-date{color:var(--color-gray, #999);font-size:.8rem}.referral-reward{text-align:right}.reward-amount{font-size:1.2rem;font-weight:700;color:#28a745;margin-bottom:var(--spacing-xs, .5rem)}.reward-status{font-size:.85rem;padding:var(--spacing-xs, .25rem) var(--spacing-sm, .5rem);border-radius:var(--radius-sm, 6px);margin-bottom:var(--spacing-xs, .5rem)}.reward-status.pending{background:#fff3cd;color:#856404}.reward-status.awarded{background:#d4edda;color:#155724}.reward-status.claimed{background:#d1ecf1;color:#0c5460}.btn-claim{padding:var(--spacing-xs, .5rem) var(--spacing-sm, .75rem);background:#28a745;color:#fff;border:none;border-radius:var(--radius-sm, 6px);font-weight:600;cursor:pointer;transition:all .3s;font-size:.85rem}.btn-claim:hover{background:#218838;transform:translateY(-2px)}.empty-state{background:#fff;border-radius:var(--radius-xl, 16px);padding:var(--spacing-xl, 3rem);text-align:center;box-shadow:0 4px 12px #0000001a}.empty-state h3{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-sm, .75rem);color:var(--color-dark, #1a1a1a)}.empty-state p{color:var(--color-gray, #666);font-size:1rem}@media(max-width:768px){.referral-page{padding:var(--spacing-md, 1rem) var(--spacing-sm, .5rem)}.referral-header h1{font-size:1.8rem}.code-badge{font-size:1.8rem;letter-spacing:2px;padding:var(--spacing-sm, .75rem) var(--spacing-md, 1rem)}.code-display{flex-direction:column}.stats-grid{grid-template-columns:repeat(2,1fr)}.steps-grid{grid-template-columns:1fr}.referral-item{flex-direction:column;text-align:center}.referral-reward{text-align:center}}.activity-page{min-height:100vh;background:var(--color-background, #f8f9fa);padding:var(--spacing-xl, 2rem) var(--spacing-md, 1rem)}.activity-container{max-width:1200px;margin:0 auto}.activity-header{margin-bottom:var(--spacing-xl, 2rem);text-align:center}.activity-header h1{font-size:2.5rem;font-weight:900;color:var(--color-dark, #1a1a1a);margin-bottom:var(--spacing-xs, .5rem)}.activity-header p{color:var(--color-gray, #666);font-size:1.1rem}.activity-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md, 1rem);margin-bottom:var(--spacing-xl, 2rem)}.activity-stat-card{background:#fff;border-radius:var(--radius-xl, 16px);padding:var(--spacing-lg, 1.5rem);text-align:center;box-shadow:0 4px 12px #00000014;transition:all .3s}.activity-stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001f}.activity-stat-card.highlight{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff}.activity-stat-card .stat-icon{font-size:2.5rem;margin-bottom:var(--spacing-sm, .75rem)}.activity-stat-card .stat-value{font-size:2rem;font-weight:900;margin-bottom:var(--spacing-xs, .5rem)}.activity-stat-card .stat-label{font-size:.9rem;opacity:.9}.activity-feed-card{background:#fff;border-radius:var(--radius-xl, 16px);box-shadow:0 4px 12px #00000014;overflow:hidden}.feed-header{padding:var(--spacing-lg, 1.5rem);border-bottom:2px solid var(--color-light, #f0f0f0)}.feed-header h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-md, 1rem)}.activity-tabs{display:flex;gap:var(--spacing-sm, .5rem);flex-wrap:wrap}.activity-tabs .tab{padding:var(--spacing-xs, .5rem) var(--spacing-md, 1rem);border:2px solid var(--color-light, #e0e0e0);background:transparent;border-radius:var(--radius-lg, 10px);font-weight:600;cursor:pointer;transition:all .3s;color:var(--color-gray, #666)}.activity-tabs .tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.activity-tabs .tab.active{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border-color:var(--color-primary);color:#fff}.activity-timeline{padding:var(--spacing-lg, 1.5rem);max-height:700px;overflow-y:auto}.activity-item{display:flex;gap:var(--spacing-md, 1rem);padding:var(--spacing-md, 1rem);margin-bottom:var(--spacing-md, 1rem);border-left:4px solid var(--color-primary);border-radius:var(--radius-md, 8px);background:var(--color-light, #f8f9fa);cursor:pointer;transition:all .3s;position:relative}.activity-item:hover{background:#e9ecef;transform:translate(4px);box-shadow:0 4px 12px #0000001a}.activity-icon{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;color:#fff}.activity-content{flex:1}.activity-title{font-weight:700;font-size:1.05rem;color:var(--color-dark, #1a1a1a);margin-bottom:var(--spacing-xs, .25rem)}.activity-description{color:var(--color-gray, #666);font-size:.9rem;margin-bottom:var(--spacing-xs, .5rem)}.activity-meta{display:flex;gap:var(--spacing-md, 1rem);align-items:center;font-size:.85rem}.activity-date{color:var(--color-gray, #999)}.activity-amount{color:#28a745;font-weight:700;padding:var(--spacing-xs, .25rem) var(--spacing-sm, .5rem);background:#d4edda;border-radius:var(--radius-sm, 6px)}.activity-arrow{align-self:center;color:var(--color-gray, #999);font-size:1.5rem;opacity:0;transition:opacity .3s}.activity-item:hover .activity-arrow{opacity:1}.empty-activity{text-align:center;padding:var(--spacing-xl, 3rem)}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-md, 1rem);opacity:.5}.empty-activity h3{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-sm, .75rem);color:var(--color-dark, #1a1a1a)}.empty-activity p{color:var(--color-gray, #666);font-size:1rem}.activity-timeline::-webkit-scrollbar{width:8px}.activity-timeline::-webkit-scrollbar-track{background:var(--color-light, #f0f0f0);border-radius:10px}.activity-timeline::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:10px}.activity-timeline::-webkit-scrollbar-thumb:hover{background:#5568d3}@media(max-width:768px){.activity-page{padding:var(--spacing-md, 1rem) var(--spacing-sm, .5rem)}.activity-header h1{font-size:1.8rem}.activity-stats-grid{grid-template-columns:repeat(2,1fr)}.activity-tabs{justify-content:center}.activity-tabs .tab{font-size:.85rem;padding:var(--spacing-xs, .5rem)}.activity-item{flex-direction:column;text-align:center}.activity-icon{margin:0 auto}.activity-arrow{display:none}.activity-timeline{max-height:500px}}.gift-cards-page{min-height:100vh;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);padding:2rem 1rem}.gift-cards-container{max-width:1200px;margin:0 auto}.gift-cards-header{text-align:center;color:#fff;margin-bottom:2rem}.gift-cards-header h1{font-size:3rem;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.gift-cards-header p{font-size:1.2rem;opacity:.95}.gift-cards-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}.gift-cards-actions .btn{padding:1rem 2rem;font-size:1.1rem;border-radius:12px;border:none;cursor:pointer;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #0003}.gift-cards-actions .btn-primary{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff}.gift-cards-actions .btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.gift-cards-actions .btn-secondary{background:#fff;color:var(--color-primary)}.gift-cards-actions .btn-secondary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.gift-cards-tabs{display:flex;gap:.5rem;background:#ffffff26;padding:.5rem;border-radius:12px;margin-bottom:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gift-cards-tabs .tab{flex:1;padding:1rem;background:transparent;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .3s ease}.gift-cards-tabs .tab:hover{background:#ffffff1a}.gift-cards-tabs .tab.active{background:#fff;color:var(--color-primary);box-shadow:0 4px 12px #00000026}.how-it-works-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.info-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 20px #0000001a}.info-card h3{color:var(--color-primary);margin-bottom:1.5rem;font-size:1.5rem}.info-card ol,.info-card ul{padding-left:1.5rem}.info-card li{margin-bottom:.75rem;color:#555;line-height:1.6}.cards-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;margin-top:2rem}.gift-card-item{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.gift-card-item:hover{transform:translateY(-5px);box-shadow:0 8px 30px #00000026}.card-visual{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);padding:2rem;color:#fff;position:relative;min-height:150px;display:flex;flex-direction:column;justify-content:space-between}.card-visual.redeemed{background:linear-gradient(135deg,#95a5a6,#7f8c8d)}.card-amount{font-size:2.5rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.card-code{font-family:Courier New,monospace;font-size:1.2rem;letter-spacing:2px;opacity:.9}.redeemed-badge{position:absolute;top:1rem;right:1rem;background:#ffffff4d;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:700}.card-details{padding:1.5rem}.detail-row{display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #eee}.detail-row:last-child{border-bottom:none}.detail-row .label{color:#888;font-weight:500}.detail-row .value{color:#333;font-weight:600}.status{padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:uppercase}.status.active{background:#d4edda;color:#155724}.status.redeemed{background:#cce5ff;color:#004085}.status.expired{background:#f8d7da;color:#721c24}.status.cancelled{background:#e2e3e5;color:#383d41}.card-message{margin-top:1rem;padding:1rem;background:#f8f9fa;border-left:3px solid var(--color-primary);border-radius:4px;font-style:italic;color:#555}.btn-copy-code{width:100%;padding:.75rem;background:var(--color-primary);color:#fff;border:none;border-radius:0;cursor:pointer;font-weight:600;transition:background .3s ease}.btn-copy-code:hover{background:#5568d3}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;grid-column:1 / -1}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{color:#333;margin-bottom:.5rem}.empty-state p{color:#888}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:16px;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 40px #0000004d}.modal-content h3{color:var(--color-primary);margin-bottom:1.5rem;font-size:1.8rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:600}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary)}.form-group textarea{resize:vertical;font-family:inherit}.amount-presets{display:flex;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.preset-btn{padding:.5rem 1rem;border:2px solid #e0e0e0;background:#fff;color:#666;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.preset-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.preset-btn.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.modal-actions{display:flex;gap:1rem;margin-top:2rem;justify-content:flex-end}.modal-actions .btn{padding:.75rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.modal-actions .btn-secondary{background:#e0e0e0;color:#666}.modal-actions .btn-secondary:hover{background:#d0d0d0}.modal-actions .btn-primary{background:var(--color-primary);color:#fff}.modal-actions .btn-primary:hover{background:#5568d3}.modal-actions .btn:disabled{opacity:.5;cursor:not-allowed}.valid-card-info{margin:1.5rem 0;padding:1.5rem;background:#d4edda;border-radius:8px;border-left:4px solid #28a745}.success-message{color:#155724;font-weight:700;font-size:1.1rem;margin-bottom:1rem}.card-info p{color:#155724;margin:.5rem 0}@media(max-width:768px){.gift-cards-header h1{font-size:2rem}.gift-cards-header p{font-size:1rem}.gift-cards-actions{flex-direction:column}.gift-cards-actions .btn{width:100%}.gift-cards-tabs{flex-direction:column}.cards-list,.how-it-works-section{grid-template-columns:1fr}.modal-content{padding:1.5rem}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.wishlist-page{min-height:100vh;background:linear-gradient(135deg,#f093fb,#f5576c);padding:2rem 1rem}.wishlist-container{max-width:1400px;margin:0 auto}.wishlist-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;color:#fff;flex-wrap:wrap;gap:1rem}.wishlist-header h1{font-size:3rem;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.wishlist-header p{font-size:1.2rem;opacity:.95}.view-toggle{display:flex;gap:.5rem;background:#fff3;padding:.25rem;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toggle-btn{padding:.75rem 1.5rem;background:transparent;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s ease}.toggle-btn:hover{background:#fff3}.toggle-btn.active{background:#fff;color:#f5576c}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;text-align:center;box-shadow:0 4px 15px #0000001a;transition:transform .3s ease}.stat-card:hover{transform:translateY(-5px)}.stat-card.events{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff}.stat-card.establishments{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.stat-card.products{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.stat-value{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{font-size:1rem;opacity:.9}.wishlist-tabs{display:flex;gap:.5rem;background:#ffffff26;padding:.5rem;border-radius:12px;margin-bottom:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-wrap:wrap}.wishlist-tabs .tab{flex:1;min-width:150px;padding:1rem;background:transparent;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .3s ease}.wishlist-tabs .tab:hover{background:#ffffff1a}.wishlist-tabs .tab.active{background:#fff;color:#f5576c;box-shadow:0 4px 12px #00000026}.wishlist-grid.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.wishlist-grid.list{display:flex;flex-direction:column;gap:1.5rem}.wishlist-item{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.wishlist-item:hover{transform:translateY(-5px);box-shadow:0 8px 30px #00000026}.wishlist-item.list{display:flex;flex-direction:row}.wishlist-item.list .item-image{width:300px;height:250px;flex-shrink:0}.item-image{position:relative;height:250px;overflow:hidden;cursor:pointer}.item-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.item-image:hover img{transform:scale(1.05)}.item-badge{position:absolute;top:1rem;right:1rem;background:#fffffff2;color:#333;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem;box-shadow:0 2px 8px #0003}.item-badge.event{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff}.item-badge.establishment{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.item-badge.product{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.item-content{padding:1.5rem;flex:1}.item-content h3{color:#333;margin-bottom:.75rem;font-size:1.4rem;cursor:pointer;transition:color .3s ease}.item-content h3:hover{color:#f5576c}.item-description{color:#666;line-height:1.6;margin-bottom:1rem}.item-info{margin-bottom:1rem}.info-item{display:flex;align-items:center;gap:.5rem;color:#555;margin-bottom:.5rem}.info-item .icon{font-size:1.1rem}.price{font-size:1.5rem;font-weight:700;color:#f5576c;margin:.5rem 0}.rating{color:orange;font-weight:600;margin:.5rem 0}.out-of-stock{color:#e74c3c;font-weight:600;margin:.5rem 0}.item-notes{background:#f8f9fa;padding:.75rem;border-left:3px solid #f5576c;border-radius:4px;margin-bottom:1rem;display:flex;align-items:flex-start;gap:.5rem;font-style:italic;color:#555}.item-actions{display:flex;gap:.75rem;margin-top:1rem}.item-actions .btn{flex:1;padding:.75rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.item-actions .btn-primary{background:#f5576c;color:#fff}.item-actions .btn-primary:hover{background:#e04659;transform:translateY(-2px)}.item-actions .btn-danger{background:#e0e0e0;color:#666}.item-actions .btn-danger:hover{background:#e74c3c;color:#fff}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000001a}.empty-icon{font-size:5rem;margin-bottom:1rem}.empty-state h3{color:#333;font-size:2rem;margin-bottom:1rem}.empty-state p{color:#666;font-size:1.2rem;margin-bottom:2rem}.empty-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.empty-actions .btn{padding:1rem 2rem;border:none;border-radius:12px;cursor:pointer;font-weight:600;font-size:1.1rem;transition:all .3s ease}.empty-actions .btn-primary{background:#f5576c;color:#fff}.empty-actions .btn-primary:hover{background:#e04659;transform:translateY(-2px)}.empty-actions .btn-secondary{background:#fff;color:#f5576c;border:2px solid #f5576c}.empty-actions .btn-secondary:hover{background:#f5576c;color:#fff;transform:translateY(-2px)}@media(max-width:1024px){.wishlist-grid.grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.wishlist-item.list{flex-direction:column}.wishlist-item.list .item-image{width:100%;height:250px}}@media(max-width:768px){.wishlist-header{flex-direction:column;align-items:flex-start}.wishlist-header h1{font-size:2rem}.wishlist-header p{font-size:1rem}.view-toggle{width:100%}.toggle-btn{flex:1}.stats-grid{grid-template-columns:repeat(2,1fr)}.wishlist-tabs{flex-direction:column}.wishlist-tabs .tab{min-width:100%}.wishlist-grid.grid{grid-template-columns:1fr}.item-actions,.empty-actions{flex-direction:column}.empty-actions .btn{width:100%}}.owner-dashboard{padding:40px 20px;min-height:calc(100vh - 200px)}.owner-dashboard .container{max-width:1400px;margin:0 auto}.owner-dashboard .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:40px;gap:20px;flex-wrap:wrap}.owner-dashboard .page-header>div:first-child{flex:1}.owner-dashboard .page-header h1{font-size:2.5rem;color:#1a1a2e;margin:0 0 .5rem}.owner-dashboard .header-subtitle{color:#64748b;font-size:1.1rem;margin:0}.owner-dashboard .header-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.time-range-selector{display:flex;gap:.5rem;background:#fff;padding:.25rem;border-radius:12px;box-shadow:0 2px 8px #00000014}.time-range-selector button{padding:.5rem 1rem;border:none;background:transparent;color:#64748b;font-size:.9rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease}.time-range-selector button:hover{background:#f8fafc;color:#1a1a2e}.time-range-selector button.active{background:var(--color-primary);color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:25px;margin-bottom:50px}.stat-card{background:#fff;border-radius:16px;padding:25px;box-shadow:0 4px 20px #00000014;display:flex;gap:20px;align-items:flex-start;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #0000001f}.stat-icon{font-size:3rem;flex-shrink:0}.stat-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.stat-label{color:#64748b;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2.5rem;font-weight:800;color:#1a1a2e;line-height:1}.stat-footer{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.25rem}.stat-footer .growth{font-size:.85rem;font-weight:700;padding:.25rem .5rem;border-radius:6px}.stat-footer .growth.positive{color:var(--color-primary);background:#d1fae5}.stat-footer .growth.negative{color:#ef4444;background:#fee2e2}.stat-footer .stat-detail{color:#94a3b8;font-size:.85rem}.stat-alert{color:#ef4444;font-size:.85rem;font-weight:600}.stat-info{color:var(--color-primary);font-size:.85rem;font-weight:600}.dashboard-content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:25px;margin-bottom:50px}.dashboard-section{background:#fff;border-radius:16px;padding:25px;box-shadow:0 2px 12px #0000000f}.dashboard-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f1f5f9}.dashboard-section .section-header h2{font-size:1.4rem;color:#1a1a2e;margin:0}.products-list{display:flex;flex-direction:column;gap:15px}.product-item{display:flex;align-items:center;gap:15px;padding:15px;background:#f8fafc;border-radius:12px;transition:all .3s ease}.product-item:hover{background:#f1f5f9;transform:translate(5px)}.product-rank{width:35px;height:35px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary),#FFD700);color:#fff;font-weight:800;border-radius:8px;font-size:.9rem;flex-shrink:0}.product-info{flex:1}.product-info h4{margin:0 0 4px;color:#1a1a2e;font-size:1rem}.product-info p{margin:0;color:#64748b;font-size:.85rem}.product-revenue{font-size:1.1rem;font-weight:700;color:var(--color-primary);flex-shrink:0}.reservations-preview-list{display:flex;flex-direction:column;gap:15px}.reservation-preview-item{display:flex;align-items:center;gap:15px;padding:15px;background:#f8fafc;border-radius:12px;transition:all .3s ease}.reservation-preview-item:hover{background:#f1f5f9;box-shadow:0 4px 12px #00000014}.reservation-date-badge{width:60px;height:60px;background:linear-gradient(135deg,var(--color-primary),#00d664);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.reservation-date-badge .date-day{font-size:1.5rem;font-weight:800;line-height:1}.reservation-date-badge .date-month{font-size:.75rem;font-weight:600;text-transform:uppercase;margin-top:2px}.reservation-preview-info{flex:1;min-width:0}.reservation-preview-info h4{margin:0 0 6px;color:#1a1a2e;font-size:1rem}.reservation-preview-info p{margin:0;color:#64748b;font-size:.85rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.reservation-preview-info .separator{color:#cbd5e1}.reservation-preview-time{font-size:1.1rem;font-weight:700;color:var(--color-primary);background:#fff;padding:.5rem 1rem;border-radius:8px;flex-shrink:0}.events-preview-list{display:flex;flex-direction:column;gap:15px}.event-preview-item{display:flex;align-items:center;gap:15px;padding:15px;background:#f8fafc;border-radius:12px;transition:all .3s ease}.event-preview-item:hover{background:#f1f5f9;box-shadow:0 4px 12px #00000014}.event-date-badge{width:60px;height:60px;background:linear-gradient(135deg,gold,orange);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.event-date-badge .date-day{font-size:1.5rem;font-weight:800;line-height:1}.event-date-badge .date-month{font-size:.75rem;font-weight:600;text-transform:uppercase;margin-top:2px}.event-preview-info{flex:1;min-width:0}.event-preview-info h4{margin:0 0 6px;color:#1a1a2e;font-size:1rem}.event-preview-info p{margin:0;color:#64748b;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.event-preview-time{font-size:1.1rem;font-weight:700;color:orange;background:#fff;padding:.5rem 1rem;border-radius:8px;flex-shrink:0}.quick-actions-section{margin-bottom:50px}.quick-actions-section h2{font-size:1.8rem;color:#1a1a2e;margin-bottom:25px}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.action-card{background:linear-gradient(135deg,var(--color-primary) 0%,#FFD700 100%);border-radius:16px;padding:30px;text-decoration:none;color:#fff;display:flex;flex-direction:column;align-items:center;text-align:center;gap:15px;transition:transform .3s ease,box-shadow .3s ease;box-shadow:0 4px 15px #7c3aed33}.action-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #7c3aed4d}.action-icon{font-size:2.5rem}.action-label{font-size:1.1rem;font-weight:600}.recent-orders-section{margin-bottom:50px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.section-header h2{font-size:1.8rem;color:#1a1a2e;margin:0}.view-all-link{color:var(--color-primary);text-decoration:none;font-weight:600;transition:color .3s ease}.view-all-link:hover{color:#008040}.orders-table{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;overflow:hidden}.orders-table table{width:100%;border-collapse:collapse}.orders-table thead{background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.orders-table th{padding:15px 20px;text-align:left;font-weight:600;color:#1a1a2e;font-size:.9rem}.orders-table td{padding:15px 20px;border-top:1px solid #f1f5f9;color:#64748b}.orders-table tbody tr{transition:background-color .2s ease}.orders-table tbody tr:hover{background-color:#f8fafc}.status-badge{padding:6px 12px;border-radius:12px;font-size:.85rem;font-weight:600;display:inline-block}.status-pending{background-color:#fef3c7;color:#92400e}.status-confirmed{background-color:#dbeafe;color:#1e40af}.status-preparing{background-color:#e0e7ff;color:#3730a3}.status-ready,.status-completed{background-color:#d1fae5;color:#065f46}.status-cancelled{background-color:#fee2e2;color:#991b1b}.loading{text-align:center;padding:60px 20px;color:#64748b;font-size:1.1rem}.empty-state-message{text-align:center;padding:40px 20px;background:#f8fafc;border-radius:12px;border:2px dashed #e2e8f0}.empty-state-message p{color:#64748b;font-size:1rem;margin:0}@media(max-width:768px){.stats-grid,.dashboard-content-grid{grid-template-columns:1fr}.actions-grid{grid-template-columns:repeat(2,1fr)}.owner-dashboard .header-actions{width:100%;flex-direction:column}.time-range-selector{width:100%;justify-content:space-between}.time-range-selector button{flex:1;padding:.6rem .5rem;font-size:.8rem}.orders-table{overflow-x:auto}.orders-table table{min-width:600px}.reservation-preview-item{flex-wrap:wrap}.reservation-preview-time{margin-left:75px}.event-preview-item{flex-wrap:wrap}.event-preview-time{margin-left:75px}}@media(max-width:576px){.owner-dashboard .page-header{flex-direction:column;align-items:flex-start}.actions-grid,.dashboard-content-grid{grid-template-columns:1fr}.stat-card{flex-direction:column;align-items:center;text-align:center}.product-item{flex-wrap:wrap}.product-revenue{width:100%;text-align:center;padding-top:10px;border-top:1px solid #e2e8f0}}.product-item.clickable,.reservation-preview-item.clickable,.event-preview-item.clickable{text-decoration:none;color:inherit;transition:all .3s ease;cursor:pointer}.product-item.clickable:hover,.reservation-preview-item.clickable:hover,.event-preview-item.clickable:hover{transform:translateY(-2px);box-shadow:0 8px 16px #00000026}.clickable-row{transition:background-color .2s ease}.clickable-row:hover{background-color:#f8fafc}.admin-dashboard-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);padding:2rem 0}.admin-container{max-width:1400px;margin:0 auto;padding:0 2rem}.admin-dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.admin-dashboard-header h1{font-size:2.5rem;color:#1a1a2e;margin:0 0 .5rem}.admin-dashboard-header p{color:#64748b;font-size:1.1rem;margin:0}.admin-header-actions{display:flex;gap:1rem}.admin-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.admin-btn-secondary{background:#fff;color:#64748b;box-shadow:0 2px 8px #0000001a}.admin-btn-secondary:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.admin-time-range-selector{display:flex;gap:.5rem;background:#fff;padding:.5rem;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:2rem;width:fit-content}.admin-range-btn{padding:.75rem 1.5rem;border:none;background:transparent;color:#64748b;font-size:.95rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s}.admin-range-btn:hover{background:#f8fafc}.admin-range-btn.active{background:var(--color-primary);color:#fff}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:3rem}.admin-stat-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 12px #00000014;transition:transform .2s,box-shadow .2s}.admin-stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 20px #0000001f}.admin-stat-icon{font-size:2.5rem;margin-bottom:1rem}.admin-stat-content{display:flex;flex-direction:column;gap:.5rem}.admin-stat-value{font-size:2rem;font-weight:700;color:#1a1a2e}.admin-stat-label{font-size:.95rem;color:#64748b}.admin-stat-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.admin-stat-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.admin-stat-badge.positive{background:#d1fae5;color:#065f46}.admin-stat-badge.warning{background:#fef3c7;color:#92400e}.admin-stat-growth{font-size:.9rem;font-weight:600}.admin-stat-growth.positive{color:#10b981}.admin-stat-growth.negative{color:#ef4444}.admin-quick-actions-section{margin-bottom:3rem}.admin-quick-actions-section h2{font-size:1.75rem;color:#1a1a2e;margin-bottom:1.5rem}.admin-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.admin-action-card{background:#fff;border-radius:16px;padding:2rem;text-decoration:none;box-shadow:0 2px 12px #00000014;transition:all .3s;display:flex;flex-direction:column;gap:1rem}.admin-action-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #7c3aed33}.admin-action-icon{font-size:3rem}.admin-action-card h3{font-size:1.25rem;color:#1a1a2e;margin:0}.admin-action-card p{font-size:.95rem;color:#64748b;margin:0}.admin-content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-bottom:3rem}.admin-section-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 2px 12px #00000014}.admin-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.admin-section-header h2{font-size:1.5rem;color:#1a1a2e;margin:0}.admin-view-all-link{color:var(--color-primary);text-decoration:none;font-weight:500;font-size:.95rem;transition:color .2s}.admin-view-all-link:hover{color:#008a43}.admin-users-list{display:flex;flex-direction:column;gap:1rem}.admin-user-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:12px;background:#f8fafc;transition:background .2s}.admin-user-item:hover{background:#e2e8f0}.admin-user-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.25rem;flex-shrink:0}.admin-user-info{flex:1;min-width:0}.admin-user-info h4{margin:0 0 .25rem;font-size:1rem;color:#1a1a2e}.admin-user-info p{margin:0;font-size:.875rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-user-meta{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.admin-role-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize}.admin-role-badge.customer{background:#dbeafe;color:#1e40af}.admin-role-badge.owner{background:#fef3c7;color:#92400e}.admin-role-badge.admin{background:#fce7f3;color:#9f1239}.admin-status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize}.admin-status-badge.active{background:#d1fae5;color:#065f46}.admin-status-badge.pending{background:#fef3c7;color:#92400e}.admin-status-badge.suspended{background:#fee2e2;color:#991b1b}.admin-top-list{display:flex;flex-direction:column;gap:1rem}.admin-top-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:12px;background:#f8fafc;transition:background .2s}.admin-top-item:hover{background:#e2e8f0}.admin-top-rank{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,orange,#ff8c00);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex-shrink:0}.admin-top-info{flex:1;min-width:0}.admin-top-info h4{margin:0 0 .25rem;font-size:1rem;color:#1a1a2e}.admin-top-info p{margin:0;font-size:.875rem;color:#64748b}.admin-top-revenue{font-size:1.1rem;font-weight:700;color:var(--color-primary);flex-shrink:0}.admin-platform-health{margin-bottom:3rem}.admin-platform-health h2{font-size:1.75rem;color:#1a1a2e;margin-bottom:1.5rem}.admin-health-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.admin-health-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 2px 12px #00000014;text-align:center}.admin-health-icon{font-size:3rem;margin-bottom:1rem}.admin-health-card h3{font-size:1.25rem;color:#1a1a2e;margin:0 0 .5rem}.admin-health-card p{font-size:.95rem;color:#64748b;margin:0}.admin-dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.admin-dashboard-loading p{color:#64748b;font-size:1.1rem}@media(max-width:768px){.admin-container{padding:0 1rem}.admin-dashboard-header{flex-direction:column;align-items:flex-start}.admin-stats-grid,.admin-actions-grid,.admin-content-grid,.admin-health-grid{grid-template-columns:1fr}.admin-dashboard-header h1{font-size:2rem}.admin-time-range-selector{width:100%}.admin-range-btn{flex:1;padding:.75rem .5rem;font-size:.85rem}}.admin-users-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);padding:2rem 0}.admin-users-page .container{max-width:1400px;margin:0 auto;padding:0 1rem}.page-header h1{font-size:2.5rem;color:#333;margin:0 0 .5rem}.page-header p{font-size:1.1rem;color:#666;margin:0}.search-box{margin-bottom:1rem}.search-box input{width:100%;padding:.75rem 1rem;border:2px solid #e0e7ff;border-radius:8px;font-size:1rem}.role-filters{display:flex;gap:.75rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1rem;border:2px solid #e0e7ff;background:#fff;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s}.users-table{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;overflow-x:auto}table{width:100%;border-collapse:collapse}thead tr{border-bottom:2px solid #e0e7ff}th{padding:1rem;text-align:left;font-weight:700;color:#333}td{padding:1rem;border-bottom:1px solid #f0f0f0}.role-badge{padding:.25rem .75rem;border-radius:999px;font-size:.85rem;font-weight:600}.role-user{background:#dbeafe;color:#1e40af}.role-owner{background:#fef3c7;color:#92400e}.role-admin{background:#fce7f3;color:#9f1239}.status-badge{padding:.25rem .75rem;border-radius:999px;font-size:.85rem;font-weight:600}.status-active{background:#d1fae5;color:#065f46}.status-inactive{background:#fee2e2;color:#991b1b}.actions-cell{display:flex;gap:.5rem}.btn-icon{border:none;background:none;cursor:pointer;font-size:1.2rem;padding:.25rem;transition:transform .2s}.btn-icon:hover{transform:scale(1.2)}.btn-icon.danger{color:#ef4444}.btn-icon.success{color:#10b981}.empty-state{text-align:center;padding:3rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;max-width:500px;width:90%;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid #f0f0f0}.modal-header h2{margin:0;font-size:1.5rem}.close-btn{font-size:2rem;border:none;background:none;cursor:pointer;width:40px;height:40px;border-radius:50%;transition:all .3s}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#333}.form-group input,.form-group select{width:100%;padding:.75rem;border:2px solid #e0e7ff;border-radius:8px;font-size:1rem}.modal-footer{padding:1.5rem;border-top:2px solid #f0f0f0;display:flex;gap:1rem;justify-content:flex-end}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block}.btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;box-shadow:0 4px 12px #667eea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-secondary{background:#fff;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-secondary:hover{background:var(--color-primary);color:#fff}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.users-table{overflow-x:scroll}table{min-width:800px}}.admin-events-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);padding:2rem 0}.admin-events-page .container{max-width:1400px;margin:0 auto;padding:0 1rem}.filters-section{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #00000014}.filter-group{margin-bottom:1rem}.filter-group:last-child{margin-bottom:0}.filter-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#333}.filter-buttons{display:flex;gap:.75rem;flex-wrap:wrap}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.item-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014;transition:all .3s}.item-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026}.item-image{width:100%;height:200px;overflow:hidden;background:#f0f0f0}.item-image img{width:100%;height:100%;object-fit:cover}.placeholder-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;background:linear-gradient(135deg,#e0e7ff,#f0f4ff)}.item-content{padding:1.5rem}.item-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.item-header h3{font-size:1.25rem;margin:0;color:#333;flex:1}.type-badge{padding:.25rem .75rem;border-radius:999px;font-size:.85rem;font-weight:600}.type-event{background:#fef3c7;color:#92400e}.type-establishment{background:#dbeafe;color:#1e40af}.item-description{color:#666;margin-bottom:1rem;line-height:1.5}.item-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0;font-size:.9rem;color:#666}.status-badge{padding:.25rem .75rem;border-radius:999px;font-size:.85rem;font-weight:600;text-transform:capitalize}.status-pending{background:#fef3c7;color:#92400e}.status-approved{background:#d1fae5;color:#065f46}.status-rejected{background:#fee2e2;color:#991b1b}.status-suspended{background:#e5e7eb;color:#374151}.item-actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}@media(max-width:768px){.items-grid{grid-template-columns:1fr}.item-actions{flex-direction:column}.item-actions .btn{width:100%}}.admin-orders-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);padding:2rem 0}.admin-orders-page .container{max-width:1400px;margin:0 auto;padding:0 1rem}.orders-table{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;overflow-x:auto}.text-small{font-size:.85rem;color:#666}.amount-cell{font-weight:700;color:var(--color-primary)}.payment-badge{padding:.25rem .75rem;border-radius:999px;font-size:.85rem;font-weight:600;text-transform:capitalize}.payment-paid{background:#d1fae5;color:#065f46}.payment-pending{background:#fef3c7;color:#92400e}.payment-failed{background:#fee2e2;color:#991b1b}.payment-refunded{background:#e5e7eb;color:#374151}.status-filters{display:flex;gap:.75rem;flex-wrap:wrap}@media(max-width:768px){.orders-table{overflow-x:scroll}table{min-width:900px}}.admin-moderation-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);padding:2rem 0}.admin-moderation-page .container{max-width:1400px;margin:0 auto;padding:0 1rem}.moderation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.moderation-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014;transition:all .3s}.moderation-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026}.card-header{display:flex;justify-content:space-between;padding:1rem 1.5rem;background:#f8f9fa;border-bottom:2px solid #e9ecef}.card-content{padding:1.5rem}.photo-preview{width:100%;max-height:300px;margin-bottom:1rem;overflow:hidden;border-radius:8px}.photo-preview img{width:100%;height:100%;object-fit:cover}.review-content{margin-bottom:1rem}.rating{font-size:1.2rem;margin-bottom:.5rem}.review-text,.comment-text{color:#333;line-height:1.6;margin-bottom:1rem}.item-meta{display:flex;justify-content:space-between;padding-top:1rem;border-top:1px solid #f0f0f0;font-size:.9rem;color:#666}.report-info{margin-top:1rem;padding:1rem;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:4px;color:#92400e}.card-actions{display:flex;gap:.75rem;padding:1.5rem;border-top:2px solid #f0f0f0;flex-wrap:wrap}.card-actions .btn{flex:1;min-width:fit-content}@media(max-width:768px){.moderation-grid{grid-template-columns:1fr}.card-actions{flex-direction:column}}.owner-establishments-page{padding:2rem;max-width:1400px;margin:0 auto}.form-section-divider{margin:1.5rem 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.form-section-divider h3{font-size:.95rem;font-weight:700;color:#374151;margin:0 0 .25rem}.form-hint{font-size:.8rem;color:#6b7280;margin:0}.form-hint a{color:#7c3aed}.input-prefix-wrap{display:flex;align-items:center;border:1px solid #d1d5db;border-radius:6px;overflow:hidden;background:#fff}.input-prefix-wrap:focus-within{border-color:#7c3aed;box-shadow:0 0 0 2px #7c3aed26}.input-prefix{padding:0 10px;background:#f3f4f6;color:#6b7280;font-size:.9rem;border-right:1px solid #d1d5db;height:100%;display:flex;align-items:center;white-space:nowrap}.input-prefix-wrap input{border:none!important;box-shadow:none!important;border-radius:0!important;flex:1}.page-title h1{margin:0;color:#333;font-size:2rem}.page-title p{margin:.5rem 0 0;color:#666;font-size:1rem}.btn-add{padding:.65rem 1.5rem;background:var(--primary-color, var(--color-primary));color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s;width:fit-content;display:inline-flex;align-items:center;gap:.5rem}.btn-add:hover{background:var(--color-primary-dark)}.establishments-table-wrapper{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.establishments-table{width:100%;border-collapse:collapse}.establishments-table thead{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff}.establishments-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.establishments-table tbody tr{border-bottom:1px solid #eee;transition:background .2s}.establishments-table tbody tr:hover{background:#f8f9fa}.establishments-table tbody tr:last-child{border-bottom:none}.establishments-table td{padding:1rem;vertical-align:middle}.establishment-logo-cell{width:80px}.establishment-logo-img{width:60px;height:60px;border-radius:8px;object-fit:contain;background:#f5f5f5;padding:.25rem;border:2px solid #eee}.establishment-logo-placeholder{width:60px;height:60px;border-radius:8px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);display:flex;align-items:center;justify-content:center;font-size:2rem;line-height:1}.establishment-name-cell{min-width:200px}.name-wrapper{display:flex;flex-direction:column;gap:.25rem}.name-wrapper strong{color:#333;font-size:1rem}.description-preview{color:#666;font-size:.8rem;line-height:1.4}.establishment-type-cell{width:130px}.type-badge{display:inline-block;padding:.35rem .85rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px}.establishment-address-cell{min-width:180px}.address-wrapper{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem}.address-wrapper span{color:#666}.address-wrapper .city{color:#999;font-size:.8rem;padding-left:1.25rem;text-transform:capitalize}.establishment-contact-cell{min-width:150px}.contact-wrapper{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;color:#666}.establishment-actions-cell{width:240px}.action-buttons{display:flex;gap:.5rem;justify-content:flex-end;flex-wrap:wrap}.btn-edit,.btn-manage,.btn-delete{border:none;border-radius:6px;cursor:pointer;transition:all .2s;text-decoration:none;font-size:.8rem;font-weight:600;white-space:nowrap}.btn-text{padding:.5rem .85rem;display:inline-flex;align-items:center;justify-content:center}.btn-edit.btn-text{background:#f0f0f0;color:#333}.btn-edit.btn-text:hover{background:#e0e0e0;transform:translateY(-1px)}.btn-manage.btn-text{background:var(--color-primary);color:#fff}.btn-manage.btn-text:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.btn-delete.btn-text{background:#fee;color:#dc2626}.btn-delete.btn-text:hover{background:#dc2626;color:#fff;transform:translateY(-1px)}.owner-establishments-page .establishments-grid{display:none}.establishment-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.establishment-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.establishment-image{width:100%;height:200px;overflow:hidden;background:#f5f5f5}.establishment-image img{width:100%;height:100%;object-fit:cover}.establishment-content{padding:1.5rem}.establishment-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem;gap:1rem}.establishment-header h3{margin:0;color:#333;flex:1}.type-badge{padding:.25rem .75rem;background:var(--primary-color, var(--color-primary));color:#fff;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}.establishment-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.info-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#666}.info-item .icon{font-size:1rem}.establishment-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid #eee}.btn-edit,.btn-manage,.btn-delete{flex:1;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background .2s;text-align:center;text-decoration:none;display:inline-block}.btn-manage{background:var(--primary-color, var(--color-primary));color:#fff}.btn-manage:hover{background:var(--color-primary-dark)}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;margin:auto}.establishment-form{padding:1.5rem}.form-section{margin-bottom:2rem}.form-section h3{margin:0 0 1rem;color:#333;font-size:1.125rem}.opening-hours{display:flex;flex-direction:column;gap:.75rem}.hours-row{display:grid;grid-template-columns:100px 100px 80px 30px 80px;gap:.5rem;align-items:center}.day-label{font-weight:500;color:#333}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#666}.checkbox-label input[type=checkbox]{width:auto}.hours-row input[type=time]{padding:.5rem;border:1px solid #ddd;border-radius:6px;font-size:.875rem}.hours-row span{text-align:center;color:#999;font-size:.875rem}@media(max-width:768px){.owner-establishments-page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.establishments-table-wrapper{overflow-x:auto}.establishments-table{min-width:900px}.establishment-actions{flex-direction:column}.form-row{grid-template-columns:1fr}.hours-row{grid-template-columns:1fr;gap:.5rem}.hours-row span{display:none}.modal-overlay{padding:0}.modal-content{max-height:100vh;border-radius:0}}@media(max-width:480px){.page-header h1{font-size:1.5rem}.btn-primary{width:100%}}.gallery-previews{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-top:1rem;margin-bottom:.5rem}.gallery-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:2px solid var(--border-color, #e0e0e0)}.gallery-item img{width:100%;height:100%;object-fit:cover}.gallery-item .remove-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#ef4444e6;color:#fff;border:none;cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s}.gallery-item .remove-btn:hover{background:#dc2626}.form-group small{color:#666;font-size:.875rem;margin-top:.5rem;display:block}.tags-input-container{display:flex;gap:.5rem;margin-bottom:.5rem}.tags-input-container input{flex:1}.btn-add-tag{background:var(--color-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;font-weight:600;transition:background .2s}.btn-add-tag:hover{background:#00a550}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.tag-item{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:.4rem .8rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;display:inline-flex;align-items:center;gap:.5rem}.remove-tag{background:#fff3;border:none;color:#fff;width:20px;height:20px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;transition:background .2s}.remove-tag:hover{background:#ffffff4d}.owner-products-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.filters-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:2rem;background:none;border:none;box-shadow:none;padding:0}.filters{display:flex;gap:.5rem;flex-wrap:wrap;flex:1;align-items:center;margin:auto 0}.btn-add-product{margin-left:.5rem}.add-product-wrapper{display:flex;justify-content:flex-end;align-items:center}.filters-section .btn-primary{padding:.5rem 1rem;background:#4f46e5;border-radius:8px;font-size:.875rem;font-weight:500;line-height:1.5;white-space:nowrap;box-shadow:none;transition:all .2s ease}.filters-section .btn-primary:hover{background:#4338ca;box-shadow:0 2px 6px #7c3aed4d;transform:translateY(-1px)}.filter-btn{padding:.5rem 1rem;border:1px solid #ddd;background:#fff;border-radius:20px;cursor:pointer;transition:all .2s;font-size:.875rem;line-height:1.5}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.product-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.product-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.product-card.unavailable{opacity:.7}.product-image{width:100%;height:200px;overflow:hidden;background:#f5f5f5;position:relative}.product-image img{width:100%;height:100%;object-fit:cover}.unavailable-badge{position:absolute;top:1rem;right:1rem;background:#ff0000e6;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600}.product-content{padding:1.5rem}.product-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.5rem;gap:1rem}.product-header h3{margin:0;color:#333;flex:1}.price{font-size:1.25rem;font-weight:600;color:var(--primary-color, var(--color-primary));white-space:nowrap}.category-badge{display:inline-block;padding:.25rem .75rem;background:#f0f0f0;color:#666;border-radius:12px;font-size:.75rem;font-weight:500;margin-bottom:.75rem}.description{color:#666;margin-bottom:1rem;line-height:1.5;font-size:.875rem}.prep-time,.allergens{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem;color:#666}.prep-time .icon,.allergens .icon{font-size:1rem}.product-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem;padding-top:1rem;border-top:1px solid #eee}.btn-toggle{padding:.5rem;border:1px solid #ddd;background:#fff;border-radius:6px;font-size:.75rem;cursor:pointer;transition:all .2s}.btn-toggle.active{background:var(--primary-color, var(--color-primary));color:#fff;border-color:var(--primary-color, var(--color-primary))}.btn-toggle:not(.active){background:#fee;color:#c00;border-color:#fdd}.btn-edit,.btn-delete{padding:.5rem;border:none;border-radius:6px;font-size:.75rem;cursor:pointer;transition:background .2s}.product-form{padding:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto}.allergens-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;padding:1rem;background:#f9f9f9;border-radius:6px}.allergen-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.875rem;cursor:pointer}.allergen-checkbox input[type=checkbox]{width:auto}.image-preview{margin-top:1rem;border-radius:8px;overflow:hidden;max-width:300px}.image-preview img{width:100%;height:auto;display:block}@media(max-width:768px){.owner-products-page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.products-grid,.product-actions,.form-row,.allergens-grid{grid-template-columns:1fr}}.owner-orders-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{margin-bottom:2rem}.page-header h1{margin:0 0 .5rem;color:#333}.page-header p{margin:0;color:#666}.filters{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.orders-list{display:flex;flex-direction:column;gap:1.5rem}.order-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:box-shadow .2s}.order-card:hover{box-shadow:0 4px 16px #00000026}.order-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #eee}.order-info h3{margin:0 0 .5rem;color:#333;font-size:1.25rem}.customer-name{margin:.25rem 0;color:#666;font-weight:500}.order-date{margin:.25rem 0;color:#999;font-size:.875rem}.order-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600;white-space:nowrap}.status-confirmed{background:#cfe2ff;color:#084298}.status-preparing{background:#e7f3ff;color:#0369a1}.status-ready{background:#d1e7dd;color:#0f5132}.order-total{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-primary)}.order-establishment{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:#f9f9f9;border-radius:8px;font-weight:500;color:#666}.order-establishment .icon{font-size:1.25rem}.order-items{margin-bottom:1rem}.order-items h4{margin:0 0 .75rem;color:#333;font-size:1rem}.order-item{display:grid;grid-template-columns:50px 1fr auto;gap:1rem;padding:.5rem 0;border-bottom:1px solid #f0f0f0}.order-item:last-child{border-bottom:none}.item-quantity{color:#666;font-weight:600}.item-name{color:#333}.item-price{color:var(--color-primary);font-weight:600}.pickup-info,.order-notes{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.75rem;background:#f9f9f9;border-radius:8px;font-size:.875rem;color:#666}.pickup-info .icon,.order-notes .icon{font-size:1rem}.order-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid #eee}.btn-next-status,.btn-cancel,.btn-details{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background .2s}.btn-next-status{background:var(--color-primary);color:#fff;flex:0 0 auto;min-width:140px}.btn-next-status:hover{background:var(--color-primary-dark)}.btn-cancel{background:#fee;color:#c00;flex:0 0 auto;min-width:100px}.btn-details{background:#f0f0f0;color:#333;flex:0 0 auto;min-width:100px}.btn-details:hover{background:#e0e0e0}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.detail-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #eee}.detail-section:last-child{border-bottom:none}.detail-section h3{margin:0 0 .75rem;color:#333;font-size:1rem;font-weight:600}.detail-section p{margin:.25rem 0;color:#666}.items-list{display:flex;flex-direction:column;gap:.75rem}.item-detail{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f9f9f9;border-radius:8px}.item-info{display:flex;align-items:center;gap:.75rem}.item-info .quantity{color:#666;font-weight:600;min-width:30px}.item-info .name{color:#333}.item-detail .price{color:var(--color-primary);font-weight:600}.total-amount{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.modal-actions{display:flex;gap:1rem;padding-top:1.5rem;border-top:1px solid #eee}.btn-primary,.btn-danger{flex:0 0 auto;min-width:180px;height:44px;padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;white-space:nowrap}.btn-primary{background:var(--color-primary)!important;color:#fff!important;border:none!important}.btn-primary:hover{background:var(--color-primary-dark)!important}.btn-danger{background:#dc3545!important;color:#fff!important;border:none!important}.btn-danger:hover{background:#c82333!important}@media(max-width:768px){.owner-orders-page{padding:1rem}.order-header{flex-direction:column;align-items:flex-start}.order-meta{align-items:flex-start;margin-top:1rem}.order-item{grid-template-columns:40px 1fr auto}.order-actions{flex-direction:column}.btn-next-status,.btn-cancel,.btn-details,.btn-primary,.btn-danger{flex:1;min-width:100%}.modal-overlay{padding:0}.modal-content{max-height:100vh;border-radius:0}}.owner-analytics{padding:2rem;max-width:1400px;margin:0 auto}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.analytics-header h1{font-size:2rem;color:var(--text-dark);margin:0}.analytics-controls{display:flex;gap:1rem;align-items:center}.date-range-picker{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border-radius:8px;border:1px solid var(--border-color)}.date-range-picker input[type=date]{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem}.date-range-picker span{color:var(--text-light);font-size:.9rem}.analytics-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:1rem;transition:transform .2s}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.card-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:50%}.card-content h3{font-size:.9rem;color:var(--text-light);margin:0 0 .5rem;font-weight:500}.card-value{font-size:2rem;font-weight:700;color:var(--primary-color);margin:0}.card-revenue{font-size:1rem;color:var(--success-color);margin:.25rem 0 0;font-weight:600}.analytics-section{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.analytics-section h2{font-size:1.5rem;color:var(--text-dark);margin:0 0 1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{margin:0}.section-stats{display:flex;gap:2rem;font-size:.9rem}.section-stats span{color:var(--text-light)}.section-stats span:first-child{color:var(--primary-color);font-weight:600}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:2rem;margin-bottom:2rem}.items-list{margin-top:1.5rem}.item-row{display:flex;align-items:center;gap:1rem;padding:1rem;border-bottom:1px solid var(--border-color);transition:background .2s}.item-row:hover{background:var(--background-light)}.item-row:last-child{border-bottom:none}.item-rank{font-weight:700;color:var(--primary-color);font-size:1.1rem;min-width:30px}.item-name{flex:1;font-weight:500;color:var(--text-dark)}.item-sales{color:var(--text-light);font-size:.9rem}.item-revenue{font-weight:600;color:var(--success-color);min-width:100px;text-align:right}.customer-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-item{text-align:center;padding:1.5rem;background:var(--background-light);border-radius:8px}.stat-item h3{font-size:2.5rem;color:var(--primary-color);margin:0 0 .5rem}.stat-item p{font-size:.9rem;color:var(--text-light);margin:0}.subsection-title{font-size:1.2rem;color:var(--text-dark);margin:2rem 0 1rem}.customers-list{margin-top:1rem}.customer-row{display:flex;align-items:center;gap:1rem;padding:1rem;border-bottom:1px solid var(--border-color);transition:background .2s}.customer-row:hover{background:var(--background-light)}.customer-row:last-child{border-bottom:none}.customer-rank{font-weight:700;color:var(--primary-color);font-size:1.1rem;min-width:30px}.customer-info{flex:1}.customer-name{font-weight:500;color:var(--text-dark);margin:0 0 .25rem}.customer-email{font-size:.85rem;color:var(--text-light);margin:0}.customer-stats{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.customer-orders{font-size:.9rem;color:var(--text-light)}.customer-total{font-weight:600;color:var(--success-color);font-size:1.1rem}.no-data{text-align:center;padding:3rem;color:var(--text-light);font-style:italic}@media(max-width:768px){.owner-analytics{padding:1rem}.analytics-header{flex-direction:column;align-items:flex-start;gap:1rem}.analytics-controls,.date-range-picker{flex-direction:column;width:100%}.date-range-picker input[type=date]{width:100%}.analytics-grid{grid-template-columns:1fr}.summary-card{flex-direction:column;text-align:center}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.section-stats{flex-direction:column;gap:.5rem}}.owner-reservations-page{padding:2rem;max-width:1400px;margin:0 auto}.owner-reservations-page-header{margin-bottom:2rem;padding:0 .5rem}.owner-reservations-page-title{margin:0 0 .5rem;color:#333;font-size:2rem;font-weight:700;line-height:1.2}.owner-reservations-page-subtitle{margin:0;color:#666;font-size:1rem;line-height:1.5}.filters-container{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.filters{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.filters h3{margin:0;font-size:.875rem;color:#666;font-weight:600}.filter-btn{padding:.5rem 1rem;border:1px solid #ddd;background:#fff;border-radius:20px;cursor:pointer;transition:all .2s;font-size:.875rem}.filter-btn:hover{border-color:var(--primary-color, var(--color-primary));color:var(--primary-color, var(--color-primary))}.filter-btn.active{background:var(--primary-color, var(--color-primary));color:#fff;border-color:var(--primary-color, var(--color-primary))}.reservations-list{display:flex;flex-direction:column;gap:1.5rem}.reservation-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:box-shadow .2s;position:relative}.owner-reservation-card{background:#fff;border-radius:12px;padding:1.5rem!important;box-shadow:0 2px 8px #0000001a;transition:box-shadow .2s;position:relative}.reservation-card:hover,.owner-reservation-card:hover{box-shadow:0 4px 16px #00000026}.reservation-card.today,.owner-reservation-card.today{border:2px solid var(--primary-color, var(--color-primary))}.today-badge,.owner-today-badge{position:absolute;top:1rem;right:1rem;background:var(--primary-color, var(--color-primary));color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.75rem;font-weight:600}.reservation-header,.owner-reservation-header{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;padding-bottom:1rem;border-bottom:1px solid #eee}.reservation-info,.owner-reservation-info{display:flex;align-items:center;gap:2rem;flex:1}.reservation-info h3,.owner-reservation-info h3{margin:0;color:#333;font-size:1.25rem;white-space:nowrap}.info-row,.owner-info-row{display:flex;align-items:center;gap:.5rem;color:#666;font-size:.875rem;white-space:nowrap}.info-row .icon,.owner-info-row .icon{font-size:1rem}.reservation-meta,.owner-reservation-meta{display:flex;align-items:center;gap:1rem}.status-badge,.owner-status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600;white-space:nowrap}.status-pending{background:#fff3cd;color:#856404}.status-confirmed{background:#d1e7dd;color:#0f5132}.status-cancelled{background:#f8d7da;color:#721c24}.status-completed{background:#d1ecf1;color:#0c5460}.datetime{display:flex;align-items:center;gap:.5rem}.date{font-size:.875rem;font-weight:600;color:#333;background:#f0f0f0;padding:.4rem .8rem;border-radius:6px}.time{font-size:.875rem;font-weight:700;color:#fff;background:var(--primary-color, var(--color-primary));padding:.4rem .8rem;border-radius:6px}.reservation-details{display:none}.detail-item{display:flex;align-items:center;gap:.5rem;color:#666;font-size:.875rem}.detail-item .icon{font-size:1rem}.special-requests{display:flex;align-items:start;gap:.5rem;margin-bottom:1rem;padding:1rem;background:#f9f9f9;border-radius:8px;color:#666;font-size:.875rem}.special-requests .icon{font-size:1rem;margin-top:.125rem}.reservation-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid #eee;flex-wrap:wrap}.btn-confirm,.btn-complete,.btn-cancel{flex:0 0 auto;min-width:140px;padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background .2s;font-weight:600}.btn-confirm,.btn-complete{background:var(--primary-color, var(--color-primary));color:#fff}.btn-confirm:hover,.btn-complete:hover{background:var(--color-primary-dark)}.btn-cancel{background:#fee;color:#c00}.btn-cancel:hover{background:#fdd}.empty-state p{margin:0;color:#666;font-size:1.125rem}@media(max-width:768px){.owner-reservations-page{padding:1rem}.owner-reservations-page-header{padding:0}.owner-reservations-page-title{font-size:1.75rem;line-height:1.3}.owner-reservations-page-subtitle{font-size:.9rem}.reservation-header{flex-direction:column;align-items:flex-start}.reservation-meta{align-items:flex-start;margin-top:1rem;width:100%}.datetime{text-align:left}.today-badge{position:static;display:inline-block;margin-bottom:1rem}.reservation-actions{flex-direction:column}.btn-confirm,.btn-complete,.btn-cancel{width:100%;min-width:auto}}.reservation-settings-page{padding:2rem 0;min-height:calc(100vh - 70px);background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.reservation-settings-page .container{max-width:1200px;margin:0 auto;padding:0 2rem}.reservation-settings-page .page-header{margin-bottom:2rem;display:flex;flex-direction:column;gap:.5rem}.reservation-settings-page .page-header h1{font-size:2rem;color:#1e293b;margin:0;line-height:1.3}.reservation-settings-page .establishment-name{color:#64748b;font-size:1.1rem;margin:0;line-height:1.4;display:block}.reservation-settings-page .back-btn{background:none;border:none;color:var(--color-primary);font-size:1rem;cursor:pointer;padding:.5rem 0;display:inline-flex;align-items:center;gap:.5rem;transition:all .3s ease;margin-bottom:.5rem;width:fit-content}.reservation-settings-page .back-btn:hover{color:#008040;transform:translate(-5px)}.reservation-settings-page .settings-grid{display:grid;gap:2rem;margin-bottom:2rem}.reservation-settings-page .settings-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 20px #00000014}.reservation-settings-page .card-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f1f5f9}.reservation-settings-page .card-header h2{font-size:1.5rem;color:#1e293b;margin-bottom:.5rem;line-height:1.3}.reservation-settings-page .card-description{color:#64748b;font-size:.9rem;margin:0;line-height:1.4}.reservation-settings-page .setting-group{margin-bottom:1.5rem}.reservation-settings-page .setting-group label{display:block;font-weight:600;color:#1e293b;margin-bottom:.5rem;line-height:1.4}.reservation-settings-page .setting-description{font-size:.85rem;color:#64748b;margin:.25rem 0 .5rem;line-height:1.4}.reservation-settings-page .setting-toggle{display:flex;justify-content:space-between;align-items:center;gap:1rem}.reservation-settings-page .setting-toggle>div{flex:1}.reservation-settings-page .toggle-switch{position:relative;display:inline-block;width:50px;height:28px;flex-shrink:0}.reservation-settings-page .toggle-switch input{opacity:0;width:0;height:0}.reservation-settings-page .toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.3s;border-radius:28px}.reservation-settings-page .toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}.reservation-settings-page .toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary)}.reservation-settings-page .toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.reservation-settings-page .form-control{width:100%;padding:.75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .3s ease}.reservation-settings-page .form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #7c3aed1a}.reservation-settings-page .add-slot-form,.reservation-settings-page .add-special-date-form{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.reservation-settings-page .add-slot-form .form-control,.reservation-settings-page .add-special-date-form .form-control{flex:1;min-width:150px}.reservation-settings-page .checkbox-label{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#f8fafc;border-radius:8px;cursor:pointer;white-space:nowrap}.reservation-settings-page .checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.reservation-settings-page .slots-list,.reservation-settings-page .special-dates-list{display:flex;flex-direction:column;gap:.75rem}.reservation-settings-page .slot-item,.reservation-settings-page .special-date-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;transition:all .3s ease}.reservation-settings-page .slot-item:hover,.reservation-settings-page .special-date-item:hover{box-shadow:0 2px 8px #00000014}.reservation-settings-page .slot-info,.reservation-settings-page .special-date-info{flex:1}.reservation-settings-page .slot-info strong,.reservation-settings-page .special-date-info strong{display:block;color:#1e293b;margin-bottom:.25rem;line-height:1.4}.reservation-settings-page .slot-info p,.reservation-settings-page .special-date-info p{color:#64748b;font-size:.9rem;margin:0;line-height:1.4}.reservation-settings-page .closed-badge{display:inline-block;padding:.25rem .75rem;background:#fee;color:#dc2626;border-radius:12px;font-size:.85rem;font-weight:600}.reservation-settings-page .btn-remove{background:none;border:none;color:#dc2626;font-size:1.5rem;cursor:pointer;padding:.5rem;line-height:1;transition:all .3s ease;flex-shrink:0}.reservation-settings-page .btn-remove:hover{color:#b91c1c;transform:scale(1.2)}.reservation-settings-page .empty-state{text-align:center;color:#94a3b8;font-style:italic;padding:2rem;background:#f8fafc;border-radius:8px;border:1px dashed #cbd5e1}.reservation-settings-page .actions-bar{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 0}.reservation-settings-page .actions-bar .btn{width:auto;flex:0 0 auto}.reservation-settings-page .btn{padding:.75rem 2rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.reservation-settings-page .btn-primary{background:var(--color-primary);color:#fff}.reservation-settings-page .btn-primary:hover:not(:disabled){background:#008040;transform:translateY(-2px);box-shadow:0 4px 12px #7c3aed4d}.reservation-settings-page .btn-primary:disabled{opacity:.6;cursor:not-allowed}.reservation-settings-page .btn-secondary{background:#f1f5f9;color:#1e293b}.reservation-settings-page .btn-secondary:hover{background:#e2e8f0}.reservation-settings-page .loading-container{display:flex;justify-content:center;align-items:center;min-height:50vh}.reservation-settings-page .spinner{width:50px;height:50px;border:4px solid #f3f4f6;border-top:4px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.reservation-settings-page{padding:1rem 0}.reservation-settings-page .container{padding:0 1rem}.reservation-settings-page .settings-card{padding:1.5rem}.reservation-settings-page .add-slot-form,.reservation-settings-page .add-special-date-form{flex-direction:column}.reservation-settings-page .add-slot-form .form-control,.reservation-settings-page .add-special-date-form .form-control{width:100%}.reservation-settings-page .actions-bar{flex-direction:column;align-items:stretch}.reservation-settings-page .actions-bar .btn{width:100%}}.owner-events-page{padding:2rem;max-width:1400px;margin:0 auto}.owner-events-page .page-header{display:flex;justify-content:flex-start;margin-bottom:2rem}.owner-events-page .header-actions{display:inline-block}.owner-events-page .header-actions button,.owner-events-page .header-actions .btn-primary,.owner-events-page .page-header button,.owner-events-page .page-header .btn-primary{width:auto!important;flex-shrink:0}.owner-events-page .page-title{margin-bottom:2rem}.owner-events-page .page-title h1{margin:0 0 .5rem;color:#333}.owner-events-page .page-title p{margin:0;color:#666}.owner-events-list{display:flex;flex-direction:column;gap:1.5rem}.owner-event-card-horizontal{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;display:flex;gap:1.5rem;align-items:flex-start}.owner-event-card-horizontal:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.owner-event-image-thumbnail{width:120px;max-height:170px;flex-shrink:0;border-radius:8px;overflow:hidden;background:#f5f5f5;position:relative}.owner-event-image-thumbnail img{width:100%;height:100%;object-fit:cover}.owner-event-status-badge{position:absolute;top:.5rem;right:.5rem;padding:.25rem .5rem;border-radius:12px;font-size:.65rem;font-weight:600}.owner-event-status-badge.status-past{background:#808080e6;color:#fff}.owner-event-status-badge.status-soon{background:#ffa500e6;color:#fff}.owner-event-status-badge.status-upcoming{background:#7c3aede6;color:#fff}.owner-event-main-info{flex:1;min-width:0}.owner-event-title-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem;flex-wrap:wrap}.owner-event-title-row h3{margin:0;font-size:1.25rem;color:#1a1a2e}.owner-event-category-tag{padding:.25rem .75rem;background:#e8f5e9;color:#2e7d32;border-radius:12px;font-size:.75rem;font-weight:600}.owner-event-description{margin:0 0 1rem;color:#666;font-size:.95rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.owner-event-meta{display:flex;flex-wrap:wrap;gap:1.5rem;font-size:.9rem;color:#555}.owner-event-meta-item{display:flex;align-items:center;gap:.5rem}.owner-event-meta-item .icon{font-size:1rem}.owner-event-actions-column{display:flex;flex-direction:column;gap:.5rem;min-width:120px}.owner-event-btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;text-align:center;text-decoration:none;transition:all .2s}.owner-event-btn-view{background:var(--color-primary);color:#fff}.owner-event-btn-view:hover{background:#008a43}.owner-event-btn-pricing{background:orange;color:#fff}.owner-event-btn-pricing:hover{background:#ff8c00}.owner-event-btn-edit{background:#f0f0f0;color:#333}.owner-event-btn-edit:hover{background:#e0e0e0}.owner-event-btn-delete{background:#ffebee;color:#c62828}.owner-event-btn-delete:hover{background:#ffcdd2}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.event-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.event-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.event-image{width:100%;height:200px;overflow:hidden;background:#f5f5f5;position:relative}.event-image img{width:100%;height:100%;object-fit:cover}.event-status{position:absolute;top:1rem;right:1rem;padding:.5rem 1rem;border-radius:20px;font-size:.75rem;font-weight:600}.status-past{background:#808080e6;color:#fff}.status-soon{background:#ffa500e6;color:#fff}.status-upcoming{background:#7c3aede6;color:#fff}.event-content{padding:1.5rem}.event-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem;gap:1rem}.event-header h3{margin:0;color:#333;flex:1}.category-badge{padding:.25rem .75rem;background:var(--primary-color, var(--color-primary));color:#fff;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}.description{color:#666;margin-bottom:1rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.event-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:1rem;background:#f9f9f9;border-radius:8px}.detail-row{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#666}.detail-row .icon{font-size:1rem;width:1.5rem}.event-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid #eee;justify-content:center;align-items:center}.btn-view,.btn-pricing,.btn-edit,.btn-delete{flex:1;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background .2s;text-align:center;text-decoration:none;display:inline-block}.btn-view{background:var(--primary-color, var(--color-primary));color:#fff}.btn-view:hover{background:var(--color-primary-dark)}.btn-pricing{background:#ff9800;color:#fff}.btn-pricing:hover{background:#f57c00}.btn-edit{background:#f0f0f0;color:#333}.btn-edit:hover{background:#e0e0e0}.btn-delete{background:#fee;color:#c00}.btn-delete:hover{background:#fdd}.empty-state p{margin-bottom:1.5rem;color:#666;font-size:1.125rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;overflow-y:auto}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:700px;max-height:90vh;overflow-y:auto;margin:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #eee;position:sticky;top:0;background:#fff;z-index:1}.modal-close{background:none;border:none;font-size:2rem;color:#999;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.modal-close:hover{background:#f0f0f0}.event-form{padding:1.5rem}.form-group{margin-bottom:1rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color, var(--color-primary))}.form-note{background:#e3f2fd;border-left:4px solid #2196f3;padding:1rem;margin-top:1.5rem;border-radius:4px}.form-note p{margin:0;color:#1565c0;font-size:.95rem}.form-note strong{color:#0d47a1}.form-actions{display:flex;gap:1rem;padding-top:1.5rem;border-top:1px solid #eee;justify-content:flex-end}.btn-primary,.btn-secondary{padding:.75rem 2rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s}@media(max-width:768px){.owner-events-page{padding:1rem}.owner-events-page .page-header{flex-direction:column;align-items:flex-start;gap:1rem}.events-grid{grid-template-columns:1fr}.event-actions{flex-direction:column}.form-row{grid-template-columns:1fr}.modal-overlay{padding:0}.modal-content{max-height:100vh;border-radius:0}.owner-event-card-horizontal{flex-direction:column;gap:1rem}.owner-event-image-thumbnail{width:100%;height:180px}.owner-event-actions-column{flex-direction:row;flex-wrap:wrap;width:100%}.owner-event-btn{flex:1;min-width:calc(50% - .25rem)}.owner-event-meta{gap:1rem}}.image-preview{margin-top:.75rem;border-radius:8px;overflow:hidden;max-width:300px}.image-preview img{width:100%;height:auto;display:block;object-fit:cover}.owner-event-pricing-page{padding:2rem 0;min-height:100vh;background-color:#f8f9fa}.owner-event-pricing-page .container{max-width:1200px;margin:0 auto;padding:0 1rem}.owner-event-pricing-page .page-header{margin-bottom:2rem;display:flex;flex-direction:column;gap:.5rem}.owner-event-pricing-page .page-header .back-btn{background:none;border:none;color:#00796b;font-size:1rem;cursor:pointer;padding:.5rem 0;display:inline-block;align-self:flex-start}.owner-event-pricing-page .page-header .back-btn:hover{text-decoration:underline}.owner-event-pricing-page .page-header h1{color:#333;margin:0;line-height:1.3;font-size:2rem;display:block}.owner-event-pricing-page .page-header .event-name{color:#666;font-size:1.1rem;font-weight:500;margin:0;line-height:1.5;display:block}.owner-event-pricing-page .tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e0e0e0}.owner-event-pricing-page .tab{padding:1rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;color:#666;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.tab:hover{color:#00796b}.tab.active{color:#00796b;border-bottom-color:#00796b}.section-header{margin-bottom:.5rem}.section-header h2{color:#333;font-size:1.5rem;margin:0}.section-actions{margin-bottom:1.5rem}.section-actions .btn{width:auto}.price-types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.price-type-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.price-type-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.price-type-card .card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.price-type-card h3{color:#333;font-size:1.25rem;margin:0}.price-type-card .price{background:#00796b;color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:1.1rem}.price-type-card .description{color:#666;margin-bottom:1rem;line-height:1.5}.price-type-card .stats{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:1rem;background:#f8f9fa;border-radius:8px}.price-type-card .stat{display:flex;justify-content:space-between}.price-type-card .stat .label{color:#666;font-size:.9rem}.price-type-card .stat .value{color:#333;font-weight:500}.packs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.pack-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;border:2px solid transparent;transition:all .2s}.pack-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:#00796b}.pack-card .card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.pack-card h3{color:#333;font-size:1.25rem;margin:0}.pack-card .price-block{display:flex;flex-direction:column;align-items:flex-end}.pack-card .price{background:#00796b;color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:1.2rem}.pack-card .savings{background:#ff9800;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;margin-top:.5rem}.pack-card .pack-details{margin-top:1rem}.pack-card .detail{font-size:1rem;color:#333;margin-bottom:.5rem}.pack-card .included-goods{background:#f8f9fa;padding:1rem;border-radius:8px;margin:1rem 0}.pack-card .included-goods strong{color:#00796b;display:block;margin-bottom:.5rem}.pack-card .included-goods ul{list-style:none;padding:0;margin:0}.pack-card .included-goods li{padding:.25rem 0;color:#666}.card-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.btn-edit,.btn-delete{flex:1;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-edit{background:#2196f3;color:#fff}.btn-edit:hover{background:#1976d2}.btn-delete{background:#f44336;color:#fff}.btn-delete:hover{background:#d32f2f}.empty-state{grid-column:1 / -1;text-align:center;padding:3rem 1rem;background:#fff;border-radius:12px;border:2px dashed #e0e0e0}.empty-state p{color:#666;font-size:1.1rem;margin-bottom:1rem}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-content.large{max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;color:#333}.close-btn{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.close-btn:hover{background:#f0f0f0}.modal-body{padding:1.5rem}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid #e0e0e0}.form-group small{display:block;margin-top:.25rem;color:#666;font-size:.85rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#00796b}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.goods-selector{background:#f8f9fa;border-radius:8px;padding:1rem}.products-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;margin-bottom:1rem}.product-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:all .2s}.product-item:hover{border-color:#00796b;background:#e0f2f1}.product-item .product-price{font-weight:700;color:#00796b}.selected-goods{border-top:2px solid #ddd;padding-top:1rem;margin-top:1rem}.selected-goods strong{display:block;margin-bottom:.5rem;color:#00796b}.selected-good{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#fff;border-radius:6px;margin-bottom:.5rem}.selected-good>span:first-child{flex:1}.quantity-controls{display:flex;align-items:center;gap:.5rem}.quantity-controls button{width:28px;height:28px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;transition:all .2s}.quantity-controls button:hover{background:#00796b;color:#fff;border-color:#00796b}.quantity-controls span{min-width:30px;text-align:center;font-weight:500}.remove-btn{background:#f44336;color:#fff;border:none;border-radius:4px;width:28px;height:28px;cursor:pointer;transition:background .2s}.remove-btn:hover{background:#d32f2f}.goods-total{text-align:right;padding:1rem;background:#fff;border-radius:6px;font-weight:700;color:#00796b;margin-top:.5rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-primary{background:#00796b;color:#fff}.btn-primary:hover:not(:disabled){background:#00695c}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{background:#666;color:#fff}.btn-secondary:hover{background:#555}.loading-container{display:flex;justify-content:center;align-items:center;min-height:50vh}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #00796b;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.flyers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.flyer-card{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;background:#fff}.flyer-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.flyer-card img{width:100%;height:300px;object-fit:cover;display:block}.remove-flyer-btn{position:absolute;top:10px;right:10px;width:32px;height:32px;background:#f44336e6;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 4px #0003}.remove-flyer-btn:hover{background:#d32f2f;transform:scale(1.1)}.flyers-section .empty-state{grid-column:1 / -1}.flyers-section .help-text{color:#999;font-size:.95rem;margin-top:.5rem}@media(max-width:768px){.price-types-grid,.packs-grid,.form-row,.products-list{grid-template-columns:1fr}.section-header{flex-direction:column;gap:1rem;align-items:stretch}.modal-content{max-width:100%;max-height:100vh;border-radius:0}.flyers-grid{grid-template-columns:1fr}}.owner-staff-page{padding:2rem;max-width:1400px;margin:0 auto}.page-title{margin-bottom:1rem}.page-title h1{margin:0 0 .5rem;color:#333}.page-title p{margin:0;color:#666}.page-header{display:flex;justify-content:flex-start;margin-bottom:2rem}.page-header .btn-primary{width:auto}.back-link{display:inline-block;color:#666;text-decoration:none;margin-bottom:.5rem;font-size:.9rem}.back-link:hover{color:#333}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.empty-state p{margin-bottom:2rem;color:#666;font-size:1.1rem}.staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.staff-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.staff-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.staff-header{display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.staff-avatar{flex-shrink:0}.staff-avatar img{width:60px;height:60px;border-radius:50%;object-fit:cover}.avatar-placeholder{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600}.staff-info h3{margin:0 0 .5rem;color:#333;font-size:1.125rem}.role-badge{display:inline-block;padding:.25rem .75rem;background:#e0f2fe;color:#0369a1;border-radius:12px;font-size:.75rem;font-weight:500;margin-bottom:.5rem}.staff-info .email{margin:.5rem 0 .25rem;color:#666;font-size:.875rem}.staff-info .phone{margin:.25rem 0 0;color:#666;font-size:.875rem}.permissions-list{margin-bottom:1.5rem}.permissions-list h4{margin:0 0 .75rem;color:#333;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.permissions-list ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.permissions-list li{color:#10b981;font-size:.875rem}.staff-actions{display:flex;gap:.75rem}.btn-edit,.btn-delete{flex:1;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-edit{background:#f0f9ff;color:#0369a1}.btn-edit:hover{background:#e0f2fe}.btn-delete{background:#fef2f2;color:#dc2626}.btn-delete:hover{background:#fee2e2}.modal-content{background:#fff;border-radius:12px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h2{margin:0 0 1.5rem;color:#333}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input[type=email],.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.form-group small{display:block;margin-top:.5rem;color:#666;font-size:.875rem}.permissions-checkboxes{display:grid;grid-template-columns:1fr;gap:.75rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:background .2s}.checkbox-label:hover{background:#f9fafb}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px}.checkbox-label span{color:#333}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn-primary,.btn-secondary{padding:.75rem 2rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s;font-weight:500}.btn-primary{background:var(--primary-color, var(--color-primary));color:#fff}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:#f0f0f0;color:#333}.loading{text-align:center;padding:4rem 2rem;color:#666}@media(max-width:768px){.owner-staff-page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.staff-grid,.permissions-list ul{grid-template-columns:1fr}.modal-content{padding:1.5rem}}.owner-tables{padding:2rem;max-width:1200px;margin:0 auto}.owner-tables-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.owner-tables-header h1{font-size:1.75rem;font-weight:700;color:#1a1a2e}.empty-state{text-align:center;padding:4rem 2rem;background:#f8f9fa;border-radius:12px;color:#666}.empty-state p{margin-bottom:1rem;font-size:1.1rem}.tables-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem}.table-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 2px 8px #00000014;border-left:4px solid #ccc;transition:transform .2s}.table-card:hover{transform:translateY(-2px)}.table-card.status-available{border-left-color:#28a745}.table-card.status-occupied{border-left-color:#dc3545}.table-card.status-reserved{border-left-color:#ffc107}.table-card.status-unavailable{border-left-color:#6c757d}.table-number{font-size:1.1rem;font-weight:700;color:#1a1a2e;margin-bottom:.5rem}.table-meta{display:flex;gap:.75rem;font-size:.85rem;color:#666;margin-bottom:.75rem}.table-status{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;margin-bottom:1rem}.table-status.status-available{background:#d4edda;color:#155724}.table-status.status-occupied{background:#f8d7da;color:#721c24}.table-status.status-reserved{background:#fff3cd;color:#856404}.table-status.status-unavailable{background:#e2e3e5;color:#383d41}.table-actions{display:flex;gap:.5rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:16px;padding:2rem;width:100%;max-width:480px;box-shadow:0 20px 60px #0003}.modal h2{font-size:1.4rem;font-weight:700;color:#1a1a2e;margin-bottom:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-weight:600;color:#333;margin-bottom:.4rem;font-size:.9rem}.form-group input,.form-group select{width:100%;padding:.6rem .9rem;border:1.5px solid #ddd;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary)}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.btn-primary{padding:.6rem 1.25rem;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:.9rem;transition:opacity .2s}.btn-primary:hover:not(:disabled){opacity:.9}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:.6rem 1.25rem;background:#f0f0f0;color:#333;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:.9rem}.btn-secondary:hover{background:#e0e0e0}.btn-edit{padding:.4rem .8rem;background:#e3f0ff;color:#1a6fc4;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer}.btn-edit:hover{background:#cce0ff}.btn-delete{padding:.4rem .8rem;background:#fde8e8;color:#c0392b;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer}.btn-delete:hover{background:#fbd0d0}.owner-waitlist{padding:2rem;max-width:1100px;margin:0 auto}.owner-waitlist-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.owner-waitlist-header h1{font-size:1.75rem;font-weight:700;color:#1a1a2e}.loading{text-align:center;padding:3rem;color:#666}.establishment-filter{margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.establishment-filter label{font-weight:600;color:#333;font-size:.9rem}.establishment-filter select{padding:.5rem .9rem;border:1.5px solid #ddd;border-radius:8px;font-size:.95rem;outline:none;min-width:220px}.establishment-filter select:focus{border-color:var(--color-primary)}.empty-state{text-align:center;padding:4rem 2rem;background:#f8f9fa;border-radius:12px;color:#666;font-size:1.05rem}.waitlist-table-wrapper{overflow-x:auto}.waitlist-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014}.waitlist-table th{background:#f8f9fa;padding:.85rem 1rem;text-align:left;font-size:.85rem;font-weight:700;color:#555;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #eee}.waitlist-table td{padding:.9rem 1rem;border-bottom:1px solid #f0f0f0;font-size:.9rem;color:#333;vertical-align:middle}.waitlist-table tr:last-child td{border-bottom:none}.position-cell{font-weight:700;color:var(--color-primary)}.client-info{display:flex;flex-direction:column;gap:.2rem}.client-name{font-weight:600}.client-phone{font-size:.8rem;color:#888}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600}.status-badge.status-waiting{background:#fff3cd;color:#856404}.status-badge.status-notified{background:#cce5ff;color:#004085}.status-badge.status-confirmed{background:#d4edda;color:#155724}.status-badge.status-cancelled{background:#f8d7da;color:#721c24}.status-badge.status-expired{background:#e2e3e5;color:#383d41}.entry-actions{display:flex;gap:.5rem}.btn-notify{padding:.6rem 1.25rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:.9rem;transition:opacity .2s}.btn-notify:hover:not(:disabled){opacity:.9}.btn-notify:disabled{opacity:.6;cursor:not-allowed}.btn-confirm{padding:.35rem .8rem;background:#d4edda;color:#155724;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer}.btn-confirm:hover{background:#c3e6cb}.btn-cancel{padding:.35rem .8rem;background:#fde8e8;color:#c0392b;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer}.btn-cancel:hover{background:#fbd0d0}.stripe-onboarding-page{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--color-bg)}.stripe-onboarding-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;padding:3rem 2.5rem;max-width:480px;width:100%;text-align:center;box-shadow:0 4px 24px #0000000f}.stripe-onboarding-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem;margin:0 auto 1.5rem}.stripe-onboarding-icon--success{background:#d1fae5;color:var(--color-green)}.stripe-onboarding-icon--warning{background:#fef3c7;color:#d97706}.stripe-onboarding-card h1{font-size:1.5rem;font-weight:700;color:var(--color-text);margin:0 0 1rem}.stripe-onboarding-card p{color:var(--color-text-secondary);line-height:1.6;margin:0 0 1rem}.stripe-onboarding-hint{background:var(--color-primary-soft);border-radius:8px;padding:.875rem 1rem;font-size:.9rem;color:var(--color-primary-dark)!important}.stripe-onboarding-loading{font-size:.85rem;color:var(--color-text-light)!important;margin-top:1rem!important}:root{--color-primary: #7C3AED;--color-primary-light: #9061F9;--color-primary-dark: #5B21B6;--color-primary-soft: #EDE4FF;--color-orange: #F97316;--color-orange-soft: #FFE4CC;--color-green: #10B981;--color-blue: #3B82F6;--color-blue-soft: #DBEAFE;--color-error: #EF4444;--color-bg: #FAF8F5;--color-surface: #FFFFFF;--color-surface-alt: #F3EFE9;--color-text: #1A1625;--color-text-secondary:#5A5468;--color-text-light: #8B8597;--color-white: #FFFFFF;--color-border: rgba(26, 22, 37, .08);--color-border-strong: rgba(26, 22, 37, .16);--color-dark: #1A1625;--color-dark-light: #2C2537;--color-gray: #5A5468;--color-gray-light: #8B8597;--color-light: #EDE4FF;--color-secondary: #EDE4FF;--color-accent: #EDE4FF;--primary-color: #7C3AED;--primary-light: #EDE4FF;--border-color: rgba(26, 22, 37, .08);--gradient-primary: linear-gradient(135deg, #7C3AED 0%, #5B21B6 100%);--gradient-secondary: linear-gradient(135deg, #EDE4FF 0%, #FAF8F5 100%);--gradient-hero: linear-gradient(135deg, #5B21B6 0%, #7C3AED 60%, #9061F9 100%);--gradient-chrome: linear-gradient(135deg, #5B21B6 0%, #7C3AED 50%, #EDE4FF 100%);--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--spacing-2xl: 4rem;--shadow-sm: 0 1px 3px rgba(26, 22, 37, .06), 0 1px 2px rgba(26, 22, 37, .04);--shadow-md: 0 4px 12px rgba(26, 22, 37, .08), 0 2px 4px rgba(26, 22, 37, .05);--shadow-lg: 0 8px 24px rgba(26, 22, 37, .1), 0 4px 8px rgba(26, 22, 37, .06);--shadow-xl: 0 20px 48px rgba(26, 22, 37, .12), 0 8px 16px rgba(26, 22, 37, .08);--shadow-primary: 0 8px 24px rgba(124, 58, 237, .25);--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--transition: all .22s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}#root{width:100%;min-height:100vh}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--color-text);background-color:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{width:100%;min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg)}.main-content{width:100%;flex:1;padding-top:68px}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}@media(max-width:640px){.container{padding:0 1rem}}.btn{padding:.625rem 1.25rem;border:none;border-radius:var(--radius-full);font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;white-space:nowrap;letter-spacing:-.01em}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px #7c3aed59;color:#fff}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1.5px solid var(--color-border-strong)}.btn-secondary:hover{background:var(--color-surface-alt);border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary-soft)}.btn-ghost:hover{background:var(--color-primary-soft)}.btn-full{width:100%;justify-content:center}.btn-sm{padding:.45rem 1rem;font-size:.82rem}.btn-lg{padding:.875rem 1.75rem;font-size:1rem}.section{padding:var(--spacing-2xl) 0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.section-header-center{text-align:center;margin-bottom:var(--spacing-xl)}.section-tag{display:inline-block;padding:.375rem .875rem;background:var(--color-primary-soft);color:var(--color-primary);border-radius:var(--radius-full);font-weight:600;font-size:.8rem;letter-spacing:.02em;margin-bottom:var(--spacing-sm);text-transform:uppercase}.section-title{font-size:2.25rem;font-weight:800;color:var(--color-text);letter-spacing:-.04em;line-height:1.2}.section-subtitle{font-size:1.05rem;color:var(--color-text-secondary);max-width:540px;margin:.75rem auto 0;line-height:1.65}.section-link{color:var(--color-primary);font-weight:600;text-decoration:none;font-size:.9rem;display:inline-flex;align-items:center;gap:.375rem;transition:var(--transition)}.section-link:hover{color:var(--color-primary-dark);gap:.625rem}.card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);overflow:hidden;transition:var(--transition)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--color-border-strong)}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:700}.badge-green{background:#10b9811f;color:#10b981}.badge-red{background:#ef44441f;color:#ef4444}.badge-orange{background:#f973161f;color:#f97316}.badge-blue{background:#3b82f61f;color:#3b82f6}.badge-purple{background:var(--color-primary-soft);color:var(--color-primary)}.badge-gray{background:var(--color-surface-alt);color:var(--color-text-light)}.form-group{display:flex;flex-direction:column;gap:.375rem;margin-bottom:var(--spacing-sm)}.form-group label{font-size:.875rem;font-weight:600;color:var(--color-text)}.form-group input,.form-group select,.form-group textarea{padding:.75rem 1rem;border:1.5px solid var(--color-border-strong);border-radius:var(--radius-lg);font-size:.95rem;font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:var(--transition);outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-light)}.alert{padding:.875rem 1rem;border-radius:var(--radius-lg);font-size:.9rem;font-weight:500;margin-bottom:var(--spacing-sm)}.alert-error{background:#ef444414;border:1px solid rgba(239,68,68,.25);color:#dc2626}.alert-success{background:#10b98114;border:1px solid rgba(16,185,129,.25);color:#059669}.alert-info{background:var(--color-primary-soft);border:1px solid rgba(124,58,237,.25);color:var(--color-primary-dark)}.loading{text-align:center;padding:var(--spacing-2xl);font-size:1rem;color:var(--color-text-light)}.no-content{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-secondary);font-size:.95rem}@media(max-width:768px){.section{padding:var(--spacing-xl) 0}.section-title{font-size:1.75rem}.section-header{flex-direction:column;align-items:flex-start;gap:.75rem}}@media(max-width:480px){.section-title{font-size:1.5rem}}
