:root{--district-bg:#f3f3f9;--district-header-bg:#fff;--district-surface:#fff;--district-text:#1a1a1a;--district-text-secondary:#6b6b6b;--district-text-muted:#8a8a8a;--district-border:#e8e8e8;--district-purple-soft:#e8e4f8;--district-purple-text:#4c1d95;--district-purple-mid:#7c3aed;--district-search-border:#e5e5e5;--district-icon-muted:#9ca3af;--district-shadow:0 1px 3px #0000000f;--district-shadow-card:0 4px 20px #00000014;color:var(--district-text);background-color:var(--district-bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}html{height:100%}body{-webkit-tap-highlight-color:transparent;background:var(--district-bg);min-height:100dvh;margin:0;overflow-x:hidden}#root{flex-direction:column;width:100%;min-height:100dvh;display:flex}.app-shell{flex-direction:column;flex:1;width:100%;min-height:100dvh;display:flex}a{color:inherit}.district-page{background:var(--district-bg);width:100%;min-height:100dvh;color:var(--district-text);flex-direction:column;flex:1;display:flex;overflow-x:hidden}.district-header.site-header{z-index:20;background:var(--district-header-bg);border-bottom:1px solid var(--district-border);width:100%;position:sticky;top:0;box-shadow:0 1px #00000008}.header-inner{width:100%;max-width:none;padding:max(12px, env(safe-area-inset-top)) max(20px, env(safe-area-inset-right), 4vw) 12px max(20px, env(safe-area-inset-left), 4vw);flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:12px 20px;margin:0;display:flex}.header-left{flex-shrink:0;align-items:center;gap:14px;display:flex}.logo-block{flex-direction:column;flex-shrink:0;gap:0;line-height:1.1;display:flex}.logo-word{letter-spacing:-.03em;color:var(--district-text);font-size:1.5rem;font-style:italic;font-weight:800}.location-box{border:1px solid var(--district-border);background:var(--district-surface);height:40px;color:var(--district-text);cursor:default;font-size:.8125rem;font-weight:500;font:inherit;border-radius:10px;flex-shrink:0;align-items:center;gap:8px;padding:8px 14px;display:inline-flex}.location-svg{color:var(--district-text-secondary);flex-shrink:0}.location-text{white-space:nowrap}.nav-pills{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:4px;display:flex}.nav-pill{color:var(--district-text-secondary);cursor:pointer;min-height:40px;font-size:.875rem;font-weight:600;font:inherit;white-space:nowrap;background:0 0;border:none;border-radius:999px;padding:8px 16px;line-height:1.2}.nav-pill:hover{color:var(--district-text);background:#7c3aed14}.nav-pill--active{background:var(--district-purple-soft);color:var(--district-purple-text)}.district-search.header-search{border:1px solid var(--district-search-border);background:var(--district-surface);min-width:160px;max-width:none;min-height:44px;box-shadow:var(--district-shadow);border-radius:50px;flex:1;align-items:center;gap:12px;margin-left:0;padding:0 18px;display:flex}.search-icon{color:var(--district-icon-muted);flex-shrink:0}.district-search input{min-width:0;color:var(--district-text);background:0 0;border:none;outline:none;flex:1;padding:10px 0;font-size:.9375rem}.district-search input::placeholder{color:#a3a3a3}.header-right{flex-shrink:0;align-items:center;gap:12px;display:flex}.header-account{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.header-phone{color:var(--district-text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:min(160px,38vw);font-size:.8rem;overflow:hidden}.header-signout{color:var(--district-purple-mid);cursor:pointer;font-size:.85rem;font-weight:600;font:inherit;background:0 0;border:none;padding:4px 0}.header-signout:hover{text-decoration:underline}.profile-avatar{border:1px solid var(--district-border);cursor:pointer;width:40px;height:40px;box-shadow:none;background:#f3f4f6;border-radius:50%;flex-shrink:0;padding:0;overflow:hidden}.profile-avatar--rich{background:linear-gradient(145deg,#7c3aed 0%,#a855f7 55%,#c084fc 100%);border:2px solid #fff;box-shadow:0 0 0 1px #7c3aed59,0 4px 12px #5b21b62e}.profile-avatar-inner{background:linear-gradient(#e5e7eb 0%,#d1d5db 100%);border-radius:50%;width:100%;height:100%;display:block}.profile-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%;display:block}.profile-avatar-initials{color:#fff;letter-spacing:.02em;text-transform:uppercase;justify-content:center;align-items:center;width:100%;height:100%;font-size:.8125rem;font-weight:800;display:flex}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=900px){.nav-pills{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:100%;order:5;justify-content:flex-start;padding-bottom:4px;overflow-x:auto}.nav-pills::-webkit-scrollbar{display:none}.district-search.header-search{flex:100%;order:6;max-width:none;margin-left:0}.header-right{margin-left:auto}}.district-main{width:100%;max-width:1280px;padding:20px max(16px, env(safe-area-inset-left)) max(32px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-right));flex:1;margin:0 auto}.district-hero-strip{text-align:center;margin-bottom:8px;padding:28px 16px 36px}.district-hero-title{letter-spacing:-.02em;color:var(--district-text);margin:0 0 8px;font-size:clamp(1.5rem,4vw,2rem);font-weight:800}.district-hero-sub{color:var(--district-text-secondary);margin:0 0 20px;font-size:1rem}.btn-primary-lg{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6d28d9 0%,#7c3aed 50%,#8b5cf6 100%);border:none;border-radius:12px;justify-content:center;align-items:center;min-height:48px;padding:0 28px;font-size:1rem;font-weight:700;display:inline-flex;box-shadow:0 8px 24px #7c3aed47}.btn-primary-lg:hover:not(:disabled){filter:brightness(1.05)}.btn-primary-lg:disabled{opacity:.55;cursor:not-allowed}.btn-secondary-lg{border:1px solid var(--district-border);background:var(--district-surface);min-height:48px;color:var(--district-text);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;padding:0 24px;font-size:1rem;font-weight:600;display:inline-flex}.btn-secondary-lg:hover:not(:disabled){background:#fafafa;border-color:#d4d4d4}.btn-secondary-lg:disabled{opacity:.55;cursor:not-allowed}.district-section{margin-bottom:36px}.district-section-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.district-section-title{letter-spacing:-.02em;color:var(--district-text);margin:0;font-size:clamp(1.25rem,3vw,1.65rem);font-weight:800}.carousel-chevron{border:1px solid var(--district-border);background:var(--district-surface);cursor:pointer;width:40px;height:40px;box-shadow:var(--district-shadow);border-radius:50%;flex-shrink:0;font-size:1.1rem}.carousel-chevron:hover{border-color:#d4d4d4}.event-carousel{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;gap:16px;margin:0 -4px;padding:4px 4px 16px;scroll-padding-inline:8px;display:flex;overflow-x:auto}.event-card{scroll-snap-align:start;background:var(--district-surface);border:1px solid var(--district-border);box-shadow:var(--district-shadow-card);border-radius:16px;flex:0 0 min(78vw,280px);overflow:hidden}@media (width>=640px){.event-card{flex:0 0 260px}}.event-card--club{flex-direction:column;display:flex}.event-card-poster{aspect-ratio:2/3;background-position:50%;background-size:cover;width:100%;max-height:200px}.event-card-poster--violet{background:linear-gradient(145deg,#7c3aed 0%,#c084fc 45%,#f0abfc 100%)}.event-card-poster--movieA{background:linear-gradient(145deg,#4c1d95 0%,#a78bfa 50%,#fce7f3 100%)}.event-card-poster--movieB{background:linear-gradient(145deg,#6d28d9 0%,#e879f9 55%,#fbcfe8 100%)}.event-card-poster--movieC{background:linear-gradient(145deg,#5b21b6 0%,#818cf8 40%,#fef3c7 100%)}.event-card-poster--club-wrap{background:#0f172a;padding:0;overflow:hidden}.event-card-poster--club-img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.event-card--club .event-card-poster{max-height:158px}.event-card--club .event-card-body{flex-direction:column;flex:1;padding:10px 12px 14px;display:flex}.event-card--club .event-card-title{margin-bottom:4px}.event-card--club .event-card-venue{margin-bottom:6px}.event-card-body{padding:14px 14px 16px}.event-card-date{color:#a16207;margin:0 0 6px;font-size:.75rem;font-weight:600}.event-card--club .event-card-date--club-muted{color:#a16207;opacity:.68}.event-card-title{color:var(--district-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 6px;font-size:.95rem;font-weight:700;line-height:1.35;display:-webkit-box;overflow:hidden}.event-card-venue{color:var(--district-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 8px;font-size:.8rem;line-height:1.4;display:-webkit-box;overflow:hidden}.event-card-foot{color:var(--district-text-secondary);margin:0;font-size:.8rem;font-weight:600}.user-home{background:var(--district-bg);width:100%;min-height:100dvh;color:var(--district-text);flex-direction:column;flex:1;display:flex;overflow-x:hidden}.user-dashboard-location-note{color:var(--district-text-secondary);margin:8px 0 0;font-size:.85rem;line-height:1.45}.user-dashboard-muted{color:var(--district-text-secondary);margin:0;font-size:.95rem}.user-dashboard-error{margin-top:10px}.btn-show-interest{color:#fff;letter-spacing:.01em;cursor:pointer;background:linear-gradient(135deg,#6d28d9 0%,#7c3aed 55%,#8b5cf6 100%);border:none;border-radius:12px;justify-content:center;align-items:center;min-height:44px;padding:0 20px;font-family:inherit;font-size:.92rem;font-weight:700;transition:filter .15s,opacity .15s,transform .12s;display:inline-flex;box-shadow:0 6px 18px #7c3aed47}.btn-show-interest:hover:not(:disabled){filter:brightness(1.06)}.btn-show-interest:active:not(:disabled){transform:scale(.98)}.btn-show-interest:focus-visible{outline-offset:2px;outline:2px solid #7c3aed}.btn-show-interest:disabled{opacity:.72;cursor:not-allowed;filter:none;transform:none}.btn-show-interest--sent{background:linear-gradient(135deg,#4b5563 0%,#6b7280 100%);box-shadow:0 4px 12px #4b556333}.btn-show-interest.btn-show-interest--card{box-sizing:border-box;white-space:nowrap;flex-shrink:0;width:100%;margin-top:auto;padding:0 14px;font-size:.875rem}.club-card-dual-actions{grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;margin-bottom:10px;display:grid}.club-user-tile{cursor:pointer;min-height:40px;font:inherit;text-align:left;white-space:nowrap;border:none;border-radius:12px;flex-direction:row;align-items:center;gap:10px;padding:8px 10px;transition:transform .18s,box-shadow .18s;display:flex;position:relative;overflow:hidden}.club-user-tile-glow{opacity:0;pointer-events:none;transition:opacity .25s;position:absolute;inset:0}.club-user-tile:hover .club-user-tile-glow{opacity:1}.club-user-tile:active{transform:scale(.98)}.club-user-tile:focus-visible{outline-offset:2px;outline:2px solid #7c3aed}.club-user-tile--events{color:#0f172a;background:linear-gradient(135deg,#fffbeb 0%,#fffaf0 50%,#fff 100%);border:1px solid #f59e0b61;box-shadow:0 2px 8px #f59e0b1f,inset 0 1px #fffffff2}.club-user-tile--events .club-user-tile-glow{background:radial-gradient(140% 100% at 20%,#fbbf2440,#0000 55%)}.club-user-tile--events:hover{box-shadow:0 4px 14px #f59e0b38,inset 0 1px #fff}.club-user-tile--bottles{color:#faf5ff;background:linear-gradient(135deg,#5b21b6 0%,#7c3aed 55%,#8b5cf6 100%);border:1px solid #c4b5fd73;box-shadow:0 2px 10px #6d28d959,inset 0 1px #ffffff2e}.club-user-tile--bottles .club-user-tile-glow{background:radial-gradient(130% 90% at 85% 30%,#f472b638,#0000 50%)}.club-user-tile--bottles:hover{box-shadow:0 6px 18px #5b21b66b,inset 0 1px #ffffff38}.club-user-tile-icon{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.club-user-tile--events .club-user-tile-icon{color:#b45309;background:#f59e0b38}.club-user-tile--bottles .club-user-tile-icon{color:#fff;background:#fff3}.club-user-tile-text{flex:1;min-width:0;overflow:hidden}.club-user-tile-label{letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:700;line-height:1.2;display:block;overflow:hidden}@media (width>=640px){.club-card-dual-actions{gap:10px}.club-user-tile{padding:9px 12px}}.modal-backdrop--venue-sheet{align-items:flex-end;padding-bottom:0}@media (width>=640px){.modal-backdrop--venue-sheet{padding-bottom:max(16px, env(safe-area-inset-bottom));align-items:center}}.venue-sheet-panel{background:var(--district-surface,#fff);border:1px solid var(--district-border,#e5e5e5);flex-direction:column;width:100%;max-height:min(92vh,760px);animation:.38s cubic-bezier(.22,1,.36,1) both venue-sheet-in;display:flex;position:relative;overflow:hidden;box-shadow:0 -12px 48px #0f172a2e}@media (width<=639px){.venue-sheet-panel{border-radius:22px 22px 0 0;max-height:92vh}}@media (width>=640px){.venue-sheet-panel{border-radius:24px;width:min(440px,100%);box-shadow:0 24px 64px #0f172a38}}@keyframes venue-sheet-in{0%{opacity:0;transform:translateY(18px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width>=640px){@keyframes venue-sheet-in{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}}.venue-sheet-grabber{background:#d4d4d8;border-radius:999px;flex-shrink:0;width:40px;height:5px;margin:10px auto 4px}@media (width>=640px){.venue-sheet-grabber{display:none}}.venue-sheet-close{z-index:3;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a59;border:1px solid #ffffff59;border-radius:12px;width:40px;height:40px;font-size:1.35rem;line-height:1;position:absolute;top:12px;right:12px}@media (width>=640px){.venue-sheet-close{border-color:var(--district-border,#e5e5e5);background:var(--district-surface,#fff);color:var(--district-text,#171717);top:16px;right:16px}.venue-sheet-panel--bottle-menu .venue-sheet-close,.venue-sheet-panel--events .venue-sheet-close{color:#fff;background:#0f172a66;border-color:#fff6}}.venue-sheet-body{-webkit-overflow-scrolling:touch;flex:1;padding:0 20px 24px;overflow-y:auto}.bottle-menu-hero{flex-shrink:0;position:relative}.bottle-menu-hero-visual{background:#0f172a;height:min(28vh,200px);min-height:140px;position:relative}.bottle-menu-hero-img{object-fit:cover;width:100%;height:100%;display:block}.bottle-menu-hero-scrim{background:linear-gradient(#0000 0%,#0f172a8c 55%,#0f172aeb 100%);position:absolute;inset:0}.bottle-menu-hero-copy{padding:20px 20px 18px;position:absolute;bottom:0;left:0;right:0}.bottle-menu-kicker{letter-spacing:.14em;text-transform:uppercase;color:#c4b5fd;margin:0 0 6px;font-size:.68rem;font-weight:800}.bottle-menu-title{letter-spacing:-.02em;color:#fff;margin:0 0 6px;font-size:1.35rem;font-weight:800;line-height:1.2}.bottle-menu-sub{color:#e2e8f0e6;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.82rem;line-height:1.45;display:-webkit-box;overflow:hidden}.bottle-menu-body{padding-top:20px}.bottle-menu-state--loading{flex-direction:column;gap:12px;padding:8px 0 24px;display:flex}.bottle-menu-shimmer{background:linear-gradient(90deg,#f1f5f9 0%,#e2e8f0 40%,#f1f5f9 80%) 0 0/200% 100%;border-radius:14px;height:56px;animation:1.2s ease-in-out infinite bottle-shimmer}.bottle-menu-shimmer--short{width:70%;height:44px}@keyframes bottle-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.bottle-menu-error{margin:12px 0}.bottle-menu-empty{text-align:center;padding:32px 12px 24px}.bottle-menu-empty-icon{color:#7c3aed;background:linear-gradient(145deg,#faf5ff,#ede9fe);border:1px solid #7c3aed33;border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 16px;display:flex}.bottle-menu-empty-title{color:var(--district-text,#171717);margin:0 0 8px;font-size:1.1rem;font-weight:800}.bottle-menu-empty-text{color:var(--district-text-secondary,#737373);margin:0;max-width:320px;margin-inline:auto;font-size:.9rem;line-height:1.55}.bottle-menu-section{margin-bottom:24px}.bottle-menu-section--muted{opacity:.92}.bottle-menu-section-title{letter-spacing:.1em;text-transform:uppercase;color:#5b21b6;align-items:center;gap:8px;margin:0 0 12px;font-size:.72rem;font-weight:800;display:flex}.bottle-menu-section-title--muted{color:#64748b}.bottle-menu-section-dot{background:linear-gradient(145deg,#a855f7,#7c3aed);border-radius:50%;width:8px;height:8px;box-shadow:0 0 0 3px #7c3aed33}.bottle-menu-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.bottle-menu-row{background:linear-gradient(145deg,#fff 0%,#faf5ff 100%);border:1px solid #7c3aed1f;border-radius:16px;align-items:center;gap:12px;padding:14px;display:flex;box-shadow:0 2px 12px #5b21b60f}.bottle-menu-row--live{border-color:#7c3aed38}.bottle-menu-row--muted{box-shadow:none;background:#f8fafc;border-color:#e2e8f0}.bottle-menu-row-icon{color:#6d28d9;background:linear-gradient(145deg,#ede9fe,#f5f3ff);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.bottle-menu-row-icon--muted{color:#94a3b8;background:#f1f5f9}.bottle-menu-row-main{flex:1;min-width:0}.bottle-menu-row-name{color:var(--district-text,#171717);font-size:1rem;font-weight:700;line-height:1.3;display:block}.bottle-menu-row-meta{color:var(--district-text-secondary,#737373);margin-top:4px;font-size:.78rem;display:block}.bottle-menu-pill{letter-spacing:.06em;text-transform:uppercase;color:#047857;background:#ecfdf5;border-radius:999px;flex-shrink:0;padding:6px 10px;font-size:.65rem;font-weight:800}.bottle-menu-pill--live{color:#065f46;background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.bottle-menu-pill--ended{color:#64748b;background:#f1f5f9}.bottle-menu-footnote{border-top:1px solid var(--district-border,#e5e5e5);color:var(--district-text-secondary,#737373);margin:8px 0 0;padding-top:16px;font-size:.78rem;line-height:1.5}.club-events-hero{flex-shrink:0;position:relative}.club-events-hero-visual{background:#0f172a;height:min(26vh,180px);min-height:132px;position:relative}.club-events-hero-img{object-fit:cover;width:100%;height:100%;display:block}.club-events-hero-scrim{background:linear-gradient(#0000 0%,#78350f73 50%,#451a03eb 100%);position:absolute;inset:0}.club-events-hero-copy{padding:20px 20px 18px;position:absolute;bottom:0;left:0;right:0}.club-events-kicker{letter-spacing:.14em;text-transform:uppercase;color:#fcd34d;margin:0 0 6px;font-size:.68rem;font-weight:800}.club-events-title{letter-spacing:-.02em;color:#fffbeb;margin:0 0 6px;font-size:1.2rem;font-weight:800;line-height:1.25}.club-events-sub{color:#fef3c7e0;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.82rem;line-height:1.45;display:-webkit-box;overflow:hidden}.club-events-body{padding-top:18px}.club-events-banner{color:#92400e;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #f59e0b59;border-radius:14px;align-items:flex-start;gap:10px;margin:0 0 18px;padding:12px 14px;font-size:.82rem;font-weight:600;line-height:1.45;display:flex}.club-events-banner-icon{color:#d97706;flex-shrink:0;font-size:1rem;line-height:1.2}.club-events-list{flex-direction:column;gap:14px;margin:0;padding:0;list-style:none;display:flex}.club-event-card{border:1px solid var(--district-border,#e5e5e5);background:var(--district-surface,#fff);border-radius:18px;animation:.5s cubic-bezier(.22,1,.36,1) both club-event-in;position:relative;overflow:hidden;box-shadow:0 4px 20px #0f172a0f}.club-event-card--spotlight{border-color:#f59e0b73;box-shadow:0 8px 32px #f59e0b33,inset 0 0 0 1px #fbbf2426}.club-event-card-accent{background:linear-gradient(#f59e0b,#ea580c);width:4px;position:absolute;top:0;bottom:0;left:0}.club-event-card--spotlight .club-event-card-accent{background:linear-gradient(#fbbf24,#f59e0b,#ea580c);width:5px}.club-event-card-inner{padding:16px 16px 16px 20px}.club-event-card-tag{letter-spacing:.08em;text-transform:uppercase;color:#b45309;background:#fbbf2440;border-radius:999px;margin-bottom:8px;padding:4px 10px;font-size:.65rem;font-weight:800;display:inline-block}.club-event-card-title{letter-spacing:-.02em;color:var(--district-text,#171717);margin:0 0 6px;font-size:1.05rem;font-weight:800}.club-event-card-when{color:#7c3aed;margin:0 0 10px;font-size:.82rem;font-weight:600}.club-event-card-blurb{color:var(--district-text-secondary,#737373);margin:0;font-size:.88rem;line-height:1.5}.club-events-footnote{color:var(--district-text-secondary,#737373);margin:20px 0 0;font-size:.78rem;line-height:1.5}@keyframes club-event-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-backdrop{z-index:100;padding:max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(16px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);-webkit-overflow-scrolling:touch;background:#1a1a1a73;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow-y:auto}.login-modal{border-radius:12px;width:100%;max-width:420px;max-height:min(640px,100dvh - 32px);position:relative;overflow:hidden auto;box-shadow:0 24px 48px #0000002e}@media (width<=480px){.modal-backdrop{padding:0;padding-bottom:env(safe-area-inset-bottom);align-items:flex-end}.login-modal{max-width:none;max-height:calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom));border-radius:16px 16px 0 0}.login-modal-header,.login-modal-body{padding:22px 18px 20px}}.modal-close{z-index:2;color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:8px;width:36px;height:36px;font-size:1.5rem;line-height:1;position:absolute;top:12px;right:12px}.modal-close:hover{background:#ffffff40}.interest-hint-modal{background:var(--district-surface,#fff);border-radius:16px;width:100%;max-width:400px;position:relative;overflow:hidden;box-shadow:0 24px 48px #0000002e}.interest-hint-modal .modal-close{color:var(--district-text,#171717);background:#0000000f}.interest-hint-modal .modal-close:hover{background:#0000001a}.interest-hint-modal-body{text-align:center;padding:28px 24px 24px}.interest-hint-modal-text{color:var(--district-text,#171717);margin:0 0 22px;font-size:1.05rem;font-weight:600;line-height:1.45}.interest-hint-modal-ok{width:100%}.login-modal-header{color:#fff;text-align:center;background:linear-gradient(135deg,#5b21b6 0%,#7c3aed 45%,#a855f7 100%);padding:28px 24px 24px}.login-modal-brand{flex-direction:column;align-items:center;gap:4px;display:flex}.brand-district{letter-spacing:-.02em;font-size:2rem;font-style:italic;font-weight:800}.login-modal-tagline{opacity:.92;margin:16px 0 0;font-size:.8rem;line-height:1.45}.login-modal-body{color:#111;background:#fff;padding:28px 24px 24px}.login-modal-title{text-align:center;margin:0 0 8px;font-size:1.35rem;font-weight:700}.login-modal-sub{color:#6b7280;text-align:center;margin:0 0 20px;font-size:.9rem;line-height:1.5}.phone-row{align-items:stretch;gap:10px;display:flex}.country-box{color:#111827;cursor:default;min-width:108px;min-height:48px;font:inherit;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:0 12px;display:flex}.flag-emoji{font-size:1.25rem}.country-code-text{font-size:.95rem;font-weight:600}.chevron{color:#9ca3af;margin-top:2px;font-size:.75rem}.phone-input{border:1px solid #e5e7eb;border-radius:8px;outline:none;flex:1;min-width:0;padding:14px;font-size:1rem}.phone-input:focus{border-color:#a855f7;box-shadow:0 0 0 3px #a855f733}.referral-block{margin-top:14px}.referral-toggle{text-align:center;width:100%;margin:0;padding:4px 0;display:block}.referral-field{flex-direction:column;gap:6px;margin:0;display:flex}.referral-label{color:#374151;font-size:.8rem;font-weight:600}.referral-input{box-sizing:border-box;font-variant-numeric:tabular-nums;letter-spacing:.06em;border:1px solid #e5e7eb;border-radius:8px;outline:none;width:100%;padding:12px 14px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:1rem}.referral-input:focus{border-color:#a855f7;box-shadow:0 0 0 3px #a855f733}.referral-hint{color:#6b7280;font-size:.75rem;line-height:1.4}.btn-continue{cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:18px;padding:14px 16px;font-size:1rem;font-weight:700;transition:background .15s,opacity .15s}.btn-continue.enabled{color:#fff;background:#111}.btn-continue.enabled:hover{background:#000}.btn-continue.disabled{color:#9ca3af;cursor:not-allowed;background:#e5e7eb}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin;display:inline-block}.btn-continue.disabled .spinner{border-color:#888 #ccc #ccc}@keyframes spin{to{transform:rotate(360deg)}}.muted-center{text-align:center;color:#6b7280;margin-top:10px;font-size:.85rem}.code-hint{color:#6b7280;text-align:center;margin:0 0 16px;font-size:.9rem;line-height:1.5}.otp-input{letter-spacing:.35em;text-align:center;font-variant-numeric:tabular-nums;border:1px solid #e5e7eb;border-radius:8px;width:100%;padding:14px 16px;font-size:1.35rem}.otp-input:focus{border-color:#a855f7;outline:none;box-shadow:0 0 0 3px #a855f733}.link-btn{color:#5b21b6;cursor:pointer;background:0 0;border:none;margin:14px auto 0;padding:8px;font-size:.95rem;font-weight:600;text-decoration:underline;display:block}.link-btn.inline{font-size:inherit;margin:0;padding:0;display:inline}.legal{color:#6b7280;text-align:center;margin-top:20px;font-size:.75rem;line-height:1.5}.legal a{color:#4b5563;font-weight:600;text-decoration:underline}.form-error{color:#b91c1c;margin:10px 0 0;font-size:.875rem}.admin-page{background:var(--district-bg);flex:1;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.admin-card{border:1px solid var(--district-border);background:var(--district-surface);width:100%;max-width:400px;box-shadow:var(--district-shadow-card);border-radius:16px;padding:32px}.admin-title{color:var(--district-text);margin:0 0 8px;font-size:1.5rem}.admin-sub{color:var(--district-text-secondary);margin:0 0 24px;font-size:.95rem}.admin-form{flex-direction:column;gap:16px;display:flex}.admin-form.club-form{gap:0}.field{min-width:0;color:var(--district-text-secondary);flex-direction:column;gap:8px;font-size:.85rem;display:flex}.field input{border:1px solid var(--district-border);width:100%;min-width:0;max-width:100%;color:var(--district-text);box-sizing:border-box;background:#fafafa;border-radius:10px;padding:12px 14px;font-size:1rem}.field input:focus{border-color:var(--district-purple-mid);outline:none;box-shadow:0 0 0 3px #7c3aed26}.admin-back{color:var(--district-text-secondary);margin-top:20px}.admin-dashboard{min-height:100dvh;color:var(--district-text);background:linear-gradient(160deg,#f5f0ff 0%,#f3f3f9 42%,#eef3ff 100%);flex-direction:column;flex:1;display:flex;position:relative;overflow-x:hidden}.admin-dashboard:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(90% 55% at 100% -15%,#7c3aed24,#0000 55%),radial-gradient(70% 45% at -10% 90%,#3b82f61a,#0000 50%),radial-gradient(50% 35% at 80% 85%,#a78bfa14,#0000 45%);position:absolute;inset:0}.admin-dashboard>*{z-index:1;position:relative}.admin-dash-header{-webkit-backdrop-filter:blur(14px);background:#ffffffb8;border-bottom:1px solid #7c3aed1f;justify-content:space-between;align-items:flex-start;gap:20px;padding:22px 24px 26px;display:flex;box-shadow:0 4px 24px #4c1d950f}.admin-dash-header-main{align-items:flex-start;gap:16px;min-width:0;display:flex}.admin-dash-brand{background:linear-gradient(145deg,#faf5ff 0%,#ede9fe 100%);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex;box-shadow:inset 0 1px #ffffffe6,0 4px 14px #7c3aed2e}.admin-dash-brand-icon{display:block}.admin-dash-kicker{letter-spacing:.14em;text-transform:uppercase;color:#7c3aed;opacity:.9;margin:0 0 6px;font-size:.68rem;font-weight:700}.admin-dash-title{letter-spacing:-.045em;color:#111827;flex-wrap:wrap;align-items:center;gap:10px;margin:0;font-size:clamp(1.55rem,3vw,2rem);font-weight:800;line-height:1.15;display:flex}.admin-title-pill{letter-spacing:.06em;text-transform:uppercase;color:#5b21b6;background:linear-gradient(135deg,#ede9fe,#ddd6fe);border:1px solid #7c3aed38;border-radius:999px;align-items:center;padding:4px 11px;font-size:.65rem;font-weight:700;display:inline-flex;box-shadow:0 1px 2px #5b21b614}.admin-dash-tagline{max-width:28rem;color:var(--district-text-secondary);margin:10px 0 0;font-size:.92rem;line-height:1.5}.admin-dash-sub{color:var(--district-text-secondary);margin:8px 0 0;font-size:.88rem;font-weight:500}.admin-dash-sub-label{color:var(--district-text-muted);font-weight:500}.admin-dash-actions{flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;align-items:center;gap:10px;display:flex}.btn-admin-outline{color:#5b21b6;cursor:pointer;background:#ffffffe6;border:1px solid #7c3aed47;border-radius:999px;padding:10px 18px;font-family:inherit;font-size:.88rem;font-weight:600;transition:background .15s,border-color .15s,transform .15s;box-shadow:0 1px 2px #5b21b60f}.btn-admin-outline:hover{background:#faf5ff;border-color:#7c3aed73}.btn-admin-outline:active{transform:scale(.98)}.admin-nav-tabs{box-sizing:border-box;flex-wrap:wrap;gap:8px;width:100%;max-width:1400px;margin:0 auto;padding:0 24px 18px;display:flex}.admin-nav-tab{color:var(--district-text-secondary);border:1px solid #0000;border-radius:10px;align-items:center;padding:9px 16px;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.admin-nav-tab:hover{color:#5b21b6;background:#7c3aed14}.admin-nav-tab--active{color:#5b21b6;background:#7c3aed1f;border-color:#7c3aed40}.pm-meta{word-break:break-word;font-size:.86rem;line-height:1.45}.muted{color:var(--district-text-secondary);font-size:.9rem}.admin-dash-grid{gap:20px;max-width:960px;margin:0 auto;padding:24px;display:grid}@media (width>=700px){.admin-dash-grid{grid-template-columns:1fr 1fr}}.admin-panel{background:linear-gradient(165deg,#fffffff2 0%,#fcfbfffa 100%);border:1px solid #ffffffd9;border-radius:20px;padding:28px 26px 30px;position:relative;overflow:hidden;box-shadow:0 1px 2px #0f172a0a,0 12px 40px #4c1d9514,0 0 0 1px #7c3aed0f}.admin-panel--form{overflow:visible}.admin-panel:before{content:"";opacity:.85;background:linear-gradient(90deg,#a78bfa,#7c3aed 45%,#c4b5fd);height:3px;position:absolute;top:0;left:0;right:0}.admin-panel--form:after{content:"";pointer-events:none;background:radial-gradient(circle,#a78bfa1f,#0000 70%);border-radius:50%;width:120px;height:120px;position:absolute;top:48px;right:-40px}.admin-panel h2{margin:0 0 12px;font-size:1.1rem}.admin-panel p{color:var(--district-text-secondary);margin:0;font-size:.95rem;line-height:1.5}.admin-panel-h2{letter-spacing:-.03em;color:#111827;margin:0 0 8px;font-size:1.2rem;font-weight:800}.admin-stats{flex-direction:column;gap:12px;margin:20px 0 0;padding:0;list-style:none;display:flex}.admin-stats li{flex-direction:column;gap:4px;display:flex}.admin-stats strong{font-size:1.5rem}.admin-stats span{color:var(--district-text-secondary);font-size:.85rem}.admin-clubs-body{box-sizing:border-box;flex-direction:column;gap:20px;width:100%;max-width:1400px;margin:0 auto;padding:24px;display:flex}.admin-clubs-main{width:100%;min-width:0}.admin-inline-alert{color:#991b1b;background:linear-gradient(135deg,#fff1f2,#fef2f2);border:1px solid #f8717173;border-radius:14px;padding:14px 18px;font-size:.9rem;line-height:1.45;box-shadow:0 4px 16px #b91c1c14}.admin-inline-success{color:#14532d;background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border:1px solid #22c55e66;border-radius:14px;justify-content:space-between;align-items:flex-start;gap:14px;padding:14px 18px;font-size:.9rem;line-height:1.45;display:flex;box-shadow:0 4px 16px #16a34a14}.admin-inline-success .mono{letter-spacing:.06em;font-weight:700}.admin-inline-success-dismiss{color:#14532d;cursor:pointer;background:#fff9;border:1px solid #14532d40;border-radius:8px;flex-shrink:0;padding:4px 10px;font-size:.82rem;font-weight:600}.admin-inline-success-dismiss:hover{background:#fffffff2}.admin-panel--list-full{width:100%}.admin-panel-head{align-items:flex-start;gap:14px;margin-bottom:22px;display:flex}.admin-panel-head-icon{color:#6d28d9;background:linear-gradient(145deg,#f5f3ff,#ede9fe);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex;box-shadow:0 2px 8px #7c3aed26}.admin-panel-head-icon svg{display:block}.admin-panel-lead{color:var(--district-text-secondary);margin:0;font-size:.9rem;line-height:1.5}.admin-panel--form.admin-panel--editing{border-color:#a78bfa8c;box-shadow:0 12px 40px #6d28d91f,0 0 0 2px #7c3aed33}.admin-panel--form.admin-panel--editing:before{opacity:1;height:4px}.admin-edit-hint{color:#5b21b6;background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:1px solid #7c3aed2e;border-radius:12px;margin:0 0 18px;padding:12px 14px;font-size:.85rem;line-height:1.55;box-shadow:0 2px 10px #5b21b60f}.admin-panel--list{min-width:0}.club-form-section{flex-direction:column;gap:14px;min-width:0;margin-bottom:28px;display:flex}.club-form-section:last-of-type{margin-bottom:12px}.club-form-section-label{letter-spacing:.11em;text-transform:uppercase;color:#6d28d9;margin:0;padding-top:2px;font-size:.72rem;font-weight:700}.club-form-section:not(:first-child) .club-form-section-label{margin-top:4px}.club-form-section-hint{color:var(--district-text-muted);margin:-4px 0 0;font-size:.82rem;line-height:1.45}.field-premium span{color:#4b5563;font-weight:600}.field-premium input{background:#fff;border-color:#7c3aed1f;width:100%;min-width:0;transition:border-color .15s,box-shadow .15s;box-shadow:0 1px 2px #0f172a0a}.field-premium input:hover{border-color:#7c3aed38}.field-premium input:focus{border-color:#a78bfa;box-shadow:0 0 0 3px #a78bfa38,0 4px 12px #7c3aed14}.club-form-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px 14px;width:100%;min-width:0;display:grid}.club-form-row>.field{min-width:0}@media (width<=560px){.club-form-row{grid-template-columns:minmax(0,1fr)}}.club-form-actions{flex-wrap:wrap;align-items:center;gap:12px;margin-top:18px;padding-top:6px;display:flex}.btn-admin-cta{cursor:pointer;color:#fff;background:linear-gradient(135deg,#7c3aed 0%,#6d28d9 40%,#8b5cf6 100%);border:none;border-radius:12px;justify-content:center;align-items:center;min-height:48px;padding:0 28px;font-family:inherit;font-size:1rem;font-weight:700;transition:filter .15s,transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 4px 14px #6d28d959,inset 0 1px #fff3}.btn-admin-cta:hover:not(:disabled){filter:brightness(1.06);box-shadow:0 8px 24px #6d28d966,inset 0 1px #fff3}.btn-admin-cta:active:not(:disabled){transform:translateY(1px)}.btn-admin-cta:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-admin-cta--compact{gap:8px;min-height:42px;padding:0 18px;font-size:.9rem}.btn-admin-cta--compact svg{flex-shrink:0}.btn-admin-cta--toolbar{gap:8px;min-height:44px;padding:0 18px;font-size:.92rem}.btn-admin-cta--toolbar svg{flex-shrink:0}.btn-admin-ghost{color:#5b21b6;cursor:pointer;background:#ffffffb3;border:1px solid #7c3aed33;border-radius:12px;min-height:48px;padding:0 22px;font-family:inherit;font-size:.95rem;font-weight:600;transition:background .15s,border-color .15s}.btn-admin-ghost:hover:not(:disabled){background:#faf5ff;border-color:#7c3aed59}.btn-admin-ghost:disabled{opacity:.5;cursor:not-allowed}.clubs-form-dialog:not([open]){display:none}.clubs-form-dialog[open]{box-sizing:border-box;background:0 0;border:none;justify-content:center;align-items:center;width:100vw;max-width:100vw;height:100%;max-height:100dvh;margin:0;padding:20px;display:flex}.clubs-form-dialog::backdrop{-webkit-backdrop-filter:blur(8px);background:#0f172a85}.clubs-form-dialog-panel{z-index:1;box-sizing:border-box;background:linear-gradient(165deg,#fffffffa 0%,#fcfbff 100%);border:1px solid #ffffffe6;border-radius:20px;width:min(580px,100vw - 24px);min-width:0;max-width:100%;max-height:min(90dvh,840px);padding:22px 20px 26px;position:relative;overflow:visible auto;box-shadow:0 24px 48px #4c1d952e,0 0 0 1px #7c3aed14}.clubs-form-dialog-panel .admin-form.club-form{width:100%;min-width:0}.clubs-form-dialog-panel .club-form-section{gap:12px;margin-bottom:18px}.clubs-form-dialog-panel .club-form-section:last-of-type{margin-bottom:8px}.clubs-form-dialog-panel .club-form-section:not(:first-child) .club-form-section-label{margin-top:0}.clubs-form-dialog-panel .club-form-row{grid-template-columns:minmax(0,1fr);gap:12px}.clubs-form-dialog-panel input[type=number]{appearance:textfield}.clubs-form-dialog-panel input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.clubs-form-dialog-panel input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.clubs-form-dialog-panel .club-form-actions{margin-top:12px;padding-top:0}.clubs-form-dialog-panel:before{content:"";background:linear-gradient(90deg,#a78bfa,#7c3aed 45%,#c4b5fd);border-radius:20px 20px 0 0;height:3px;display:block;position:absolute;top:0;left:0;right:0}.clubs-form-dialog-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:4px;display:flex;position:relative}.clubs-dialog-head-inner.admin-panel-head{flex:1;min-width:0;margin-bottom:0;padding-right:8px}.clubs-form-dialog-close{color:#5b21b6;cursor:pointer;background:#7c3aed14;border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;margin:-6px -8px 0 0;padding:0;transition:background .15s;display:flex}.clubs-form-dialog-close:hover{background:#7c3aed26}.clubs-form-dialog-close svg{display:block}.clubs-list-toolbar{background:linear-gradient(135deg,#f5f3ffe6,#fff9);border:1px solid #7c3aed1a;border-radius:14px;justify-content:space-between;align-items:flex-start;gap:16px;margin:-4px -6px 18px;padding:14px 16px;display:flex;box-shadow:0 2px 12px #4c1d950d}.clubs-toolbar-left{align-items:flex-start;gap:12px;min-width:0;display:flex}.clubs-toolbar-icon{color:#6d28d9;background:#fffffff2;border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 2px 8px #7c3aed1f}.clubs-toolbar-icon svg{display:block}.clubs-toolbar-right{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.clubs-dir-title{letter-spacing:-.03em;color:#111827;margin:0 0 4px;font-size:1.15rem;font-weight:800}.clubs-dir-desc{color:var(--district-text-secondary);margin:0;font-size:.86rem;line-height:1.4}.clubs-count-badge{color:#5b21b6;background:linear-gradient(145deg,#fff,#faf5ff);border:1px solid #7c3aed33;border-radius:12px;flex-shrink:0;align-items:baseline;gap:6px;padding:8px 14px 8px 12px;font-weight:700;display:inline-flex;box-shadow:0 2px 8px #5b21b614}.clubs-count-num{font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:1.25rem}.clubs-count-label{text-transform:uppercase;letter-spacing:.04em;opacity:.85;font-size:.75rem;font-weight:600}.clubs-skeleton{flex-direction:column;gap:12px;padding:4px 0;display:flex}.clubs-skeleton-row{background:linear-gradient(90deg,#ede9fe 0%,#f8f5ff 45%,#ede9fe 85%) 0 0/200% 100%;border-radius:16px;height:92px;animation:1.2s ease-in-out infinite clubs-shimmer}@keyframes clubs-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@media (prefers-reduced-motion:reduce){.clubs-skeleton-row{background:#ede9fe;animation:none}}.clubs-empty{text-align:center;background:linear-gradient(165deg,#fffffff2,#faf5ffd9);border:1px solid #7c3aed24;border-radius:18px;padding:44px 24px 40px;position:relative;overflow:hidden;box-shadow:inset 0 1px #fffc}.clubs-empty:after{content:"";pointer-events:none;background:radial-gradient(#a78bfa1f,#0000 70%);width:120%;height:60%;position:absolute;bottom:-30%;left:50%;transform:translate(-50%)}.clubs-empty-orbit{width:120px;height:120px;margin:0 auto 20px;position:relative}.clubs-empty-orbit-ring{border:2px dashed #7c3aed38;border-radius:50%;animation:28s linear infinite orbit-spin;position:absolute;inset:0}.clubs-empty-orbit-dot{background:#a78bfa;border-radius:50%;width:8px;height:8px;margin-left:-4px;position:absolute;top:4px;left:50%;box-shadow:0 0 12px #7c3aed80}@keyframes orbit-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion:reduce){.clubs-empty-orbit-ring{animation:none}}.clubs-empty-icon-wrap{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.clubs-empty-pin{filter:drop-shadow(0 8px 16px #7c3aed40);animation:3.5s ease-in-out infinite pin-float;display:block}@keyframes pin-float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@media (prefers-reduced-motion:reduce){.clubs-empty-pin{animation:none}}.clubs-empty-title{z-index:1;letter-spacing:-.03em;color:#1f2937;margin:0 0 10px;font-size:1.15rem;font-weight:800;position:relative}.clubs-empty-text{z-index:1;max-width:300px;color:var(--district-text-secondary);margin:0 auto;font-size:.92rem;line-height:1.55;position:relative}.clubs-empty-cta{z-index:1;margin-top:22px;position:relative}.clubs-card-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.club-card{background:linear-gradient(145deg,#fff 0%,#fafaff 100%);border:1px solid #7c3aed1a;border-radius:16px;flex-direction:row;align-items:stretch;padding:0;transition:transform .2s,border-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 4px #0f172a0a,0 12px 28px #4c1d9512}@media (hover:hover){.club-card:hover{border-color:#7c3aed40;transform:translateY(-2px);box-shadow:0 4px 8px #0f172a0f,0 18px 40px #4c1d951a}}.club-card-accent{opacity:.95;background:linear-gradient(#e9d5ff 0%,#7c3aed 50%,#a78bfa 100%);flex-shrink:0;width:5px}.club-card-inner{flex-direction:column;flex:1;gap:16px;min-width:0;padding:18px 18px 18px 16px;display:flex}@media (width>=560px){.club-card-inner{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:20px;padding:20px 22px 20px 18px}}.club-card--editing{border-color:#7c3aed73;box-shadow:0 0 0 2px #7c3aed40,0 16px 40px #5b21b61f}.club-card--editing .club-card-accent{width:6px;box-shadow:2px 0 12px #7c3aed59}.club-card-avatar{letter-spacing:.02em;color:#fff;background:linear-gradient(145deg,#8b5cf6 0%,#6d28d9 100%);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:.95rem;font-weight:800;display:flex;box-shadow:0 4px 12px #6d28d959,inset 0 1px #fff3}@media (width>=560px){.club-card-avatar{width:52px;height:52px;font-size:1rem}}.club-card-avatar--thumb{padding:0;overflow:hidden}.club-card-avatar--photo{background:#eef2ff}.club-card-avatar--photo img{object-fit:cover;width:100%;height:100%;display:block}.club-card-avatar.club-card-avatar--thumb.club-card-avatar--default{color:inherit;background:#0f172a;box-shadow:0 4px 14px #0f172a40,inset 0 0 0 1px #ffffff1f}.club-card-default-cover{width:100%;height:100%;overflow:hidden}.club-card-default-cover-img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.club-cover-upload{flex-direction:column;gap:14px;display:flex}.club-cover-preview{background:linear-gradient(165deg,#fdfcff,#f5f3ff);border:1px dashed #7c3aed66;border-radius:14px;justify-content:center;align-items:center;min-height:140px;display:flex;overflow:hidden}.club-cover-preview--has-image{background:#f8fafc;border-style:solid;border-color:#7c3aed38;padding:0}.club-cover-preview--default-art{background:#0f172a;border-style:solid;border-color:#0f172a26;padding:0}.club-cover-preview img{object-fit:cover;width:100%;height:140px;display:block}.club-cover-preview-default-wrap{width:100%;height:140px;position:relative;overflow:hidden}.club-cover-preview-default-img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.club-cover-preview-default-label{color:#f3f4f6eb;text-align:center;letter-spacing:.01em;background:linear-gradient(#0000 0%,#0f172ae0 55%);padding:8px 12px;font-size:.72rem;font-weight:600;position:absolute;bottom:0;left:0;right:0}.club-cover-upload-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.club-cover-file-input{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.club-cover-upload-btn{color:#5b21b6;cursor:pointer;background:linear-gradient(#fff 0%,#faf5ff 55%,#f5f0ff 100%);border:1px solid #7c3aed61;border-radius:12px;justify-content:center;align-items:center;gap:10px;min-height:48px;margin:0;padding:0 22px;font-family:inherit;font-size:.95rem;font-weight:700;transition:border-color .15s,box-shadow .15s,filter .15s;display:inline-flex;box-shadow:0 2px 8px #7c3aed24,inset 0 1px #fffffff2}.club-cover-upload-btn:hover{border-color:#7c3aed8c;box-shadow:0 6px 18px #7c3aed38,inset 0 1px #fffffff2}.club-cover-upload-btn:active{filter:brightness(.97)}.club-cover-upload-btn-icon{color:#7c3aed;flex-shrink:0;display:flex}.club-cover-upload-btn-text{line-height:1.2}.club-cover-remove-btn{color:var(--district-text-secondary);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;border-radius:10px;padding:10px 12px;font-family:inherit;font-size:.88rem;font-weight:600;text-decoration:underline}.club-cover-remove-btn:hover{color:#b91c1c}.club-card-body{flex:1;min-width:0}@media (width<=559px){.club-card-inner{flex-direction:column}.club-card-inner>.club-card-avatar{align-self:flex-start}}.club-card-name{letter-spacing:-.02em;color:var(--district-text);margin:0 0 8px;font-size:1.05rem;font-weight:700;line-height:1.3}.club-card-address{color:var(--district-text-secondary);align-items:flex-start;gap:8px;margin:0 0 10px;font-size:.9rem;line-height:1.45;display:flex}.club-card-address-icon{color:var(--district-icon-muted);flex-shrink:0;margin-top:2px}.club-card-coords{flex-wrap:wrap;align-items:center;gap:6px;margin:0;display:flex}.club-card-coords .mono{font-family:ui-monospace,SF Mono,Menlo,Monaco,monospace;font-size:.8rem}.club-coord-pill{color:#4b5563;background:linear-gradient(#f9fafb,#f3f4f6);border:1px solid #7c3aed14;border-radius:8px;padding:4px 9px}.club-coord-sep{color:var(--district-text-muted);-webkit-user-select:none;user-select:none}.club-card-actions{flex-wrap:wrap;flex-shrink:0;gap:8px;display:flex}@media (width>=560px){.club-card-actions{flex-direction:column;align-items:stretch}}.btn-club-action{color:#5b21b6;cursor:pointer;background:#fffffff2;border:1px solid #7c3aed26;border-radius:10px;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:0 14px;font-family:inherit;font-size:.88rem;font-weight:600;transition:background .15s,border-color .15s,box-shadow .15s;display:inline-flex}.btn-club-action:hover:not(:disabled){background:#faf5ff;border-color:#7c3aed59;box-shadow:0 2px 8px #7c3aed1f}.btn-club-action:disabled{opacity:.5;cursor:not-allowed}.btn-club-action--danger{color:#b91c1c;background:snow;border-color:#fecaca}.btn-club-action--danger:hover:not(:disabled){background:linear-gradient(#fff1f2,#fef2f2);border-color:#fca5a5;box-shadow:0 2px 8px #b91c1c1a}.link-btn.danger{color:#b91c1c}.bottle-master-panel{overflow:hidden}.bottle-master-hero{border-bottom:1px solid #7c3aed1f;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:4px;padding:8px 4px 20px;display:flex}.bottle-master-title{letter-spacing:-.02em;color:#1e1b4b;margin:0 0 8px;font-size:1.45rem;font-weight:800}.bottle-master-lead{color:#64748b;max-width:520px;margin:0;font-size:.95rem;line-height:1.55}.btn-bottle-add-wow{font:inherit;color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed 0%,#6d28d9 45%,#5b21b6 100%);border:none;border-radius:14px;align-items:center;gap:10px;padding:14px 22px;font-size:.95rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:inline-flex;position:relative;box-shadow:0 4px 14px #5b21b659,inset 0 1px #fff3}.btn-bottle-add-wow:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #5b21b666,inset 0 1px #ffffff40}.btn-bottle-add-wow:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-bottle-add-wow-glow{z-index:-1;filter:blur(12px);opacity:.85;background:linear-gradient(135deg,#c4b5fd80,#7c3aed26);border-radius:16px;position:absolute;inset:-2px}.bottle-venue-dock{background:linear-gradient(165deg,#faf5ff 0%,#f8fafc 50%,#eef2ff 100%);border:1px solid #7c3aed26;border-radius:16px;margin:20px 0 24px;padding:20px;box-shadow:0 8px 32px #5b21b614}.bottle-venue-dock-label{letter-spacing:.12em;text-transform:uppercase;color:#7c3aed;margin:0 0 12px;font-size:.7rem;font-weight:800}.bottle-venue-chips-scroller{scrollbar-width:thin;scrollbar-color:#7c3aed59 transparent;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:10px;margin:0 -4px;padding:4px 2px 12px;display:flex;overflow-x:auto}.bottle-venue-chips-scroller::-webkit-scrollbar{height:6px}.bottle-venue-chips-scroller::-webkit-scrollbar-thumb{background:#7c3aed4d;border-radius:999px}.bottle-venue-chip{font:inherit;color:#334155;cursor:pointer;background:#fff;border:2px solid #94a3b859;border-radius:999px;flex:none;align-items:center;gap:10px;padding:10px 16px 10px 12px;font-size:.9rem;font-weight:600;transition:border-color .2s,box-shadow .2s,transform .15s;display:inline-flex;position:relative;box-shadow:0 2px 8px #0f172a0f}.bottle-venue-chip:hover{border-color:#7c3aed73;box-shadow:0 4px 16px #7c3aed1f}.bottle-venue-chip--active{color:#4c1d95;background:linear-gradient(#fff 0%,#faf5ff 100%);border-color:#7c3aed;transform:scale(1.02);box-shadow:0 0 0 1px #7c3aed40,0 8px 24px #5b21b626}.bottle-venue-chip-avatar{color:#5b21b6;background:linear-gradient(145deg,#ede9fe,#e9d5ff);border:1px solid #7c3aed33;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:.72rem;font-weight:800;display:flex}.bottle-venue-chip--active .bottle-venue-chip-avatar{color:#fff;background:linear-gradient(145deg,#7c3aed,#a855f7);border-color:#0000}.bottle-venue-chip-name{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.bottle-venue-chip-check{color:#7c3aed;margin-left:2px;display:flex}.bottle-venue-active-banner{background:#fff;border:1px solid #7c3aed1f;border-radius:14px;flex-wrap:wrap;align-items:center;gap:14px 20px;margin-top:8px;padding:16px 18px;display:flex;box-shadow:0 2px 12px #0f172a0a}.bottle-venue-active-icon{color:#7c3aed;background:linear-gradient(145deg,#f5f3ff,#ede9fe);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.bottle-venue-active-copy{flex-direction:column;flex:1;gap:4px;min-width:200px;display:flex}.bottle-venue-active-kicker{letter-spacing:.1em;text-transform:uppercase;color:#a855f7;font-size:.68rem;font-weight:800}.bottle-venue-active-name{color:#1e1b4b;letter-spacing:-.02em;font-size:1.15rem;font-weight:800}.bottle-venue-active-hint{color:#64748b;font-size:.86rem;line-height:1.45}.bottle-venue-back-link{color:#5b21b6;background:#7c3aed14;border:1px solid #7c3aed33;border-radius:10px;flex-shrink:0;padding:10px 16px;font-size:.88rem;font-weight:700;text-decoration:none;transition:background .15s}.bottle-venue-back-link:hover{background:#7c3aed24}.bottle-card-list{margin:0;padding:0;list-style:none}.bottle-row-card--premium{border-radius:16px;transition:box-shadow .2s;overflow:hidden;box-shadow:0 4px 24px #0f172a0f}.bottle-row-card--premium:hover{box-shadow:0 8px 32px #5b21b61a}.bottle-row-card--muted{opacity:.88}.bottle-row-accent{width:5px;background:linear-gradient(#a855f7,#7c3aed)!important}.bottle-row-inner--premium{align-items:stretch;gap:16px}.bottle-row-icon{background:linear-gradient(145deg,#faf5ff,#f3e8ff);border:1px solid #7c3aed26;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.bottle-row-body{flex:1;min-width:0}.bottle-row-title-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;display:flex}.bottle-row-title{margin:0!important}.bottle-servings-visual{flex-direction:column;gap:8px;display:flex}.bottle-servings-track{background:#e2e8f0;border-radius:999px;height:8px;overflow:hidden}.bottle-servings-fill{background:linear-gradient(90deg,#34d399,#10b981);border-radius:999px;height:100%;transition:width .35s}.bottle-servings-fill--empty{background:linear-gradient(90deg,#9ca3af,#d1d5db)}.bottle-servings-fill--expired{background:linear-gradient(90deg,#f87171,#ef4444)}.bottle-servings-nums{color:#64748b;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:8px;font-size:.86rem;display:flex}.bottle-servings-nums strong{color:#0f172a;font-size:1rem}.bottle-servings-expiry{color:#94a3b8;font-size:.8rem}.bottle-row-actions--premium{flex-direction:column;align-items:stretch;min-width:148px}.btn-bottle-pour{font:inherit;color:#fff;cursor:pointer;background:linear-gradient(135deg,#059669,#047857);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 14px;font-size:.88rem;font-weight:700;transition:transform .12s,box-shadow .12s;display:inline-flex;box-shadow:0 4px 12px #0596694d}.btn-bottle-pour:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #05966961}.btn-bottle-pour:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;background:#94a3b8;transform:none}.btn-bottle-pour-icon{background:#fff3;border-radius:8px;justify-content:center;align-items:center;width:22px;height:22px;font-size:1.1rem;line-height:1;display:flex}.bottle-status{letter-spacing:.04em;text-transform:uppercase;border-radius:8px;padding:4px 10px;font-size:.72rem;font-weight:700}.bottle-status--active{color:#047857;background:#ecfdf5}.bottle-status--empty{color:#64748b;background:#f1f5f9}.bottle-status--expired{color:#b91c1c;background:#fef2f2}@media (width>=900px){.bottle-row-inner--premium{flex-direction:row;align-items:center}.bottle-row-actions--premium{flex-direction:column;justify-content:center}}.btn-club-bottles-wow{color:#4c1d95;box-sizing:border-box;background:linear-gradient(145deg,#faf5ff 0%,#fff 40%,#f5f3ff 100%);border:2px solid #7c3aed59;border-radius:14px;align-items:center;gap:12px;min-height:48px;padding:12px 16px;text-decoration:none;transition:transform .15s,border-color .15s,box-shadow .15s;display:inline-flex;position:relative;box-shadow:0 4px 16px #5b21b61f,inset 0 1px #ffffffe6}.btn-club-bottles-wow:hover{border-color:#7c3aed8c;transform:translateY(-2px);box-shadow:0 12px 28px #5b21b62e,inset 0 1px #fffffff2}.btn-club-bottles-wow-shine{pointer-events:none;background:linear-gradient(#ffffffa6,#0000);border-radius:12px 12px 40% 40%;height:45%;position:absolute;top:0;left:0;right:0}.btn-club-bottles-wow-icon{color:#fff;background:linear-gradient(145deg,#8b5cf6,#6d28d9);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 4px 12px #6d28d959}.btn-club-bottles-wow-text{flex-direction:column;align-items:flex-start;gap:2px;min-width:0;display:flex}.btn-club-bottles-wow-label{letter-spacing:-.01em;font-size:.92rem;font-weight:800;line-height:1.2}.btn-club-bottles-wow-hint{color:#7c3aed;opacity:.9;font-size:.72rem;font-weight:600}@media (width<=560px){.btn-club-bottles-wow{flex:100%;justify-content:flex-start}}.auth-loading{background:var(--district-bg);min-height:100dvh;color:var(--district-text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.spinner-page{border:3px solid #e8e8e8;border-top-color:var(--district-purple-mid);border-radius:50%;width:36px;height:36px;animation:.75s linear infinite spin}.auth-banner{color:#991b1b;text-align:center;background:#fef2f2;border-bottom:1px solid #fecaca;padding:12px 20px;font-size:.9rem}.profile-onboarding-backdrop{z-index:110}.profile-onboarding-modal{background:#fff;border-radius:20px;width:100%;max-width:420px;max-height:min(90dvh,640px);position:relative;overflow:hidden;box-shadow:0 24px 64px #00000038}.profile-onboarding-hero{color:#fff;text-align:center;background:linear-gradient(155deg,#4c1d95 0%,#7c3aed 42%,#c084fc 100%);padding:36px 28px 28px}.profile-onboarding-hero--compact{padding:28px 24px 22px}.profile-onboarding-hero-icon{background:#ffffff2e;border:1px solid #ffffff59;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:1.5rem;line-height:1;display:flex}.profile-onboarding-title{letter-spacing:-.02em;margin:0 0 10px;font-size:1.5rem;font-weight:800;line-height:1.2}.profile-onboarding-lead{opacity:.94;margin:0;font-size:.95rem;line-height:1.55}.profile-onboarding-body{color:#111827;background:#fff;padding:24px 24px 28px}.profile-onboarding-primary{width:100%}.profile-onboarding-label{text-align:left;display:block}.profile-onboarding-label-text{color:#6b7280;margin-bottom:8px;font-size:.8rem;font-weight:600;display:block}.profile-onboarding-input{box-sizing:border-box;border:1px solid #e5e7eb;border-radius:12px;outline:none;width:100%;padding:14px;font-size:1rem}.profile-onboarding-input:focus{border-color:#a855f7;box-shadow:0 0 0 3px #a855f733}.profile-onboarding-actions{justify-content:space-between;align-items:center;gap:12px;margin-top:20px;display:flex}.profile-onboarding-actions--stack{flex-direction:column-reverse;align-items:stretch}.profile-onboarding-photo-wrap{justify-content:center;margin-bottom:16px;display:flex}.profile-onboarding-photo-preview{object-fit:cover;border:3px solid #ede9fe;border-radius:50%;width:120px;height:120px;box-shadow:0 8px 24px #5b21b626}.profile-onboarding-photo-placeholder{color:#9ca3af;background:#f9fafb;border:2px dashed #d1d5db;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;font-size:2rem;font-weight:300;display:flex}.profile-onboarding-file-btn{text-align:center;cursor:pointer;color:#5b21b6;background:#fafafa;border:1px solid #e5e7eb;border-radius:12px;padding:12px;font-size:.9rem;font-weight:600;display:block}.profile-onboarding-file-btn:hover{background:#f3e8ff;border-color:#d8b4fe}@media (width<=480px){.profile-onboarding-modal{border-radius:20px 20px 0 0;align-self:flex-end;max-width:none}.profile-onboarding-backdrop{padding:0;padding-bottom:env(safe-area-inset-bottom);align-items:flex-end}}.account-modal{background:var(--district-surface,#fff);border-radius:20px;width:100%;max-width:400px;position:relative;overflow:hidden;box-shadow:0 24px 48px #0000002e}.account-modal-close{color:var(--district-text,#171717);background:#0000000f}.account-modal-close:hover{background:#0000001a}.account-modal-header{text-align:center;border-bottom:1px solid var(--district-border,#e8e8e8);padding:28px 24px 20px}.account-modal-avatar-large{background:linear-gradient(145deg,#7c3aed 0%,#a855f7 100%);border:3px solid #fff;border-radius:50%;width:72px;height:72px;margin:0 auto 12px;overflow:hidden;box-shadow:0 4px 16px #5b21b640}.account-modal-avatar-img{object-fit:cover;width:100%;height:100%;display:block}.account-modal-avatar-initials{color:#fff;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.25rem;font-weight:800;display:flex}.account-modal-title{color:var(--district-text,#171717);margin:0 0 4px;font-size:1.2rem;font-weight:700}.account-modal-phone{color:var(--district-text-secondary,#6b7280);margin:0;font-size:.88rem}.account-modal-body{padding:20px 24px 24px}.account-modal-section{margin-bottom:20px}.account-modal-section-title{letter-spacing:.06em;text-transform:uppercase;color:var(--district-text-secondary,#6b7280);margin:0 0 8px;font-size:.75rem;font-weight:700}.account-modal-muted{color:var(--district-text-secondary,#6b7280);margin:0 0 12px;font-size:.9rem;line-height:1.5}.account-modal-mono{color:var(--district-text,#171717);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-weight:600}.account-modal-referral-row{flex-flow:row;align-items:stretch;gap:10px;width:100%;display:flex}.account-modal-input{border:1px solid var(--district-border,#e5e7eb);letter-spacing:.04em;box-sizing:border-box;border-radius:10px;flex:1 1 0;width:0;min-width:0;padding:12px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.95rem}.account-modal-save-ref.btn-continue{flex:none;align-self:stretch;width:auto;min-width:92px;margin-top:0}.account-modal-signout{color:#7c3aed;cursor:pointer;background:0 0;border:none;border-radius:12px;width:100%;margin-top:8px;padding:14px;font-family:inherit;font-size:.95rem;font-weight:600}.account-modal-signout:hover{background:#faf5ff}
