.admin-shell{min-height:100vh;display:grid;grid-template-columns:220px 1fr;background:var(--surface-bg);color:var(--ink-900);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.admin-side{display:flex;flex-direction:column;gap:var(--s-2);padding:var(--s-5) var(--s-4);background:#14161b;color:#e5e7eb}.admin-brand{display:flex;align-items:center;gap:var(--s-2);margin-bottom:var(--s-5);font-weight:900;font-size:var(--text-md);letter-spacing:-.2px}.admin-brand span{width:22px;height:22px;background:var(--brand-gradient);clip-path:polygon(50% 0%,61% 38%,100% 50%,61% 62%,50% 100%,39% 62%,0% 50%,39% 38%)}.admin-nav button{width:100%;display:flex;align-items:center;gap:var(--s-3);padding:10px var(--s-3);border-radius:var(--radius-sm);background:transparent;color:#cdd1da;font-size:var(--text-sm);font-weight:700;text-align:left}.admin-nav button:hover{background:#1f232a;color:#fff}.admin-nav .active{background:#2a2f37;color:#fff}.admin-side .admin-logout{margin-top:auto;padding:10px var(--s-3);color:#8b909b;font-size:var(--text-sm);text-align:left}.admin-side .admin-logout:hover{color:#fff}.admin-main{padding:var(--s-6);overflow-y:auto}.admin-page h1{margin:0 0 var(--s-2);font-size:var(--text-2xl);font-weight:900;letter-spacing:-.4px}.admin-page>p{margin:0 0 var(--s-5);color:var(--ink-500);font-size:var(--text-sm)}.admin-card{padding:var(--s-4) var(--s-5);border:1px solid var(--ink-100);border-radius:var(--radius-md);background:var(--surface);box-shadow:var(--shadow-sm)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--s-3);margin-bottom:var(--s-5)}.kpi-card{padding:var(--s-4);border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--ink-100)}.kpi-card .label{color:var(--ink-500);font-size:var(--text-sm);font-weight:600}.kpi-card .value{margin-top:4px;color:var(--ink-900);font-size:var(--text-2xl);font-weight:900;letter-spacing:-.4px}.kpi-card .sub{margin-top:2px;color:var(--ink-400);font-size:var(--text-xs);font-weight:600}.admin-section h2{margin:var(--s-5) 0 var(--s-3);font-size:var(--text-md);font-weight:800}.admin-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--ink-100);border-radius:var(--radius-md);overflow:hidden}.admin-table th,.admin-table td{padding:10px var(--s-3);border-bottom:1px solid var(--ink-100);font-size:var(--text-sm);text-align:left}.admin-table thead{background:var(--surface-subtle);font-weight:800}.admin-table tbody tr:last-child td{border-bottom:0}.admin-table .right{text-align:right}.admin-table .mono{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12px;color:var(--ink-500)}.btn{display:inline-flex;align-items:center;gap:6px;padding:0 var(--s-3);height:var(--h-btn);border-radius:var(--radius-sm);background:var(--ink-50);color:var(--ink-900);font-size:var(--text-sm);font-weight:700}.btn-primary{background:var(--brand-primary);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{background:transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.row-actions{display:flex;gap:6px}.row-actions .btn{height:28px;padding:0 10px;font-size:12px}.admin-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--s-3)}.login-shell{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#1f1738,#3a1b5a);color:#fff;padding:var(--s-5)}.login-card{width:100%;max-width:360px;padding:28px;border-radius:16px;background:#fffffff7;color:var(--ink-900);box-shadow:0 30px 60px #0000004d}.login-card h1{margin:0 0 6px;font-size:var(--text-xl);font-weight:900}.login-card p{margin:0 0 var(--s-4);color:var(--ink-500);font-size:var(--text-sm)}.field{display:grid;gap:6px;margin-bottom:var(--s-3)}.field label{color:var(--ink-700);font-size:var(--text-sm);font-weight:700}.field input,.field select,.field textarea{height:var(--h-input);padding:0 var(--s-3);border:1px solid var(--ink-200);border-radius:var(--radius-sm);font:inherit;font-size:var(--text-sm);background:#fff;outline:none}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand-primary)}.error-line{color:var(--danger);font-size:var(--text-sm);margin-top:8px}.muted{color:var(--ink-500)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;background:#0f121973}.modal{width:min(100%,460px);padding:var(--s-5);border-radius:var(--radius-lg);background:#fff;box-shadow:0 30px 60px #00000040}.modal h2{margin:0 0 var(--s-3);font-size:var(--text-lg);font-weight:900}.modal-row{display:flex;gap:var(--s-2);justify-content:flex-end;margin-top:var(--s-3)}@media(max-width:720px){.admin-shell{grid-template-columns:1fr}.admin-side{flex-direction:row;padding:var(--s-3)}.admin-nav{display:flex;flex:1;gap:4px}.admin-nav button{width:auto;padding:6px 10px}.admin-side .admin-logout{margin:0;padding:6px 10px}}:root{--brand-primary: #6d28d9;--brand-secondary: #e83ea7;--brand-gold: #ffd34d;--brand-gradient: linear-gradient(135deg, #7b61ff 0%, #e83ea7 55%, #ffd34d 100%);--brand-gradient-flat: linear-gradient(90deg, #45d1df, #e83ea7);--ink-900: #1f2329;--ink-700: #4a4f57;--ink-500: #8d929b;--ink-400: #aaaeb5;--ink-300: #c4c8d1;--ink-200: #dde1e8;--ink-100: #edf0f4;--ink-50: #f6f7f9;--surface: #fff;--surface-subtle: #f6f7f9;--surface-bg: #f8fafc;--surface-tint: #fdf1f9;--success: #16a34a;--danger: #dc2626;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-pill: 999px;--text-xs: 10px;--text-sm: 12px;--text-base: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 26px;--h-topbar: 56px;--h-bottom: 64px;--h-btn: 36px;--h-btn-sm: 28px;--h-btn-lg: 44px;--h-input: 40px;--avatar-sm: 40px;--avatar-md: 48px;--avatar-lg: 64px;--shadow-sm: 0 2px 6px rgba(38, 46, 64, .04);--shadow-md: 0 4px 12px rgba(38, 46, 64, .06);--shadow-lg: 0 12px 28px rgba(38, 46, 64, .1);color:var(--ink-900);background:#eef1f6;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}button{border:0;background:none;color:inherit;font:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent}.app-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.phone-frame{position:relative;width:min(100%,430px);height:min(920px,calc(100vh - 48px));overflow:hidden;border:1px solid #dde1e8;border-radius:28px;background:#fff;box-shadow:0 30px 70px #1e253829}.top-bar,.page-title{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:1px solid #edf0f4;background:#fff}.page-title>button{width:32px;height:32px;display:grid;place-items:center;border-radius:50%}.page-title>button svg{width:20px;height:20px}.page-title>button:active{transform:scale(.96)}.brand-mark{position:relative;width:auto;height:32px;flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;border-radius:999px}.brand-mark span{width:20px;height:20px;background:linear-gradient(135deg,#7b61ff,#e83ea7 55%,#ffd34d);clip-path:polygon(50% 0%,61% 38%,100% 50%,61% 62%,50% 100%,39% 62%,0% 50%,39% 38%);filter:drop-shadow(0 4px 8px rgba(123,97,255,.28))}.brand-mark strong{background:linear-gradient(135deg,#1f2937,#6d28d9 60%,#e83ea7);-webkit-background-clip:text;background-clip:text;color:transparent;font-size:16px;font-weight:900;letter-spacing:-.3px}.top-actions{display:flex;align-items:center;gap:8px;color:#41444a}.top-actions button{width:32px;height:32px;display:grid;place-items:center;border-radius:50%}.top-actions svg{width:18px;height:18px}.top-actions button:active,.quick-actions button:active,.mission-grid button:active,.vote-button:active,.selected-pick button:active{transform:scale(.96)}.screen{height:calc(100% - 120px);overflow-y:auto;overflow-x:hidden;scrollbar-width:none;background:linear-gradient(180deg,#fff,#f8fafc)}.screen::-webkit-scrollbar{display:none}.view{min-height:100%;padding-bottom:26px}.campaign-card img,.mission-thumb img{width:100%;height:100%;object-fit:cover;display:block}.main-banner-carousel{position:relative;overflow:hidden}.main-banner-track{display:flex;transition:transform .5s cubic-bezier(.22,.61,.36,1)}.main-banner-track>.main-banner{flex:0 0 100%;width:100%}.main-banner{position:relative;height:132px;overflow:hidden;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:radial-gradient(circle at 85% 18%,rgba(255,211,77,.7),transparent 14%),radial-gradient(circle at 12% 78%,rgba(232,62,167,.55),transparent 18%),linear-gradient(125deg,#2a0e4a,#6d28d9 45%,#e83ea7);color:#fff;isolation:isolate}.banner-dots{position:absolute;left:50%;bottom:8px;transform:translate(-50%);display:flex;gap:6px;z-index:2}.banner-dots button{width:6px;height:6px;padding:0;border:0;border-radius:50%;background:#ffffff73;cursor:pointer;transition:width .3s ease,background .3s ease}.banner-dots button.active{width:18px;border-radius:999px;background:#fff}.main-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(255,255,255,.7) 1px,transparent 1px),linear-gradient(90deg,transparent 0 52%,rgba(255,255,255,.1) 52% 73%,transparent 73%);background-size:42px 42px,100% 100%;opacity:.55;z-index:-1}.main-banner div{display:grid;gap:2px}.main-banner span{font-size:13px;font-weight:800;letter-spacing:.4px;opacity:.88}.main-banner strong{font-size:22px;font-weight:900;line-height:1;letter-spacing:-.2px}.main-banner p{margin:4px 0 0;font-size:11px;font-weight:700;opacity:.8}.main-banner b{position:relative;z-index:1;color:#ffd34d;font-size:13px;font-weight:900;line-height:1.1;letter-spacing:.2px;text-align:right}.main-banner b:before{content:"";position:absolute;top:-17px;right:0;width:54px;height:26px;background:#f6da4b;clip-path:polygon(0 62%,68% 62%,100% 0,82% 100%,0 100%);z-index:-1;opacity:.95}.main-banner i{position:absolute;right:36px;top:30px;width:10px;height:10px;border-radius:50%;background:#fff;box-shadow:-76px 12px #ffffffbf,-156px 58px #ffffff73,-28px 74px #45d1dfbf}.middle-banners{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;overflow:hidden;padding:16px 18px 12px}.middle-banner{position:relative;min-height:62px;overflow:hidden;border-radius:10px;display:grid;align-content:end;gap:2px;padding:10px 12px;color:#fff;box-shadow:0 6px 14px #272f4112;text-align:left}.middle-banner:before,.middle-banner:after{content:"";position:absolute;border-radius:50%;opacity:.42}.middle-banner:before{width:56px;height:56px;top:-22px;right:-16px;background:#ffffff8c}.middle-banner:after{width:34px;height:34px;right:12px;bottom:10px;border:6px solid rgba(255,255,255,.26)}.middle-banner strong,.middle-banner span{position:relative;z-index:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.middle-banner strong{font-size:11px;font-weight:900}.middle-banner span{font-size:9px;font-weight:700;opacity:.84}.middle-banner.show{background:linear-gradient(135deg,#5f31cef2,#2f267bf2),#4a35bd}.middle-banner.champ{background:linear-gradient(135deg,#e5f5fff5,#ffcfeaf5),#f4fbff;color:#1d9eaf}.middle-banner.special{background:linear-gradient(135deg,#ba9974f0,#563c2deb),#7d5a45}.section-block{padding:12px 18px 18px}.eyebrow{margin:0 0 2px;color:#1f2329;font-size:18px;font-weight:900;letter-spacing:-.2px}.section-block h1{margin:0 0 14px;color:#a4a7ad;font-size:13px;font-weight:600;letter-spacing:-.1px}.mission-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.mission-grid button{aspect-ratio:1;display:grid;place-items:center;gap:6px;border-radius:14px;background:#f6f7f9;color:#4a4f57;font-size:13px;font-weight:800;transition:transform .14s ease,background-color .14s ease}.mission-grid svg{width:26px;height:26px;color:#6785ef;filter:drop-shadow(0 6px 8px rgba(117,146,235,.22))}.page-title h1{margin:0;font-size:18px;font-weight:900;letter-spacing:-.2px}.page-title span{margin-left:4px;color:#e83ea7;font-size:13px}.segmented{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:10px 16px;border-bottom:1px solid #eceff3;background:#fff}.segmented button{height:32px;border-radius:999px;background:#f6f7f9;font-size:12px;font-weight:800;color:#5a5e66}.segmented .active{border-bottom:0;background:#30333a;color:#26292f;color:#fff}.podium{min-height:220px;display:grid;grid-template-columns:repeat(3,1fr);align-items:end;gap:6px;padding:20px 14px 12px;background:radial-gradient(circle at 50% 0%,rgba(69,209,223,.18),transparent 42%),#fafbfc}.podium-item{display:grid;justify-items:center;gap:4px;color:#8e9299}.podium-item span{font-size:18px;font-weight:900;color:#59616d}.podium-item img{width:min(22vw,76px);aspect-ratio:1;object-fit:cover;border:1px solid #edf0f4;border-radius:50%}.podium-item.rank-1{align-self:start;padding-top:8px}.podium-item.rank-1 img{width:min(28vw,104px);border:6px solid #edf0f4;box-shadow:inset 0 0 0 2px #d6bcff}.crown{width:22px;height:22px;color:#c9dfff}.podium-item strong{margin-top:4px;color:#94979d;font-size:13px;font-weight:800}.podium-item small{color:#555b66;font-size:15px;font-weight:900}.chart-list,.rank-section{padding:14px 16px 20px}.list-head,.rank-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;color:#9ea2a9;font-size:12px;font-weight:800}.rank-toolbar button{display:inline-flex;align-items:center;gap:6px}.candidate-row{display:grid;grid-template-columns:52px minmax(0,1fr) 52px;align-items:center;gap:10px;width:100%;padding:10px 12px;margin-bottom:6px;border:1px solid #edf1f6;border-radius:12px;background:#fff;box-shadow:0 4px 12px #262e400a;text-align:left}.candidate-row.compact{grid-template-columns:44px minmax(0,1fr) 40px;gap:8px;padding:8px 10px}.candidate-row>img{width:48px;aspect-ratio:1;object-fit:cover;border-radius:50%;background:#111}.candidate-row.compact>img{width:40px}.candidate-main{min-width:0}.candidate-title{display:flex;align-items:center;gap:8px}.candidate-title span{color:#9aa3b2;font-size:14px;font-weight:900}.candidate-title strong{overflow:hidden;color:#2f3239;font-size:14px;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.candidate-main small{display:block;overflow:hidden;margin:1px 0 5px;color:#aaaeb5;font-size:11px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.candidate-main em{display:block;margin-top:3px;color:#a2a6ad;font-size:11px;font-style:normal}.progress-track{height:12px;overflow:hidden;border-radius:999px;background:#f0f1f3}.progress-fill{height:100%;min-width:40px;display:grid;place-items:center;border-radius:inherit;background:linear-gradient(90deg,#45d1df,#e83ea7);color:#fff;font-size:10px;font-weight:900}.vote-button{min-height:34px;padding:0 10px;border-radius:999px;background:linear-gradient(135deg,#eefbff,#fdf1f9);color:#333740;font-size:12px;font-weight:900;box-shadow:inset 0 0 0 1px #e83ea71a}.event-picker{display:flex;gap:8px;padding:10px 16px 4px;overflow-x:auto;scrollbar-width:none;background:var(--surface);border-bottom:1px solid var(--ink-100)}.event-picker::-webkit-scrollbar{display:none}.event-picker button{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-pill);background:var(--ink-50);color:var(--ink-700);font-size:var(--text-sm);font-weight:700;white-space:nowrap}.event-picker button .badge{padding:1px 6px;border-radius:999px;background:var(--brand-secondary);color:#fff;font-size:10px;font-weight:900}.event-picker .active{background:var(--ink-900);color:#fff}.event-picker .active .badge{background:var(--brand-gold);color:var(--ink-900)}.event-picker .badge.soon{background:linear-gradient(90deg,#ff6a00,#ee0979);color:#fff;animation:pulseBadge 1.5s ease-in-out infinite}@keyframes pulseBadge{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.event-closing{margin:0;padding:8px 16px;background:linear-gradient(90deg,#ff6a001f,#ee09791f);color:#b91c1c;font-size:var(--text-sm);font-weight:800;text-align:center}.event-info-dl{margin:0;display:grid;grid-template-columns:80px 1fr;row-gap:6px;column-gap:12px;font-size:var(--text-sm)}.event-info-dl dt{color:var(--ink-500);font-weight:700}.event-info-dl dd{margin:0;color:var(--ink-900);font-weight:700;font-variant-numeric:tabular-nums}@keyframes mc-fade-in{0%{opacity:0}to{opacity:1}}@keyframes mc-fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes mc-fade-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes mc-pop-in{0%{opacity:0;transform:scale(.92)}60%{opacity:1;transform:scale(1.04)}to{transform:scale(1)}}@keyframes mc-sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes mc-modal-in{0%{opacity:0;transform:scale(.94) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes mc-pulse-hearts{0%{transform:scale(1)}30%{transform:scale(1.18)}60%{transform:scale(.96)}to{transform:scale(1)}}@keyframes mc-bounce-dot{0%{transform:scale(.4)}60%{transform:scale(1.3)}to{transform:scale(1)}}@keyframes mc-shimmer{0%{background-position:-200px 0}to{background-position:200px 0}}@keyframes mc-cascade{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.screen>.view{animation:mc-fade-up .32s cubic-bezier(.22,.61,.36,1)}.sheet-backdrop{animation:mc-fade-in .18s ease-out}.action-sheet{animation:mc-sheet-up .36s cubic-bezier(.16,1,.3,1)}.modal{animation:mc-modal-in .28s cubic-bezier(.16,1,.3,1)}.modal-backdrop{animation:mc-fade-in .18s ease-out}.action-sheet .menu-profile{animation:mc-fade-up .32s ease-out}.action-sheet .menu-section:nth-of-type(1){animation:mc-cascade .3s .04s both}.action-sheet .menu-section:nth-of-type(2){animation:mc-cascade .3s .1s both}.action-sheet .menu-section:nth-of-type(3){animation:mc-cascade .3s .16s both}.action-sheet .menu-section:nth-of-type(4){animation:mc-cascade .3s .22s both}.action-sheet .menu-logout{animation:mc-fade-in .4s .28s both}.middle-banner,.mission-grid button,.podium-item img,.candidate-row,.rank-choice,.vote-button,.primary-sheet-button,.menu-list button,.shop-grid button,.event-picker button,.segmented button,.talk-categories button,.btn,.bottom-nav button{transition:transform .18s cubic-bezier(.22,.61,.36,1),box-shadow .18s ease,background-color .18s ease,color .18s ease,opacity .18s ease}@media(hover:hover){.middle-banner:hover,.mission-grid button:hover:not(:disabled),.candidate-row:hover,.rank-choice:hover,.primary-sheet-button:hover:not(:disabled),.shop-grid button:hover{transform:translateY(-2px);box-shadow:0 10px 24px #262e401a}}.middle-banner:active,.mission-grid button:active:not(:disabled),.candidate-row:active,.rank-choice:active,.vote-button:active,.primary-sheet-button:active:not(:disabled),.menu-list button:active,.shop-grid button:active,.event-picker button:active,.segmented button:active,.talk-categories button:active,.btn:active:not(:disabled),.bottom-nav button:active{transform:scale(.96)}.podium-item.rank-1 img{animation:mc-pop-in .5s .1s cubic-bezier(.22,.61,.36,1) both}.podium-item.rank-2 img{animation:mc-pop-in .5s .18s cubic-bezier(.22,.61,.36,1) both}.podium-item.rank-3 img{animation:mc-pop-in .5s .26s cubic-bezier(.22,.61,.36,1) both}.hearts-pill{animation:mc-pulse-hearts .6s cubic-bezier(.22,.61,.36,1)}.bottom-nav .active .bottom-nav-dot{animation:mc-bounce-dot .36s cubic-bezier(.22,1.5,.36,1)}.toast.visible{animation:mc-pop-in .36s cubic-bezier(.22,.61,.36,1)}.rank-section>.rank-choice{animation:mc-fade-up .34s ease-out both}.rank-section>.rank-choice:nth-child(2){animation-delay:.03s}.rank-section>.rank-choice:nth-child(3){animation-delay:.06s}.rank-section>.rank-choice:nth-child(4){animation-delay:.09s}.rank-section>.rank-choice:nth-child(5){animation-delay:.12s}.rank-section>.rank-choice:nth-child(n+6){animation-delay:.15s}.chart-list>.candidate-row{animation:mc-fade-up .32s ease-out both}.chart-list>.candidate-row:nth-child(2){animation-delay:.03s}.chart-list>.candidate-row:nth-child(3){animation-delay:.06s}.chart-list>.candidate-row:nth-child(4){animation-delay:.09s}.chart-list>.candidate-row:nth-child(5){animation-delay:.12s}.chart-list>.candidate-row:nth-child(n+6){animation-delay:.15s}.middle-banners>.middle-banner{animation:mc-fade-up .36s ease-out both}.middle-banners>.middle-banner:nth-child(2){animation-delay:.05s}.middle-banners>.middle-banner:nth-child(3){animation-delay:.1s}.mission-grid>button{animation:mc-pop-in .36s ease-out both}.mission-grid>button:nth-child(2){animation-delay:.06s}.mission-grid>button:nth-child(3){animation-delay:.12s}.progress-fill{transition:width .6s cubic-bezier(.22,.61,.36,1)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;transition-duration:1ms!important}}.campaign-card{background:#202229;overflow:hidden}.campaign-visual{min-height:116px;display:grid;align-content:end;gap:4px;padding:14px 18px;color:#fff;background:linear-gradient(140deg,rgba(65,43,198,.95) 0 45%,transparent 45%),linear-gradient(24deg,rgba(17,213,211,.6) 0 42%,transparent 42%),radial-gradient(circle at 75% 26%,rgba(232,62,167,.72),transparent 22%),radial-gradient(circle at 88% 76%,rgba(69,209,223,.68),transparent 18%),#2a2391}.campaign-visual span{width:fit-content;padding:3px 9px;border-radius:999px;background:#e83ea7;font-size:10px;font-weight:900}.campaign-visual strong{font-size:17px;font-weight:900;letter-spacing:-.2px}.campaign-visual p{margin:0;font-size:11px;font-weight:700;opacity:.86}.campaign-time{padding:8px 16px;color:#fff;font-size:11px;font-weight:700;letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vote-info{padding:14px 18px 10px;background:#fff}.vote-info h1{margin:0 0 8px;color:#2f3239;font-size:17px;font-weight:900}.vote-info p,.vote-info strong{display:block;margin:0 0 6px;color:#8b909a;font-size:12px;font-weight:700}.vote-info strong{color:#2f3239;font-weight:800}.quick-actions{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid #edf0f4;border-bottom:1px solid #edf0f4;background:#fff}.quick-actions button{min-height:52px;display:grid;align-content:center;justify-items:center;gap:2px;color:#8f939a;font-size:11px;font-weight:700;transition:transform .14s ease,color .14s ease}.quick-actions button.active{color:#e83ea7}.quick-actions svg{width:18px;height:18px}.sub-tabs{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid #edf0f4;background:#fff}.sub-tabs button{height:38px;color:#8d929b;font-size:13px;font-weight:700}.sub-tabs .active{color:#1f2329;font-weight:900;border-bottom:2px solid #1f2329}.my-pick{padding:14px 16px 8px}.my-pick>span{color:#9498a1;font-size:13px;font-weight:900}.my-pick p{margin:8px 0 10px;color:#a9adb5;font-size:12px;font-weight:700}.selected-pick{display:grid;grid-template-columns:44px minmax(0,1fr) 56px;align-items:center;gap:10px;padding:10px;border-radius:12px;background:#f7f9fc;border:1px solid #edf1f6}.selected-pick img{width:44px;aspect-ratio:1;object-fit:cover;border-radius:50%}.selected-pick strong,.selected-pick small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-pick strong{font-size:13px;font-weight:900}.selected-pick small{color:#9ca1aa;font-size:10px}.selected-pick button{height:32px;border-radius:999px;background:linear-gradient(90deg,#45d1df,#e83ea7);color:#fff;font-size:12px;font-weight:900}.rank-choice{display:block;width:100%;text-align:inherit}.info-panel{margin:14px 16px;padding:14px 16px;border:1px solid #edf1f6;border-radius:12px;background:#fff;box-shadow:0 4px 12px #262e400a}.info-panel strong{display:block;margin-bottom:6px;font-size:14px;font-weight:900}.info-panel p{margin:0;color:#747a84;font-size:12px;font-weight:600;line-height:1.55}.supabase-pill{position:sticky;bottom:12px;width:fit-content;margin:8px auto;padding:9px 14px;border:1px solid #dfe5ef;border-radius:999px;background:#ffffffeb;color:#747a84;font-size:13px;font-weight:800;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.supabase-pill.connected{border-color:#45d1df73;color:#12878f}.supabase-pill.error{border-color:#e83ea773;color:#b7277d}.simple-view>div{min-height:460px;display:grid;place-items:center;align-content:center;gap:12px;padding:26px;text-align:center}.simple-view svg{color:#e83ea7}.simple-view h1{margin:0;font-size:25px}.simple-view p{margin:0;color:#8f949d;font-weight:700}.bottom-nav{position:absolute;inset:auto 0 0;height:64px;display:grid;grid-template-columns:repeat(4,1fr);align-items:center;border-top:1px solid #dde1e8;border-radius:24px 24px 0 0;background:#fffffff7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.bottom-nav svg{width:20px;height:20px}.talk-hero{margin:14px 16px;padding:14px 16px;border-radius:12px;background:linear-gradient(135deg,#45d1df2e,#e83ea724),#fff;border:1px solid #edf1f6}.talk-hero strong{display:block;margin-bottom:4px;color:#30333a;font-size:16px;font-weight:900}.talk-hero p{margin:0;color:#818792;font-size:12px;font-weight:600;line-height:1.45}.talk-categories{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:0 16px 10px}.talk-categories button{height:30px;border-radius:999px;background:#f3f5f8;color:#656b75;font-size:12px;font-weight:800}.talk-categories .active{background:#30333a;color:#fff}.talk-composer{display:grid;gap:10px;margin:0 18px 18px;padding:14px;border:1px solid #edf1f6;border-radius:8px;background:#fff;box-shadow:0 10px 24px #262e400d}.talk-composer select,.talk-composer input,.talk-composer textarea{width:100%;border:1px solid #e3e8f0;border-radius:8px;outline:0;background:#f8fafc;color:#30333a;font:inherit;font-weight:800}.talk-composer select,.talk-composer input{height:42px;padding:0 12px}.talk-composer textarea{min-height:82px;resize:vertical;padding:12px}.talk-composer button{height:44px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:8px;background:linear-gradient(90deg,#45d1df,#e83ea7);color:#fff;font-weight:900}.talk-list{display:grid;gap:12px;padding:0 18px 24px}.talk-post{padding:16px;border:1px solid #edf1f6;border-radius:8px;background:#fff;box-shadow:0 10px 24px #262e400d}.talk-post-head,.talk-post-actions{display:flex;align-items:center;justify-content:space-between;gap:10px}.talk-post-head span{padding:4px 9px;border-radius:999px;background:#eefbff;color:#12878f;font-size:12px;font-weight:900}.talk-post-head small{overflow:hidden;color:#9aa0aa;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.talk-post h2{margin:8px 0 4px;color:#30333a;font-size:14px;font-weight:900;letter-spacing:-.1px}.talk-post p{margin:0 0 10px;color:#696f7a;font-size:12px;font-weight:600;line-height:1.5}.talk-post-actions{justify-content:flex-start}.talk-post-actions button{display:inline-flex;align-items:center;gap:5px;height:32px;padding:0 10px;border-radius:999px;background:#f5f7fa;color:#676d77;font-size:13px;font-weight:900}.bottom-nav button{position:relative;display:grid;justify-items:center;gap:2px;color:#8d929b;font-size:10px;font-weight:700}.bottom-nav-dot{width:4px;height:4px;margin-top:2px;border-radius:50%;background:transparent;transition:background .2s ease}.bottom-nav .active .bottom-nav-dot{background:var(--brand-secondary)}.bottom-nav .active{color:#111319}.toast{position:absolute;left:50%;top:calc(var(--h-topbar) + 8px);transform:translate(-50%,-12px);z-index:30;padding:8px 14px;max-width:calc(100% - 32px);border-radius:var(--radius-pill);background:#1f2329f0;color:#fff;font-size:var(--text-sm);font-weight:700;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;box-shadow:0 10px 24px #0f12194d}.toast.visible{opacity:1;transform:translate(-50%)}.muted-hint{margin:6px 0 10px;color:var(--ink-400);font-size:var(--text-xs);font-weight:600}.menu-profile{display:flex;align-items:center;gap:12px;margin:0 0 16px;padding:12px 14px;border-radius:var(--radius-md);background:linear-gradient(135deg,#7b61ff1f,#e83ea714)}.menu-avatar{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;background:var(--brand-gradient);color:#fff}.menu-profile-info{display:flex;flex-direction:column;gap:2px;min-width:0}.menu-profile-info strong{font-size:var(--text-base);font-weight:800;letter-spacing:-.2px}.menu-profile-info small{color:var(--ink-500);font-size:var(--text-xs);font-weight:600}.menu-section{margin:12px 0}.menu-section h3{margin:0 0 6px;padding:0 4px;color:var(--ink-500);font-size:var(--text-xs);font-weight:800;letter-spacing:.4px;text-transform:uppercase}.menu-section ul{list-style:none;margin:0;padding:0;display:grid;gap:2px}.menu-section li{display:block}.menu-section li button,.menu-section li.menu-toggle{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:transparent;color:var(--ink-900);font-size:var(--text-sm);font-weight:700;text-align:left}.menu-section li button:hover{background:var(--ink-50)}.menu-section li button>span{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.menu-section li button>small.muted,.menu-section li.menu-toggle small.muted{color:var(--ink-400);font-size:var(--text-xs);font-weight:600}.menu-section li button svg:first-child,.menu-section li.menu-toggle>span>svg{color:var(--ink-500)}.menu-section li.menu-toggle{cursor:default}.menu-section li.menu-toggle>span{display:flex;align-items:center;gap:10px;flex:1}.menu-section li.menu-toggle>span>svg{color:var(--ink-500)}.menu-section li.menu-toggle .toggle{position:relative;width:36px;height:20px;border-radius:999px;background:var(--ink-200);transition:background .2s ease;flex:0 0 auto}.menu-section li.menu-toggle .toggle span{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s ease;box-shadow:0 1px 3px #0003}.menu-section li.menu-toggle .toggle.on{background:var(--brand-secondary)}.menu-section li.menu-toggle .toggle.on span{transform:translate(16px)}.menu-logout{width:100%;margin-top:16px;padding:10px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-pill);background:var(--ink-50);color:var(--ink-700);font-size:var(--text-sm);font-weight:800}.menu-logout:hover{background:#fee2e2;color:var(--danger)}.phone-frame.dark-mode{background:#14161b;color:#f3f4f6}.phone-frame.dark-mode .top-bar,.phone-frame.dark-mode .page-title,.phone-frame.dark-mode .bottom-nav{background:#1a1d24;border-color:#2a2f37}.phone-frame.dark-mode .screen{background:linear-gradient(180deg,#14161b,#1a1d24)}.sheet-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;align-items:end;background:#161a2247}.action-sheet{position:relative;max-height:74%;overflow-y:auto;overflow-x:hidden;padding:var(--s-5) var(--s-4) var(--s-5);border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:var(--surface);box-shadow:0 -18px 48px #161a222e;scrollbar-width:none}.action-sheet::-webkit-scrollbar{display:none}.sheet-close{position:absolute;top:18px;right:18px;width:36px;height:36px;display:grid;place-items:center;border-radius:50%;background:#f4f6f9}.action-sheet h2{margin:0 44px 12px 0;color:var(--ink-900);font-size:var(--text-lg);font-weight:900;letter-spacing:-.2px}.action-sheet p{margin:0 0 12px;color:var(--ink-500);font-size:var(--text-sm);font-weight:600;line-height:1.5}.search-field{display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:var(--s-2);height:var(--h-input);padding:0 var(--s-3);border:1px solid var(--ink-100);border-radius:var(--radius-md);background:var(--surface-bg)}.search-field input{min-width:0;border:0;outline:0;background:transparent;color:#30333a;font:inherit;font-weight:800}.sheet-list,.menu-list{display:grid;gap:10px;margin-top:14px}.sheet-list button{display:grid;grid-template-columns:44px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;border-radius:8px;background:#f8fafc;text-align:left}.sheet-list img{width:44px;aspect-ratio:1;object-fit:cover;border-radius:50%}.sheet-list span,.sheet-list small,.menu-list button{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:900}.sheet-list small{color:#8f949d;font-size:13px}.shop-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.shop-grid button{min-height:88px;display:grid;place-items:center;gap:var(--s-2);padding:var(--s-3);border-radius:var(--radius-md);background:linear-gradient(135deg,#f7fbff,#fff5fb);color:var(--ink-700);font-size:var(--text-sm);font-weight:800}.shop-grid svg{width:22px;height:22px;color:var(--brand-secondary)}.menu-list button,.primary-sheet-button{height:var(--h-btn-lg);border-radius:var(--radius-pill);background:var(--surface-subtle);font-size:var(--text-base);font-weight:800}.primary-sheet-button{width:100%;background:var(--brand-gradient-flat);color:#fff}@media(max-width:520px){.app-shell{padding:0;background:#fff}.phone-frame{width:100%;height:100vh;border:0;border-radius:0;box-shadow:none}.bottom-nav{border-radius:22px 22px 0 0}.podium-item img{width:96px}.podium-item.rank-1 img{width:124px}}@media(max-width:390px){.bottom-nav button{font-size:11px}.candidate-row{grid-template-columns:58px minmax(0,1fr) 58px;gap:8px}.candidate-row>img{width:52px}.candidate-title strong{font-size:17px}.vote-button{font-size:14px}}
