.p-mobile{display:flex;flex-direction:column;min-height:0;background:#f1f5f9;color:#0f172a;overflow:hidden;box-sizing:border-box}.p-mobile *,.p-mobile *:before,.p-mobile *:after{box-sizing:border-box}.p-mobile__header{flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px 14px 10px;background:linear-gradient(180deg,#0f172a,#1e293b);color:#f8fafc;border-bottom:1px solid rgba(255,255,255,.08)}.p-mobile__header-main{flex:1;min-width:0}.p-mobile__live{display:inline-flex;align-items:center;gap:6px;margin-bottom:4px;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#94a3b8}.p-mobile__live-dot{width:7px;height:7px;border-radius:50%;background:#64748b}.p-mobile__live-dot--on{background:#4ade80;box-shadow:0 0 0 3px #4ade8040}.p-mobile__header .p-mobile__title{margin:0 0 6px;font-size:1.05rem;font-weight:800;line-height:1.25;letter-spacing:-.02em;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.p-mobile__meta{display:flex;flex-wrap:wrap;gap:6px 12px;font-size:12px;font-weight:600;color:#94a3b8}.p-mobile__meta code{font-family:ui-monospace,monospace;font-size:11px;font-weight:700;letter-spacing:.12em;color:#c7d2fe;background:none}.p-mobile__menu-btn{flex-shrink:0;display:grid;place-items:center;width:40px;height:40px;border:1px solid rgba(255,255,255,.15);border-radius:10px;background:#ffffff14;color:#e2e8f0;cursor:pointer}.p-mobile__toolbar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;background:#fff;border-bottom:1px solid #e2e8f0}.p-mobile__toolbar h2{display:inline-flex;align-items:center;gap:6px;margin:0;font-size:13px;font-weight:800;color:#0f172a}.p-mobile__toolbar-count{font-size:12px;font-weight:700;color:#64748b}.p-mobile__scroll{flex:1;min-height:0;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 14px 12px}.p-mobile__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:140px;padding:24px 16px}.p-mobile__empty-icon{display:grid;place-items:center;width:56px;height:56px;margin-bottom:14px;border-radius:16px;background:#eef2ff;color:#4f46e5}.p-mobile__empty h3{margin:0 0 6px;font-size:1rem;font-weight:800}.p-mobile__empty p{margin:0;max-width:260px;font-size:14px;line-height:1.5;color:#64748b}.p-mobile__cards{list-style:none;margin:0;padding:0;display:grid;gap:12px}.p-mobile__card{display:flex;gap:0;border-radius:16px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0f172a0d;overflow:hidden}.p-mobile__card--mine{border-color:#a5b4fc;box-shadow:0 4px 14px #4f46e51f}.p-mobile__card-rail{flex-shrink:0;display:flex;align-items:flex-start;justify-content:center;width:44px;padding:14px 0 12px;background:linear-gradient(180deg,#eef2ff,#e0e7ff);border-right:1px solid #e2e8f0}.p-mobile__card--mine .p-mobile__card-rail{background:linear-gradient(180deg,#4f46e5,#6366f1);border-right-color:transparent}.p-mobile__card-rank{font-size:12px;font-weight:800;letter-spacing:-.02em;color:#4f46e5}.p-mobile__card--mine .p-mobile__card-rank{color:#fff}.p-mobile__card-body{flex:1;min-width:0;padding:12px 14px 12px 12px}.p-mobile__card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}.p-mobile__card-labels{display:flex;flex-wrap:wrap;align-items:center;gap:6px;min-width:0}.p-mobile__card-badge{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:999px;background:#4f46e5;color:#fff}.p-mobile__card-status{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:3px 8px;border-radius:999px;background:#f1f5f9;color:#64748b}.p-mobile__card-votes{flex-shrink:0;display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:999px;font-size:13px;font-weight:800;font-family:inherit;color:#4f46e5;background:#eef2ff;border:1px solid #c7d2fe;cursor:pointer;transition:background .15s ease,transform .1s ease}.p-mobile__card-votes:active:not(:disabled){transform:scale(.96)}.p-mobile__card-votes:disabled{cursor:default}.p-mobile__card-votes--voted{color:#fff;background:#4f46e5;border-color:#4f46e5}.p-mobile__card-text{margin:0 0 10px;font-size:15px;font-weight:600;line-height:1.5;color:#0f172a;word-break:break-word}.p-mobile__card-author{margin:0;font-size:12px;font-weight:600;color:#64748b}.p-mobile__pager{margin:10px 0 14px;padding:12px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 1px 3px #0f172a0a}.p-mobile .question-pager--mobile{flex-direction:row;align-items:center;justify-content:space-between;gap:12px}.p-mobile .question-pager--mobile .question-pager__summary{margin:0;font-size:13px;font-weight:600;color:#64748b;text-align:left;line-height:1.4}.p-mobile .question-pager--mobile .question-pager__summary strong{color:#0f172a;font-weight:800}.p-mobile .question-pager--mobile .question-pager__controls{flex-shrink:0;gap:4px}.p-mobile .question-pager--mobile .question-pager__btn{min-width:64px;height:34px;font-size:12px;border-radius:10px}.p-mobile .question-pager--mobile .question-pager__page{min-width:48px;height:34px;font-size:11px;border-radius:10px;background:#f8fafc}.p-mobile__banner{flex-shrink:0;display:flex;align-items:center;gap:8px;margin:0 14px 8px;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:600}.p-mobile__banner--success{background:#ecfdf5;color:#047857}.p-mobile__banner--error{background:#fef2f2;color:#b91c1c}.p-mobile__dock{flex-shrink:0;padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px));background:#fff;border-top:1px solid #e2e8f0;box-shadow:0 -4px 20px #0f172a14}.p-mobile--keyboard .p-mobile__dock{padding-top:8px;padding-bottom:8px;box-shadow:0 -2px 12px #0f172a0f}.p-mobile__form{margin:0}.p-mobile__input-row{display:flex;align-items:stretch;gap:8px}.p-mobile__input{flex:1;min-width:0;height:48px;padding:0 14px;font-family:inherit;font-size:16px;font-weight:500;color:#0f172a;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px}.p-mobile__input:focus{outline:none;border-color:#4f46e5;background:#fff;box-shadow:0 0 0 3px #4f46e526}.p-mobile__send{flex-shrink:0;display:grid;place-items:center;width:48px;height:48px;border:none;border-radius:12px;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;cursor:pointer}.p-mobile__send:disabled{opacity:.45;cursor:not-allowed}.p-mobile__dock-note{margin:8px 0 0;font-size:12px;line-height:1.4;text-align:left;color:#94a3b8}.p-mobile--keyboard .p-mobile__dock-note{display:none}.p-mobile__overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:40;background:#0f172a73}.p-mobile__sheet{position:absolute;left:0;right:0;bottom:0;z-index:50;padding:8px 12px calc(12px + env(safe-area-inset-bottom,0px));border-radius:16px 16px 0 0;background:#fff;box-shadow:0 -12px 40px #0f172a33}.p-mobile__sheet button,.p-mobile__sheet a{display:flex;align-items:center;gap:10px;width:100%;padding:14px 12px;border:none;border-radius:10px;background:none;color:#0f172a;font-size:15px;font-weight:600;text-decoration:none;cursor:pointer;text-align:left}.p-mobile__sheet button:active,.p-mobile__sheet a:active{background:#f1f5f9}.p-mobile__user{display:flex;align-items:center;gap:8px;padding:10px 12px 6px;font-size:13px;font-weight:600;color:#64748b}.p-mobile__user span{color:#0f172a}@media (min-width: 768px){.join-page--session{display:flex;flex-direction:column;align-items:stretch;padding:0;background:#e2e8f0}.join-page--session .join-session-wrap{flex:1;display:flex;flex-direction:column;width:100%;max-width:none;margin:0;padding:20px 24px 24px;min-height:0}.p-event--desktop{flex:1;display:flex;flex-direction:column;min-height:min(88vh,920px);max-width:1200px;width:100%;margin:0 auto;border-radius:16px;overflow:hidden;border:1px solid var(--color-border);box-shadow:0 20px 50px #0f172a1f}.p-event--desktop .p-event__feed{flex:1;min-height:0;border-right:none}.p-event--desktop .p-event__feed-scroll{padding:16px 24px 20px}.p-event--desktop .p-event__feed-head{padding:14px 24px}.p-event--desktop .p-event__dock{flex-shrink:0;width:100%;margin-top:auto;background:#fff;border-top:1px solid var(--color-border);box-shadow:0 -8px 32px #0f172a0f}.p-event--desktop .p-event__dock-inner{width:100%;padding:20px 24px 24px}.p-event--desktop .p-event__dock-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:14px}.p-event--desktop .p-event__dock-title{flex-shrink:0;margin:0;font-size:1rem;font-weight:800;letter-spacing:-.02em;color:var(--color-text);text-transform:none}.p-event--desktop .p-event__dock-sub{margin:0;flex:1;min-width:0;font-size:14px;font-weight:500;line-height:1.45;color:var(--color-text-muted);text-align:right}.p-event--desktop .p-event__dock-form{margin:0;width:100%}.p-event--desktop .p-event__dock-row{display:flex;align-items:stretch;gap:12px;width:100%}.p-event--desktop .p-event__dock-input{flex:1;min-width:0;height:56px;padding:0 18px;font-family:inherit;font-size:16px;font-weight:500;color:var(--color-text);background:#f8fafc;border:2px solid var(--color-border);border-radius:12px;transition:border-color .15s ease,box-shadow .15s ease}.p-event--desktop .p-event__dock-input:focus{outline:none;border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 4px #4f46e51f}.p-event--desktop .p-event__dock-send{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:120px;height:56px;padding:0 22px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--color-primary),#7c3aed);color:#fff;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 4px 16px #4f46e559;transition:transform .12s ease,opacity .12s ease}.p-event--desktop .p-event__dock-send:hover:not(:disabled){transform:translateY(-1px)}.p-event--desktop .p-event__dock-send:disabled{opacity:.45;cursor:not-allowed;transform:none}.p-event--desktop .p-event__toast{margin-bottom:12px}}@media (min-width: 768px) and (max-width: 900px){.p-event--desktop .p-event__dock-head{flex-direction:column;align-items:flex-start;gap:6px}.p-event--desktop .p-event__dock-sub{text-align:left}}.live-board{position:relative;min-height:100vh;min-height:100dvh;padding:20px 24px 28px;color:#0f172a;overflow-x:hidden;background:#fff}.live-board--loading,.live-board--error{display:grid;place-items:center;background:#fff}.live-board__loader{text-align:center;color:#64748b}.live-board__loader-ring{width:48px;height:48px;margin:0 auto 16px;border:3px solid #e2e8f0;border-top-color:#4f46e5;border-radius:50%;animation:live-board-spin .9s linear infinite}@keyframes live-board-spin{to{transform:rotate(360deg)}}.live-board__error{max-width:400px;padding:32px;text-align:center}.live-board__bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:#fff}.live-board__glow{position:fixed;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0;opacity:.5}.live-board__glow--a{width:480px;height:480px;top:-160px;right:-100px;background:#6366f114}.live-board__glow--b{width:400px;height:400px;bottom:-120px;left:-80px;background:#0ea5e90f}.live-board__header,.live-board__layout{position:relative;z-index:1;max-width:1400px;margin:0 auto}.live-board__header{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #e2e8f0}.live-board__brand{display:flex;align-items:flex-start;gap:16px}.live-board__brand .brand-mark{color:#0f172a}.live-board__brand .brand-icon{background:#eef2ff;color:#4f46e5}.live-board__event h1{margin:6px 0 8px;font-size:clamp(1.5rem,3vw,2.25rem);font-weight:800;letter-spacing:-.03em;color:#0f172a;line-height:1.15}.live-board__code{margin:0;font-size:14px;color:#64748b}.live-board__code strong{font-family:ui-monospace,monospace;letter-spacing:.14em;color:#4f46e5}.live-board__live{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:#94a3b8}.live-board__live--on{color:#059669;animation:live-board-pulse 2s ease infinite}@keyframes live-board-pulse{0%,to{opacity:1}50%{opacity:.65}}.live-board__stats{display:flex;flex-wrap:wrap;gap:12px}.live-board__stat{display:flex;align-items:center;gap:12px;padding:12px 18px;border-radius:14px;background:#f8fafc;border:1px solid #e2e8f0;box-shadow:0 1px 2px #0f172a0a}.live-board__stat--accent{background:#eef2ff;border-color:#c7d2fe}.live-board__stat svg{flex-shrink:0;color:#4f46e5}.live-board__stat-value{display:block;font-size:1.5rem;font-weight:800;line-height:1.1;color:#0f172a;letter-spacing:-.03em}.live-board__stat-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.live-board__layout{display:grid;grid-template-columns:1fr 300px;gap:24px;align-items:start}.live-board__main{min-width:0}.live-board__main-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.live-board__main-head h2{display:inline-flex;align-items:center;gap:10px;margin:0;font-size:1.25rem;font-weight:800;color:#0f172a}.live-board__queue-pill{font-size:12px;font-weight:700;padding:6px 14px;border-radius:999px;background:#eef2ff;color:#4338ca;border:1px solid #c7d2fe}.live-board .live-board__pager{margin-bottom:16px;padding:12px 16px;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0}.live-board .live-board__pager .question-pager__summary{color:#64748b}.live-board .live-board__pager .question-pager__summary strong{color:#0f172a}.live-board .live-board__pager .question-pager__btn,.live-board .live-board__pager .question-pager__page{background:#fff;border-color:#e2e8f0;color:#0f172a}.live-board__cards{display:grid;gap:14px}.live-board__empty{text-align:center;padding:48px 24px;border-radius:20px;background:#f8fafc;border:1px dashed #cbd5e1}.live-board__empty-icon{display:grid;place-items:center;width:72px;height:72px;margin:0 auto 16px;border-radius:20px;background:#eef2ff;color:#4f46e5}.live-board__empty h3{margin:0 0 8px;font-size:1.2rem;color:#0f172a}.live-board__empty p{margin:0 auto;max-width:360px;color:#64748b;line-height:1.55}.live-board__card{display:flex;gap:0;border-radius:18px;overflow:hidden;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0f172a0f;animation:live-board-card-in .45s ease backwards;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.live-board__card:hover{transform:translateY(-2px);border-color:#c7d2fe;box-shadow:0 8px 24px #4f46e51f}.live-board__card--featured{border-color:#fcd34d;background:linear-gradient(135deg,#fffbeb,#fff);box-shadow:0 8px 28px #f59e0b26}.live-board__card--new{animation:live-board-card-new .6s ease;border-color:#34d399;box-shadow:0 0 0 2px #34d39959,0 8px 24px #34d3991f}@keyframes live-board-card-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes live-board-card-new{0%{transform:scale(1.02);box-shadow:0 0 0 3px #34d39980}to{transform:scale(1)}}.live-board__card-rank{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:56px;background:#eef2ff;border-right:1px solid #e2e8f0}.live-board__card--featured .live-board__card-rank{background:linear-gradient(180deg,#fbbf24,#f59e0b);border-right-color:transparent}.live-board__card-rank span{font-size:1.1rem;font-weight:800;color:#4f46e5}.live-board__card--featured .live-board__card-rank span{color:#fff}.live-board__card-body{flex:1;min-width:0;padding:16px 18px 14px}.live-board__card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px}.live-board__status{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:3px 10px;border-radius:999px}.live-board__status--top{background:#fef3c7;color:#b45309}.live-board__status--review{background:#e0f2fe;color:#0369a1}.live-board__status--queued{background:#f1f5f9;color:#475569}.live-board__author{font-size:13px;font-weight:600;color:#64748b}.live-board__question{margin:0 0 14px;font-size:clamp(1.05rem,2vw,1.35rem);font-weight:600;line-height:1.45;color:#0f172a}.live-board__votes{position:relative;display:inline-flex;align-items:center;gap:6px;padding:6px 14px 6px 10px;border-radius:999px;background:#eef2ff;border:1px solid #c7d2fe;color:#4338ca;font-size:15px;font-weight:800;overflow:hidden}.live-board__vote-bar{position:absolute;left:0;top:0;bottom:0;background:#4f46e51f;border-radius:999px;z-index:0;transition:width .4s ease}.live-board__votes svg,.live-board__votes span{position:relative;z-index:1}.live-board__aside{position:sticky;top:20px}.live-board__join{padding:22px 20px;text-align:center;background:#f8fafc!important;border:1px solid #e2e8f0!important;color:#0f172a;box-shadow:0 2px 8px #0f172a0a}.live-board__join h3{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin:0 0 8px;font-size:1rem;color:#0f172a}.live-board__join p{margin:0 0 16px;font-size:13px;color:#64748b;line-height:1.5}.live-board__qr{display:inline-block;padding:12px;border-radius:16px;background:#fff;border:1px solid #e2e8f0;margin-bottom:12px}.live-board__join-url{display:block;margin-bottom:14px;padding:8px 10px;font-size:10px;word-break:break-all;border-radius:8px;background:#fff;border:1px solid #e2e8f0;color:#475569}.live-board__join-btn{display:inline-block;padding:10px 18px;border-radius:10px;font-size:14px;font-weight:700;text-decoration:none;color:#fff;background:linear-gradient(135deg,#4f46e5,#6366f1)}.live-board__credit{margin:14px 0 0;text-align:center;font-size:11px;color:#94a3b8}.live-board--paused .live-board__live{color:#dc2626}@media (max-width: 960px){.live-board__layout{grid-template-columns:1fr}.live-board__aside{position:static;order:-1}.live-board__join{display:grid;grid-template-columns:auto 1fr;grid-template-areas:"title title" "desc desc" "qr url" "btn btn";gap:12px 16px;text-align:left}.live-board__join h3{grid-area:title;justify-content:flex-start}.live-board__join p{grid-area:desc;margin:0}.live-board__qr{grid-area:qr;margin:0}.live-board__join-url{grid-area:url;align-self:center;margin:0}.live-board__join-btn{grid-area:btn;text-align:center}}@media (max-width: 640px){.live-board{padding:14px 14px 24px}.live-board__header{flex-direction:column;align-items:stretch}.live-board__stats{display:grid;grid-template-columns:repeat(3,1fr)}.live-board__stat{flex-direction:column;align-items:flex-start;gap:6px;padding:10px 12px}.live-board__stat-value{font-size:1.25rem}}:root{--font-sans: "Plus Jakarta Sans", "Manrope", "Segoe UI", sans-serif;--color-bg: #f4f6fb;--color-surface: #ffffff;--color-surface-elevated: #ffffff;--color-border: #e2e8f0;--color-border-subtle: #f1f5f9;--color-text: #0f172a;--color-text-secondary: #475569;--color-text-muted: #64748b;--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-primary-soft: #eef2ff;--color-primary-muted: #c7d2fe;--color-accent: #0ea5e9;--color-success: #059669;--color-error: #dc2626;--color-error-soft: #fef2f2;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow-md: 0 4px 16px rgba(15, 23, 42, .06);--shadow-lg: 0 12px 40px rgba(15, 23, 42, .08);--shadow-xl: 0 24px 64px rgba(79, 70, 229, .12);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 24px;--nav-height: 64px}*{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}html{-webkit-text-size-adjust:100%}#root{min-height:100dvh;min-height:var(--app-vh, 100dvh)}body.join-session-active{overflow:hidden;position:fixed;width:100%;height:100%;height:var(--app-vh, 100dvh)}.brand-mark{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--color-text);font-weight:800;letter-spacing:-.02em}.brand-mark--sm .brand-text{font-size:1rem}.brand-mark--md .brand-text{font-size:1.15rem}.brand-icon{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(135deg,var(--color-primary),#6366f1);color:#fff;box-shadow:0 4px 14px #4f46e559}.brand-mark--sm .brand-icon{width:32px;height:32px;border-radius:9px}.app-shell{max-width:1120px;margin:0 auto;padding:24px 20px 32px;display:grid;gap:20px}.site-nav{position:sticky;top:0;z-index:50;height:var(--nav-height);display:flex;align-items:center;justify-content:space-between;padding:0 20px;margin:0 auto;max-width:1120px;background:#f4f6fbd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid transparent}.site-nav--bordered{border-bottom-color:var(--color-border-subtle)}.card{border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-md)}.card--flat{box-shadow:var(--shadow-sm)}.eyebrow{margin:0 0 6px;color:var(--color-primary);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}h1,h2,h3{margin:0;color:var(--color-text);letter-spacing:-.025em}h1{font-size:clamp(1.75rem,3vw,2.35rem);font-weight:800;line-height:1.15}h2{font-size:1.125rem;font-weight:700}.subtext{margin:10px 0 0;color:var(--color-text-secondary);font-size:.95rem;max-width:52ch;line-height:1.6}.primary-btn,.secondary-btn,.ghost-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-sm);font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;text-decoration:none;border:none}.primary-btn{padding:12px 20px;background:linear-gradient(135deg,var(--color-primary) 0%,#6366f1 100%);color:#fff;box-shadow:0 4px 14px #4f46e559}.primary-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #4f46e566}.primary-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.secondary-btn{padding:10px 16px;background:var(--color-surface);color:var(--color-primary);border:1px solid var(--color-primary-muted)}.secondary-btn:hover{background:var(--color-primary-soft)}.ghost-btn{padding:10px 14px;background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.ghost-btn:hover{background:var(--color-border-subtle)}label{display:grid;gap:8px;font-size:13px;font-weight:600;color:var(--color-text)}input,textarea{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:12px 14px;font:inherit;font-size:15px;color:var(--color-text);background:var(--color-surface);transition:border-color .15s ease,box-shadow .15s ease}input::placeholder,textarea::placeholder{color:#94a3b8}input:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e526}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;padding:28px 32px}.page-header--hero{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.page-header__actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.meta-pill{display:inline-flex;align-items:center;font-size:12px;font-weight:600;color:#3730a3;background:var(--color-primary-soft);border:1px solid var(--color-primary-muted);border-radius:999px;padding:6px 12px}.hero-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.stat-card{padding:20px;transition:transform .15s ease,box-shadow .15s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-icon-wrap{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--color-primary-soft);color:var(--color-primary);margin-bottom:12px}.stat-label{display:block;color:var(--color-text-muted);font-size:13px;font-weight:600}.stat-value{font-size:1.75rem;font-weight:800;letter-spacing:-.03em}.accent-blue{color:#1d4ed8}.accent-purple{color:#7c3aed}.accent-teal{color:#0d9488}.questions-card{padding:24px}.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:12px}.section-actions{display:flex;gap:8px;align-items:center}.pill{font-size:12px;font-weight:700;background:var(--color-primary-soft);color:#4338ca;border-radius:999px;padding:6px 12px}.questions-list{display:grid;gap:12px}.question-row{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;display:flex;justify-content:space-between;gap:16px;align-items:flex-start;background:#fafbfc;transition:border-color .15s ease,box-shadow .15s ease}.question-row:hover{border-color:var(--color-primary-muted);box-shadow:var(--shadow-sm)}.question-content{margin:0;font-weight:600;font-size:15px;color:var(--color-text);line-height:1.45}.question-meta{color:var(--color-text-muted);font-size:13px}.vote-btn,.vote-count{border-radius:var(--radius-sm);font-weight:700;font-size:13px;padding:8px 14px;min-width:52px;text-align:center;flex-shrink:0}.vote-btn{border:1px solid var(--color-primary-muted);color:var(--color-primary);background:var(--color-primary-soft);cursor:pointer}.vote-btn:hover{background:#e0e7ff}.vote-count{border:1px solid var(--color-border);color:var(--color-text-secondary);background:var(--color-surface)}.empty-state{border:1px dashed #cbd5e1;border-radius:var(--radius-md);padding:32px 24px;text-align:center;background:linear-gradient(180deg,#f8fafc,#fff)}.empty-state h3{margin:0 0 8px;font-size:1.05rem}.empty-state p{margin:0 auto;color:var(--color-text-muted);max-width:36ch;font-size:14px}.qr-panel{padding:24px 28px;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:28px;background:linear-gradient(135deg,#fff,#f8fafc)}.qr-wrap{display:grid;justify-items:center;gap:10px;padding:16px;background:#fff;border-radius:var(--radius-md);border:1px solid var(--color-border)}.qr-title{display:inline-flex;align-items:center;gap:6px;font-weight:600;color:var(--color-text-secondary)}.qr-note{margin:0}.landing-page{min-height:100vh}.landing-hero{padding:48px 40px;background:linear-gradient(145deg,#1e1b4b,#312e81 45%,#4338ca);border:none;color:#fff;box-shadow:var(--shadow-xl);position:relative;overflow:hidden}.landing-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 80% 20%,rgba(255,255,255,.12),transparent 45%);pointer-events:none}.landing-hero .eyebrow{color:#a5b4fc}.landing-hero h1,.landing-hero .subtext{color:#fff;position:relative}.landing-hero .subtext{opacity:.9;max-width:48ch}.landing-hero .primary-btn{margin-top:24px;background:#fff;color:var(--color-primary);box-shadow:0 8px 24px #0003}.landing-hero .primary-btn:hover{background:#f8fafc}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.feature-card{padding:24px;display:grid;gap:10px}.feature-card__icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--color-primary-soft);color:var(--color-primary)}.feature-card h3{font-size:1rem}.feature-card p{margin:0;font-size:14px;color:var(--color-text-muted);line-height:1.5}.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-panel-brand{display:flex;flex-direction:column;justify-content:space-between;padding:48px;background:linear-gradient(160deg,#0f172a,#1e1b4b 40%,#312e81);color:#fff}.login-panel-brand .brand-mark,.login-panel-brand .brand-text{color:#fff}.login-panel-brand .app-footer{margin-top:auto;justify-content:flex-start}.login-panel-brand h1{color:#fff;font-size:2rem;margin-top:48px}.login-panel-brand .subtext{color:#cbd5e1;margin-top:12px}.login-features{display:grid;gap:16px;margin-top:auto;padding-top:48px}.login-feature{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:#e2e8f0}.login-feature strong{display:block;color:#fff;margin-bottom:2px}.login-panel-form{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px 32px;background:var(--color-bg)}.login-form-card{width:100%;max-width:400px;padding:36px;border-radius:var(--radius-xl);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.login-form-card h2{font-size:1.5rem;margin:8px 0 6px}.login-form-card .subtext{margin-bottom:24px;font-size:14px}.login-form{display:grid;gap:18px}.error-banner{padding:12px 14px;border-radius:var(--radius-sm);background:var(--color-error-soft);border:1px solid #fecaca;color:var(--color-error);font-size:13px;font-weight:600;margin:0}.admin-layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:#f1f5f9}.admin-sidebar{display:flex;flex-direction:column;gap:28px;padding:28px 20px;background:linear-gradient(180deg,#0f172a,#1e293b);color:#e2e8f0;border-right:1px solid #334155}.admin-sidebar .brand-mark,.admin-sidebar .brand-text{color:#fff}.admin-sidebar .brand-icon{background:#ffffff1f;color:#fff}.admin-sidebar__nav{display:grid;gap:6px}.admin-sidebar__link{display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);color:#cbd5e1;text-decoration:none;font-size:14px;font-weight:600;transition:background .15s ease,color .15s ease}.admin-sidebar__link:hover{background:#ffffff14;color:#fff}.admin-sidebar__link--active{background:#6366f140;color:#fff}.admin-sidebar__footer{margin-top:auto;padding-top:20px;border-top:1px solid #334155}.admin-sidebar__user{margin:0 0 10px;font-size:13px;font-weight:700;color:#f8fafc;text-transform:capitalize}.admin-sidebar__logout{display:inline-flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:1px solid #475569;border-radius:var(--radius-md);background:transparent;color:#e2e8f0;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease}.admin-sidebar__logout:hover{background:#ffffff0f}.admin-main{padding:28px 32px 40px;overflow-x:auto}.admin-main--centered{display:grid;place-items:center;min-height:100vh}.admin-loading{color:var(--color-text-muted);font-weight:600}.admin-topbar{margin-bottom:24px}.admin-topbar__eyebrow{margin:0 0 6px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary)}.admin-topbar h1{margin:0;font-size:1.85rem;letter-spacing:-.03em}.admin-topbar__sub{margin:8px 0 0;color:var(--color-text-muted);font-size:15px;max-width:52ch}.admin-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.admin-stat{display:flex;align-items:center;gap:14px;padding:18px 20px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.admin-stat__icon{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--color-primary-soft);color:var(--color-primary)}.admin-stat--success .admin-stat__icon{background:#ecfdf5;color:#059669}.admin-stat--accent .admin-stat__icon{background:#fef3c7;color:#d97706}.admin-stat__label{display:block;font-size:12px;font-weight:600;color:var(--color-text-muted);margin-bottom:4px}.admin-stat__value{font-size:1.5rem;letter-spacing:-.02em}.admin-panel-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:22px 24px;margin-bottom:20px}.admin-panel-card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.admin-panel-card__head h2{display:inline-flex;align-items:center;gap:8px;margin:0;font-size:1.05rem}.admin-panel-card__meta{font-size:13px;font-weight:600;color:var(--color-text-muted)}.admin-create-form{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end}.admin-create-form__field{display:grid;gap:6px}.admin-create-form__field span{font-size:13px;font-weight:600;color:var(--color-text-muted)}.admin-flash{margin:14px 0 0;padding:10px 14px;border-radius:var(--radius-md);background:#ecfdf5;color:#047857;font-size:13px;font-weight:600}.admin-empty{padding:32px 16px;text-align:center}.admin-empty h3{margin:0 0 8px}.admin-empty p{margin:0;color:var(--color-text-muted)}.admin-table-wrap{overflow-x:auto;margin:0 -8px;padding:0 8px}.admin-table{width:100%;border-collapse:collapse;font-size:14px}.admin-table th{text-align:left;padding:10px 12px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.admin-table td{padding:14px 12px;border-bottom:1px solid var(--color-border-subtle);vertical-align:middle}.admin-table__row--muted td{opacity:.72}.admin-table__title{display:block;font-size:14px}.admin-table__date{display:block;margin-top:2px;font-size:12px;color:var(--color-text-muted);font-weight:500}.admin-code{font-family:ui-monospace,monospace;font-size:12px;padding:4px 8px;border-radius:6px;background:#f1f5f9;border:1px solid var(--color-border-subtle)}.admin-status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700}.admin-status-badge__dot{width:7px;height:7px;border-radius:50%}.admin-status-badge--live{background:#ecfdf5;color:#047857}.admin-status-badge--live .admin-status-badge__dot{background:#10b981}.admin-status-badge--off{background:#fef2f2;color:#b91c1c}.admin-status-badge--off .admin-status-badge__dot{background:#ef4444}.admin-table__actions{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.admin-icon-btn{display:inline-grid;place-items:center;width:34px;height:34px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;color:var(--color-text);cursor:pointer;text-decoration:none;transition:background .15s ease,border-color .15s ease}.admin-icon-btn:hover{background:var(--color-bg-subtle);border-color:var(--color-primary);color:var(--color-primary)}.admin-toggle-btn{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 12px;border-radius:var(--radius-md);font-size:12px;font-weight:700;cursor:pointer;border:1px solid transparent;transition:background .15s ease}.admin-toggle-btn--disable{background:#fff;border-color:#fecaca;color:#b91c1c}.admin-toggle-btn--disable:hover{background:#fef2f2}.admin-toggle-btn--enable{background:#ecfdf5;border-color:#a7f3d0;color:#047857}.admin-toggle-btn--enable:hover{background:#d1fae5}.admin-toggle-btn:disabled{opacity:.6;cursor:not-allowed}.admin-main-footer{margin-top:8px;font-size:12px;font-weight:600;color:var(--color-text-muted)}.event-disabled-banner{margin-bottom:16px;padding:14px 18px;border-radius:var(--radius-md);background:#fef2f2;border:1px solid #fecaca;color:#991b1b;font-size:14px;font-weight:600}.meta-pill--live{background:#ecfdf5;color:#047857;border-color:#a7f3d0}.meta-pill--off{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.status-text{color:var(--color-success);font-size:13px;font-weight:600;margin:12px 0 0}.join-page{position:relative;min-height:100dvh;min-height:var(--app-vh, 100dvh);overflow-x:hidden;background:linear-gradient(165deg,#eef2ff,#f8fafc 45%,#f4f6fb)}.join-page:not(.join-page--session){overflow-y:auto;-webkit-overflow-scrolling:touch}.join-page__glow{position:fixed;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0}.join-page__glow--a{width:420px;height:420px;top:-120px;right:-80px;background:#4f46e52e}.join-page__glow--b{width:360px;height:360px;bottom:-100px;left:-60px;background:#0ea5e91f}.join-header{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;max-width:1120px;margin:0 auto;padding:20px 24px}.join-header__live{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#ecfdf5;color:#047857;font-size:12px;font-weight:700;border:1px solid #a7f3d0}.join-layout{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;max-width:1120px;margin:0 auto;padding:8px 24px 48px}.join-hero{padding:24px 8px 24px 0}.join-hero__badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#ffffffd9;border:1px solid var(--color-border);font-size:12px;font-weight:700;color:var(--color-primary);margin-bottom:20px;box-shadow:var(--shadow-sm)}.join-hero__title{margin:0 0 16px;font-size:clamp(2rem,4vw,2.75rem);line-height:1.12;letter-spacing:-.03em}.join-hero__accent{display:block;background:linear-gradient(135deg,var(--color-primary),#7c3aed);-webkit-background-clip:text;background-clip:text;color:transparent}.join-hero__lead{margin:0 0 28px;font-size:1.05rem;color:var(--color-text-secondary);max-width:38ch;line-height:1.65}.join-hero__features{list-style:none;margin:0;padding:0;display:grid;gap:14px}.join-hero__features li{display:flex;align-items:center;gap:12px;font-size:15px;font-weight:600;color:var(--color-text)}.join-hero__features svg{flex-shrink:0;color:var(--color-primary)}.join-hero__event{margin-top:32px;padding:18px 20px;border-radius:var(--radius-lg);background:#ffffffb3;border:1px solid var(--color-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.join-hero__event-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:6px}.join-hero__event strong{font-size:1.15rem}.join-main{display:flex;flex-direction:column;gap:20px;min-width:0}.join-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:28px 28px 32px}.join-card--loading,.join-card--closed{text-align:center;padding:48px 28px}.join-card--closed h2{margin:12px 0 8px}.join-card__sub{color:var(--color-text-muted);margin:0 0 20px;line-height:1.6}.join-card__icon-muted{color:var(--color-text-muted);opacity:.5}.join-card__cta{display:inline-flex;justify-content:center;width:100%;max-width:280px;margin:8px auto 0}.join-card__head{margin-bottom:20px}.join-card__head h2{margin:0 0 8px;font-size:1.35rem;letter-spacing:-.02em}.join-card__head p{margin:0;color:var(--color-text-muted);font-size:14px;line-height:1.55}.join-stepper{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:22px}.join-stepper__item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;border-radius:var(--radius-md);background:#f8fafc;border:1px solid var(--color-border-subtle);transition:all .2s ease}.join-stepper__item--active{background:var(--color-primary-soft);border-color:var(--color-primary-muted);box-shadow:0 0 0 3px #4f46e51f}.join-stepper__item--done{background:#ecfdf5;border-color:#a7f3d0}.join-stepper__item--done .join-stepper__icon{color:#059669}.join-stepper__icon{display:grid;place-items:center;width:28px;height:28px;border-radius:8px;background:#fff;color:var(--color-text-muted)}.join-stepper__item--active .join-stepper__icon{color:var(--color-primary)}.join-stepper__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);text-align:center}.join-stepper__item--active .join-stepper__label{color:var(--color-primary)}.join-code-badge{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:22px;border-radius:var(--radius-md);background:linear-gradient(135deg,#f8fafc,#eef2ff);border:1px dashed var(--color-primary-muted)}.join-code-badge__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.join-code-badge__value{flex:1;font-family:ui-monospace,Cascadia Code,monospace;font-size:1.1rem;font-weight:800;letter-spacing:.12em;color:var(--color-primary)}.join-code-badge__change{padding:4px 10px;border:none;background:transparent;color:var(--color-primary);font-size:12px;font-weight:700;cursor:pointer;text-decoration:underline;text-underline-offset:3px}.join-form{display:grid;gap:18px}.join-field{display:grid;gap:8px}.join-field>span{font-size:13px;font-weight:700;color:var(--color-text-secondary)}.join-code-input-wrap,.join-input-wrap{position:relative;display:flex;align-items:center}.join-code-input-wrap__icon,.join-input-wrap__icon{position:absolute;left:14px;color:var(--color-text-muted);pointer-events:none}.join-code-input{width:100%;padding:16px 16px 16px 44px;font-family:ui-monospace,monospace;font-size:1.25rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;border:2px solid var(--color-border);border-radius:var(--radius-md);background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.join-code-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #4f46e526}.join-input-wrap input{width:100%;padding:14px 14px 14px 44px;font-size:16px;scroll-margin-bottom:120px}.join-code-input{scroll-margin-bottom:120px}.join-textarea{width:100%;min-height:120px;padding:14px 16px;font-family:inherit;font-size:15px;line-height:1.5;border:2px solid var(--color-border);border-radius:var(--radius-md);resize:vertical;transition:border-color .15s ease,box-shadow .15s ease}.join-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #4f46e526}.join-submit{width:100%;padding:14px 20px;font-size:15px;justify-content:center}.join-change-name{display:inline-block;margin:-8px 0 12px;padding:0;border:none;background:none;color:var(--color-primary);font-size:13px;font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:3px}.join-board-link{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:16px;padding:12px;border-radius:var(--radius-md);background:#f8fafc;border:1px solid var(--color-border);color:var(--color-text);font-size:14px;font-weight:600;text-decoration:none;transition:background .15s ease,border-color .15s ease}.join-board-link:hover{background:var(--color-primary-soft);border-color:var(--color-primary-muted);color:var(--color-primary)}.join-flash{display:flex;align-items:flex-start;gap:10px;margin:18px 0 0;padding:12px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:600;line-height:1.45}.join-flash--success{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}.join-flash--error{background:var(--color-error-soft);color:var(--color-error);border:1px solid #fecaca}.join-flash--info{background:var(--color-primary-soft);color:var(--color-primary-hover);border:1px solid var(--color-primary-muted)}.join-spinner{width:40px;height:40px;margin:0 auto 16px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.join-footer{text-align:center;padding-bottom:8px}.join-footer .company-credit{justify-content:center}.join-page--session{position:fixed;top:0;left:0;right:0;width:100%;height:var(--app-vh, 100dvh);max-height:var(--app-vh, 100dvh);min-height:0;display:flex;flex-direction:column;background:#f1f5f9;overflow:hidden;overscroll-behavior:none}body.keyboard-open.join-session-active .join-page--session{top:var(--vv-top, 0);height:var(--app-vh, 100dvh);max-height:var(--app-vh, 100dvh);overflow:hidden;touch-action:none}body.keyboard-open.join-session-active .join-header{display:none}.join-page--session .join-header{flex-shrink:0;background:#fff;border-bottom:1px solid var(--color-border);max-width:none;margin:0}.join-page--session .join-page__glow{display:none}.join-session-wrap{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;min-height:0;width:100%;max-width:640px;margin:0 auto;padding:0}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.p-event{flex:1;display:flex;flex-direction:column;min-height:0;background:#fff;border-radius:0;box-shadow:none;overflow:hidden}.p-event__bar{flex-shrink:0;background:#0f172a;color:#f8fafc;border-bottom:1px solid #1e293b}.p-event__bar-top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:#1e293b;border-bottom:1px solid rgba(255,255,255,.06)}.p-event__bar-body{padding:18px 16px 20px}.p-event__bar h1,.p-event__bar .p-event__name{color:#fff;font-size:1.3rem;font-weight:800;letter-spacing:-.02em;line-height:1.3}.p-event__live-pill{display:inline-flex;align-items:center;gap:6px;padding:0;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8}.p-event__dot{width:8px;height:8px;border-radius:50%;background:#94a3b8}.p-event__dot--on{background:#4ade80;box-shadow:0 0 8px #4ade80;animation:p-event-pulse 1.5s ease infinite}@keyframes p-event-pulse{0%,to{opacity:1}50%{opacity:.5}}.p-event__name{margin:0 0 8px}.p-event__code-line{margin:0;font-size:13px;font-weight:500;color:#94a3b8}.p-event__code-line strong{font-family:ui-monospace,monospace;font-size:14px;font-weight:700;letter-spacing:.14em;color:#c7d2fe}.p-event__audience{font-weight:600;color:#94a3b8}html.join-session-active,body.join-session-active,html.p-mobile-active,body.p-mobile-active{overflow:hidden;overscroll-behavior:none;height:100%}.p-event__bar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.p-event__user-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:6px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);font-size:12px;font-weight:600;color:#e2e8f0;max-width:130px}.p-event__user-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.p-event__menu-wrap{position:relative}.p-event__menu-btn{display:grid;place-items:center;width:36px;height:36px;border:1px solid rgba(255,255,255,.12);border-radius:6px;background:#ffffff0f;color:#e2e8f0;cursor:pointer}.p-event__menu{position:absolute;top:calc(100% + 6px);right:0;z-index:20;min-width:180px;padding:6px;border-radius:var(--radius-md);background:#fff;border:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.p-event__menu button,.p-event__menu a{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:none;border-radius:8px;background:none;color:var(--color-text);font-size:13px;font-weight:600;text-decoration:none;cursor:pointer;text-align:left}.p-event__menu button:hover,.p-event__menu a:hover{background:var(--color-primary-soft);color:var(--color-primary)}.p-event__feed{flex:1;display:flex;flex-direction:column;min-height:0;background:#f8fafc}.p-event__feed-head{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border-subtle);background:#fff}.p-event__feed-head h2{display:inline-flex;align-items:center;gap:8px;margin:0;font-size:14px;font-weight:800;color:var(--color-text)}.p-event__count{font-size:12px;font-weight:700;color:var(--color-text-muted)}.p-event__feed-scroll{flex:1;overflow-y:auto;padding:12px 14px 16px;-webkit-overflow-scrolling:touch}.p-event__empty{text-align:center;padding:40px 20px}.p-event__empty-icon{display:grid;place-items:center;width:64px;height:64px;margin:0 auto 16px;border-radius:20px;background:var(--color-primary-soft);color:var(--color-primary)}.p-event__empty h3{margin:0 0 8px;font-size:1.1rem}.p-event__empty p{margin:0;font-size:14px;color:var(--color-text-muted);line-height:1.55}.p-event__list{list-style:none;margin:0;padding:0;display:grid;gap:10px}.p-event__item{padding:14px 16px;border-radius:var(--radius-md);background:#fff;border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm)}.p-event__item--mine{border-color:var(--color-primary-muted);background:linear-gradient(135deg,#fafbff,#eef2ff);box-shadow:0 2px 12px #4f46e51a}.p-event__item-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}.p-event__item-rank{font-size:11px;font-weight:800;color:var(--color-primary)}.p-event__item-badge{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:999px;background:var(--color-primary);color:#fff}.p-event__item-votes{margin-left:auto;display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:800;color:var(--color-primary)}.p-event__vote-btn{margin-left:auto;display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:999px;font-family:inherit;font-size:13px;font-weight:800;color:var(--color-primary);background:var(--color-primary-soft);border:1px solid var(--color-primary-muted);cursor:pointer;transition:background .15s ease,color .15s ease,transform .1s ease}.p-event__vote-btn:hover:not(:disabled){background:#e0e7ff;border-color:var(--color-primary)}.p-event__vote-btn:disabled{cursor:default}.p-event__vote-btn--voted{color:#fff;background:var(--color-primary);border-color:var(--color-primary)}.p-event__item-text{margin:0 0 8px;font-size:15px;font-weight:600;line-height:1.5;color:var(--color-text)}.p-event__item-meta{margin:0;font-size:12px;font-weight:600;color:var(--color-text-muted)}.p-event__composer{flex-shrink:0;padding:12px 14px calc(12px + env(safe-area-inset-bottom,0px));background:#fff;border-top:1px solid var(--color-border);box-shadow:0 -4px 24px #0f172a0f;position:relative;z-index:2}.p-event__toast{display:flex;align-items:center;gap:8px;margin:0 0 10px;padding:10px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:600}.p-event__toast--success{background:#ecfdf5;color:#047857}.p-event__toast--error{background:var(--color-error-soft);color:var(--color-error)}.p-event__form{margin:0}.p-event__composer-label{display:block;margin:0 0 8px;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-muted)}.p-event__composer-hint{margin:0 0 10px;font-size:13px;line-height:1.45;color:var(--color-text-muted)}.p-event__composer-field{display:flex;align-items:center;gap:8px;padding:6px 6px 6px 14px;border:2px solid var(--color-border);border-radius:999px;background:#f8fafc;transition:border-color .15s ease,box-shadow .15s ease}.p-event__composer-field:focus-within{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 4px #4f46e51f}.p-event__input{flex:1;min-width:0;min-height:44px;padding:10px 0;font-family:inherit;font-size:16px;line-height:1.45;border:none;border-radius:0;background:transparent}.p-event__input:focus{outline:none;box-shadow:none}.p-event__send{flex-shrink:0;display:grid;place-items:center;width:44px;height:44px;border:none;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#7c3aed);color:#fff;cursor:pointer;box-shadow:0 4px 14px #4f46e559;transition:transform .12s ease,opacity .12s ease}.p-event__send:hover:not(:disabled){transform:scale(1.04)}.p-event__send:disabled{opacity:.45;cursor:not-allowed;transform:none}.p-event__hint{margin:10px 0 0;font-size:11px;font-weight:600;color:var(--color-text-muted);text-align:center}.p-event__pager{flex-shrink:0;margin:0;padding:10px 16px;background:#fff;border-bottom:1px solid var(--color-border-subtle)}.p-event__pager--top{border-top:1px solid var(--color-border-subtle)}.question-pager{display:flex;flex-direction:column;align-items:stretch;gap:10px;width:100%}.question-pager--inset{margin:0 0 16px;padding:12px 16px;background:#f8fafc;border:1px solid var(--color-border);border-radius:var(--radius-md)}.question-pager__summary{margin:0;font-size:12px;font-weight:600;color:var(--color-text-muted);text-align:center;line-height:1.4}.question-pager__summary strong{color:var(--color-text);font-weight:800}.question-pager__controls{display:flex;align-items:center;justify-content:center;gap:6px;width:100%}.question-pager__btn{display:inline-flex;align-items:center;justify-content:center;gap:2px;min-width:72px;height:36px;padding:0 10px;font-family:inherit;font-size:13px;font-weight:700;color:var(--color-text);background:#fff;border:1px solid var(--color-border);border-radius:999px;cursor:pointer;transition:border-color .15s ease,background .15s ease}.question-pager__btn:hover:not(:disabled){border-color:var(--color-primary);background:#f5f3ff}.question-pager__btn:disabled{opacity:.4;cursor:not-allowed}.question-pager__page{display:inline-flex;align-items:center;justify-content:center;min-width:56px;height:36px;padding:0 8px;font-size:12px;font-weight:800;color:var(--color-text);background:#fff;border:1px solid var(--color-border);border-radius:999px}@media (min-width: 480px){.question-pager{flex-direction:row;align-items:center;justify-content:space-between;gap:16px}.question-pager__summary{text-align:left;flex:1;min-width:0}.question-pager__controls{flex:0 0 auto;width:auto;justify-content:flex-end}}@media (min-width: 768px){.p-event__bar h1,.p-event__bar .p-event__name{font-size:1.45rem}}.loading-screen{min-height:60vh;display:grid;place-content:center;justify-items:center;gap:16px;color:var(--color-text-muted);font-weight:600}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.company-credit{display:inline-flex;align-items:center;gap:10px;margin:0;font-size:12px;font-weight:600;letter-spacing:.02em;color:var(--color-text-muted)}.company-credit__text{line-height:1.4}.company-credit__mark{display:inline-flex;align-items:center;flex-shrink:0;line-height:0}.company-credit--on-dark{color:#94a3b8}.wph-logo{display:block;width:auto;height:22px;object-fit:contain}.wph-logo--md{height:28px}.app-footer{display:flex;justify-content:center;padding:12px 0 6px}.marketing-site{min-height:100vh;background:var(--color-bg)}.marketing-nav{position:sticky;top:0;z-index:100;background:#ffffffe6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border-subtle)}.marketing-nav__inner{max-width:1200px;margin:0 auto;padding:0 24px;height:72px;display:flex;align-items:center;justify-content:space-between;gap:24px}.marketing-nav__links{display:flex;gap:28px}.marketing-nav__links a{text-decoration:none;color:var(--color-text-secondary);font-size:14px;font-weight:600;transition:color .15s ease}.marketing-nav__links a:hover{color:var(--color-primary)}.marketing-nav__actions{display:flex;align-items:center;gap:10px}.marketing-btn-lg{padding:14px 22px;font-size:15px}.marketing-hero{position:relative;padding:64px 24px 80px;overflow:hidden;background:linear-gradient(180deg,#f8fafc 0%,var(--color-bg) 100%)}.marketing-hero__glow{position:absolute;top:-120px;right:-80px;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.2),transparent 65%);pointer-events:none}.marketing-hero__inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;position:relative}.marketing-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:var(--color-primary-soft);color:var(--color-primary);font-size:13px;font-weight:700;margin-bottom:20px}.marketing-hero h1{font-size:clamp(2rem,4.5vw,3.25rem);line-height:1.1;margin-bottom:20px}.marketing-gradient-text{background:linear-gradient(135deg,var(--color-primary),#7c3aed);-webkit-background-clip:text;background-clip:text;color:transparent}.marketing-hero__lead{font-size:1.1rem;color:var(--color-text-secondary);line-height:1.65;max-width:48ch;margin:0 0 28px}.marketing-hero__cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:28px}.marketing-hero__checks{list-style:none;margin:0;padding:0;display:grid;gap:10px}.marketing-hero__checks li{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--color-text-secondary)}.marketing-hero__checks svg{color:var(--color-success);flex-shrink:0}.marketing-hero__visual{position:relative;min-height:380px}.marketing-mockup--back{position:absolute;top:24px;right:-20px;bottom:-20px;left:40px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#c7d2fe,#a5b4fc);opacity:.5}.marketing-mockup--front{position:relative;padding:20px;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl)}.marketing-mockup__header{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:12px;font-weight:700;color:var(--color-text-muted)}.marketing-mockup__dot{width:8px;height:8px;border-radius:50%;background:#e2e8f0}.marketing-mockup__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}.marketing-mockup__stats div{padding:12px;border-radius:var(--radius-sm);background:#f8fafc;border:1px solid var(--color-border)}.marketing-mockup__stats strong{display:block;font-size:1.25rem;color:var(--color-text)}.marketing-mockup__stats span{font-size:11px;color:var(--color-text-muted);font-weight:600}.marketing-mockup__questions{display:grid;gap:8px}.marketing-mockup__q{padding:12px;border-radius:var(--radius-sm);background:#fafbfc;border:1px solid var(--color-border)}.marketing-mockup__q p{margin:0 0 6px;font-size:13px;font-weight:600;color:var(--color-text)}.marketing-mockup__q span{font-size:11px;color:var(--color-primary);font-weight:700}.marketing-mockup__q--dim{opacity:.65}.marketing-stats{padding:0 24px;margin-top:-32px;position:relative;z-index:2}.marketing-stats__inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:24px 28px;background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.marketing-stats__inner>div{display:grid;gap:4px;text-align:center}.marketing-stats__inner svg{margin:0 auto 4px;color:var(--color-primary)}.marketing-stats__inner strong{font-size:15px;color:var(--color-text)}.marketing-stats__inner span{font-size:12px;color:var(--color-text-muted)}.marketing-section{padding:80px 24px}.marketing-section--alt{background:linear-gradient(180deg,#fff,#f8fafc)}.marketing-section__inner{max-width:1200px;margin:0 auto}.marketing-section__head{max-width:640px;margin-bottom:48px}.marketing-section__head--center{margin-left:auto;margin-right:auto;text-align:center}.marketing-section__head h2{font-size:clamp(1.75rem,3vw,2.25rem);margin:8px 0 16px}.marketing-section__lead{margin:0;font-size:1.05rem;color:var(--color-text-secondary);line-height:1.65;max-width:56ch}.marketing-section__head--center .marketing-section__lead{margin-left:auto;margin-right:auto}.marketing-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.marketing-feature-card{padding:28px;transition:transform .2s ease,box-shadow .2s ease}.marketing-feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.marketing-feature-card__icon{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;background:var(--color-primary-soft);color:var(--color-primary);margin-bottom:16px}.marketing-feature-card h3{font-size:1.05rem;margin-bottom:8px}.marketing-feature-card p{margin:0;font-size:14px;color:var(--color-text-muted);line-height:1.55}.marketing-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.marketing-step-card{padding:32px 28px;position:relative}.marketing-step-card__num{display:inline-block;font-size:2.5rem;font-weight:800;color:var(--color-primary-muted);line-height:1;margin-bottom:12px}.marketing-step-card h3{font-size:1.15rem;margin-bottom:10px}.marketing-step-card p{margin:0;font-size:14px;color:var(--color-text-muted);line-height:1.55}.marketing-use-cases{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.marketing-use-card{padding:32px;text-align:center}.marketing-use-card__icon{width:56px;height:56px;margin:0 auto 16px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--color-primary-soft),#e0e7ff);color:var(--color-primary)}.marketing-use-card h3{margin-bottom:10px}.marketing-use-card p{margin:0;font-size:14px;color:var(--color-text-muted);line-height:1.55}.marketing-cta{padding:0 24px 80px}.marketing-cta__inner{max-width:1200px;margin:0 auto;padding:48px 56px;display:flex;justify-content:space-between;align-items:center;gap:32px;background:linear-gradient(135deg,#1e1b4b,#4338ca);border:none;color:#fff;box-shadow:var(--shadow-xl)}.marketing-cta__inner h2{color:#fff;font-size:1.75rem;margin-bottom:10px}.marketing-cta__inner p{margin:0;color:#c7d2fe;font-size:1rem;max-width:42ch}.marketing-cta__inner .primary-btn{background:#fff;color:var(--color-primary);flex-shrink:0;box-shadow:0 8px 24px #0003}.marketing-footer{background:#0f172a;color:#94a3b8;padding:56px 24px 24px}.marketing-footer .brand-mark,.marketing-footer .brand-text{color:#fff}.marketing-footer__inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid #1e293b}.marketing-footer__tagline{margin:16px 0 0;font-size:14px;line-height:1.6;max-width:36ch}.marketing-footer__cols{display:grid;grid-template-columns:1fr 1fr;gap:32px}.marketing-footer__cols h4{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.06em;margin:0 0 14px}.marketing-footer__cols a{display:block;color:#94a3b8;text-decoration:none;font-size:14px;margin-bottom:10px;font-weight:500}.marketing-footer__cols a:hover{color:#fff}.marketing-footer__bottom{max-width:1200px;margin:24px auto 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:13px;font-weight:600}.marketing-footer__copy{color:#64748b}@media (max-width: 1024px){.join-layout{grid-template-columns:1fr;gap:24px;padding:0 20px 40px}.join-hero{padding:0 0 8px;text-align:center}.join-hero__lead{margin-left:auto;margin-right:auto}.join-hero__features{max-width:360px;margin:0 auto;text-align:left}.join-hero__event{max-width:400px;margin:24px auto 0;text-align:left}.marketing-nav__links{display:none}.marketing-hero__inner{grid-template-columns:1fr;text-align:center}.marketing-hero__lead{margin-left:auto;margin-right:auto}.marketing-hero__cta{justify-content:center}.marketing-hero__checks{justify-items:center}.marketing-hero__visual{max-width:480px;margin:0 auto}.marketing-features-grid,.marketing-steps,.marketing-use-cases,.marketing-stats__inner{grid-template-columns:repeat(2,1fr)}.marketing-cta__inner{flex-direction:column;text-align:center;padding:40px 32px}}@media (max-width: 960px){.login-page{grid-template-columns:1fr}.login-panel-brand{display:none}.admin-layout{grid-template-columns:1fr}.admin-sidebar{flex-direction:row;flex-wrap:wrap;align-items:center;gap:12px;padding:16px}.admin-sidebar__nav{display:flex;flex:1}.admin-sidebar__footer{margin-top:0;padding-top:0;border-top:none;display:flex;align-items:center;gap:8px}.admin-sidebar__user{margin:0}.admin-sidebar__logout{width:auto}.admin-main{padding:20px 16px 32px}.admin-stats-row,.admin-create-form,.feature-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.qr-panel{grid-template-columns:1fr;justify-items:center;text-align:center}.page-header{flex-direction:column;padding:24px}}@media (max-width: 640px){body.keyboard-open .join-layout .join-hero{display:none}body.keyboard-open .join-layout{gap:12px;padding-bottom:16px}body.keyboard-open .join-header{padding:12px 16px}.join-code-input{font-size:16px;letter-spacing:.14em}.join-header{padding:16px}.join-layout{padding:0 16px 32px}.join-card{padding:22px 18px 26px}.join-stepper__label{font-size:9px}.marketing-nav__inner{padding:0 16px;height:64px}.marketing-nav__actions .ghost-btn{display:none}.marketing-hero{padding:40px 16px 56px}.marketing-hero__cta{flex-direction:column}.marketing-hero__cta .primary-btn,.marketing-hero__cta .secondary-btn{width:100%}.marketing-features-grid,.marketing-steps,.marketing-use-cases,.marketing-stats__inner{grid-template-columns:1fr}.marketing-section{padding:56px 16px}.marketing-footer__inner{grid-template-columns:1fr}.marketing-footer__bottom{flex-direction:column;text-align:center}.app-shell{padding:16px 14px 24px}.landing-hero{padding:32px 24px}.stats-grid{grid-template-columns:1fr}.question-row,.event-row{flex-direction:column}.event-row-actions{width:100%}.event-row-actions .secondary-btn{flex:1}.vote-btn,.primary-btn{width:100%}}
