:root{--color-cream: #FDFBF7;--color-sand: #F5F1EA;--color-stone: #E8E1D5;--color-earth: #8B7E6A;--color-charcoal: #2D2A26;--color-deep: #1A1816;--color-accent: #B8956A;--font-display: "Cormorant Garamond", serif;--font-body: "Jost", sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--line-height-tight: 1.2;--line-height-base: 1.5;--line-height-relaxed: 1.6;--radius: 8px;--max-width: 480px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100dvh;overflow:hidden;overscroll-behavior:contain}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:pan-x pan-y;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-weight:300;color:var(--color-charcoal);background:var(--color-cream);line-height:1.5}input,button,textarea{font-family:inherit;font-weight:inherit;font-size:16px}#app{max-width:var(--max-width);margin:0 auto;height:100dvh;overflow:hidden;display:flex;flex-direction:column;position:fixed;left:0;right:0}.view{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.loading{color:var(--color-earth);text-align:center;padding-top:var(--space-2xl)}.logo{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:500;color:var(--color-deep);letter-spacing:-.01em}.join-view{justify-content:center;align-items:center;text-align:center;gap:var(--space-lg)}.subtitle{color:var(--color-earth);font-size:var(--font-size-base)}.tagline{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:400;font-style:italic;color:var(--color-earth)}.description{color:var(--color-earth);font-size:var(--font-size-sm);line-height:1.6;max-width:320px;text-align:center}.back-link-wrap{text-align:center}.back-link{color:var(--color-earth);font-size:var(--font-size-sm);text-decoration:underline;text-underline-offset:2px;transition:color .2s}.back-link:hover{color:var(--color-charcoal)}.back-link-sub{display:block;font-size:var(--font-size-xs);color:var(--color-earth);opacity:.7;margin-top:2px}.join-form,.identify-form{display:flex;flex-direction:column;gap:var(--space-sm);width:100%;max-width:320px}.join-form input,.identify-form input{padding:var(--space-md);border:1px solid var(--color-stone);border-radius:var(--radius);background:#fff;font-size:var(--font-size-base);color:var(--color-charcoal);text-align:center;transition:border-color .2s}.join-form input:focus,.identify-form input:focus{outline:none;border-color:var(--color-accent)}.join-form input::placeholder,.identify-form input::placeholder{color:var(--color-earth)}button{cursor:pointer;border:none;border-radius:var(--radius);font-size:var(--font-size-base);font-weight:400;transition:all .2s}.join-form button,.identify-form button{padding:var(--space-md);background:var(--color-charcoal);color:var(--color-cream)}.join-form button:hover,.identify-form button:hover{background:var(--color-deep)}.join-form button:disabled,.identify-form button:disabled{opacity:.6;cursor:not-allowed}.error{color:#c0392b;font-size:var(--font-size-sm);text-align:center}.info{color:var(--color-accent);font-size:var(--font-size-sm);text-align:center}.identify-view{justify-content:center;align-items:center;text-align:center;gap:var(--space-lg)}.returning-toggle{padding:var(--space-sm) var(--space-md);background:none;color:var(--color-earth);font-size:var(--font-size-sm);text-decoration:underline;text-underline-offset:2px}.returning-toggle:hover{color:var(--color-charcoal)}.divider{display:flex;align-items:center;width:100%;max-width:320px;gap:var(--space-md);color:var(--color-earth);font-size:var(--font-size-sm)}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--color-stone)}#app:has(.room-view){max-width:none}.room-view{gap:0;position:relative}.room-header{padding:var(--space-md) var(--space-md) var(--space-sm);border-bottom:1px solid var(--color-stone);flex-shrink:0;transform:translateZ(0)}.room-header-top{display:flex;justify-content:space-between;align-items:flex-start}.header-left{display:flex;flex-direction:column;gap:var(--space-xs);min-width:0}.header-title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:500;color:var(--color-deep);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-right{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);flex-shrink:0}.phase-label{font-size:var(--font-size-xs);font-weight:400}.phase-pre{color:var(--color-earth)}.phase-live{color:var(--color-accent)}.phase-ended{color:var(--color-earth);font-style:italic}.others-link{background:none;color:var(--color-earth);font-size:var(--font-size-xs);padding:0;border-radius:0;white-space:nowrap;letter-spacing:.02em}.others-link:hover{color:var(--color-charcoal)}.settings-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;color:var(--color-earth);border-radius:50%;padding:0}.settings-btn:hover{background:var(--color-sand);color:var(--color-charcoal)}.exit-session-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;color:var(--color-earth);border-radius:50%;padding:0;margin-right:8px;opacity:.7;transition:opacity .2s ease,background .2s ease}.exit-session-btn:hover{background:var(--color-sand);color:var(--color-charcoal);opacity:1}.focus-board{flex:1;position:relative;overflow:hidden;user-select:none;-webkit-user-select:none}.focus-board.pannable{cursor:grab}.focus-board:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5}.others-canvas{position:absolute;top:50%;left:50%;z-index:1;transition:opacity .6s ease}.others-canvas.others-hidden{opacity:0;pointer-events:none}.center-shadow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:480px;height:300px;border-radius:50%;background:radial-gradient(ellipse at center,rgba(0,0,0,.035) 0%,rgba(0,0,0,.015) 40%,transparent 75%);z-index:2;pointer-events:none}.center-blur-zone{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:440px;height:280px;z-index:2;background:radial-gradient(ellipse at center,rgba(253,251,247,.4) 0%,rgba(253,251,247,.2) 35%,transparent 75%);pointer-events:none;border-radius:50%}.board-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:50;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:var(--space-sm);width:85%;max-width:360px;pointer-events:none}.board-center .bubble-mine,.board-center .reciprocity-prompt{pointer-events:auto}.reciprocity-prompt{color:var(--color-earth);font-size:var(--font-size-base);line-height:1.6;text-align:center;animation:fadeIn .4s ease both}.threshold-teaser{color:var(--color-earth);font-size:var(--font-size-sm);font-style:italic;text-align:center;margin-top:var(--space-sm);opacity:.8}.pre-event-hint{color:var(--color-earth);font-size:var(--font-size-sm);text-align:center;margin-top:var(--space-sm);opacity:.7}.compose-examples{text-align:center;color:var(--color-earth);font-size:var(--font-size-sm);opacity:.6;margin-top:var(--space-xs)}.compose-examples-inline{margin-top:var(--space-sm)}.example-phrase{font-style:italic}.compose-reassurance{text-align:center;color:var(--color-earth);font-size:var(--font-size-xs);opacity:.5;margin-top:var(--space-xs);font-style:italic}.bubble{width:fit-content;max-width:240px;border-radius:20px;padding:var(--space-sm) var(--space-md);line-height:1.4}.bubble-mine{font-size:var(--font-size-base);background:var(--color-cream);color:var(--color-charcoal);cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-sm);transition:box-shadow .2s ease,background .2s ease,max-width .2s ease,border-color .2s ease;position:relative;padding:var(--space-md) var(--space-lg);max-width:300px;box-shadow:0 2px 8px #0000001a;border:1px solid var(--color-stone);z-index:100}.bubble-mine.bubble-new{animation:fadeIn .3s ease both}.bubble-mine:hover{box-shadow:0 0 0 2px var(--color-stone),0 1px 4px #0000000f}.bubble-pencil{position:absolute;right:-22px;top:50%;transform:translateY(-50%);opacity:0;transition:opacity .15s;color:var(--color-earth);pointer-events:none;line-height:0}@media(hover:hover){.bubble-mine:hover .bubble-pencil{opacity:.6}}.bubble-mine.editing{background:#fff;box-shadow:0 0 0 2px var(--color-accent);cursor:default;max-width:300px;flex-direction:column;align-items:stretch;gap:var(--space-sm);overflow:visible}.bubble-mine.editing .bubble-pencil{display:none}.bubble-other{position:absolute;font-size:var(--font-size-xs);background:var(--color-stone);color:var(--color-earth);opacity:.45;margin-bottom:var(--space-md);max-width:200px;z-index:1;contain:layout style}.bubble-drift-1{animation:bubbleDrift1 8s ease-in-out infinite}.bubble-drift-2{animation:bubbleDrift2 10s ease-in-out infinite}.bubble-drift-3{animation:bubbleDrift3 9s ease-in-out infinite}.bubble-drift-4{animation:bubbleDrift4 11s ease-in-out infinite}.bubble-other.bubble-new{animation:gentleFadeIn .6s ease both}.bubble-other.bubble-new.bubble-drift-1{animation:gentleFadeIn .6s ease both,bubbleDrift1 8s ease-in-out .6s infinite}.bubble-other.bubble-new.bubble-drift-2{animation:gentleFadeIn .6s ease both,bubbleDrift2 10s ease-in-out .6s infinite}.bubble-other.bubble-new.bubble-drift-3{animation:gentleFadeIn .6s ease both,bubbleDrift3 9s ease-in-out .6s infinite}.bubble-other.bubble-new.bubble-drift-4{animation:gentleFadeIn .6s ease both,bubbleDrift4 11s ease-in-out .6s infinite}.bubble-other.bubble-new:nth-child(2){animation-delay:.1s}.bubble-other.bubble-new:nth-child(3){animation-delay:.2s}.bubble-other.bubble-new:nth-child(4){animation-delay:.3s}.bubble-other.bubble-new:nth-child(5){animation-delay:.4s}.bubble-other.bubble-new:nth-child(6){animation-delay:.5s}.others-overflow{position:absolute;bottom:var(--space-lg);left:50%;transform:translate(-50%);background:var(--color-sand);color:var(--color-earth);font-size:var(--font-size-xs);padding:var(--space-sm) var(--space-md);border-radius:16px;border:1px solid var(--color-stone);z-index:4;white-space:nowrap}.bubble-author{font-size:var(--font-size-xs);color:var(--color-earth);position:absolute;bottom:-13px;right:8px;white-space:nowrap}.add-btn{position:fixed;bottom:var(--space-lg);left:50%;transform:translate(-50%);width:52px;height:52px;border-radius:50%;background:var(--color-charcoal);color:var(--color-cream);font-size:var(--font-size-2xl);display:flex;align-items:center;justify-content:center;border:none;line-height:1;box-shadow:0 4px 12px #0003;z-index:10;transform:translate(-50%) translateZ(0)}.add-btn-glyph{padding-top:1px}.add-btn:hover:not(:disabled){background:var(--color-deep);transform:translate(-50%) scale(1.05)}.add-btn-disabled{opacity:.35;cursor:not-allowed!important}.add-btn-tooltip{position:fixed;bottom:calc(var(--space-lg) + 62px);left:50%;transform:translate(-50%);background:var(--color-charcoal);color:var(--color-cream);font-size:var(--font-size-sm);padding:var(--space-sm) var(--space-md);border-radius:12px;max-width:260px;text-align:center;z-index:10;animation:fadeIn .3s ease both}.compose-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1d181666;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding-top:35vh;z-index:50;padding-left:var(--space-md);padding-right:var(--space-md)}.compose-overlay.compose-hidden{display:none}.compose-wrap{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%;max-width:360px}.compose-input-wrap{position:relative;width:100%}.compose-input-wrap input{width:100%;padding:var(--space-md) 44px var(--space-md) var(--space-md);border:1px solid var(--color-stone);border-radius:24px;background:#fff;font-size:var(--font-size-base);color:var(--color-charcoal);box-shadow:0 4px 20px #0000001a;transition:border-color .2s,opacity .3s}.compose-input-wrap input:focus{outline:none;border-color:var(--color-accent)}.compose-input-wrap input::placeholder{color:var(--color-earth)}.compose-input-wrap input.compose-input-locked{opacity:.5;pointer-events:none}.compose-check{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;color:var(--color-stone);padding:var(--space-sm);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .15s}.compose-check:hover{color:var(--color-earth)}.compose-check.compose-check-post{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-earth);right:6px;padding:var(--space-xs) var(--space-sm);border-radius:12px;background:var(--color-sand)}.compose-check.compose-check-post:hover{background:var(--color-stone);color:var(--color-charcoal)}.bubble-edit-input{border:none;background:transparent;font-size:var(--font-size-base);color:var(--color-charcoal);font-family:var(--font-body);font-weight:300;padding:0;min-width:80px;width:100%;resize:none;overflow:hidden;line-height:1.4}.bubble-edit-input:focus{outline:none}.bubble-post-btn{position:absolute;bottom:-8px;right:-8px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:var(--color-cream);color:var(--color-earth);border-radius:50%;padding:0;cursor:pointer;box-shadow:0 1px 4px #0000001a;transition:background .15s,color .15s;z-index:1}.bubble-post-btn svg{width:11px;height:11px}.bubble-post-btn:hover{background:#fff;color:var(--color-charcoal)}.bubble-delete{position:absolute;top:-8px;left:-8px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:var(--color-cream);color:var(--color-earth);border-radius:50%;padding:0;box-shadow:0 1px 4px #0000001a;transition:background .15s,color .15s;z-index:1}.bubble-delete svg{width:11px;height:11px}.bubble-delete:hover{background:#fff;color:#c0392b}.identify-email-row{display:flex;align-items:center;gap:var(--space-sm);width:100%;max-width:320px}.identify-email-row input{flex:1;padding:var(--space-md);border:1px solid var(--color-stone);border-radius:var(--radius);background:#fff;font-size:var(--font-size-base);color:var(--color-charcoal);transition:border-color .2s}.identify-email-row input:focus{outline:none;border-color:var(--color-accent)}.identify-email-row input::placeholder{color:var(--color-earth)}.email-arrow-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-charcoal);color:var(--color-cream);border-radius:50%;flex-shrink:0;padding:0}.email-arrow-btn:hover{background:var(--color-deep)}.email-arrow-btn:disabled{opacity:.6;cursor:not-allowed}.identify-otp-message{font-size:var(--font-size-sm);color:var(--color-earth);line-height:1.5;margin-bottom:var(--space-sm);max-width:320px;text-align:center}.settings-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:transparent;transition:background .3s ease}.settings-panel.settings-hidden{display:none}.settings-panel.settings-visible{background:#1d181626}.settings-content{position:absolute;top:58px;right:max(var(--space-md),calc((100vw - var(--max-width)) / 2 + var(--space-md)));width:260px;max-width:calc(100vw - var(--space-md) * 2);background:#fdfbf7f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;padding:var(--space-md) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm);box-shadow:0 4px 20px #00000014;border:1px solid var(--color-stone);transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .3s ease}.settings-panel.settings-visible .settings-content{transform:translateY(0);opacity:1;pointer-events:all}.settings-header{display:flex;justify-content:space-between;align-items:center}.settings-header h3{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:500}.settings-close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;color:var(--color-earth);border-radius:50%;padding:0}.settings-close-btn:hover{background:var(--color-sand);color:var(--color-charcoal)}.settings-row{display:flex;align-items:center;gap:var(--space-sm)}.settings-label{font-size:var(--font-size-sm);color:var(--color-charcoal)}.settings-name-value{font-size:var(--font-size-sm);font-weight:500;color:var(--color-charcoal);outline:none;border-bottom:1px solid transparent;transition:border-color .2s}.settings-name-value.name-editing{border-bottom-color:var(--color-accent)}.settings-inline-btn{display:inline-flex;align-items:center;justify-content:center;background:none;color:var(--color-earth);padding:var(--space-xs);border-radius:50%}.settings-inline-btn:hover{background:var(--color-sand);color:var(--color-charcoal)}.settings-expandable{overflow:hidden;max-height:60px;transition:max-height .25s ease,opacity .25s ease;opacity:1}.settings-expandable.settings-collapsed{max-height:0;opacity:0;margin:0}.settings-note{font-size:var(--font-size-sm);color:var(--color-earth)}.settings-link-btn{background:none;color:var(--color-accent);font-size:var(--font-size-sm);padding:0;text-align:left;text-decoration:underline;text-underline-offset:2px}.settings-link-btn:hover{color:var(--color-charcoal)}.settings-email-section{display:flex;align-items:center;gap:var(--space-sm)}.settings-email-input{flex:1;min-width:0;padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-stone);border-radius:var(--radius);background:#fff;font-size:var(--font-size-sm);color:var(--color-charcoal)}.settings-email-input:focus{outline:none;border-color:var(--color-accent)}@media(min-width:768px){:root{--max-width: 720px}.room-header{max-width:720px;margin:0 auto;width:100%}.board-center{max-width:420px}.center-blur-zone{width:560px;height:340px}.center-shadow{width:600px;height:360px}.focus-board:after{background:radial-gradient(ellipse at center,transparent 70%,rgba(253,251,247,.25) 88%,rgba(253,251,247,.5) 100%)}}.checkin-view{overflow-y:auto;align-items:center;justify-content:center;text-align:center;gap:var(--space-lg);padding:var(--space-2xl) var(--space-lg)}.checkin-header{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);text-align:center}.checkin-title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:500;color:var(--color-deep)}.checkin-meta{color:var(--color-earth);font-size:var(--font-size-sm)}.checkin-note{color:var(--color-earth);font-size:var(--font-size-sm);padding:var(--space-sm) var(--space-md);background:var(--color-sand);border-radius:var(--radius);max-width:360px}.checkin-message{color:var(--color-charcoal);font-size:var(--font-size-base);line-height:1.5;max-width:360px}.checkin-form{display:flex;flex-direction:column;gap:var(--space-sm);width:100%;max-width:320px}.checkin-input{padding:var(--space-md);border:1px solid var(--color-stone);border-radius:var(--radius);background:#fff;font-size:var(--font-size-base);color:var(--color-charcoal);text-align:center;transition:border-color .2s}.checkin-input:focus{outline:none;border-color:var(--color-accent)}.checkin-input::placeholder{color:var(--color-earth)}.checkin-btn-primary{padding:var(--space-md) var(--space-xl);background:var(--color-charcoal);color:var(--color-cream);border-radius:var(--radius);font-size:var(--font-size-base);font-weight:400;min-height:44px;text-decoration:none;text-align:center;transition:background .2s}.checkin-btn-primary:hover{background:var(--color-charcoal)}.checkin-btn-primary:disabled{opacity:.6;cursor:not-allowed}.checkin-btn-secondary{padding:var(--space-sm) var(--space-md);background:none;color:var(--color-earth);font-size:var(--font-size-sm);text-decoration:underline;text-underline-offset:2px;transition:color .2s}.checkin-btn-secondary:hover{color:var(--color-charcoal)}.checkin-troubleshoot{display:flex;flex-direction:column;gap:var(--space-md);width:100%;max-width:360px}.checkin-troubleshoot-option{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md);background:var(--color-sand);border:1px solid var(--color-stone);border-radius:var(--radius);text-align:left;cursor:pointer;transition:border-color .2s}.checkin-troubleshoot-option:hover{border-color:var(--color-earth)}.checkin-troubleshoot-option strong{color:var(--color-charcoal);font-size:var(--font-size-base)}.checkin-troubleshoot-option span{color:var(--color-earth);font-size:var(--font-size-sm);line-height:1.4}.checkin-troubleshoot-divider{border-top:1px solid var(--color-stone);margin:var(--space-xs) 0}.checkin-troubleshoot-note{color:var(--color-earth);font-size:var(--font-size-sm);line-height:1.4;text-align:center;max-width:360px}.checkin-btn-back{font-size:var(--font-size-base);color:var(--color-charcoal);font-weight:500;text-decoration:none}.checkin-troubleshoot-footer{color:var(--color-earth);font-size:var(--font-size-sm);text-align:center}.checkin-link-inline{background:none;border:none;padding:0;color:var(--color-earth);text-decoration:underline;text-underline-offset:2px;font-size:inherit;cursor:pointer}.checkin-link-inline:hover{color:var(--color-charcoal)}.checkin-confirm{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);text-align:center;max-width:360px;animation:fadeIn .3s ease both}.checkin-icon{color:var(--color-earth);display:flex;align-items:center;justify-content:center;width:48px;height:48px}.checkin-icon svg{width:48px;height:48px}.checkin-checkmark{width:64px;height:64px;color:var(--color-accent);animation:scaleIn .4s cubic-bezier(.34,1.56,.64,1) both}.checkin-checkmark svg{width:64px;height:64px}@keyframes scaleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.checkin-success{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);text-align:center;animation:fadeIn .3s ease both}.checkin-redirect{color:var(--color-earth);font-size:var(--font-size-sm);font-style:italic}.checkin-walkin{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%;max-width:320px}.checkin-walkin-options{display:flex;flex-direction:column;gap:var(--space-sm);width:100%;animation:fadeIn .3s ease both}.admin-view{padding:var(--space-lg);overflow-y:auto;gap:var(--space-lg)}#app:has(.admin-view){max-width:720px;position:static}.admin-title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:500;color:var(--color-deep)}.admin-subtitle{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:500;color:var(--color-deep);margin-top:var(--space-md)}.admin-desc{font-size:var(--font-size-sm);color:var(--color-earth)}.admin-section{display:flex;flex-direction:column;gap:var(--space-md)}.admin-form-row{display:flex;gap:var(--space-sm);flex-wrap:wrap}.admin-input{flex:1;min-width:120px;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-stone);border-radius:var(--radius);background:#fff;color:var(--color-charcoal)}.admin-input:focus{outline:none;border-color:var(--color-accent)}.admin-btn{padding:var(--space-sm) var(--space-md);background:var(--color-charcoal);color:var(--color-cream);border-radius:var(--radius);white-space:nowrap}.admin-btn:hover{background:var(--color-deep)}.admin-back-btn{display:inline-flex;align-items:center;gap:var(--space-xs);background:none;color:var(--color-earth);padding:0;font-size:var(--font-size-sm)}.admin-back-btn:hover{color:var(--color-charcoal)}.admin-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.admin-table th{text-align:left;padding:var(--space-sm);border-bottom:2px solid var(--color-stone);color:var(--color-earth);font-weight:400}.admin-table td{padding:var(--space-sm);border-bottom:1px solid var(--color-sand)}.admin-table a{color:var(--color-accent);text-decoration:underline;text-underline-offset:2px}.admin-delete-btn{background:none;color:var(--color-earth);font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm);border-radius:4px}.admin-delete-btn:hover{background:var(--color-sand);color:#c0392b}.admin-settings{display:flex;flex-direction:column;gap:var(--space-sm)}.admin-toggle-label{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-charcoal);cursor:pointer}.admin-participant-card{border:1px solid var(--color-stone);border-radius:var(--radius);padding:var(--space-md);margin-top:var(--space-sm)}.admin-participant-header{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.admin-email{font-size:var(--font-size-sm);color:var(--color-earth)}.admin-badge{font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-sm);border-radius:10px}.badge-verified{background:#b8956a26;color:var(--color-accent)}.badge-unverified{background:var(--color-sand);color:var(--color-earth)}.admin-items-list{margin-top:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-xs)}.admin-item-row{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm);background:var(--color-sand);border-radius:6px}.admin-add-item-row{margin-top:var(--space-xs)}.lobby-view{overflow-y:auto;align-items:center}.lobby-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:var(--space-2xl) var(--space-lg);width:100%;max-width:420px}.lobby-title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:500;color:var(--color-deep);text-align:center}.lobby-meta{color:var(--color-earth);font-size:var(--font-size-sm);text-align:center}.lobby-links{display:flex;flex-direction:column;gap:var(--space-sm);width:100%}.lobby-link-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-sand);border-radius:var(--radius);color:var(--color-charcoal);text-decoration:none;transition:background .2s}.lobby-link-card:hover{background:var(--color-stone)}.lobby-link-card svg{flex-shrink:0;color:var(--color-earth)}.lobby-link-card strong{font-size:var(--font-size-sm);font-weight:500}.lobby-link-card p{font-size:var(--font-size-sm);color:var(--color-earth)}.lobby-checkin-section{width:100%;display:flex;flex-direction:column;gap:var(--space-md)}.lobby-form-row{display:flex;gap:var(--space-sm);width:100%}.lobby-input{flex:1;min-width:0;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-stone);border-radius:var(--radius);background:#fff;font-size:var(--font-size-base);color:var(--color-charcoal)}.lobby-input:focus{outline:none;border-color:var(--color-accent)}.lobby-input::placeholder{color:var(--color-earth)}.lobby-btn{padding:var(--space-sm) var(--space-md);background:var(--color-charcoal);color:var(--color-cream);border-radius:var(--radius);white-space:nowrap;font-size:var(--font-size-sm)}.lobby-btn:hover{background:var(--color-deep)}.lobby-btn:disabled{opacity:.6;cursor:not-allowed}.lobby-success{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);text-align:center;color:var(--color-charcoal)}.lobby-success p{font-size:var(--font-size-base)}.lobby-walkin{display:flex;flex-direction:column;gap:var(--space-md)}.lobby-walkin-note{font-size:var(--font-size-sm);color:var(--color-earth)}.lobby-footer{padding-top:var(--space-md);border-top:1px solid var(--color-stone);width:100%;text-align:center}.lobby-room-link{color:var(--color-earth);font-size:var(--font-size-sm);text-decoration:underline;text-underline-offset:2px}.lobby-room-link:hover{color:var(--color-charcoal)}.checkout-view{overflow-y:auto;align-items:center;justify-content:center}.checkout-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:var(--space-2xl) var(--space-lg);width:100%;max-width:420px}.checkout-title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:500;color:var(--color-deep)}.checkout-meta{color:var(--color-earth);font-size:var(--font-size-sm)}.checkout-form{width:100%;display:flex;flex-direction:column;gap:var(--space-md)}.checkout-success{text-align:center;display:flex;flex-direction:column;gap:var(--space-sm)}.checkout-thanks{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:500;color:var(--color-deep)}.checkout-note{color:var(--color-earth);font-size:var(--font-size-sm)}.admin-reg-card{border:1px solid var(--color-stone);border-radius:var(--radius);padding:var(--space-md);margin-top:var(--space-sm)}.admin-reg-header{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.admin-reg-focus{font-size:var(--font-size-sm);color:var(--color-earth);font-style:italic;margin-top:var(--space-xs)}.admin-reg-times{display:flex;gap:var(--space-md);font-size:var(--font-size-xs);color:var(--color-earth);margin-top:var(--space-xs)}.admin-links{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.admin-links a{color:var(--color-accent);text-decoration:underline;text-underline-offset:2px;font-size:var(--font-size-sm)}.admin-links a:hover{color:var(--color-charcoal)}.admin-field-label{display:flex;flex-direction:column;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-earth);flex:1;min-width:140px}.admin-field-label .admin-input{margin-top:2px}.admin-settings-fields,.admin-create-form{display:flex;flex-direction:column;gap:var(--space-sm)}.admin-assign-btn{font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-sm)}.badge-registered{background:var(--color-sand);color:var(--color-earth)}.badge-checked-in{background:#4caf501f;color:#2e7d32}.badge-checked-out{background:#2196f31f;color:#1565c0}.badge-cancelled{background:#f443361a;color:#c62828}.badge-walkin{background:#b8956a26;color:var(--color-accent)}.badge-time{background:var(--color-sand);color:var(--color-earth);font-size:var(--font-size-xs)}.admin-reg-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-top:var(--space-sm)}.focus-preview{cursor:pointer;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px}.focus-preview:hover{color:var(--color-charcoal)}.admin-toast{position:fixed;right:24px;background:var(--color-accent);color:#fff;padding:var(--space-md);border-radius:8px;display:flex;align-items:center;gap:var(--space-md);box-shadow:0 4px 12px #00000026;z-index:1000;animation:slideInUp .3s ease both;transition:bottom .3s ease,opacity .3s ease}.admin-toast svg{flex-shrink:0}.admin-toast-fade-out{opacity:0}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.admin-highlight-new{animation:highlightPulse 2s ease}@keyframes highlightPulse{0%{background:#b8956a33}to{background:transparent}}.headphone-outstanding-link{color:var(--color-accent);text-decoration:underline;text-underline-offset:2px;font-size:var(--font-size-xs);cursor:pointer}.headphone-outstanding-link:hover{color:var(--color-charcoal)}.admin-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1d181666;display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-lg)}.admin-modal{background:var(--color-cream);border-radius:12px;width:100%;max-width:560px;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000026}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-stone);flex-shrink:0}.admin-modal-title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:500;color:var(--color-deep)}.admin-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;color:var(--color-earth);border-radius:50%;padding:0;flex-shrink:0}.admin-modal-close:hover{background:var(--color-sand);color:var(--color-charcoal)}.admin-modal-body{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm);overflow-y:auto}.admin-modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-stone);flex-shrink:0}.admin-btn-secondary{padding:var(--space-sm) var(--space-md);background:var(--color-sand);color:var(--color-charcoal);border-radius:var(--radius);white-space:nowrap}.admin-btn-secondary:hover{background:var(--color-stone)}.admin-group-card{background:var(--color-sand);border-radius:var(--radius);padding:var(--space-md);margin-top:var(--space-sm)}.admin-group-header{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.admin-group-date{font-size:var(--font-size-sm);color:var(--color-earth)}.admin-group-count{font-size:var(--font-size-sm);color:var(--color-earth);margin-left:auto}.admin-group-actions{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-sm)}.admin-group-hint{font-size:var(--font-size-sm);color:var(--color-earth)}.admin-quick-actions{display:flex;align-items:center;gap:var(--space-sm)}.admin-headphone-tracker{background:var(--color-sand);border-radius:var(--radius);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.headphone-header{display:flex;align-items:center;gap:var(--space-sm)}.headphone-icon{color:var(--color-accent);display:flex;align-items:center}.headphone-count{display:flex;align-items:baseline;gap:var(--space-sm)}.headphone-count .count-large{font-size:var(--font-size-3xl);font-weight:400;color:var(--color-accent);font-family:var(--font-display);line-height:1}.headphone-count .count-label{font-size:var(--font-size-base);color:var(--color-earth)}.headphone-bar{width:100%;height:8px;background:var(--color-stone);border-radius:4px;overflow:hidden}.headphone-bar-fill{height:100%;background:var(--color-accent);transition:width .3s ease}.headphone-detail{font-size:var(--font-size-sm);color:var(--color-earth)}.admin-reassign-btn{background:var(--color-sand);color:var(--color-charcoal);font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-sm);border-radius:4px}.admin-reassign-btn:hover{background:var(--color-stone)}.admin-modal-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.admin-modal-table th{text-align:left;padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--color-stone);color:var(--color-earth);font-weight:400}.admin-modal-table td{padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--color-sand)}.admin-modal-table .truncate{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-stale-banner{position:fixed;top:0;left:0;right:0;background:#ffc107;color:#663c00;padding:var(--space-sm) var(--space-md);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);z-index:1000;font-size:var(--font-size-sm);box-shadow:0 2px 8px #0000001a}.admin-stale-banner button{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm)}.admin-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg);margin:var(--space-lg) 0}.summary-card{background:#fff;border:1px solid var(--color-stone);border-radius:var(--radius);padding:var(--space-lg);box-shadow:0 1px 3px #0000000d}.card-label{font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--color-earth);margin-bottom:var(--space-xs)}.card-value{font-size:var(--font-size-3xl);font-weight:600;color:var(--color-charcoal);margin:var(--space-xs) 0}.card-sublabel{font-size:var(--font-size-sm);color:var(--color-earth);margin-top:var(--space-xs)}.activity-mini-feed{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-sm)}.activity-item{display:flex;flex-wrap:wrap;gap:var(--space-xs);font-size:var(--font-size-sm);line-height:1.4}.activity-name{font-weight:500;color:var(--color-charcoal)}.activity-action{color:var(--color-earth)}.activity-time{margin-left:auto;font-size:var(--font-size-xs);color:var(--color-earth);opacity:.7}.admin-section-expandable{margin:var(--space-lg) 0;border:1px solid var(--color-stone);border-radius:var(--radius);background:#fff;padding:var(--space-md)}.admin-section-expandable summary{cursor:pointer;font-size:var(--font-size-lg);font-weight:500;color:var(--color-charcoal);list-style:none;-webkit-user-select:none;user-select:none;padding:var(--space-sm) 0}.admin-section-expandable summary::-webkit-details-marker{display:none}.admin-section-expandable summary:before{content:"▶";display:inline-block;margin-right:var(--space-sm);font-size:var(--font-size-xs);transition:transform .2s}.admin-section-expandable[open] summary:before{transform:rotate(90deg)}.admin-section-expandable .admin-registrations,.admin-section-expandable .admin-participants{margin-top:var(--space-md)}.admin-btn-secondary.active{background:var(--color-accent);color:#fff}@media(max-width:640px){.admin-summary-grid{grid-template-columns:1fr}.summary-card{padding:var(--space-md)}.card-value{font-size:var(--font-size-2xl)}}.identify-header{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);text-align:center}.identify-title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:500;color:var(--color-deep)}.identify-meta{color:var(--color-earth);font-size:var(--font-size-sm)}.identify-step{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%;max-width:320px;animation:fadeIn .3s ease both}.identify-welcome{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:500;color:var(--color-deep);text-align:center}.identify-focus-preview{font-size:var(--font-size-sm);color:var(--color-earth);font-style:italic;text-align:center;padding:var(--space-sm) var(--space-md);background:var(--color-sand);border-radius:var(--radius);width:100%}.identify-guidance{font-size:var(--font-size-sm);color:var(--color-earth);text-align:center;line-height:1.5}.identify-link{display:inline-block;color:var(--color-accent);font-size:var(--font-size-sm);text-decoration:underline;text-underline-offset:2px}.identify-link:hover{color:var(--color-charcoal)}.identify-secondary-btn{padding:var(--space-sm) var(--space-md);background:var(--color-sand);color:var(--color-charcoal);border-radius:var(--radius);font-size:var(--font-size-sm)}.identify-secondary-btn:hover{background:var(--color-stone)}.lobby-timegate{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);text-align:center;padding:var(--space-lg);background:var(--color-sand);border-radius:var(--radius);width:100%}.lobby-timegate-label{font-size:var(--font-size-sm);color:var(--color-earth)}.lobby-timegate-time{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:500;color:var(--color-deep)}.lobby-countdown{font-size:var(--font-size-sm);color:var(--color-accent);font-variant-numeric:tabular-nums}.lobby-postcheckin{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);width:100%;animation:fadeIn .3s ease both}.lobby-welcome{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:500;color:var(--color-deep);text-align:center}.lobby-btn-primary{padding:var(--space-md) var(--space-xl);background:var(--color-charcoal);color:var(--color-cream);border-radius:var(--radius);font-size:var(--font-size-base);white-space:nowrap}.lobby-btn-primary:hover{background:var(--color-deep)}.lobby-btn-secondary{width:100%;padding:var(--space-md) var(--space-lg);background:transparent;color:var(--color-earth);border:1px solid var(--color-stone);border-radius:var(--radius);font-size:var(--font-size-base);cursor:pointer;transition:background .2s,border-color .2s;text-align:center}.lobby-btn-secondary:hover{background:var(--color-sand);border-color:var(--color-earth)}.lobby-wrong-session{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);text-align:center;padding:var(--space-md);background:var(--color-sand);border-radius:var(--radius);width:100%}.lobby-wrong-session p{font-size:var(--font-size-sm);color:var(--color-earth)}.checkout-links,.focuslab-form{display:flex;flex-direction:column;gap:var(--space-sm);width:100%}.focuslab-form .lobby-input{width:100%}.lobby-welcome-heading{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:500;color:var(--color-deep);text-align:center;line-height:1.3}.focuslab-wifi-inline{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-earth)}.focuslab-wifi-inline svg{flex-shrink:0;width:14px;height:14px}.focuslab-callout{display:flex;align-items:flex-start;gap:var(--space-md);width:100%;padding:var(--space-md);background:var(--color-sand);border-radius:var(--radius);font-size:var(--font-size-sm);color:var(--color-charcoal);line-height:1.5}.focuslab-callout svg{flex-shrink:0;color:var(--color-earth);margin-top:2px}.focuslab-tips{width:100%}.focuslab-tips-title{font-family:var(--font-display);font-size:var(--font-size-base);font-weight:500;color:var(--color-deep);margin-bottom:var(--space-sm)}.focuslab-tips ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:var(--space-sm)}.focuslab-tips li{font-size:var(--font-size-sm);color:var(--color-charcoal);padding-left:var(--space-md);position:relative}.focuslab-tips li:before{content:"•";position:absolute;left:0;color:var(--color-earth)}.focuslab-note{font-size:var(--font-size-sm);color:var(--color-earth);font-style:italic;text-align:center}.focuslab-newsletter-toggle{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-charcoal);cursor:pointer;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-stone);border-radius:var(--radius);width:100%;transition:border-color .2s,background .2s}.focuslab-newsletter-toggle:hover{border-color:var(--color-earth)}.focuslab-newsletter-toggle.is-checked{background:var(--color-sand);border-color:var(--color-accent)}.focuslab-newsletter-toggle input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-accent);flex-shrink:0;cursor:pointer}.focuslab-secondary-links{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.focuslab-secondary-link{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--color-earth);font-size:var(--font-size-sm);text-decoration:underline;text-underline-offset:2px;padding:var(--space-xs) 0}.focuslab-secondary-link:hover{color:var(--color-charcoal)}.focuslab-checkout-step{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);text-align:center;padding:var(--space-lg) 0}.focuslab-checkout-step svg{color:var(--color-earth);width:32px;height:32px}.focuslab-checkout-heading{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:500;color:var(--color-deep)}.focuslab-checkout-note{font-size:var(--font-size-sm);color:var(--color-earth);line-height:1.5}@keyframes checkoutFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.checkout-fade{opacity:0;animation:checkoutFadeIn .4s ease forwards;animation-delay:max(0s,.25s + (var(--fade-order, 0) - 1) * .85s)}.checkout-summary{text-align:center;margin-bottom:1.25rem}.checkout-heading{font-family:var(--font-display, "Cormorant Garamond", serif);font-size:var(--font-size-2xl);margin-bottom:.5rem;color:var(--color-charcoal, #2D2A26)}.checkout-upcoming{width:100%;margin-bottom:1.75rem}.upcoming-header{font-family:var(--font-display, "Cormorant Garamond", serif);font-size:var(--font-size-sm);color:var(--color-earth, #8B7E6A);letter-spacing:.02em;text-transform:lowercase;margin-bottom:.4rem}.upcoming-dates{display:flex;gap:.5rem;margin-bottom:.6rem}.upcoming-date{flex:1;padding:.4rem .5rem;background:var(--color-sand, #F5F1EA);border:1px solid var(--color-stone, #E8E1D5);border-radius:.4rem;font-size:var(--font-size-sm);color:var(--color-charcoal, #2D2A26);white-space:nowrap;text-align:center}.upcoming-schedule-link{display:block;text-align:center;font-size:var(--font-size-sm);color:var(--color-accent, #B8956A);text-decoration:none;border-bottom:none;transition:opacity .2s}.upcoming-schedule-link:hover{opacity:.8}.retention-section{width:100%;margin-bottom:1.5rem}.retention-group-title{font-family:var(--font-display, "Cormorant Garamond", serif);font-size:var(--font-size-xl);color:var(--color-earth, #8B7E6A);margin-bottom:.6rem;letter-spacing:.02em;text-transform:lowercase}.retention-cards{display:flex;flex-direction:column;gap:.6rem}.retention-card{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--color-sand, #F5F1EA);border:1px solid var(--color-stone, #E8E1D5);border-radius:.75rem;text-decoration:none;color:var(--color-charcoal, #2D2A26);cursor:pointer;transition:background .2s,border-color .2s;font:inherit;font-size:inherit;text-align:left}.retention-card:hover{background:var(--color-stone, #E8E1D5);border-color:var(--color-earth, #8B7E6A)}.retention-card-light{background:transparent;border-color:var(--color-stone, #E8E1D5)}.retention-card-light:hover{background:var(--color-sand, #F5F1EA)}.retention-card strong{display:block;font-size:var(--font-size-sm)}.retention-card .feedback-label{font-weight:400}.retention-card p{font-size:var(--font-size-sm);color:var(--color-earth, #8B7E6A);margin:.1rem 0 0}.retention-card svg{flex-shrink:0;color:var(--color-accent, #B8956A);width:20px;height:20px}.retention-card-text{display:flex;align-items:baseline;gap:.35rem;flex-wrap:wrap}.retention-card-hint{font-size:var(--font-size-sm);font-weight:400;color:var(--color-earth, #8B7E6A)}.invite-buttons{display:flex;gap:.6rem}.invite-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;background:var(--color-accent, #B8956A);color:var(--color-cream, #FDFBF7);border:2px solid var(--color-accent, #B8956A);border-radius:.6rem;font-size:var(--font-size-sm);font-weight:500;text-decoration:none;cursor:pointer;transition:background .2s,border-color .2s}.invite-btn:hover{background:#a6854e;border-color:#a6854e}.invite-btn svg{width:18px;height:18px;flex-shrink:0}.invite-btn-outline{background:transparent;color:var(--color-accent, #B8956A)}.invite-btn-outline:hover{background:var(--color-sand, #F5F1EA)}.invite-btn:disabled{opacity:.6;cursor:default}.invite-btn-subscribed{background:var(--color-sand, #F5F1EA);border-color:var(--color-stone, #E8E1D5);color:var(--color-earth, #8B7E6A);cursor:default}.invite-btn-subscribed .unsubscribe-link{font-size:var(--font-size-xs);color:var(--color-earth, #8B7E6A);opacity:.7;text-decoration:underline;margin-left:.25rem}.unsubscribe-link{font-size:var(--font-size-sm);color:var(--color-earth, #8B7E6A);text-decoration:underline}.subscribed-confirmation{font-size:var(--font-size-sm);color:var(--color-accent, #B8956A);display:flex;align-items:center;gap:.5rem}.feedback-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d2a2680;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;transition:opacity .3s}.feedback-overlay.feedback-hidden{display:none}.feedback-card{background:var(--color-cream, #FDFBF7);border-radius:1rem;padding:1.5rem;max-width:400px;width:100%;position:relative;max-height:90vh;overflow-y:auto}.feedback-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;font-size:var(--font-size-xl);color:var(--color-earth, #8B7E6A);cursor:pointer;padding:.25rem;line-height:1}.feedback-progress{display:flex;justify-content:center;gap:.5rem;margin-bottom:1rem}.progress-dot{width:8px;height:8px;border-radius:50%;background:var(--color-stone, #E8E1D5);transition:background .2s}.progress-dot.active{background:var(--color-accent, #B8956A)}.progress-dot.completed{background:var(--color-earth, #8B7E6A)}.feedback-question{font-family:var(--font-display, "Cormorant Garamond", serif);font-size:var(--font-size-xl);text-align:center;margin-bottom:1.25rem;color:var(--color-charcoal, #2D2A26)}.feedback-hint{text-align:center;font-size:var(--font-size-sm);color:var(--color-earth, #8B7E6A);margin:-.75rem 0 .75rem}.emoji-buttons{display:flex;justify-content:center;gap:1rem}.emoji-btn{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.75rem 1rem;background:var(--color-sand, #F5F1EA);border:2px solid var(--color-stone, #E8E1D5);border-radius:.75rem;cursor:pointer;transition:border-color .2s,background .2s;flex:1;max-width:100px}.emoji-btn:hover{border-color:var(--color-accent, #B8956A);background:var(--color-stone, #E8E1D5)}.emoji-btn svg{width:28px;height:28px;color:var(--color-earth, #8B7E6A)}.emoji-btn .emoji-label{font-size:var(--font-size-xs);color:var(--color-earth, #8B7E6A);white-space:nowrap}.pill-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.pill-btn{padding:.5rem .875rem;border:1px solid var(--color-stone, #E8E1D5);border-radius:2rem;background:var(--color-sand, #F5F1EA);color:var(--color-charcoal, #2D2A26);font-size:var(--font-size-sm);cursor:pointer;transition:all .2s}.pill-btn:hover{border-color:var(--color-accent, #B8956A)}.pill-btn.pill-active{background:var(--color-accent, #B8956A);color:var(--color-cream, #FDFBF7);border-color:var(--color-accent, #B8956A)}.other-input-wrap{margin-bottom:1rem}.other-input-wrap.hidden{display:none}.other-textarea{width:100%;min-height:80px;padding:.75rem;border:1px solid var(--color-stone, #E8E1D5);border-radius:.5rem;background:var(--color-sand, #F5F1EA);color:var(--color-charcoal, #2D2A26);font-family:var(--font-body, "Jost", sans-serif);font-size:var(--font-size-sm);resize:vertical}.other-textarea:focus{outline:none;border-color:var(--color-accent, #B8956A)}.feedback-actions{display:flex;gap:.75rem;justify-content:center}.feedback-actions button{flex:1;max-width:140px}.feedback-submit-btn{padding:.6rem 1.5rem;background:var(--color-accent, #B8956A);color:var(--color-cream, #FDFBF7);border:none;border-radius:.5rem;cursor:pointer;font-size:var(--font-size-sm);transition:background .2s}.feedback-submit-btn:hover{background:#a6854e}.feedback-skip-btn{padding:.6rem 1.5rem;background:transparent;color:var(--color-earth, #8B7E6A);border:1px solid var(--color-stone, #E8E1D5);border-radius:.5rem;cursor:pointer;font-size:var(--font-size-sm)}.feedback-thanks{font-family:var(--font-display, "Cormorant Garamond", serif);font-size:var(--font-size-xl);text-align:center;margin-bottom:1rem;color:var(--color-charcoal, #2D2A26)}.checkout-secondary-btn{display:block;width:100%;padding:.65rem;background:transparent;border:1px solid var(--color-stone, #E8E1D5);border-radius:.5rem;color:var(--color-earth, #8B7E6A);font-size:var(--font-size-sm);cursor:pointer;text-align:center;margin-top:1.25rem;transition:background .2s}.checkout-secondary-btn:hover{background:var(--color-sand, #F5F1EA)}.lobby-card{border:1px solid var(--color-stone);border-radius:12px;margin-bottom:var(--space-md);background:var(--color-sand);overflow:hidden;transition:box-shadow .2s ease}.lobby-card:hover{box-shadow:0 2px 8px #00000014}.lobby-card-header{padding:var(--space-md);cursor:pointer;display:flex;align-items:center;gap:var(--space-sm);list-style:none;-webkit-user-select:none;user-select:none;font-family:var(--font-body);font-weight:500;color:var(--color-charcoal)}.lobby-card-header::-webkit-details-marker{display:none}.lobby-card-header:after{content:"›";margin-left:auto;font-size:var(--font-size-xl);transition:transform .2s ease;color:var(--color-earth)}.lobby-card[open] .lobby-card-header:after{transform:rotate(90deg)}.lobby-card-content{padding:0 var(--space-md) var(--space-md);color:var(--color-charcoal);font-size:var(--font-size-sm);line-height:1.5}.lobby-card-content ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:var(--space-sm)}.lobby-card-content li{padding-left:var(--space-md);position:relative}.lobby-card-content li:before{content:"•";position:absolute;left:0;color:var(--color-earth)}.info-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d2a2699;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease both}.info-modal-overlay.modal-exit{animation:fadeOut .2s ease forwards}.info-modal-card{background:var(--color-cream);padding:var(--space-lg);border-radius:12px;max-width:90vw;width:400px;position:relative;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1) both;box-shadow:0 8px 32px #0003}.modal-exit .info-modal-card{animation:slideOut .2s ease forwards}.info-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--color-charcoal);font-size:var(--font-size-2xl);cursor:pointer;border-radius:50%;transition:background .2s}.info-modal-close:hover{background:var(--color-sand)}.info-modal-title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:500;color:var(--color-charcoal);margin-bottom:var(--space-md)}.info-modal-card p{color:var(--color-earth);font-size:var(--font-size-sm);line-height:1.5;margin-bottom:var(--space-sm)}.info-modal-btn{width:100%;padding:var(--space-md);margin-top:var(--space-md);background:var(--color-accent);color:var(--color-cream);border:none;border-radius:8px;font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:background .2s}.info-modal-btn:hover{background:var(--color-earth)}.info-icon{position:fixed;top:16px;right:max(16px,calc((100vw - var(--max-width)) / 2 + 16px));width:32px;height:32px;border-radius:50%;background:var(--color-stone);display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;color:var(--color-earth);transition:background .2s,color .2s;z-index:100}.info-icon:hover{background:var(--color-earth);color:var(--color-cream)}.info-icon-enter{animation:iconPop .4s cubic-bezier(.34,1.56,.64,1) both}.lobby-state-indicator{display:inline-block;padding:var(--space-sm) var(--space-md);background:var(--color-accent);color:var(--color-cream);border-radius:16px;font-size:var(--font-size-sm);font-weight:500;text-align:center;margin-bottom:var(--space-md)}.lobby-hero-cta{width:100%;padding:var(--space-md) var(--space-lg);background:var(--color-accent);color:var(--color-cream);border:none;border-radius:var(--radius);font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:500;cursor:pointer;transition:background .2s,transform .2s;text-align:center}.lobby-hero-cta:hover{background:var(--color-earth);transform:translateY(-2px)}.lobby-countdown-display{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-lg);background:var(--color-sand);border-radius:var(--radius);width:100%;margin-bottom:var(--space-md)}.lobby-countdown-label{font-size:var(--font-size-sm);color:var(--color-earth)}.lobby-countdown-time{font-family:var(--font-display);font-size:var(--font-size-3xl);font-weight:500;color:var(--color-charcoal);font-variant-numeric:tabular-nums}.lobby-section{width:100%;display:flex;flex-direction:column;gap:var(--space-sm)}.lobby-section-title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:500;color:var(--color-deep)}.lobby-description{color:var(--color-earth);font-size:var(--font-size-sm);line-height:1.6}.lobby-section-divider{width:100%;height:1px;background:var(--color-stone);margin:var(--space-md) 0}.lobby-notice-highlight{padding:var(--space-md);background:#b8956a1f;border:1px solid var(--color-accent);border-radius:var(--radius);width:100%}.lobby-notice-highlight p{color:var(--color-charcoal);font-size:var(--font-size-sm);line-height:1.5;text-align:center}.star-rating{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-top:var(--space-sm)}.star-rating .star{width:32px;height:32px;cursor:pointer;transition:transform .15s ease,fill .15s ease;stroke:var(--color-earth);fill:none}.star-rating .star:hover{transform:scale(1.1);fill:var(--color-accent)}.star-rating .star.active{fill:var(--color-accent);stroke:var(--color-accent)}.lobby-focus-gate{width:100%;display:flex;flex-direction:column;gap:var(--space-sm)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-12px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes iconPop{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}@keyframes gentleFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:.45;transform:scale(1)}}@keyframes bubbleDrift1{0%,to{transform:translate(0)}25%{transform:translate(4px,-6px)}50%{transform:translate(-3px,-10px)}75%{transform:translate(5px,-4px)}}@keyframes bubbleDrift2{0%,to{transform:translate(0)}25%{transform:translate(-5px,-4px)}50%{transform:translate(6px,-8px)}75%{transform:translate(-2px,-5px)}}@keyframes bubbleDrift3{0%,to{transform:translate(0)}25%{transform:translate(3px,-8px)}50%{transform:translate(-6px,-5px)}75%{transform:translate(4px,-9px)}}@keyframes bubbleDrift4{0%,to{transform:translate(0)}25%{transform:translate(-4px,-7px)}50%{transform:translate(5px,-3px)}75%{transform:translate(-3px,-8px)}}
