@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.app{width:100%;min-height:100vh}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-primary);padding:0;height:60px;transition:all var(--transition)}.nav-container{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:100%}.nav-logo h2{font-size:1.35rem;font-weight:700;color:var(--primary);letter-spacing:-.5px;margin:0}.nav-links{display:flex;gap:.25rem;align-items:center}.nav-link{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-decoration:none;padding:.5rem .875rem;border-radius:var(--radius-full);position:relative;transition:all var(--transition)}.nav-link:after{display:none}.nav-link:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-link.active{color:var(--primary);background:var(--primary-lighter);font-weight:600}.nav-button{font-size:.875rem;font-weight:600;padding:.5rem 1.25rem;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition);text-decoration:none;display:inline-flex;align-items:center}.nav-button:hover{background:var(--primary-light);transform:none;box-shadow:none}.nav-button-mobile{display:none}.nav-button-desktop{display:inline-flex}.mobile-menu-toggle{display:none;background:none;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:var(--radius-sm);transition:background var(--transition);z-index:1001}.mobile-menu-toggle:hover{background:var(--bg-hover);transform:none}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-overlay);z-index:998;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.hero{height:85vh;width:100%;position:relative;overflow:hidden;margin-top:60px}.hero-carousel{width:100%;height:100%;position:relative}.hero-slide{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;transition:opacity 1s ease-in-out;display:flex;align-items:center;justify-content:center}.hero-slide:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#0000001a,#0006)}.hero-slide.active{opacity:1}.hero-text-overlay{position:relative;z-index:10;text-align:center;padding:2rem}.hero-chalk-text{font-family:Inter,sans-serif;font-size:3rem;font-weight:300;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.3);margin:0;line-height:1.3;letter-spacing:-.5px}.hero-crossed-out{position:relative;text-decoration:line-through;text-decoration-thickness:2px;text-decoration-color:#ffffff80;margin-right:.5rem;opacity:.7}.hero-wine-text{font-weight:600;margin-left:.3rem}.hero-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;border:1px solid rgba(255,255,255,.2);width:44px;height:44px;border-radius:var(--radius-full);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);z-index:100}.hero-nav:hover{background:#ffffff40;transform:translateY(-50%)}.hero-nav-prev{left:1.5rem}.hero-nav-next{right:1.5rem}.hero-dots{position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;gap:.5rem;z-index:100}.hero-dot{width:8px;height:8px;border-radius:var(--radius-full);border:none;background:#fff6;cursor:pointer;transition:all var(--transition);padding:0}.hero-dot:hover{background:#ffffffb3}.hero-dot.active{background:#fff;width:24px}.features{padding:6rem 1.5rem;background:var(--bg-primary)}.features-container{max-width:1000px;margin:0 auto}.features-header{text-align:center;margin-bottom:4rem}.features-title{font-size:2.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem;letter-spacing:-.5px}.features-subtitle{font-size:1.0625rem;font-weight:400;color:var(--text-secondary);max-width:520px;margin:0 auto;line-height:1.6}.features-list{display:flex;flex-direction:column;gap:4rem}.feature-item{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.feature-item.visible{opacity:1;transform:translateY(0)}.feature-item.feature-item-right .feature-image-wrapper{order:-1}.feature-content{display:flex;flex-direction:column}.feature-image-wrapper{width:100%;height:340px;overflow:hidden;border-radius:var(--radius-lg)}.feature-image{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.feature-image-wrapper:hover .feature-image{transform:scale(1.03)}.feature-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem;letter-spacing:-.3px}.feature-description{font-size:.9375rem;font-weight:400;color:var(--text-secondary);line-height:1.7}.articles{padding:5rem 1.5rem;background:var(--bg-secondary)}.articles-container{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr;gap:2.5rem;align-items:start}.articles-main{width:100%}.articles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.article-card{background:var(--bg-primary);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary);transition:all var(--transition)}.article-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.article-image-wrapper{width:100%;height:180px;overflow:hidden}.article-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.article-card:hover .article-image{transform:scale(1.03)}.article-content{padding:1.25rem}.article-date{font-size:.75rem;font-weight:500;color:var(--text-tertiary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.article-title{font-size:1.0625rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;line-height:1.4}.article-description{font-size:.8125rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.article-explore{font-size:.8125rem;font-weight:600;color:var(--primary);text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;transition:gap var(--transition);border-bottom:none;padding-bottom:0}.article-explore:hover{gap:.5rem;color:var(--primary-light)}.articles-sidebar{background:var(--text-primary);padding:2rem;border-radius:var(--radius-md);position:sticky;top:80px}.sidebar-title{font-size:.6875rem;font-weight:600;letter-spacing:1.5px;color:var(--text-tertiary);margin-bottom:1rem;text-transform:uppercase}.sidebar-divider{width:32px;height:2px;background:var(--primary);margin-bottom:1.5rem}.sidebar-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}.sidebar-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.06);cursor:pointer;transition:padding-left var(--transition)}.sidebar-item:last-child{border-bottom:none}.sidebar-item:hover{padding-left:4px}.sidebar-icon{font-size:.875rem;color:var(--primary);font-weight:500;flex-shrink:0;margin-top:2px}.sidebar-text{font-size:.875rem;font-weight:400;color:#fffc;line-height:1.5}.testimonials{padding:5rem 1.5rem;background:var(--bg-primary)}.testimonials-container{max-width:1000px;margin:0 auto}.testimonials-title{font-size:2.25rem;font-weight:700;color:var(--text-primary);text-align:center;margin-bottom:3rem;letter-spacing:-.5px}.testimonials-carousel{display:flex;align-items:center;gap:1.5rem}.testimonials-wrapper{flex:1;display:flex;flex-direction:column;gap:1.25rem}.testimonial-card{background:var(--bg-primary);padding:2rem;border-radius:var(--radius-md);border:1px solid var(--border-primary);transition:all var(--transition)}.testimonial-card-1{margin-left:0;margin-right:80px}.testimonial-card-2{margin-left:40px;margin-right:40px}.testimonial-card-3{margin-left:80px;margin-right:0}.testimonial-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.testimonial-quote-mark{font-size:4rem;font-weight:700;color:var(--primary-lighter);line-height:1;position:absolute;top:.5rem;left:1.5rem;z-index:0}.testimonial-text{font-size:.9375rem;font-weight:400;color:var(--text-secondary);line-height:1.7;margin-bottom:1.5rem;position:relative;z-index:1}.testimonial-author{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}.testimonial-info{flex:1}.testimonial-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.125rem}.testimonial-role{font-size:.8125rem;font-weight:400;color:var(--text-tertiary)}.testimonial-image-wrapper{width:48px;height:48px;border-radius:var(--radius-full);overflow:hidden;margin-left:1rem;flex-shrink:0}.testimonial-image{width:100%;height:100%;object-fit:cover}.testimonial-nav{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-secondary);width:40px;height:40px;border-radius:var(--radius-full);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0}.testimonial-nav:hover{background:var(--primary);color:var(--text-inverse);border-color:var(--primary)}.testimonial-nav-left{order:-1}.testimonial-nav-right{order:1}.newsletter{padding:5rem 1.5rem;background:var(--bg-secondary)}.newsletter-container{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:200px 1fr 200px;gap:2rem;align-items:center}.newsletter-illustration{display:flex;align-items:center;justify-content:center}.grapevine-image{width:100%;height:auto;max-width:180px;object-fit:contain;opacity:.7}.newsletter-content{text-align:center;z-index:1}.newsletter-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem;letter-spacing:-.3px;text-transform:none}.newsletter-description{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin-bottom:2rem;max-width:480px;margin-left:auto;margin-right:auto}.newsletter-form{display:flex;gap:.75rem;max-width:440px;margin:0 auto}.newsletter-input{flex:1;padding:.75rem 1rem;border:1px solid var(--border-secondary);border-radius:var(--radius-full);background:var(--bg-primary);font-size:.875rem;color:var(--text-primary);outline:none;transition:border-color var(--transition)}.newsletter-input::placeholder{color:var(--text-tertiary)}.newsletter-input:focus{border-color:var(--primary)}.newsletter-submit{background:var(--primary);color:var(--text-inverse);border:none;padding:.75rem 1.75rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--transition);white-space:nowrap;text-transform:none}.newsletter-submit:hover{background:var(--primary-light);transform:none}.footer{background:var(--text-primary);color:var(--text-inverse);padding:3.5rem 1.5rem 1.5rem;border-top:none}.footer-container{max-width:1000px;margin:0 auto}.footer-content{display:grid;grid-template-columns:1.5fr 2fr;gap:3rem;margin-bottom:2.5rem}.footer-brand{max-width:320px}.footer-logo{font-size:1.35rem;font-weight:700;color:var(--text-inverse);margin-bottom:.75rem;letter-spacing:-.3px}.footer-tagline{font-size:.875rem;font-weight:400;color:#ffffff80;line-height:1.6;margin-bottom:1.5rem}.footer-social{display:flex;gap:1.25rem}.social-link{font-size:.8125rem;font-weight:500;color:#fff9;text-decoration:none;transition:color var(--transition)}.social-link:after{display:none}.social-link:hover{color:var(--text-inverse)}.footer-links{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.footer-column{display:flex;flex-direction:column}.footer-heading{font-size:.75rem;font-weight:600;color:#fff6;margin-bottom:1rem;letter-spacing:1px;text-transform:uppercase}.footer-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.footer-link{font-size:.8125rem;font-weight:400;color:#fff9;text-decoration:none;transition:color var(--transition)}.footer-link:hover{color:var(--text-inverse);padding-left:0}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08);flex-wrap:wrap;gap:.75rem}.footer-copyright{font-size:.8125rem;color:#ffffff59}.footer-bottom-links{display:flex;align-items:center;gap:.75rem}.footer-bottom-link{font-size:.8125rem;color:#ffffff59;text-decoration:none;transition:color var(--transition)}.footer-bottom-link:hover{color:#ffffffb3}.footer-separator{color:#fff3;font-size:.75rem}.nav-desktop-right{display:flex;align-items:center;gap:12px}.nav-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);background:none;border:none;cursor:pointer;color:var(--text-secondary);text-decoration:none;transition:background var(--transition),color var(--transition)}.nav-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-notif-wrapper{position:relative}.nav-notif-badge-desktop{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;background:#e53935;color:#fff;border-radius:var(--radius-full);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;border:2px solid var(--bg-primary);pointer-events:none}.nav-notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border-primary);width:360px;max-height:480px;z-index:100;display:flex;flex-direction:column}.nav-notif-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px}.nav-notif-dropdown-title{font-weight:700;font-size:15px;color:var(--text-primary)}.nav-notif-mark-read{background:none;border:none;color:var(--primary);font-size:12px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:var(--radius-full);transition:background var(--transition)}.nav-notif-mark-read:hover{background:var(--primary-lighter)}.nav-notif-dropdown-divider{height:1px;background:var(--border-primary)}.nav-notif-dropdown-list{overflow-y:auto;max-height:360px;flex:1}.nav-notif-dropdown-item{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;width:100%;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;transition:background var(--transition)}.nav-notif-dropdown-item:hover{background:var(--bg-hover)}.nav-notif-dropdown-item.unread{background:var(--primary-lighter)}.nav-notif-dropdown-item.unread:hover{background:color-mix(in srgb,var(--primary-lighter) 70%,var(--bg-hover))}.nav-notif-dropdown-icon{font-size:16px;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;margin-top:1px}.nav-notif-dropdown-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.nav-notif-dropdown-text{font-size:13px;color:var(--text-primary);line-height:1.4}.nav-notif-dropdown-text strong{font-weight:600}.nav-notif-dropdown-time{font-size:11px;color:var(--text-tertiary)}.nav-notif-dropdown-empty{padding:24px 16px;text-align:center;font-size:13px;color:var(--text-tertiary)}.nav-notif-dropdown-viewall{display:block;text-align:center;padding:10px 16px;font-size:13px;font-weight:600;color:var(--primary);text-decoration:none;transition:background var(--transition)}.nav-notif-dropdown-viewall:hover{background:var(--bg-hover)}.nav-profile-wrapper{position:relative}.nav-profile-btn{background:none;border:none;cursor:pointer;padding:2px;border-radius:var(--radius-full);transition:box-shadow var(--transition)}.nav-profile-btn:hover{box-shadow:0 0 0 2px var(--primary-border)}.nav-avatar{width:34px;height:34px;border-radius:var(--radius-full);background:var(--primary-lighter);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--primary);font-size:14px;overflow:hidden}.nav-avatar img{width:100%;height:100%;object-fit:cover}.nav-dropdown-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99}.nav-profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border-primary);min-width:200px;padding:8px 0;z-index:100}.nav-dropdown-name{padding:8px 16px 2px;font-weight:600;font-size:14px;color:var(--text-primary)}.nav-dropdown-email{padding:0 16px 8px;font-size:12px;color:var(--text-tertiary)}.nav-dropdown-divider{height:1px;background:var(--border-primary);margin:4px 0}.nav-dropdown-item{display:block;padding:8px 16px;font-size:14px;color:var(--text-primary);text-decoration:none;transition:background var(--transition);cursor:pointer;background:none;border:none;width:100%;text-align:left;font-family:inherit}.nav-dropdown-item:hover{background:var(--bg-hover)}.nav-dropdown-logout{color:#e53935}.nav-dropdown-logout:hover{background:#fef2f2}@media (max-width: 968px){.nav-links{position:fixed;top:0;right:-100%;width:300px;height:100vh;background:var(--bg-primary);flex-direction:column;gap:0;padding:4.5rem 0 2rem;box-shadow:var(--shadow-lg);transition:right .3s cubic-bezier(.4,0,.2,1);z-index:999;overflow-y:auto;border-left:1px solid var(--border-primary)}.nav-links.mobile-open{right:0}.nav-button-desktop{display:none}.nav-button-mobile{display:block;width:calc(100% - 2rem);margin:1rem 1rem 0;text-align:center;padding:.75rem;border-radius:var(--radius-full)}.nav-link{width:100%;padding:.875rem 1.25rem;font-size:.9375rem;border-radius:0;border-bottom:1px solid var(--border-primary)}.nav-link:hover{background:var(--bg-hover);padding-left:1.5rem}.nav-link:after{display:none}.mobile-menu-toggle{display:block}.features{padding:4rem 1.5rem}.features-title{font-size:1.75rem}.feature-item{grid-template-columns:1fr!important;gap:1.5rem}.feature-item .feature-content{order:1!important}.feature-item .feature-image-wrapper,.feature-item.feature-item-right .feature-image-wrapper{order:2!important}.feature-item.feature-item-right .feature-content{order:1!important}.feature-image-wrapper{height:240px}.feature-title{font-size:1.25rem}}@media (max-width: 768px){.hero{height:70vh}.hero-chalk-text{font-size:2rem}.hero-nav{width:36px;height:36px;font-size:1rem}.hero-nav-prev{left:1rem}.hero-nav-next{right:1rem}.articles{padding:3.5rem 1.5rem}.articles-container{grid-template-columns:1fr;gap:2rem}.articles-grid{grid-template-columns:1fr;margin-right:0}.articles-sidebar{position:relative;top:0;min-height:auto;padding:1.5rem}.testimonials{padding:3.5rem 1.5rem}.testimonials-title{font-size:1.75rem;margin-bottom:2rem}.testimonial-card{margin-left:0!important;margin-right:0!important;padding:1.5rem}.testimonial-nav{width:36px;height:36px;font-size:.875rem}.newsletter{padding:3.5rem 1.5rem}.newsletter-container{grid-template-columns:1fr;position:relative}.newsletter-illustration{position:absolute;z-index:0;opacity:.4}.newsletter-illustration.newsletter-left{bottom:20px;left:-20px}.newsletter-illustration.newsletter-right{top:-10px;right:-20px}.grapevine-image{max-width:120px}.newsletter-title{font-size:1.5rem}.newsletter-form{flex-direction:column}.newsletter-submit{width:100%}.footer{padding:2.5rem 1.5rem 1.5rem}.footer-content{grid-template-columns:1fr;gap:2rem}.footer-links{grid-template-columns:repeat(2,1fr)}.footer-bottom{flex-direction:column;align-items:flex-start}.nav-desktop-right{display:none}.nav-notif-dropdown{width:calc(100vw - 32px);right:-60px}}@media (max-width: 480px){.hero{height:60vh}.hero-chalk-text{font-size:1.5rem}.features{padding:3rem 1rem}.features-title{font-size:1.5rem}.feature-image-wrapper{height:200px}.articles,.testimonials,.newsletter{padding:2.5rem 1rem}.footer{padding:2rem 1rem 1rem}.footer-links{grid-template-columns:1fr;gap:1.5rem}.nav-container{padding:0 1rem}.nav-logo h2{font-size:1.2rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);padding:0;overflow:hidden}.auth-wrapper{display:grid;grid-template-columns:1fr 1fr;width:100%;height:100vh;background:var(--bg-primary);overflow:hidden;position:relative}.auth-wrapper.signup-layout{grid-template-columns:1fr 1fr}.auth-back-link{position:absolute;top:1.5rem;left:1.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:color var(--transition);z-index:10}.auth-back-link:hover{color:var(--primary)}.auth-form-section{padding:0;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);height:100%;position:relative;animation:fadeIn .5s ease}.auth-wrapper.signup-layout .auth-form-section{order:2;animation:fadeIn .5s ease}.auth-form-content{width:100%;max-width:400px;padding:0 2rem}.auth-logo{margin-bottom:2rem}.auth-brand{display:none}.auth-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:0;letter-spacing:-.5px}.auth-subtitle{font-size:.9375rem;font-weight:400;color:var(--text-secondary);margin-bottom:2rem;margin-top:.25rem;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-google-btn{width:100%;padding:.75rem 1rem;background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all var(--transition)}.auth-google-btn:hover{border-color:var(--text-tertiary);background:var(--bg-hover)}.google-icon{flex-shrink:0}.auth-divider{display:flex;align-items:center;margin:.25rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-primary)}.auth-divider span{padding:0 .75rem;font-size:.8125rem;color:var(--text-tertiary)}.auth-input-group{width:100%}.auth-password-group{position:relative}.auth-password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-tertiary);display:flex;align-items:center;padding:.25rem;transition:color var(--transition)}.auth-password-toggle:hover{color:var(--text-primary)}.auth-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-size:.875rem;color:var(--text-primary);background:var(--bg-primary);transition:border-color var(--transition);outline:none}.auth-input-group:not(.auth-password-group) .auth-input{padding-right:1rem}.auth-input::placeholder{color:var(--text-tertiary)}.auth-input:focus{border-color:var(--primary)}.auth-submit-btn{width:100%;padding:.75rem 1rem;background:var(--primary);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;color:var(--text-inverse);cursor:pointer;transition:background var(--transition);margin-top:.25rem}.auth-submit-btn:hover{background:var(--primary-light)}.auth-submit-btn:disabled{opacity:.5;cursor:not-allowed}.auth-footer-text{margin-top:1.5rem;text-align:center;font-size:.875rem;color:var(--text-secondary)}.auth-link{color:var(--primary);font-weight:600;text-decoration:none;transition:opacity var(--transition)}.auth-link:hover{opacity:.8}.auth-image-section{width:100%;height:100%;min-height:400px;overflow:hidden;position:relative;animation:fadeIn .5s ease}.auth-wrapper.signup-layout .auth-image-section{order:1}.auth-brand-overlay{position:absolute;top:1.5rem;right:1.5rem;z-index:10}.auth-brand-overlay-signup{position:absolute;top:1.5rem;left:1.5rem;z-index:10}.auth-brand-overlay h1{font-size:1.35rem;font-weight:700;color:var(--text-inverse);letter-spacing:-.3px;margin:0;text-shadow:0 1px 8px rgba(0,0,0,.3)}.auth-back-link-signup{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:color var(--transition);z-index:10}.auth-back-link-signup:hover{color:var(--primary)}.auth-form-section .auth-back-link-signup{display:none}.auth-image-section .auth-back-link-signup-mobile{position:absolute;bottom:1.5rem;right:1.5rem;font-size:.875rem;font-weight:500;color:#ffffffe6;text-decoration:none;text-shadow:0 1px 4px rgba(0,0,0,.3);z-index:10}.auth-image{width:100%;height:100%;object-fit:cover;display:block}.auth-error{background:#fef2f2;color:#dc2626;padding:.625rem .875rem;border-radius:var(--radius-sm);font-size:.8125rem;text-align:center;border:1px solid #fecaca}@media (max-width: 968px){.auth-wrapper,.auth-wrapper.signup-layout{grid-template-columns:1fr!important;height:auto;min-height:100vh}.auth-wrapper.signup-layout .auth-form-section{order:2!important}.auth-wrapper.signup-layout .auth-image-section{order:-1!important}.auth-image-section{height:240px;min-height:240px;order:-1}.auth-form-section{padding:2rem 0 3rem;height:auto;min-height:auto;order:2}.auth-form-content{padding:0 1.5rem}.auth-brand-overlay h1{font-size:1.2rem}}@media (max-width: 480px){.auth-title{font-size:1.5rem}.auth-form-content{padding:0 1.25rem}.auth-image-section{height:200px;min-height:200px}}.wine-card{background:var(--bg-primary);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary);transition:all var(--transition);display:flex;flex-direction:column;height:100%;cursor:pointer}.wine-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.wine-card-image-wrapper{position:relative;width:100%;height:220px;overflow:hidden;background:var(--bg-tertiary)}.wine-card-image{width:100%;height:100%;object-fit:cover}.wine-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);opacity:.3}.wine-card-category-badge{position:absolute;top:.75rem;right:.75rem;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;color:var(--text-primary);background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-transform:uppercase;letter-spacing:.5px}.wine-card-content{padding:1rem;display:flex;flex-direction:column;flex:1}.wine-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;gap:.5rem}.wine-card-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;flex:1;line-height:1.3}.wine-card-rating{display:flex;gap:.125rem;flex-shrink:0}.wine-card-rating .star{font-size:.875rem;color:var(--border-secondary);transition:color var(--transition)}.wine-card-rating .star.filled{color:#f59e0b}.wine-card-meta{display:flex;align-items:center;gap:.375rem;margin-bottom:.625rem;font-size:.8125rem;color:var(--text-tertiary)}.wine-card-year{font-weight:600;color:var(--primary)}.wine-card-separator{opacity:.4}.wine-card-notes{font-size:.8125rem;color:var(--text-secondary);line-height:1.5;margin-bottom:.625rem;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.wine-card-pairing{display:flex;align-items:center;gap:.375rem;padding:.5rem;background:var(--primary-lighter);border-radius:var(--radius-sm);font-size:.75rem}.wine-card-pairing-label{font-weight:600;color:var(--primary)}.wine-card-pairing-text{color:var(--text-primary)}@media (max-width: 768px){.wine-card-image-wrapper{height:180px}.wine-card-content{padding:.875rem}.wine-card-name{font-size:.9375rem}}.wine-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;margin-top:1.5rem}.wine-grid-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;color:var(--text-tertiary)}.wine-grid-empty svg{margin-bottom:1rem;opacity:.2}.wine-grid-empty-text{font-size:.9375rem;color:var(--text-tertiary);margin:0}@media (max-width: 768px){.wine-grid{grid-template-columns:1fr;gap:1rem}}@media (min-width: 769px) and (max-width: 1024px){.wine-grid{grid-template-columns:repeat(2,1fr)}}.wine-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:all .3s ease}.wine-detail-overlay.open{opacity:1;visibility:visible}.wine-detail-panel{position:fixed;top:0;right:-100%;width:480px;max-width:90vw;height:100vh;background:var(--bg-primary);z-index:1001;box-shadow:var(--shadow-lg);transition:right .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;display:flex;flex-direction:column}.wine-detail-panel.open{right:0}.wine-detail-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:var(--radius-full);background:var(--bg-hover);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:all var(--transition);z-index:10}.wine-detail-close:hover{background:var(--bg-tertiary)}.wine-detail-content{padding:3.5rem 1.5rem 1.5rem}.wine-detail-image-section{margin-bottom:1.5rem}.wine-detail-image-wrapper{position:relative;width:100%;height:300px;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-tertiary)}.wine-detail-image{width:100%;height:100%;object-fit:cover}.wine-detail-image-edit-btn{position:absolute;bottom:.75rem;right:.75rem;display:flex;align-items:center;gap:.375rem;padding:.4rem .75rem;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.wine-detail-image-edit-btn:hover{background:#000c}.wine-detail-image-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:160px;border:2px dashed var(--border-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);background:var(--bg-secondary)}.wine-detail-image-upload-label:hover{border-color:var(--primary);background:var(--primary-lighter)}.wine-detail-image-upload-label svg{color:var(--primary);margin-bottom:.5rem}.wine-detail-image-upload-label span{font-size:.8125rem;font-weight:500;color:var(--primary)}.wine-detail-image-input{display:none}.wine-detail-form-group{margin-bottom:1rem}.wine-detail-form-group:last-child{margin-bottom:0}.wine-detail-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.wine-detail-label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:.375rem}.wine-detail-input,.wine-detail-select,.wine-detail-textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--border-secondary);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-primary);background:var(--bg-primary);transition:border-color var(--transition)}.wine-detail-input:focus,.wine-detail-select:focus,.wine-detail-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-lighter)}.wine-detail-textarea{resize:vertical;min-height:80px}.wine-detail-rating-input{display:flex;align-items:center;gap:.25rem}.detail-star-input{background:none;border:none;font-size:1.25rem;color:var(--border-secondary);cursor:pointer;transition:all var(--transition);padding:0;line-height:1}.detail-star-input:hover{transform:scale(1.1);color:#f59e0b}.detail-star-input.filled{color:#f59e0b}.wine-detail-rating-value{font-size:.875rem;font-weight:600;color:var(--text-tertiary);margin-left:.375rem}.wine-detail-section{margin-bottom:1.5rem}.wine-detail-section:last-child{margin-bottom:0}.wine-detail-section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;padding-bottom:.375rem;border-bottom:1px solid var(--border-primary)}.wine-detail-section:first-of-type .wine-detail-form-group:last-child{margin-bottom:1.5rem}.wine-detail-section:nth-of-type(3){margin-bottom:2rem}.wine-detail-section:first-of-type .wine-detail-label{color:var(--text-tertiary);font-weight:400}.wine-detail-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-primary)}.wine-detail-save-btn{flex:1;padding:.625rem 1rem;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background var(--transition)}.wine-detail-actions .wine-detail-save-btn:only-child{width:100%;flex:none}.wine-detail-save-btn:hover{background:var(--primary-light)}.wine-detail-delete-btn{display:flex;align-items:center;gap:.375rem;padding:.625rem 1rem;background:transparent;color:#dc2626;border:1px solid #fecaca;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.wine-detail-delete-btn:hover{background:#fef2f2;border-color:#dc2626}@media (max-width: 768px){.wine-detail-panel{right:0;bottom:-100%;top:auto;width:100%;max-width:100vw;height:85vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;transition:bottom .35s cubic-bezier(.4,0,.2,1)}.wine-detail-panel.open{bottom:0}.wine-detail-content{padding:2.5rem 1.25rem 1.25rem}.wine-detail-image-wrapper{height:200px}.wine-detail-form-row{grid-template-columns:1fr}.wine-detail-actions{flex-direction:column-reverse}.wine-detail-save-btn,.wine-detail-delete-btn{width:100%}.wine-detail-delete-btn{justify-content:center}}.personal-wine-cellar{min-height:100vh;background:var(--bg-secondary);padding-top:0}.personal-wine-cellar-container{max-width:1100px;margin:0 auto;padding:1.5rem 1.5rem 3rem}.cellar-cover-section{width:100%;background:var(--bg-primary);margin-bottom:0}.cellar-cover-photo{position:relative;width:100%;height:280px;overflow:hidden;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%)}.cellar-cover-photo img{width:100%;height:100%;object-fit:cover}.cellar-cover-title{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:700;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.3);margin:0;letter-spacing:-.5px;z-index:5}.cellar-edit-cover-btn{position:absolute;bottom:.75rem;right:.75rem;display:flex;align-items:center;gap:.375rem;padding:.4rem .75rem;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.cellar-edit-cover-btn:hover{background:#000c}.cellar-profile-section{position:relative;padding:0 1.5rem .75rem;display:flex;align-items:flex-end;gap:1.25rem;background:var(--bg-primary);border-bottom:1px solid var(--border-primary)}.cellar-profile-picture{position:relative;margin-top:-40px;z-index:10}.cellar-profile-avatar{width:100px;height:100px;border-radius:var(--radius-full);border:3px solid var(--bg-primary);background:var(--primary-lighter);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:2rem;font-weight:700;box-shadow:var(--shadow-md)}.cellar-profile-info{flex:1;display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem}.cellar-add-wine-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background var(--transition)}.cellar-add-wine-btn:hover{background:var(--primary-light);transform:none}.cellar-nav-tabs{display:flex;gap:0;flex:1}.cellar-nav-tab{display:flex;align-items:center;gap:.375rem;padding:.75rem 1rem;background:none;border:none;border-bottom:2px solid transparent;font-size:.8125rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.cellar-nav-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.cellar-nav-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.cellar-tab-count{padding:.125rem .4rem;border-radius:var(--radius-full);background:var(--bg-tertiary);font-size:.75rem;font-weight:600;color:var(--text-secondary)}.cellar-nav-tab.active .cellar-tab-count{background:var(--primary);color:var(--text-inverse)}.personal-wine-cellar-form-wrapper{background:var(--bg-primary);border-radius:var(--radius-md);padding:1.5rem;border:1px solid var(--border-primary)}@media (max-width: 968px){.personal-wine-cellar-container{padding:1.5rem 1rem 2rem}.cellar-cover-photo{height:220px}.cellar-profile-section{padding:0 1rem;flex-direction:column;align-items:flex-start}.cellar-profile-avatar{width:80px;height:80px;font-size:1.5rem}.cellar-profile-info{width:100%;flex-direction:column;align-items:flex-start;gap:.75rem}.cellar-cover-title{font-size:1.5rem}.cellar-add-wine-btn{width:100%;justify-content:center}.cellar-nav-tabs{width:100%;overflow-x:auto}.cellar-nav-tab{white-space:nowrap;font-size:.75rem}}.events-header{margin-bottom:2rem}.events-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:1.25rem;letter-spacing:-.3px}.events-controls{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem}.events-search-section{display:flex;align-items:center;gap:.75rem;flex:1;max-width:400px}.events-search-wrapper{position:relative;display:flex;align-items:center;flex:1}.events-search-icon{position:absolute;left:.875rem;color:var(--text-tertiary);pointer-events:none}.events-search-input{width:100%;padding:.625rem .875rem .625rem 2.5rem;border:1px solid var(--border-secondary);border-radius:var(--radius-full);font-size:.875rem;color:var(--text-primary);background:var(--bg-primary);transition:border-color var(--transition)}.events-search-input:focus{outline:none;border-color:var(--primary)}.events-find-btn{display:flex;align-items:center;gap:.375rem;padding:.625rem 1.25rem;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background var(--transition);white-space:nowrap}.events-find-btn:hover{background:var(--primary-light);transform:none;box-shadow:none}.events-view-controls{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.events-view-options{display:flex;gap:.75rem}.events-view-btn{padding:0;border:none;background:none;font-size:.8125rem;color:var(--text-secondary);cursor:pointer;transition:color var(--transition)}.events-view-btn:hover{color:var(--primary)}.events-view-btn.active{color:var(--primary);font-weight:600}.events-subscribe-btn{display:flex;align-items:center;gap:.375rem;padding:.4rem .875rem;background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.events-subscribe-btn:hover{border-color:var(--primary);color:var(--primary)}@media (max-width: 768px){.events-title{font-size:1.5rem}.events-controls{flex-direction:column}.events-search-section{flex-direction:column;width:100%;max-width:100%}.events-search-wrapper{width:100%}.events-find-btn{width:100%;justify-content:center}.events-view-controls{flex-direction:row;justify-content:space-between;width:100%}}.event-card{position:relative;display:grid;grid-template-columns:1fr 160px;gap:1.5rem;padding:1.25rem 0;border-bottom:1px solid var(--border-primary);cursor:pointer;transition:all var(--transition)}.event-card:last-child{border-bottom:none}.event-card-featured{position:relative}.event-card-featured-bar{position:absolute;left:-1rem;top:0;bottom:0;width:3px;background:var(--primary);border-radius:2px}.event-card:hover{background:var(--bg-hover);margin:0 -.75rem;padding:1.25rem .75rem;border-radius:var(--radius-sm)}.event-card-content{display:flex;flex-direction:column;gap:.375rem}.event-card-header{display:flex;align-items:center;gap:.75rem}.event-card-date{font-size:.875rem;font-weight:600;color:var(--primary)}.event-card-featured-badge{padding:.125rem .5rem;background:var(--primary);border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;color:var(--text-inverse);text-transform:uppercase;letter-spacing:.5px}.event-card-date-range{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--text-tertiary)}.event-card-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.event-card-location{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--text-tertiary)}.event-card-description{font-size:.8125rem;color:var(--text-secondary);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.event-card-footer{margin-top:auto;padding-top:.25rem}.event-card-price{font-size:.875rem;font-weight:600;color:var(--primary)}.event-card-image-wrapper{width:160px;height:160px;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-tertiary);flex-shrink:0}.event-card-image{width:100%;height:100%;object-fit:cover}@media (max-width: 968px){.event-card{grid-template-columns:1fr;gap:1rem}.event-card-image-wrapper{width:100%;height:200px;order:-1}}.events-list{display:flex;flex-direction:column;gap:2rem}.events-month-group{display:flex;flex-direction:column;gap:0}.events-month-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0;padding-bottom:.5rem;border-bottom:1px solid var(--border-primary);margin-bottom:.5rem}.events-month-events{display:flex;flex-direction:column}.events-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;color:var(--text-tertiary)}.events-list-empty svg{margin-bottom:1rem;opacity:.2}.events-list-empty-text{font-size:.9375rem;color:var(--text-tertiary);margin:0}.events-page{min-height:100vh;background:var(--bg-secondary);padding:5rem 0 3rem}.events-container{max-width:1000px;margin:0 auto;padding:0 1.5rem}@media (max-width: 968px){.events-page{padding:4.5rem 0 2rem}.events-container{padding:0 1rem}}.event-detail-page{min-height:100vh;background:var(--bg-secondary);padding:4.5rem 0 3rem}.event-detail-container{max-width:800px;margin:0 auto;padding:0 1.5rem}.event-detail-back{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary);text-decoration:none;margin-bottom:1.5rem;transition:color var(--transition);background:none;border:none;cursor:pointer;padding:0}.event-detail-back:hover{color:var(--primary)}.event-detail-hero{width:100%;height:320px;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1.5rem;background:var(--bg-tertiary)}.event-detail-hero img{width:100%;height:100%;object-fit:cover}.event-detail-hero-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%)}.event-detail-hero-placeholder svg{opacity:.2;color:#fff}.event-detail-meta{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.event-detail-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.event-detail-badge-featured{background:var(--primary);color:var(--text-inverse)}.event-detail-badge-category{background:var(--primary-lighter);color:var(--primary)}.event-detail-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:1.25rem;line-height:1.2;letter-spacing:-.3px}.event-detail-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.875rem;margin-bottom:1.5rem}.event-detail-info-item{display:flex;align-items:flex-start;gap:.625rem;padding:.875rem;background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.event-detail-info-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--primary-lighter);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary)}.event-detail-info-label{font-size:.6875rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.125rem}.event-detail-info-value{font-size:.875rem;font-weight:600;color:var(--text-primary)}.event-detail-description{font-size:.9375rem;color:var(--text-secondary);line-height:1.7;margin-bottom:2rem;padding:1.25rem;background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.event-detail-ticket-section{background:var(--bg-primary);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--primary-border);margin-bottom:1.5rem}.event-detail-ticket-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.event-detail-ticket-title{font-size:1.0625rem;font-weight:600;color:var(--text-primary)}.event-detail-price{font-size:1.5rem;font-weight:700;color:var(--primary)}.event-detail-capacity{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:1rem}.event-detail-capacity-bar{width:100%;height:4px;background:var(--bg-tertiary);border-radius:2px;margin-top:.375rem;overflow:hidden}.event-detail-capacity-fill{height:100%;background:var(--primary);border-radius:2px;transition:width .3s ease}.event-detail-buy-btn{width:100%;padding:.75rem;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:.375rem}.event-detail-buy-btn:hover:not(:disabled){background:var(--primary-light)}.event-detail-buy-btn:disabled{opacity:.5;cursor:not-allowed}.event-detail-has-ticket{text-align:center;padding:.875rem;background:#ecfdf5;border-radius:var(--radius-md);border:1px solid #a7f3d0}.event-detail-has-ticket p{font-size:.875rem;color:#059669;font-weight:500;margin-bottom:.5rem}.event-detail-view-ticket-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.4rem 1rem;background:#059669;color:#fff;border:none;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;text-decoration:none;transition:background var(--transition)}.event-detail-view-ticket-btn:hover{background:#047857}.event-detail-loading,.event-detail-error{text-align:center;padding:3rem 1.5rem;color:var(--text-tertiary)}.event-detail-error{color:#dc2626}@media (max-width: 768px){.event-detail-hero{height:220px;border-radius:var(--radius-md)}.event-detail-title{font-size:1.5rem}.event-detail-info-grid{grid-template-columns:1fr}.event-detail-ticket-header{flex-direction:column;align-items:flex-start;gap:.375rem}}.ai-sommelier-page{display:flex;height:100vh;background:var(--bg-primary);position:relative}.ai-sommelier-main{width:100%;display:flex;flex-direction:column;overflow:hidden;padding-top:60px}.ai-sommelier-content{flex:1;display:flex;flex-direction:column;padding:1.5rem;overflow-y:auto}.ai-sommelier-welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}.ai-sommelier-welcome-bubble-container{margin-bottom:1.5rem;display:flex;justify-content:center;width:100%}.ai-sommelier-welcome-bubble-wrapper{position:relative;width:96px;height:96px;margin:0 auto}.ai-sommelier-welcome-bubble-glow{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-full);filter:blur(32px);opacity:.4;background:radial-gradient(circle,var(--primary-lighter) 0%,transparent 70%)}.ai-sommelier-welcome-bubble-inner{position:absolute;top:12px;right:12px;bottom:12px;left:12px;border-radius:var(--radius-full);background:var(--primary);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;color:#fff;z-index:1}.ai-sommelier-welcome-bubble-inner svg{position:relative;z-index:2;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.ai-sommelier-welcome-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 auto .5rem;letter-spacing:-.3px}.ai-sommelier-welcome-subtitle{font-size:1rem;color:var(--text-secondary);margin:0 auto;max-width:400px}.ai-sommelier-highlight{color:var(--primary);font-weight:600}.ai-sommelier-messages{flex:1;display:flex;flex-direction:column;gap:1.25rem;padding-bottom:1.5rem;max-width:720px;margin:0 auto;width:100%}.ai-sommelier-message-wrapper{display:flex;flex-direction:column;gap:.5rem}.ai-sommelier-message{display:flex;gap:.75rem;align-items:flex-start}.ai-sommelier-message-ai{width:100%}.ai-sommelier-message-user{width:100%;flex-direction:row-reverse}.ai-sommelier-avatar{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}.ai-sommelier-avatar-ai{background:var(--primary);color:#fff}.ai-sommelier-avatar-user{background:var(--bg-tertiary);color:var(--text-secondary)}.ai-sommelier-message-content-wrapper{flex:1;display:flex;flex-direction:column;gap:.5rem}.ai-sommelier-message-content{padding:.875rem 1rem;background:var(--bg-secondary);border-radius:var(--radius-md);font-size:.875rem;line-height:1.6;color:var(--text-primary);border:1px solid var(--border-primary)}.ai-sommelier-message-user .ai-sommelier-message-content{background:var(--primary-lighter);border-color:var(--primary-border)}.ai-sommelier-message-actions{display:flex;align-items:center;gap:.75rem;padding-left:.25rem}.ai-sommelier-feedback-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition)}.ai-sommelier-feedback-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.ai-sommelier-action-text-btn{background:none;border:none;color:var(--text-primary);font-size:.8125rem;font-weight:500;cursor:pointer;padding:.25rem .5rem;border-radius:var(--radius-sm);transition:all var(--transition)}.ai-sommelier-action-text-btn:hover{background:var(--bg-hover)}.ai-sommelier-regenerate-wrapper{display:flex;justify-content:center;padding-top:.375rem}.ai-sommelier-regenerate-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1.25rem;background:var(--text-primary);color:#fff;border:none;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.ai-sommelier-regenerate-btn:hover{opacity:.9}.ai-sommelier-typing{display:flex;align-items:center;min-height:40px}.ai-sommelier-typing-dots{display:flex;align-items:center;gap:4px;padding:4px 0}.ai-sommelier-typing-dots span{width:7px;height:7px;border-radius:var(--radius-full);background:var(--primary);opacity:.3;animation:ai-sommelier-bounce 1.4s infinite ease-in-out both}.ai-sommelier-typing-dots span:nth-child(1){animation-delay:-.32s}.ai-sommelier-typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes ai-sommelier-bounce{0%,80%,to{transform:scale(.6);opacity:.3}40%{transform:scale(1);opacity:1}}.ai-sommelier-input-container{position:sticky;bottom:0;background:var(--bg-primary);padding-top:1rem;border-top:1px solid var(--border-primary);max-width:720px;margin:0 auto;width:100%}.ai-sommelier-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-secondary);border-radius:var(--radius-md);font-size:.875rem;color:var(--text-primary);background:var(--bg-secondary);outline:none;transition:all var(--transition);margin-bottom:.5rem}.ai-sommelier-input:focus{border-color:var(--primary);background:var(--bg-primary)}.ai-sommelier-input::placeholder{color:var(--text-tertiary)}.ai-sommelier-input-footer{display:flex;align-items:center;justify-content:space-between}.ai-sommelier-input-footer-left,.ai-sommelier-input-footer-right{display:flex;align-items:center;gap:.75rem}.ai-sommelier-footer-btn{display:flex;align-items:center;gap:.375rem;background:none;border:none;color:var(--text-tertiary);font-size:.8125rem;cursor:pointer;padding:.375rem;border-radius:var(--radius-sm);transition:all var(--transition)}.ai-sommelier-footer-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.ai-sommelier-send-btn{width:36px;height:36px;border-radius:var(--radius-full);background:var(--primary);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition)}.ai-sommelier-send-btn:hover{background:var(--primary-light)}@media (max-width: 768px){.ai-sommelier-content{padding:1rem}.ai-sommelier-welcome-title{font-size:1.5rem}.ai-sommelier-welcome-subtitle{font-size:.9375rem}.ai-sommelier-welcome-bubble-wrapper{width:80px;height:80px}.ai-sommelier-input-footer{flex-direction:column;align-items:flex-start;gap:.5rem}.ai-sommelier-input-footer-right{width:100%;justify-content:space-between}}.stories-page{min-height:100vh;background:var(--bg-secondary);padding:6rem 1.5rem 3rem}.stories-container{max-width:1000px;margin:0 auto}.stories-header{text-align:center;margin-bottom:3rem}.stories-journal-label{font-size:.6875rem;color:var(--primary);font-weight:600;letter-spacing:2px;text-transform:uppercase;margin:0 0 .625rem}.stories-title{font-size:2.25rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem;line-height:1.2;letter-spacing:-.5px}.stories-subtitle{font-size:.9375rem;color:var(--text-secondary);margin:0 auto;max-width:560px;line-height:1.6}.stories-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}@media (max-width: 968px){.stories-page{padding:5rem 1rem 2rem}.stories-title{font-size:1.75rem}.stories-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}}@media (max-width: 768px){.stories-header{margin-bottom:2rem}.stories-title{font-size:1.5rem}.stories-grid{grid-template-columns:1fr;gap:1rem}}.story-card-link{text-decoration:none;color:inherit;display:block}.story-card{display:flex;flex-direction:column;background:var(--bg-primary);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary);transition:all var(--transition)}.story-card-link:hover .story-card{border-color:var(--border-secondary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.story-card-image-wrapper{width:100%;height:200px;overflow:hidden;background:var(--bg-tertiary)}.story-card-image{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.story-card-link:hover .story-card-image{transform:scale(1.03)}.story-card-content{padding:1.125rem;display:flex;flex-direction:column;gap:.5rem}.story-card-metadata{display:flex;align-items:center;gap:.375rem;font-size:.6875rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.story-card-dot{color:var(--primary);font-size:.375rem}.story-card-title{font-size:1.0625rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.story-card-description{font-size:.8125rem;color:var(--text-secondary);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.story-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.25rem}.story-card-read-link{font-size:.8125rem;color:var(--primary);text-decoration:none;font-weight:600;transition:opacity var(--transition)}.story-card-read-link:hover{opacity:.8}.story-card-author{font-size:.75rem;color:var(--text-tertiary);font-style:italic}@media (max-width: 768px){.story-card-image-wrapper{height:180px}.story-card-content{padding:1rem}.story-card-title{font-size:1rem}}.story-detail-page{min-height:100vh;background:var(--bg-primary)}.story-detail-loading,.story-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:.75rem;color:var(--text-tertiary);padding:2rem;text-align:center}.story-detail-loading-spinner{width:36px;height:36px;border:3px solid var(--border-primary);border-top-color:var(--primary);border-radius:var(--radius-full);animation:spin .8s linear infinite}.story-detail-error h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.story-detail-error p{font-size:.9375rem;color:var(--text-secondary);margin:0}.story-detail-back-btn{display:inline-flex;align-items:center;gap:.375rem;margin-top:.75rem;padding:.5rem 1.25rem;background:var(--primary);color:var(--text-inverse);text-decoration:none;border-radius:var(--radius-full);font-size:.875rem;font-weight:600;transition:background var(--transition)}.story-detail-back-btn:hover{background:var(--primary-light)}.story-detail-hero{position:relative;width:100%;height:420px;overflow:hidden;margin-top:60px}.story-detail-hero-image-wrapper{position:absolute;top:0;right:0;bottom:0;left:0}.story-detail-hero-image{width:100%;height:100%;object-fit:cover;display:block}.story-detail-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#0000001a,#00000080)}.story-detail-hero-content{position:absolute;bottom:0;left:0;right:0;padding:2.5rem 1.5rem;max-width:720px;margin:0 auto;text-align:center;z-index:1}.story-detail-hero-meta{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.75rem;font-size:.6875rem;color:#fffc;text-transform:uppercase;letter-spacing:1.5px;font-weight:500}.story-detail-hero-dot{width:4px;height:4px;border-radius:var(--radius-full);background:var(--primary)}.story-detail-hero-title{font-size:2.25rem;font-weight:700;color:#fff;margin:0 0 .625rem;line-height:1.2;letter-spacing:-.5px;text-shadow:0 2px 12px rgba(0,0,0,.2)}.story-detail-hero-author{font-size:.875rem;color:#ffffffb3;font-style:italic;margin:0}.story-detail-article{padding:2.5rem 1.5rem 1.5rem}.story-detail-article-container{max-width:680px;margin:0 auto}.story-detail-lead{font-size:1.125rem;color:var(--text-secondary);line-height:1.7;margin:0 0 1.5rem}.story-detail-divider{width:48px;height:2px;background:var(--primary);margin:0 auto 2rem}.story-detail-content{font-size:1rem;color:var(--text-primary);line-height:1.8}.story-detail-paragraph{margin:0 0 1.5rem}.story-detail-paragraph:last-child{margin-bottom:0}.story-detail-h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:2rem 0 .75rem;line-height:1.3}.story-detail-h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:1.5rem 0 .625rem}.story-detail-blockquote{border-left:3px solid var(--primary);margin:1.5rem 0;padding:.75rem 1.25rem;font-size:1.0625rem;color:var(--text-secondary);font-style:italic;line-height:1.7;background:var(--primary-lighter);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.story-detail-content strong{font-weight:600;color:var(--text-primary)}.story-detail-content em{font-style:italic}.story-detail-footer-nav{max-width:680px;margin:0 auto;padding:1.5rem 1.5rem 3rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border-primary)}.story-detail-nav-link{display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--primary);text-decoration:none;font-weight:600;transition:gap var(--transition);background:none;border:none;cursor:pointer;padding:0}.story-detail-nav-link:hover{gap:.625rem}@media (max-width: 768px){.story-detail-hero{height:320px;margin-top:60px}.story-detail-hero-title{font-size:1.5rem}.story-detail-hero-content{padding:1.5rem 1rem}.story-detail-article{padding:2rem 1rem 1rem}.story-detail-content{font-size:.9375rem}}@media (max-width: 480px){.story-detail-hero{height:260px}.story-detail-hero-title{font-size:1.25rem}}.checkout-page{min-height:100vh;background:var(--bg-secondary);padding:4.5rem 0 3rem}.checkout-container{max-width:520px;margin:0 auto;padding:0 1.5rem}.checkout-back{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:0;margin-bottom:1.5rem;transition:color var(--transition)}.checkout-back:hover{color:var(--primary)}.checkout-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem;letter-spacing:-.3px}.checkout-summary{background:var(--bg-primary);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1rem;border:1px solid var(--border-primary)}.checkout-summary-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:.75rem}.checkout-summary-event{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.375rem}.checkout-summary-detail{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:.25rem}.checkout-summary-divider{height:1px;background:var(--border-primary);margin:.75rem 0}.checkout-summary-row{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem;color:var(--text-primary);margin-bottom:.375rem}.checkout-summary-total{display:flex;justify-content:space-between;align-items:center;font-size:1rem;font-weight:700;color:var(--primary);padding-top:.5rem;border-top:2px solid var(--border-primary)}.checkout-payment{background:var(--bg-primary);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1rem;border:1px solid var(--border-primary)}.checkout-payment-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:.75rem}.checkout-mock-banner{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:#fefce8;border:1px solid #fde68a;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.75rem;color:#92400e}.checkout-form-group{margin-bottom:.75rem}.checkout-form-label{display:block;font-size:.75rem;font-weight:500;color:var(--text-secondary);margin-bottom:.25rem}.checkout-form-input{width:100%;padding:.625rem .75rem;border:1px solid var(--border-secondary);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-primary);background:var(--bg-secondary);outline:none;transition:border-color var(--transition)}.checkout-form-input:focus{border-color:var(--primary)}.checkout-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.checkout-pay-btn{width:100%;padding:.75rem;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:.375rem}.checkout-pay-btn:hover:not(:disabled){background:var(--primary-light)}.checkout-pay-btn:disabled{opacity:.5;cursor:not-allowed}.checkout-processing{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem}.checkout-spinner{width:36px;height:36px;border:3px solid var(--primary-lighter);border-top-color:var(--primary);border-radius:var(--radius-full);animation:spin .8s linear infinite}.checkout-processing-text{font-size:.875rem;color:var(--text-secondary)}.checkout-error{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);padding:.5rem .75rem;margin-bottom:.75rem;font-size:.8125rem;color:#dc2626}@media (max-width: 480px){.checkout-form-row{grid-template-columns:1fr}}.confirmation-page{min-height:100vh;background:var(--bg-secondary);padding:4.5rem 0 3rem}.confirmation-container{max-width:480px;margin:0 auto;padding:0 1.5rem;text-align:center}.confirmation-success-icon{width:64px;height:64px;border-radius:var(--radius-full);background:#ecfdf5;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;animation:scaleIn .5s cubic-bezier(.34,1.56,.64,1)}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.confirmation-success-icon svg{color:#059669}.confirmation-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.375rem;letter-spacing:-.3px}.confirmation-subtitle{font-size:.9375rem;color:var(--text-secondary);margin-bottom:1.5rem}.confirmation-ticket-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--primary-border);margin-bottom:1.5rem;position:relative;overflow:hidden}.confirmation-ticket-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary)}.confirmation-ticket-code{display:inline-block;background:var(--primary);color:var(--text-inverse);padding:.375rem 1rem;border-radius:var(--radius-full);font-size:.8125rem;font-weight:600;letter-spacing:2px;margin-bottom:1rem}.confirmation-event-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.confirmation-event-detail{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:.25rem;display:flex;align-items:center;justify-content:center;gap:.25rem}.confirmation-qr-wrapper{margin:1.25rem auto;width:180px;height:180px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary)}.confirmation-qr-wrapper img{width:100%;height:100%;object-fit:contain}.confirmation-qr-hint{font-size:.75rem;color:var(--text-tertiary);margin-bottom:1.25rem}.confirmation-actions{display:flex;gap:.625rem;justify-content:center;flex-wrap:wrap}.confirmation-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.5rem 1.25rem;border-radius:var(--radius-full);font-size:.8125rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all var(--transition);border:none}.confirmation-btn-primary{background:var(--primary);color:var(--text-inverse)}.confirmation-btn-primary:hover{background:var(--primary-light)}.confirmation-btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-secondary)}.confirmation-btn-secondary:hover{background:var(--bg-hover)}.confirmation-loading{color:var(--text-tertiary);padding:3rem 0}.my-tickets-page{min-height:100vh;background:var(--bg-secondary);padding:4.5rem 0 3rem}.my-tickets-container{max-width:800px;margin:0 auto;padding:0 1.5rem}.my-tickets-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.my-tickets-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.my-tickets-filters{display:flex;gap:.375rem}.my-tickets-filter-btn{padding:.375rem .875rem;border:1px solid var(--border-secondary);border-radius:var(--radius-full);background:var(--bg-primary);font-size:.75rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.my-tickets-filter-btn:hover{border-color:var(--primary);color:var(--primary)}.my-tickets-filter-btn.active{background:var(--primary);color:var(--text-inverse);border-color:var(--primary)}.ticket-card{background:var(--bg-primary);border-radius:var(--radius-md);margin-bottom:.75rem;overflow:hidden;border:1px solid var(--border-primary);transition:all var(--transition);cursor:pointer}.ticket-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-sm)}.ticket-card-inner{display:flex;align-items:stretch}.ticket-card-qr{width:90px;min-height:90px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-right:1px dashed var(--border-primary);padding:.625rem;flex-shrink:0}.ticket-card-qr img{width:70px;height:70px;object-fit:contain}.ticket-card-qr-placeholder{width:52px;height:52px;border-radius:var(--radius-sm);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.ticket-card-content{flex:1;padding:.875rem 1rem;display:flex;flex-direction:column;justify-content:center}.ticket-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem}.ticket-card-event-name{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.ticket-card-status{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:var(--radius-full);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.ticket-card-status-confirmed{background:#ecfdf5;color:#059669}.ticket-card-status-checked_in{background:#eff6ff;color:#2563eb}.ticket-card-status-cancelled{background:#fef2f2;color:#dc2626}.ticket-card-status-pending_payment{background:#fefce8;color:#d97706}.ticket-card-details{display:flex;gap:1rem;flex-wrap:wrap}.ticket-card-detail{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--text-tertiary)}.ticket-card-code{font-size:.6875rem;font-weight:600;color:var(--primary);margin-top:.25rem;letter-spacing:1px}.my-tickets-empty{text-align:center;padding:3rem 1.5rem}.my-tickets-empty svg{color:var(--text-tertiary);opacity:.2;margin-bottom:.75rem}.my-tickets-empty-text{font-size:.9375rem;color:var(--text-secondary);margin-bottom:1rem}.my-tickets-browse-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.5rem 1.25rem;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);font-size:.8125rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background var(--transition)}.my-tickets-browse-btn:hover{background:var(--primary-light)}.my-tickets-loading{text-align:center;padding:3rem 1.5rem;color:var(--text-tertiary)}@media (max-width: 600px){.ticket-card-inner{flex-direction:column}.ticket-card-qr{width:100%;min-height:auto;border-right:none;border-bottom:1px dashed var(--border-primary);padding:.75rem}.my-tickets-filters{flex-wrap:wrap}}.ticket-view-page{min-height:100vh;background:var(--bg-secondary);padding:4.5rem 0 3rem}.ticket-view-container{max-width:440px;margin:0 auto;padding:0 1.5rem}.ticket-view-back{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:0;margin-bottom:1.25rem;text-decoration:none;transition:color var(--transition)}.ticket-view-back:hover{color:var(--primary)}.ticket-view-card{background:var(--bg-primary);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-primary);box-shadow:var(--shadow-md);margin-bottom:1.25rem}.ticket-view-header{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);padding:1.5rem;text-align:center}.ticket-view-header-label{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:#ffffffa6;margin-bottom:.375rem}.ticket-view-header-title{font-size:1.25rem;font-weight:700;color:#fff}.ticket-view-body{padding:1.5rem}.ticket-view-code-wrapper{text-align:center;margin-bottom:1rem}.ticket-view-code{display:inline-block;background:var(--primary-lighter);color:var(--primary);padding:.4rem 1.25rem;border-radius:var(--radius-full);font-size:1rem;font-weight:700;letter-spacing:3px}.ticket-view-qr-wrapper{display:flex;justify-content:center;margin:1.25rem 0}.ticket-view-qr{width:200px;height:200px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary);background:#fff}.ticket-view-qr img{width:100%;height:100%;object-fit:contain}.ticket-view-divider{height:1px;background:repeating-linear-gradient(to right,var(--border-secondary),var(--border-secondary) 6px,transparent 6px,transparent 12px);margin:1.25rem 0}.ticket-view-info{display:flex;flex-direction:column;gap:.625rem}.ticket-view-info-row{display:flex;justify-content:space-between;align-items:center}.ticket-view-info-label{font-size:.75rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px}.ticket-view-info-value{font-size:.8125rem;font-weight:600;color:var(--text-primary);text-align:right}.ticket-view-status-badge{display:inline-flex;align-items:center;padding:.175rem .5rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;text-transform:uppercase}.ticket-view-status-confirmed{background:#ecfdf5;color:#059669}.ticket-view-status-checked_in{background:#eff6ff;color:#2563eb}.ticket-view-status-cancelled{background:#fef2f2;color:#dc2626}.ticket-view-status-pending_payment{background:#fefce8;color:#d97706}.ticket-view-actions{display:flex;gap:.5rem;flex-direction:column}.ticket-view-cancel-btn{width:100%;padding:.625rem;background:var(--bg-primary);color:#dc2626;border:1px solid #fecaca;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.ticket-view-cancel-btn:hover{background:#fef2f2;border-color:#dc2626}.ticket-view-cancel-btn:disabled{opacity:.4;cursor:not-allowed}.ticket-view-print-hint{font-size:.75rem;color:var(--text-tertiary);text-align:center}.ticket-view-loading,.ticket-view-error{text-align:center;padding:3rem 1.5rem;color:var(--text-tertiary)}@media print{.ticket-view-page{padding:0;background:#fff}.ticket-view-back,.ticket-view-actions,nav{display:none!important}}.post-composer{background:var(--bg-primary);border-radius:var(--radius-md);padding:16px;margin-bottom:16px;border:1px solid var(--border-primary)}.composer-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.composer-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--primary-lighter);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--primary);font-size:14px;flex-shrink:0;overflow:hidden}.composer-avatar img{width:100%;height:100%;object-fit:cover}.composer-textarea{width:100%;min-height:72px;padding:10px 12px;border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;resize:vertical;outline:none;background:var(--bg-secondary);color:var(--text-primary);transition:border-color var(--transition)}.composer-textarea:focus{border-color:var(--primary)}.composer-char-count{text-align:right;font-size:11px;color:var(--text-tertiary);margin-top:4px}.composer-char-count.near-limit{color:#f59e0b}.composer-char-count.at-limit{color:#dc2626}.composer-type-selector{display:flex;gap:6px;margin:10px 0;flex-wrap:wrap}.type-option{padding:5px 12px;border:1px solid var(--border-secondary);border-radius:var(--radius-full);background:var(--bg-primary);cursor:pointer;font-size:12px;font-weight:500;color:var(--text-secondary);transition:all var(--transition)}.type-option:hover{background:var(--bg-hover)}.type-option.active{background:var(--primary);color:var(--text-inverse);border-color:var(--primary)}.composer-wine-tag{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:10px;margin:10px 0}.composer-wine-tag h4{margin:0 0 6px;font-size:12px;font-weight:600;color:var(--text-secondary)}.wine-tag-inputs{display:grid;grid-template-columns:1fr 1fr;gap:6px}.wine-tag-inputs input,.wine-tag-inputs select{padding:7px 10px;border:1px solid var(--border-secondary);border-radius:var(--radius-sm);font-size:13px;outline:none;background:var(--bg-primary);color:var(--text-primary)}.wine-tag-inputs input:focus,.wine-tag-inputs select:focus{border-color:var(--primary)}.composer-image-preview{display:flex;gap:6px;margin:10px 0;flex-wrap:wrap}.image-preview-item{position:relative;width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden}.image-preview-item img{width:100%;height:100%;object-fit:cover}.image-preview-remove{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:var(--radius-full);background:#0009;color:#fff;border:none;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center}.composer-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.composer-tools{display:flex;gap:6px}.composer-tool-btn{background:none;border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:5px 10px;cursor:pointer;font-size:12px;color:var(--text-secondary);transition:all var(--transition)}.composer-tool-btn:hover{background:var(--bg-hover)}.composer-submit-btn{padding:7px 20px;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);cursor:pointer;font-size:13px;font-weight:600;transition:background var(--transition)}.composer-submit-btn:hover{background:var(--primary-light)}.composer-submit-btn:disabled{background:var(--border-secondary);cursor:not-allowed;color:var(--text-tertiary)}.comment-section{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-primary)}.comment-form{display:flex;gap:8px;margin-bottom:12px}.comment-input{flex:1;padding:8px 14px;border:1px solid var(--border-secondary);border-radius:var(--radius-full);font-size:13px;outline:none;background:var(--bg-secondary);color:var(--text-primary);transition:border-color var(--transition)}.comment-input:focus{border-color:var(--primary)}.comment-submit-btn{padding:7px 14px;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);cursor:pointer;font-size:12px;font-weight:600;transition:background var(--transition)}.comment-submit-btn:hover{background:var(--primary-light)}.comment-submit-btn:disabled{background:var(--border-secondary);color:var(--text-tertiary);cursor:not-allowed}.comment-list{display:flex;flex-direction:column;gap:10px}.comment-item{display:flex;gap:8px}.comment-avatar{width:28px;height:28px;border-radius:var(--radius-full);background:var(--primary-lighter);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--primary);flex-shrink:0;overflow:hidden}.comment-avatar img{width:100%;height:100%;object-fit:cover}.comment-body{flex:1}.comment-bubble{background:var(--bg-secondary);border-radius:var(--radius-md);padding:6px 10px}.comment-author{font-weight:600;font-size:12px;color:var(--text-primary);cursor:pointer}.comment-author:hover{color:var(--primary)}.comment-text{font-size:13px;color:var(--text-primary);line-height:1.4;margin-top:1px}.comment-meta{display:flex;align-items:center;gap:10px;margin-top:3px;padding-left:4px}.comment-time{font-size:11px;color:var(--text-tertiary)}.comment-like-btn{display:flex;align-items:center;gap:3px;background:none;border:none;font-size:11px;color:var(--text-tertiary);cursor:pointer;padding:0;transition:color var(--transition)}.comment-like-btn:hover,.comment-like-btn.liked{color:#dc2626}.comment-delete-btn{background:none;border:none;font-size:11px;color:var(--text-tertiary);cursor:pointer;padding:0;transition:color var(--transition)}.comment-delete-btn:hover{color:#dc2626}.comments-loading{text-align:center;padding:12px;color:var(--text-tertiary);font-size:13px}.post-card{background:var(--bg-primary);border-radius:var(--radius-md);padding:16px;margin-bottom:12px;border:1px solid var(--border-primary);transition:border-color var(--transition)}.post-card:hover{border-color:var(--border-secondary)}.post-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.post-avatar{width:40px;height:40px;border-radius:var(--radius-full);object-fit:cover;background:var(--primary-lighter);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--primary);font-size:16px;flex-shrink:0}.post-avatar img{width:100%;height:100%;border-radius:var(--radius-full);object-fit:cover}.post-author-info{flex:1}.post-author-name{font-weight:600;font-size:14px;color:var(--text-primary);cursor:pointer}.post-author-name:hover{color:var(--primary)}.post-timestamp{font-size:12px;color:var(--text-tertiary)}.post-type-badge{font-size:11px;padding:2px 8px;border-radius:var(--radius-full);font-weight:500;background:var(--bg-tertiary);color:var(--text-secondary)}.post-type-badge.check_in{background:#ecfdf5;color:#059669}.post-type-badge.review{background:#fef2f2;color:#dc2626}.post-type-badge.cellar_share{background:#eef2ff;color:#4f46e5}.post-delete-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);font-size:16px;transition:all var(--transition)}.post-delete-btn:hover{background:#fef2f2;color:#dc2626}.post-content{font-size:14px;line-height:1.6;color:var(--text-primary);margin-bottom:10px;white-space:pre-wrap;word-break:break-word}.post-wine-tag{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:10px 14px;margin-bottom:10px;display:flex;align-items:center;gap:10px}.wine-tag-icon{display:flex;align-items:center;justify-content:center;color:var(--primary)}.wine-tag-info h4{margin:0 0 1px;font-size:13px;font-weight:600;color:var(--text-primary)}.wine-tag-meta{font-size:12px;color:var(--text-tertiary)}.wine-tag-rating{margin-left:auto;color:#f59e0b;font-size:13px;letter-spacing:1px}.post-images{display:grid;gap:3px;margin-bottom:10px;border-radius:var(--radius-sm);overflow:hidden}.post-images.count-1{grid-template-columns:1fr}.post-images.count-2{grid-template-columns:1fr 1fr}.post-images.count-3{grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr}.post-images.count-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.post-images.count-3 img:first-child{grid-row:1 / 3}.post-images img{width:100%;height:100%;object-fit:cover;min-height:160px;max-height:360px}.post-actions{display:flex;align-items:center;gap:4px;padding-top:10px;border-top:1px solid var(--border-primary)}.post-action-btn{display:flex;align-items:center;gap:5px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px 10px;border-radius:var(--radius-full);font-size:13px;transition:all var(--transition)}.post-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.post-action-btn.liked{color:#dc2626}.post-action-btn svg{flex-shrink:0}.feed-page{min-height:100vh;background:var(--bg-secondary)}.feed-container{max-width:600px;margin:0 auto;padding:76px 16px 40px}.feed-tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--bg-primary);border-radius:var(--radius-md);padding:4px;border:1px solid var(--border-primary)}.feed-tab{flex:1;padding:8px;border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all var(--transition)}.feed-tab:hover{background:var(--bg-hover)}.feed-tab.active{background:var(--primary);color:var(--text-inverse)}.feed-empty{text-align:center;padding:48px 20px;color:var(--text-secondary)}.feed-empty h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.feed-empty p{font-size:14px;margin-bottom:16px;line-height:1.5}.feed-empty-btn{padding:8px 20px;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);cursor:pointer;font-size:13px;font-weight:600;text-decoration:none;display:inline-block;transition:background var(--transition)}.feed-empty-btn:hover{background:var(--primary-light)}.feed-loading{text-align:center;padding:20px;color:var(--text-tertiary);font-size:14px}.feed-load-more{display:block;margin:16px auto;padding:8px 20px;background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:var(--radius-full);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all var(--transition)}.feed-load-more:hover{background:var(--bg-hover);border-color:var(--text-tertiary)}.user-card{background:var(--bg-primary);border-radius:var(--radius-md);padding:14px;border:1px solid var(--border-primary);display:flex;align-items:center;gap:12px;transition:all var(--transition)}.user-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-sm)}.user-card-avatar{width:44px;height:44px;border-radius:var(--radius-full);background:var(--primary-lighter);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--primary);font-size:18px;flex-shrink:0;overflow:hidden;cursor:pointer}.user-card-avatar img{width:100%;height:100%;object-fit:cover}.user-card-info{flex:1;min-width:0}.user-card-name{font-weight:600;font-size:14px;color:var(--text-primary);cursor:pointer}.user-card-name:hover{color:var(--primary)}.user-card-bio{font-size:12px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}.user-card-stats{font-size:11px;color:var(--text-tertiary);margin-top:3px}.user-card-prefs{display:flex;gap:3px;margin-top:4px;flex-wrap:wrap}.user-card-pref-tag{font-size:10px;padding:1px 6px;border-radius:var(--radius-full);background:var(--primary-lighter);color:var(--primary);font-weight:500}.follow-btn{padding:6px 16px;border-radius:var(--radius-full);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition);flex-shrink:0;border:1px solid}.follow-btn.follow{background:var(--primary);color:var(--text-inverse);border-color:var(--primary)}.follow-btn.follow:hover{background:var(--primary-light)}.follow-btn.following{background:var(--bg-primary);color:var(--primary);border-color:var(--primary)}.follow-btn.following:hover{background:#fef2f2;color:#dc2626;border-color:#dc2626}.profile-page{min-height:100vh;background:var(--bg-secondary)}.profile-container{max-width:680px;margin:0 auto;padding:72px 16px 40px}.profile-header{background:var(--bg-primary);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-primary);margin-bottom:16px}.profile-cover{height:180px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);background-size:cover;background-position:center}.profile-info{padding:0 20px 20px;position:relative}.profile-avatar-wrapper{margin-top:-40px;margin-bottom:10px;display:flex;align-items:flex-end;justify-content:space-between}.profile-avatar{width:88px;height:88px;border-radius:var(--radius-full);border:3px solid var(--bg-primary);background:var(--primary-lighter);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:var(--primary);overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-actions{display:flex;gap:8px}.profile-follow-btn{padding:7px 20px;border-radius:var(--radius-full);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition);border:1px solid}.profile-follow-btn.follow{background:var(--primary);color:var(--text-inverse);border-color:var(--primary)}.profile-follow-btn.follow:hover{background:var(--primary-light)}.profile-follow-btn.following{background:var(--bg-primary);color:var(--primary);border-color:var(--primary)}.profile-follow-btn.following:hover{background:#fef2f2;color:#dc2626;border-color:#dc2626}.profile-edit-btn{padding:7px 20px;border-radius:var(--radius-full);font-size:13px;font-weight:500;cursor:pointer;background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-secondary);transition:all var(--transition);text-decoration:none}.profile-edit-btn:hover{background:var(--bg-hover)}.profile-name{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 2px}.profile-location{font-size:13px;color:var(--text-tertiary);margin-bottom:6px}.profile-bio{font-size:14px;color:var(--text-secondary);line-height:1.5;margin-bottom:10px}.profile-prefs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:12px}.profile-pref-tag{font-size:11px;padding:3px 10px;border-radius:var(--radius-full);background:var(--primary-lighter);color:var(--primary);font-weight:500}.profile-stats{display:flex;gap:20px}.profile-stat{cursor:pointer}.profile-stat:hover .stat-count{color:var(--primary)}.stat-count{font-weight:700;font-size:15px;color:var(--text-primary);transition:color var(--transition)}.stat-label{font-size:13px;color:var(--text-tertiary);margin-left:4px}.profile-tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--bg-primary);border-radius:var(--radius-md);padding:4px;border:1px solid var(--border-primary)}.profile-tab{flex:1;padding:8px;border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all var(--transition)}.profile-tab:hover{background:var(--bg-hover)}.profile-tab.active{background:var(--primary);color:var(--text-inverse)}.public-cellar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.public-wine-card{background:var(--bg-primary);border-radius:var(--radius-md);padding:12px;border:1px solid var(--border-primary);transition:all var(--transition)}.public-wine-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-sm)}.public-wine-image{width:100%;height:120px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:8px;background:var(--bg-tertiary)}.public-wine-name{font-weight:600;font-size:13px;color:var(--text-primary)}.public-wine-meta{font-size:12px;color:var(--text-tertiary);margin-top:2px}.public-wine-rating{color:#f59e0b;font-size:12px;margin-top:3px}.public-wine-category{display:inline-block;font-size:10px;padding:2px 6px;border-radius:var(--radius-full);background:var(--primary-lighter);color:var(--primary);margin-top:4px;font-weight:500}.follow-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;z-index:1000}.follow-modal{background:var(--bg-primary);border-radius:var(--radius-lg);width:90%;max-width:400px;max-height:70vh;overflow-y:auto;padding:20px}.follow-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.follow-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.follow-modal-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-tertiary);padding:4px}.follow-modal-list{display:flex;flex-direction:column;gap:10px}.profile-loading{text-align:center;padding:48px 20px;color:var(--text-tertiary);font-size:14px}.profile-private{text-align:center;padding:48px 20px;background:var(--bg-primary);border-radius:var(--radius-md);color:var(--text-secondary);border:1px solid var(--border-primary)}.profile-private h3{color:var(--text-primary);margin-bottom:6px}.profile-section-empty{text-align:center;padding:32px 20px;color:var(--text-tertiary);font-size:14px}.explore-page{min-height:100vh;background:var(--bg-secondary)}.explore-container{max-width:680px;margin:0 auto;padding:76px 16px 40px}.explore-search-section{margin-bottom:20px}.explore-search-wrapper{position:relative}.explore-search-input{width:100%;padding:10px 16px 10px 40px;border:1px solid var(--border-secondary);border-radius:var(--radius-full);font-size:14px;outline:none;background:var(--bg-primary);color:var(--text-primary);transition:border-color var(--transition)}.explore-search-input:focus{border-color:var(--primary)}.explore-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:16px;color:var(--text-tertiary)}.explore-section{margin-bottom:24px}.explore-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.explore-section-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.explore-see-all{font-size:13px;color:var(--primary);text-decoration:none;cursor:pointer;background:none;border:none;font-weight:600}.explore-see-all:hover{opacity:.8}.explore-user-grid{display:grid;grid-template-columns:1fr;gap:10px}@media (min-width: 600px){.explore-user-grid{grid-template-columns:1fr 1fr}}.explore-loading{text-align:center;padding:32px 20px;color:var(--text-tertiary)}.explore-empty{text-align:center;padding:32px 20px;color:var(--text-secondary);background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.explore-empty h3{color:var(--text-primary);font-size:16px;margin-bottom:6px}.notifications-page{min-height:100vh;background:var(--bg-secondary)}.notifications-container{max-width:600px;margin:0 auto;padding:76px 16px 40px}.notifications-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.notifications-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.notifications-mark-read{background:none;border:none;color:var(--primary);cursor:pointer;font-size:13px;font-weight:600;padding:6px 14px;border-radius:var(--radius-full);transition:background var(--transition)}.notifications-mark-read:hover{background:var(--primary-lighter)}.notification-list{display:flex;flex-direction:column;gap:2px}.notification-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition)}.notification-item:hover{background:var(--bg-hover)}.notification-item.unread{background:var(--primary-lighter);border-left:3px solid var(--primary)}.notification-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--primary-lighter);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--primary);font-size:16px;flex-shrink:0;overflow:hidden}.notification-avatar img{width:100%;height:100%;object-fit:cover}.notification-body{flex:1;min-width:0}.notification-text{font-size:13px;color:var(--text-primary);line-height:1.4}.notification-text strong{font-weight:600}.notification-preview{font-size:12px;color:var(--text-tertiary);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-time{font-size:11px;color:var(--text-tertiary);flex-shrink:0}.notification-icon{font-size:18px;flex-shrink:0}.notifications-empty{text-align:center;padding:48px 20px;color:var(--text-secondary)}.notifications-empty h3{color:var(--text-primary);font-size:16px;margin-bottom:6px}.notifications-loading{text-align:center;padding:32px;color:var(--text-tertiary)}.notification-badge-wrapper{position:relative;display:inline-flex}.notification-badge{position:absolute;top:-5px;right:-7px;min-width:16px;height:16px;padding:0 4px;background:#e53935;color:#fff;border-radius:var(--radius-full);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.admin-sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;background:var(--text-primary);color:var(--text-inverse);display:flex;flex-direction:column;z-index:100;transition:transform .2s ease}.admin-sidebar-overlay{display:none}.admin-sidebar-header{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.08)}.admin-sidebar-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit}.admin-sidebar-logo h2{font-size:1.125rem;font-weight:600;margin:0;color:var(--text-inverse)}.admin-badge{background:var(--primary);color:var(--text-inverse);font-size:.625rem;font-weight:600;padding:.125rem .5rem;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.admin-sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto}.admin-sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.625rem 1.5rem;color:#ffffff8c;text-decoration:none;font-size:.8125rem;font-weight:450;transition:all var(--transition);border-right:2px solid transparent}.admin-sidebar-link:hover{background:#ffffff0a;color:#ffffffe6}.admin-sidebar-link.active{background:#722f3733;color:var(--text-inverse);border-right-color:var(--primary)}.admin-sidebar-link svg{flex-shrink:0;width:18px;height:18px}.admin-sidebar-footer{padding:.75rem 0}.admin-sidebar-divider{height:1px;background:#ffffff14;margin:0 1.5rem .75rem}.admin-sidebar-back{color:#fff6}.admin-sidebar-back:hover{color:#ffffffb3}@media (max-width: 768px){.admin-sidebar{transform:translate(-100%)}.admin-sidebar.open{transform:translate(0)}.admin-sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-overlay);z-index:99}}.admin-layout{display:flex;min-height:100vh;background:var(--bg-secondary)}.admin-main{flex:1;margin-left:260px;display:flex;flex-direction:column}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 2rem;background:var(--bg-primary);border-bottom:1px solid var(--border-primary);position:sticky;top:0;z-index:50}.admin-menu-toggle{display:none;background:none;border:none;padding:.5rem;cursor:pointer;color:var(--text-primary);border-radius:var(--radius-sm);transition:background var(--transition)}.admin-menu-toggle:hover{background:var(--bg-hover)}.admin-header-right{display:flex;align-items:center;gap:.75rem}.admin-header-user{display:flex;align-items:center;gap:.625rem}.admin-header-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--primary);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:600}.admin-header-username{font-weight:500;font-size:.875rem;color:var(--text-primary)}.admin-content{flex:1;padding:1.5rem 2rem}@media (max-width: 768px){.admin-main{margin-left:0}.admin-menu-toggle{display:flex}.admin-content{padding:1rem}.admin-header{padding:.75rem 1rem}}.stats-card{background:var(--bg-primary);border-radius:var(--radius-md);padding:1.25rem;display:flex;align-items:flex-start;gap:1rem;border:1px solid var(--border-primary);transition:border-color var(--transition)}.stats-card:hover{border-color:var(--border-secondary)}.stats-card-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--primary-lighter);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stats-card-content{flex:1;min-width:0}.stats-card-title{font-size:.75rem;font-weight:500;color:var(--text-tertiary);margin:0 0 .375rem;text-transform:uppercase;letter-spacing:.03em}.stats-card-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2}.stats-card-trend{font-size:.75rem;font-weight:500;margin:.375rem 0 0}.stats-card-trend.positive{color:#22c55e}.stats-card-trend.negative{color:#ef4444}@media (max-width: 768px){.stats-card{padding:1rem}.stats-card-icon{width:36px;height:36px}.stats-card-value{font-size:1.25rem}}.data-table-container{background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-primary);overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-primary)}.data-table th{background:var(--bg-secondary);font-weight:600;font-size:.6875rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.data-table td{font-size:.8125rem;color:var(--text-primary)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table tbody tr.clickable{cursor:pointer}.data-table-loading,.data-table-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-primary);color:var(--text-secondary);gap:.75rem;font-size:.875rem}.data-table-spinner{width:28px;height:28px;border:2px solid var(--border-primary);border-top-color:var(--primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}@media (max-width: 768px){.data-table-container{overflow-x:auto}.data-table{min-width:600px}.data-table th,.data-table td{padding:.625rem .75rem}}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.confirm-modal{background:var(--bg-primary);border-radius:var(--radius-md);padding:1.5rem;max-width:400px;width:100%;border:1px solid var(--border-primary)}.confirm-modal-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.confirm-modal-message{font-size:.8125rem;color:var(--text-secondary);margin:0 0 1.5rem;line-height:1.6}.confirm-modal-actions{display:flex;gap:.625rem;justify-content:flex-end}.confirm-modal-btn{padding:.5rem 1.125rem;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition);border:none}.confirm-modal-btn:disabled{opacity:.5;cursor:not-allowed}.confirm-modal-cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.confirm-modal-cancel:hover:not(:disabled){background:var(--border-secondary)}.confirm-modal-confirm.danger{background:#ef4444;color:var(--text-inverse)}.confirm-modal-confirm.danger:hover:not(:disabled){background:#dc2626}.confirm-modal-confirm.primary{background:var(--primary);color:var(--text-inverse)}.confirm-modal-confirm.primary:hover:not(:disabled){background:var(--primary-light)}.admin-dashboard{max-width:1200px;margin:0 auto}.admin-dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:var(--text-secondary);gap:.75rem;font-size:.875rem}.admin-dashboard-spinner{width:32px;height:32px;border:2px solid var(--border-primary);border-top-color:var(--primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}.admin-dashboard-header{margin-bottom:1.5rem}.admin-dashboard-header h1{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.admin-dashboard-header p{color:var(--text-secondary);font-size:.875rem;margin:0}.admin-dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.875rem;margin-bottom:1.5rem}.admin-dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1rem;margin-bottom:1.5rem}.admin-dashboard-card{background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-primary);overflow:hidden}.admin-dashboard-card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-primary)}.admin-dashboard-card-header h2{font-size:.8125rem;font-weight:600;color:var(--text-primary);margin:0}.admin-dashboard-link{font-size:.75rem;color:var(--primary);text-decoration:none;font-weight:500}.admin-dashboard-link:hover{text-decoration:underline}.admin-dashboard-list{padding:.25rem 0}.admin-dashboard-list-item{display:flex;align-items:center;gap:.75rem;padding:.625rem 1.25rem;transition:background var(--transition)}.admin-dashboard-list-item:hover{background:var(--bg-hover)}.admin-dashboard-list-avatar{width:34px;height:34px;border-radius:var(--radius-full);background:var(--primary);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem}.admin-dashboard-list-icon{width:34px;height:34px;border-radius:var(--radius-sm);background:var(--primary-lighter);color:var(--primary);display:flex;align-items:center;justify-content:center}.admin-dashboard-list-info{flex:1;min-width:0}.admin-dashboard-list-name{font-weight:500;font-size:.8125rem;color:var(--text-primary);margin:0 0 .125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-dashboard-list-meta{font-size:.75rem;color:var(--text-secondary);margin:0}.admin-dashboard-list-date{font-size:.75rem;color:var(--text-tertiary);white-space:nowrap}.admin-dashboard-actions{display:flex;gap:.75rem;flex-wrap:wrap}.admin-dashboard-action-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.125rem;background:var(--primary);color:var(--text-inverse);border-radius:var(--radius-full);text-decoration:none;font-weight:500;font-size:.8125rem;transition:background var(--transition)}.admin-dashboard-action-btn:hover{background:var(--primary-light)}@media (max-width: 768px){.admin-dashboard-grid{grid-template-columns:1fr}.admin-dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.admin-dashboard-stats{grid-template-columns:1fr}}.user-management{max-width:1200px;margin:0 auto}.user-management-header{margin-bottom:1.5rem}.user-management-header h1{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.user-management-header p{color:var(--text-secondary);font-size:.875rem;margin:0}.user-management-filters{display:flex;gap:.75rem;margin-bottom:1rem}.user-cell{display:flex;align-items:center;gap:.625rem}.user-avatar{width:34px;height:34px;border-radius:var(--radius-full);background:var(--primary);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-info{min-width:0}.user-name{font-weight:500;font-size:.8125rem;color:var(--text-primary);margin:0 0 .0625rem}.user-email{font-size:.75rem;color:var(--text-secondary);margin:0}.role-badge,.status-badge{display:inline-block;padding:.1875rem .5rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:500;text-transform:capitalize}.role-badge.role-admin{background:var(--primary-lighter);color:var(--primary)}.role-badge.role-user{background:var(--bg-tertiary);color:var(--text-secondary)}.status-badge.active{background:#22c55e14;color:#22c55e}.status-badge.banned{background:#ef444414;color:#ef4444}.user-actions{display:flex;gap:.375rem}.action-btn-ban{background:#ef444414;color:#ef4444}.action-btn-ban:hover{background:#ef444426}.action-btn-unban{background:#22c55e14;color:#22c55e}.action-btn-unban:hover{background:#22c55e26}.action-btn-promote{background:var(--primary-lighter);color:var(--primary)}.action-btn-promote:hover{background:#722f3726}.action-btn-demote{background:var(--bg-tertiary);color:var(--text-secondary)}.action-btn-demote:hover{background:var(--border-secondary)}@media (max-width: 768px){.user-management-filters{flex-direction:column}.search-input-wrapper{max-width:none}}.event-management{max-width:1200px;margin:0 auto}.event-management-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.event-management-header h1{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.event-management-header p{color:var(--text-secondary);font-size:.875rem;margin:0}.event-management-filters{display:flex;gap:.75rem;margin-bottom:1rem}.event-cell{display:flex;align-items:center;gap:.625rem}.event-image{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--primary-lighter);color:var(--primary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.event-image img{width:100%;height:100%;object-fit:cover}.event-info{min-width:0}.event-title{font-weight:500;font-size:.8125rem;color:var(--text-primary);margin:0 0 .0625rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-location{font-size:.75rem;color:var(--text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.featured-toggle{padding:.1875rem .5rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:500;cursor:pointer;border:none;transition:all var(--transition);background:var(--bg-tertiary);color:var(--text-secondary)}.featured-toggle.active{background:var(--primary-lighter);color:var(--primary)}.featured-toggle:hover{opacity:.8}.event-actions{display:flex;gap:.375rem}.form-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.form-modal{background:var(--bg-primary);border-radius:var(--radius-md);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;border:1px solid var(--border-primary)}.form-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-primary)}.form-modal-header h2{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.form-modal-close{background:none;border:none;cursor:pointer;padding:.25rem;color:var(--text-tertiary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.form-modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.form-modal-error{margin:.875rem 1.25rem 0;padding:.625rem .875rem;background:#ef444414;color:#ef4444;border-radius:var(--radius-sm);font-size:.8125rem}.form-modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:.875rem}.form-group{display:flex;flex-direction:column;gap:.25rem;flex:1}.form-group label{font-size:.75rem;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group textarea,.form-group select{padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-size:.8125rem;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;transition:border-color var(--transition)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--border-focus)}.form-group textarea{resize:vertical;min-height:60px}.form-group input.file-input{padding:.375rem;font-size:.8125rem}.form-row{display:flex;gap:.875rem}.form-modal-actions{display:flex;gap:.625rem;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--border-primary);margin-top:.25rem}.form-modal-btn{padding:.5rem 1.125rem;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition);border:none}.form-modal-btn:disabled{opacity:.5;cursor:not-allowed}.form-modal-cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.form-modal-cancel:hover:not(:disabled){background:var(--border-secondary)}.form-modal-submit{background:var(--primary);color:var(--text-inverse)}.form-modal-submit:hover:not(:disabled){background:var(--primary-light)}@media (max-width: 768px){.event-management-header{flex-direction:column;gap:.75rem}.event-management-filters{flex-direction:column}.search-input-wrapper{max-width:none}.form-row{flex-direction:column}.form-modal{max-height:85vh}}.story-management{max-width:1200px;margin:0 auto}.story-management-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.story-management-header h1{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.story-management-header p{color:var(--text-secondary);font-size:.875rem;margin:0}.story-management-filters{display:flex;gap:.75rem;margin-bottom:1rem}.story-cell{display:flex;align-items:center;gap:.625rem}.story-image{width:48px;height:34px;border-radius:6px;background:var(--primary-lighter);color:var(--primary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.story-image img{width:100%;height:100%;object-fit:cover}.story-info{min-width:0}.story-title{font-weight:500;font-size:.8125rem;color:var(--text-primary);margin:0 0 .0625rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.story-author{font-size:.75rem;color:var(--text-secondary);margin:0}.published-toggle{padding:.1875rem .5rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:500;cursor:pointer;border:none;transition:all var(--transition)}.published-toggle.published{background:#22c55e14;color:#22c55e}.published-toggle.draft{background:#f59e0b14;color:#f59e0b}.published-toggle:hover{opacity:.8}.story-actions{display:flex;gap:.375rem}.create-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1.125rem;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background var(--transition)}.create-btn:hover{background:var(--primary-light)}.action-btn{padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500;cursor:pointer;border:none;transition:all var(--transition)}.action-btn-edit{background:var(--primary-lighter);color:var(--primary)}.action-btn-edit:hover{background:#722f3726}.action-btn-delete{background:#ef444414;color:#ef4444}.action-btn-delete:hover{background:#ef444426}.search-input-wrapper{position:relative;flex:1;max-width:360px}.search-input-wrapper svg{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--text-tertiary);width:16px;height:16px}.search-input{width:100%;padding:.5rem .875rem .5rem 2.5rem;border:1px solid var(--border-primary);border-radius:var(--radius-full);font-size:.8125rem;background:var(--bg-primary);color:var(--text-primary);transition:border-color var(--transition)}.search-input:focus{outline:none;border-color:var(--border-focus)}.filter-select{padding:.5rem .875rem;border:1px solid var(--border-primary);border-radius:var(--radius-full);font-size:.8125rem;background:var(--bg-primary);color:var(--text-primary);min-width:120px;transition:border-color var(--transition)}.filter-select:focus{outline:none;border-color:var(--border-focus)}.form-group-checkbox{margin-top:.25rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.8125rem;font-weight:500;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.form-hint{font-size:.75rem;color:var(--text-tertiary);margin:.25rem 0 0 1.625rem}@media (max-width: 768px){.story-management-header{flex-direction:column;gap:.75rem}.story-management-filters{flex-direction:column}.search-input-wrapper{max-width:none}.form-row{flex-direction:column}}.admin-invite{max-width:520px;margin:0 auto}.admin-invite-header{margin-bottom:1.5rem}.admin-invite-header h1{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.admin-invite-header p{color:var(--text-secondary);font-size:.875rem;margin:0}.admin-invite-card{background:var(--bg-primary);border-radius:var(--radius-md);padding:2rem;border:1px solid var(--border-primary);text-align:center}.admin-invite-icon{width:64px;height:64px;border-radius:var(--radius-full);background:var(--primary-lighter);color:var(--primary);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem}.admin-invite-card h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.admin-invite-description{color:var(--text-secondary);font-size:.8125rem;line-height:1.6;margin:0 0 1.75rem}.admin-invite-form{text-align:left}.admin-invite-input-group{margin-bottom:1.25rem}.admin-invite-input-group label{display:block;font-size:.75rem;font-weight:500;color:var(--text-secondary);margin-bottom:.375rem}.admin-invite-input-group input{width:100%;padding:.625rem .875rem;border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-size:.8125rem;color:var(--text-primary);transition:border-color var(--transition)}.admin-invite-input-group input:focus{outline:none;border-color:var(--border-focus)}.admin-invite-error{background:#ef444414;color:#ef4444;padding:.625rem .875rem;border-radius:var(--radius-sm);font-size:.8125rem;margin-bottom:1.25rem}.admin-invite-success{background:#22c55e14;color:#22c55e;padding:.625rem .875rem;border-radius:var(--radius-sm);font-size:.8125rem;margin-bottom:1.25rem}.admin-invite-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background var(--transition)}.admin-invite-submit:hover:not(:disabled){background:var(--primary-light)}.admin-invite-submit:disabled{opacity:.5;cursor:not-allowed}.admin-invite-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--text-inverse);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.admin-invite-note{display:flex;gap:.625rem;margin-top:1.25rem;padding:.875rem;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-primary);text-align:left}.admin-invite-note svg{flex-shrink:0;color:var(--text-tertiary);margin-top:.0625rem}.admin-invite-note span{font-size:.75rem;color:var(--text-secondary);line-height:1.5}.ticket-scanner{padding:0;max-width:520px}.ticket-scanner h1{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.ticket-scanner-subtitle{font-size:.875rem;color:var(--text-secondary);margin-bottom:1.5rem}.scanner-manual-entry{background:var(--bg-primary);border-radius:var(--radius-md);padding:1.25rem;border:1px solid var(--border-primary);margin-bottom:1rem}.scanner-manual-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:.75rem}.scanner-input-row{display:flex;gap:.625rem}.scanner-input{flex:1;padding:.5rem .875rem;border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-primary);outline:none;text-transform:uppercase;letter-spacing:1px;transition:border-color var(--transition)}.scanner-input:focus{border-color:var(--border-focus)}.scanner-validate-btn{padding:.5rem 1.125rem;background:var(--primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background var(--transition);white-space:nowrap}.scanner-validate-btn:hover:not(:disabled){background:var(--primary-light)}.scanner-validate-btn:disabled{opacity:.5;cursor:not-allowed}.scanner-camera-section{background:var(--bg-primary);border-radius:var(--radius-md);padding:1.25rem;border:1px solid var(--border-primary);margin-bottom:1rem}.scanner-camera-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:.75rem}.scanner-camera-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-size:.8125rem;color:var(--text-primary);cursor:pointer;transition:all var(--transition)}.scanner-camera-toggle:hover{border-color:var(--primary-border);color:var(--primary)}.scanner-camera-view{width:100%;aspect-ratio:1;max-height:350px;border-radius:var(--radius-sm);overflow:hidden;margin-top:.75rem;background:#000}.scanner-result{border-radius:var(--radius-md);padding:1.5rem;margin-bottom:1rem;text-align:center}.scanner-result-valid{background:#22c55e0f;border:1px solid rgba(34,197,94,.15)}.scanner-result-invalid{background:#ef44440f;border:1px solid rgba(239,68,68,.15)}.scanner-result-icon{width:48px;height:48px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto .875rem}.scanner-result-valid .scanner-result-icon{background:#22c55e1a;color:#22c55e}.scanner-result-invalid .scanner-result-icon{background:#ef44441a;color:#ef4444}.scanner-result-message{font-size:1rem;font-weight:600;margin-bottom:.375rem}.scanner-result-valid .scanner-result-message{color:#22c55e}.scanner-result-invalid .scanner-result-message{color:#ef4444}.scanner-result-details{font-size:.8125rem;color:var(--text-secondary);margin-top:.5rem}.scanner-result-details p{margin:.125rem 0}.scanner-scan-again-btn{margin-top:.75rem;padding:.5rem 1.125rem;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;cursor:pointer;color:var(--text-primary);transition:all var(--transition)}.scanner-scan-again-btn:hover{background:var(--bg-hover)}.scanner-loading{text-align:center;padding:2rem;color:var(--text-secondary);font-size:.875rem}:root{--primary: #722F37;--primary-light: #8B3A44;--primary-lighter: rgba(114, 47, 55, .08);--primary-border: rgba(114, 47, 55, .2);--bg-primary: #ffffff;--bg-secondary: #f7f8fa;--bg-tertiary: #f0f2f5;--bg-hover: #f5f5f5;--bg-overlay: rgba(0, 0, 0, .5);--text-primary: #0f1419;--text-secondary: #536471;--text-tertiary: #8899a6;--text-inverse: #ffffff;--border-primary: #eff3f4;--border-secondary: #e1e4e8;--border-focus: var(--primary);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition: .2s ease;--emerald-green: var(--primary);--emerald-green-dark: var(--primary-light);--olive-green: var(--primary);--olive-green-dark: var(--primary-light);--gold: var(--primary);--gold-light: var(--primary-lighter);--gold-dark: var(--primary-light);--light-bg: var(--bg-secondary);--light-bg-transparent: rgba(247, 248, 250, .9);--dark-bg: #0f1419;--text-dark: var(--text-primary);--text-muted: var(--text-secondary);--text-light: var(--text-inverse);--card-bg: var(--bg-primary);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);overflow-x:hidden}#root{width:100%;min-height:100vh}a{color:var(--primary);text-decoration:none}button,input,textarea,select{font-family:inherit}
