:root{--primary:#7c3aed;--primary-light:#a78bfa;--primary-dark:#5b21b6;--secondary:#06b6d4;--accent:#f43f5e;--accent-light:#fb7185;--success:#10b981;--warning:#f59e0b;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--surface:#fff;--surface-glass:rgba(255,255,255,.72);--backdrop:rgba(15,23,42,.6);--white:#fff;--gradient-primary:linear-gradient(135deg,#7c3aed,#a855f7);--gradient-icon:linear-gradient(135deg,#8b5cf6,#d946ef);--shadow-sm:0 1px 2px rgba(0,0,0,.05);--shadow-md:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -2px rgba(0,0,0,.05);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -4px rgba(0,0,0,.05);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.05);--shadow-glow:0 0 40px rgba(124,58,237,.15);--shadow-primary:0 8px 24px rgba(124,58,237,.25);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--border-subtle:1px solid rgba(0,0,0,.06);--font:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;--ease-out:cubic-bezier(.16,1,.3,1);--ease-bounce:cubic-bezier(.34,1.56,.64,1);--duration-fast:150ms;--duration-normal:250ms;--duration-slow:400ms}
.darkmode{--gray-50:#0f172a;--gray-100:#1e293b;--gray-200:#334155;--gray-300:#475569;--gray-400:#64748b;--gray-500:#94a3b8;--gray-600:#cbd5e1;--gray-700:#e2e8f0;--gray-800:#f1f5f9;--gray-900:#f8fafc;--surface:#1e293b;--surface-glass:rgba(30,41,59,.85);--backdrop:rgba(0,0,0,.7);--border-subtle:1px solid rgba(255,255,255,.08);--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 4px 6px -1px rgba(0,0,0,.4),0 2px 4px -2px rgba(0,0,0,.3);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.4),0 4px 6px -4px rgba(0,0,0,.3);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.5),0 8px 10px -6px rgba(0,0,0,.4);--white:#f8fafc}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font);background:var(--gray-50);color:var(--gray-800);line-height:1.6;overflow-x:hidden;min-height:100vh}
[x-cloak]{display:none!important}
.f{display:flex}.fc{flex-direction:column}.f1{flex:1}.fw{flex-wrap:wrap}.aic{align-items:center}.jcc{justify-content:center}.jcsb{justify-content:space-between}.g4{gap:4px}.g6{gap:6px}.g8{gap:8px}.g10{gap:10px}.g12{gap:12px}.g16{gap:16px}.g20{gap:20px}.g24{gap:24px}
.p{padding}.p16{padding:16px}.p20{padding:20px}.p24{padding:24px}.px16{padding-left:16px;padding-right:16px}.py12{padding-top:12px;padding-bottom:12px}.py14{padding-top:14px;padding-bottom:14px}
.m{margin}.m-auto{margin:0 auto}.mb4{margin-bottom:4px}.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}.mb20{margin-bottom:20px}.mb24{margin-bottom:24px}.mb32{margin-bottom:32px}.mt2{margin-top:2px}.mt4{margin-top:4px}.mt8{margin-top:8px}
.w{width}.h{height}.w32{width:32px;height:32px}.w36{width:36px;height:36px}.w40{width:40px;height:40px}.w48{width:48px;height:48px}.w52{width:52px;height:52px}.w64{width:64px;height:64px}.w80{width:80px;height:80px}
.rn{border-radius:var(--radius-sm)}.rmd{border-radius:var(--radius-md)}.rlg{border-radius:var(--radius-lg)}.rxl{border-radius:var(--radius-xl)}.r2xl{border-radius:var(--radius-2xl)}.rfull{border-radius:var(--radius-full)}.r50{border-radius:50%}
.bsm{box-shadow:var(--shadow-sm)}.bmd{box-shadow:var(--shadow-md)}.blg{box-shadow:var(--shadow-lg)}.bxl{box-shadow:var(--shadow-xl)}.bprimary{box-shadow:var(--shadow-primary)}
.b{border}.b1{border:1px}.bsubtle{border:var(--border-subtle)}.bo2{border:2px}.bgray200{border-color:var(--gray-200)}.bgray300{border-color:var(--gray-300)}.bprimary{border-color:var(--primary)}.bprimarylight{border-color:var(--primary-light)}
.bg{background}.bgsurface{background:var(--surface)}.bggray50{background:var(--gray-50)}.bggray100{background:var(--gray-100)}.bggray200{background:var(--gray-200)}.bggradient{background:var(--gradient-primary)}.bgtransparent{background:0 0}
.c{color}.cwhite{color:var(--white)}.cgray400{color:var(--gray-400)}.cgray500{color:var(--gray-500)}.cgray700{color:var(--gray-700)}.cgray900{color:var(--gray-900)}.cprimary{color:var(--primary)}.caccent{color:var(--accent)}.csuccess{color:var(--success)}
.fw{font-weight}.fw400{font-weight:400}.fw500{font-weight:500}.fw600{font-weight:600}.fw700{font-weight:700}.fw800{font-weight:800}.fw900{font-weight:900}
.fs{font-size}.fs11{font-size:11px}.fs12{font-size:12px}.fs13{font-size:13px}.fs14{font-size:14px}.fs15{font-size:15px}.fs16{font-size:16px}.fs17{font-size:17px}.fs18{font-size:18px}.fs20{font-size:20px}.fs22{font-size:22px}.fs24{font-size:24px}.fs26{font-size:26px}.fs28{font-size:28px}.fs32{font-size:32px}.fs36{font-size:36px}.fs40{font-size:40px}
.lh{line-height}.lh12{line-height:1.2}.lh16{line-height:1.6}.lh17{line-height:1.7}.lh11{line-height:1.1}
.tc{text-align:center}.tt{text-transform:uppercase}.ls{letter-spacing:-.5px}.ls1{letter-spacing:-1px}.ls05{letter-spacing:.5px}
.ov{overflow}.ovh{overflow:hidden}.ova{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.trans{transition:all var(--duration-normal) var(--ease-out)}.transfast{transition:all var(--duration-fast)}.transslow{transition:all var(--duration-slow) var(--ease-out)}.transt{transition:transform var(--duration-normal) var(--ease-bounce)}.transc{transition:color var(--duration-fast)}.transb{transition:border var(--duration-fast)}.transbg{transition:background var(--duration-fast)}.transop{transition:opacity var(--duration-normal)}.transw{transition:width .6s var(--ease-out)}
.cursor{cursor:pointer}.cursorn{cursor:not-allowed}.us{user-select:none}.pointer{pointer-events:none}.ofix{position:relative;z-index:1}.posa{position:absolute}.posr{position:relative}.posf{position:fixed}.posta{position:absolute}.posticky{position:sticky}.t0{top:0}.l0{left:0}.r0{right:0}.b0{bottom:0}.inset0{inset:0}
.z{z-index}.z1{z-index:1}.z50{z-index:50}.z100{z-index:100}
.obj{object-fit:cover}.objc{object-fit:cover}
.maxw{max-width}.maxw600{max-width:600px}.maxw700{max-width:700px}.maxw800{max-width:800px}.maxw900{max-width:900px}.maxw1200{max-width:1200px}.maxw420{max-width:420px}.minw{min-width}.minw0{min-width:0}.minh{min-height}.minh100vh{min-height:100vh}.minh48{min-height:48px}.minh52{min-height:52px}.minh60{min-height:60px}
.shrink0{flex-shrink:0}.grow1{flex-grow:1}
.app-wrapper{min-height:100vh;display:flex;flex-direction:column;position:relative}
.bg-animated{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.2;animation:float 20s ease-in-out infinite}
.orb-1{width:400px;height:400px;background:var(--primary-light);top:-10%;right:-5%;animation-delay:0s}
.orb-2{width:300px;height:300px;background:var(--secondary);bottom:10%;left:-5%;animation-delay:-7s}
.orb-3{width:200px;height:200px;background:var(--accent-light);top:50%;left:50%;animation-delay:-14s;opacity:.15}
.bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(124,58,237,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(124,58,237,.03) 1px,transparent 1px);background-size:60px 60px}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(15px,15px) scale(1.02)}}
.header{position:sticky;top:0;z-index:50;background:var(--surface-glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:var(--border-subtle)}
.header-inner{max-width:1200px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none;text-decoration:none}
.logo-icon{width:40px;height:40px;background:var(--gradient-icon);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--white);transition:transform var(--duration-normal) var(--ease-bounce)}
.logo-icon .material-icons{font-size:22px}
.logo:hover .logo-icon{transform:scale(1.1) rotate(-5deg)}
.logo-text{font-size:20px;font-weight:800;color:var(--gray-900);letter-spacing:-.5px}
.logo-accent{color:var(--primary)}
.header-actions{display:flex;align-items:center;gap:12px}
.btn-toggle{width:40px;height:40px;background:var(--surface);border:1px solid var(--gray-200);border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-600);transition:all var(--duration-normal) var(--ease-out)}
.btn-toggle:hover{border-color:var(--gray-300);color:var(--gray-800)}
.btn-toggle .material-icons{font-size:22px}
.btn-toggle .icon-dark,.darkmode .btn-toggle .icon-light{display:none}
.darkmode .btn-toggle .icon-dark{display:block}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:var(--font);font-weight:600;transition:all var(--duration-normal) var(--ease-out);text-decoration:none;white-space:nowrap}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}
.btn .material-icons{font-size:20px}
.btn-create-nav{background:var(--gradient-primary);color:var(--white);padding:10px 20px;border-radius:var(--radius-full);font-size:14px;box-shadow:var(--shadow-primary)}
.btn-create-nav:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 28px rgba(124,58,237,.35)}
.btn-login{background:var(--surface);color:var(--gray-700);padding:10px 20px;border-radius:var(--radius-full);font-size:14px;border:1px solid var(--gray-200);box-shadow:var(--shadow-sm)}
.btn-login:hover{background:var(--gray-50);border-color:var(--gray-300);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-hero-primary{background:var(--gradient-primary);color:var(--white);padding:14px 28px;border-radius:var(--radius-full);font-size:16px;box-shadow:var(--shadow-primary);position:relative;overflow:hidden}
.btn-hero-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2),transparent 50%);opacity:0;transition:opacity var(--duration-normal)}
.btn-hero-primary:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 16px 32px rgba(124,58,237,.35)}
.btn-hero-primary:hover::after{opacity:1}
.btn-hero-secondary{background:var(--surface);color:var(--gray-700);padding:14px 28px;border-radius:var(--radius-full);font-size:16px;border:1px solid var(--gray-200);box-shadow:var(--shadow-md)}
.btn-hero-secondary:hover{background:var(--gray-50);border-color:var(--primary-light);color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-submit{width:100%;background:var(--gradient-primary);color:var(--white);padding:16px 28px;border-radius:var(--radius-lg);font-size:16px;box-shadow:var(--shadow-primary)}
.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 28px rgba(124,58,237,.35)}
.btn-google{width:100%;background:var(--surface);color:var(--gray-700);padding:14px 24px;border-radius:var(--radius-lg);font-size:15px;border:1px solid var(--gray-200);box-shadow:var(--shadow-md);gap:12px}
.btn-google:hover{background:var(--gray-50);border-color:var(--gray-300);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.user-menu{position:relative}
.user-trigger{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;background:var(--surface);border:1px solid var(--gray-200);border-radius:var(--radius-full);cursor:pointer;font-family:var(--font);transition:all var(--duration-normal) var(--ease-out)}
.user-trigger:hover{border-color:var(--gray-300);box-shadow:var(--shadow-md)}
.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid var(--primary-light)}
.user-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:var(--white)}
.user-avatar-placeholder .material-icons{font-size:18px}
.user-name{font-size:14px;font-weight:600;color:var(--gray-700);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chevron{font-size:18px!important;color:var(--gray-400);transition:transform var(--duration-normal) var(--ease-out)}
.chevron.rotated{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);min-width:240px;overflow:hidden;z-index:100}
.dropdown-enter{transition:all var(--duration-normal) var(--ease-out)}
.dropdown-enter-start{opacity:0;transform:translateY(-8px) scale(.96)}
.dropdown-enter-end{opacity:1;transform:translateY(0) scale(1)}
.dropdown-leave{transition:all var(--duration-fast) ease-in}
.dropdown-leave-start{opacity:1;transform:translateY(0) scale(1)}
.dropdown-leave-end{opacity:0;transform:translateY(-4px) scale(.98)}
.dropdown-user-info{display:flex;align-items:center;gap:12px;padding:16px}
.dropdown-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}
.dropdown-name{font-size:14px;font-weight:700;color:var(--gray-900)}
.dropdown-email{font-size:12px;color:var(--gray-500);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dropdown-divider{height:1px;background:var(--gray-100)}
.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;background:0 0;color:var(--gray-700);font-size:14px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background var(--duration-fast);text-align:left}
.dropdown-item:hover{background:var(--gray-50)}
.dropdown-item .material-icons{font-size:20px;color:var(--gray-500)}
.dropdown-item-danger:hover{background:rgba(244,63,94,.05);color:var(--accent)}
.dropdown-item-danger:hover .material-icons{color:var(--accent)}
.main-content{flex:1;position:relative;z-index:1}
.hero{padding:80px 24px 40px;max-width:800px;margin:0 auto;text-align:center}
.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;background:rgba(124,58,237,.08);color:var(--primary);border-radius:var(--radius-full);font-size:13px;font-weight:600;margin-bottom:24px;border:1px solid rgba(124,58,237,.15);animation:fadeInDown .6s var(--ease-out) both}
.hero-badge .material-icons{font-size:16px}
.hero-title{font-size:clamp(32px,5vw,52px);font-weight:900;line-height:1.1;color:var(--gray-900);letter-spacing:-1.5px;margin-bottom:20px;animation:fadeInUp .7s var(--ease-out) .1s both}
.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-description{font-size:clamp(16px,2vw,19px);color:var(--gray-500);max-width:560px;margin:0 auto 32px;line-height:1.7;animation:fadeInUp .7s var(--ease-out) .2s both}
.hero-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:48px;animation:fadeInUp .7s var(--ease-out) .3s both}
.hero-stats-section{padding:0 24px;max-width:700px;margin:0 auto}
.hero-stats-label{font-size:13px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;text-align:center}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:24px;padding:24px 32px;background:var(--surface-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);border:var(--border-subtle);box-shadow:var(--shadow-lg);animation:fadeInUp .7s var(--ease-out) .4s both;margin-bottom:80px}
.hero-stat{display:flex;align-items:center;gap:12px}
.hero-stat-icon{width:40px;height:40px;background:rgba(124,58,237,.08);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}
.hero-stat-icon .material-icons{font-size:20px;color:var(--primary)}
.hero-stat-value{font-size:20px;font-weight:800;color:var(--gray-900);line-height:1.2}
.hero-stat-label{font-size:12px;color:var(--gray-500);font-weight:500}
.hero-stat-divider{width:1px;height:36px;background:var(--gray-200)}
.features-section{padding:40px 24px 60px;max-width:900px;margin:0 auto}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feature-card{background:var(--surface-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:var(--border-subtle);border-radius:var(--radius-xl);padding:28px 24px;text-align:center;transition:all var(--duration-slow) var(--ease-out)}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg),var(--shadow-glow);border-color:rgba(124,58,237,.15)}
.feature-icon-wrap{width:52px;height:52px;background:var(--gradient-icon);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;transition:transform var(--duration-normal) var(--ease-bounce)}
.feature-card:hover .feature-icon-wrap{transform:scale(1.1) rotate(-5deg)}
.feature-icon-wrap .material-icons{font-size:26px;color:var(--white)}
.feature-title{font-size:16px;font-weight:700;color:var(--gray-900);margin-bottom:8px}
.feature-desc{font-size:14px;color:var(--gray-500);line-height:1.6}
.popular-section{padding:0 24px 80px;max-width:700px;margin:0 auto}
.section-header{margin-bottom:24px}
.section-title{display:flex;align-items:center;gap:10px;font-size:22px;font-weight:800;color:var(--gray-900);margin-bottom:4px}
.section-title .material-icons{font-size:26px;color:var(--accent)}
.section-subtitle{font-size:15px;color:var(--gray-500);margin-left:36px}
.battles-grid{display:flex;flex-direction:column;gap:12px}
.battle-list-card{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--surface);border:var(--border-subtle);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--duration-normal) var(--ease-out)}
.battle-list-card:hover{transform:translateY(-2px) translateX(4px);box-shadow:var(--shadow-lg);border-color:rgba(124,58,237,.15)}
.battle-rank{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;flex-shrink:0}
.position-1{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:var(--white);box-shadow:0 4px 12px rgba(245,158,11,.3)}
.position-2{background:linear-gradient(135deg,#cbd5e1,#94a3b8);color:var(--white)}
.position-3{background:linear-gradient(135deg,#d97706,#b45309);color:var(--white)}
.position-other{background:var(--gray-100);color:var(--gray-500)}
.battle-list-content{flex:1;min-width:0}
.battle-list-creator{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.creator-pic{width:18px;height:18px;border-radius:50%;object-fit:cover}
.battle-list-creator span{font-size:12px;color:var(--gray-500);font-weight:500}
.battle-list-title{font-size:15px;font-weight:700;color:var(--gray-900);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.battle-list-meta{display:flex;align-items:center;gap:12px}
.vote-count-badge{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--gray-500);font-weight:500}
.vote-count-badge .material-icons{font-size:16px;color:var(--primary)}
.battle-list-arrow{color:var(--gray-300);transition:all var(--duration-normal) var(--ease-out);flex-shrink:0}
.battle-list-card:hover .battle-list-arrow{color:var(--primary);transform:translateX(4px)}
.battle-list-arrow .material-icons{font-size:20px}
.state-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center;color:var(--gray-500);gap:12px}
.state-empty h3{font-size:18px;font-weight:700;color:var(--gray-700)}
.state-empty p{font-size:14px;color:var(--gray-500)}
.empty-illustration{width:80px;height:80px;background:var(--gray-100);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.empty-illustration .material-icons{font-size:40px;color:var(--gray-400)}
.spinner{width:36px;height:36px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.footer{padding:40px 24px;text-align:center;border-top:var(--border-subtle)}
.footer-content{max-width:600px;margin:0 auto}
.footer-logo{display:inline-flex;align-items:center;gap:8px;font-size:16px;font-weight:700;color:var(--gray-500);margin-bottom:8px}
.footer-logo .material-icons{font-size:20px;color:var(--primary-light)}
.footer-text{font-size:13px;color:var(--gray-400)}
.page-container{max-width:600px;margin:0 auto;padding:40px 24px 80px}
.page-header{display:flex;align-items:center;gap:16px;margin-bottom:32px;animation:fadeInDown .5s var(--ease-out) both}
.page-icon-wrap{width:48px;height:48px;background:var(--gradient-icon);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.page-icon-wrap .material-icons{font-size:26px;color:var(--white)}
.page-title{font-size:24px;font-weight:800;color:var(--gray-900);letter-spacing:-.5px}
.page-subtitle{font-size:14px;color:var(--gray-500);margin-top:2px}
.form-card{background:var(--surface);border:var(--border-subtle);border-radius:var(--radius-2xl);padding:32px;box-shadow:var(--shadow-lg);animation:fadeInUp .6s var(--ease-out) .1s both}
.form-group{margin-bottom:28px}
.form-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--gray-700);margin-bottom:10px}
.form-label .material-icons{font-size:18px;color:var(--primary)}
.form-input{width:100%;padding:14px 16px;background:var(--gray-50);border:2px solid var(--gray-200);border-radius:var(--radius-md);font-size:15px;font-family:var(--font);color:var(--gray-800);transition:all var(--duration-normal) var(--ease-out);outline:none}
.form-input:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 4px rgba(124,58,237,.1)}
.form-input::placeholder{color:var(--gray-400)}
.options-list{display:flex;flex-direction:column;gap:10px}
.option-row{display:flex;align-items:center;gap:10px;animation:fadeInLeft .3s var(--ease-out) both}
.option-num{width:32px;height:32px;background:var(--gradient-primary);color:var(--white);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.option-input{flex:1}
.btn-remove{width:32px;height:32px;background:var(--gray-100);border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-400);transition:all var(--duration-fast);flex-shrink:0}
.btn-remove:hover{background:rgba(244,63,94,.1);color:var(--accent)}
.btn-remove .material-icons{font-size:18px}
.btn-add-option{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:0 0;border:2px dashed var(--gray-200);border-radius:var(--radius-md);color:var(--gray-400);font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;margin-top:10px;transition:all var(--duration-normal) var(--ease-out)}
.btn-add-option:hover{border-color:var(--primary-light);color:var(--primary);background:rgba(124,58,237,.03)}
.btn-add-option .material-icons{font-size:20px}
.duration-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.duration-btn{display:flex;flex-direction:column;align-items:center;padding:14px 8px;background:var(--gray-50);border:2px solid var(--gray-200);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font);transition:all var(--duration-normal) var(--ease-out)}
.duration-btn:hover{border-color:var(--primary-light);background:rgba(124,58,237,.03)}
.duration-btn.active{border-color:var(--primary);background:rgba(124,58,237,.08)}
.duration-value{font-size:20px;font-weight:800;color:var(--gray-700);line-height:1.2}
.duration-btn.active .duration-value{color:var(--primary)}
.duration-unit{font-size:12px;color:var(--gray-500);font-weight:500}
.preview-card{margin-top:24px;background:var(--surface);border:var(--border-subtle);border-radius:var(--radius-2xl);padding:24px;box-shadow:var(--shadow-md);animation:fadeInUp .4s var(--ease-out) both}
.preview-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}
.preview-label .material-icons{font-size:16px;color:var(--primary)}
.preview-inner{background:var(--gray-50);border-radius:var(--radius-lg);padding:20px}
.preview-title{font-size:17px;font-weight:700;color:var(--gray-800);margin-bottom:16px}
.preview-options{display:flex;flex-direction:column;gap:8px}
.preview-option{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border-radius:var(--radius-md);border:var(--border-subtle)}
.preview-option span:first-child{font-size:14px;font-weight:600;color:var(--gray-700)}
.preview-votes{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--primary)}
.preview-votes .material-icons{font-size:16px}
.my-battles-list{display:flex;flex-direction:column;gap:16px}
.my-battle-card{background:var(--surface);border:var(--border-subtle);border-radius:var(--radius-2xl);padding:24px;box-shadow:var(--shadow-md);transition:all var(--duration-normal) var(--ease-out)}
.my-battle-card:hover{box-shadow:var(--shadow-lg)}
.my-battle-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.my-battle-title{font-size:17px;font-weight:700;color:var(--gray-900)}
.my-battle-status{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-500);margin-top:4px}
.status-dot{width:8px;height:8px;border-radius:50%}
.dot-active{background:var(--success);box-shadow:0 0 8px rgba(16,185,129,.4);animation:pulse-dot 2s ease-in-out infinite}
.dot-ended{background:var(--gray-400)}
.status-time{color:var(--gray-400);font-weight:500}
.btn-delete{width:36px;height:36px;background:0 0;border:1px solid var(--gray-200);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-400);transition:all var(--duration-fast);flex-shrink:0}
.btn-delete:hover:not(:disabled){background:rgba(244,63,94,.08);border-color:rgba(244,63,94,.2);color:var(--accent)}
.btn-delete .material-icons{font-size:18px}
.my-battle-options{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;cursor:pointer}
.vote-bar{position:relative;border-radius:var(--radius-md);overflow:hidden;background:var(--gray-50);border:var(--border-subtle);min-height:48px}
.vote-bar-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,rgba(124,58,237,.08),rgba(124,58,237,.15));border-radius:var(--radius-md);transition:width .6s var(--ease-out)}
.vote-bar-content{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;padding:12px 16px}
.vote-bar-label{font-size:14px;font-weight:600;color:var(--gray-700)}
.vote-bar-stats{display:flex;align-items:center;gap:10px}
.vote-bar-count{font-size:14px;font-weight:700;color:var(--primary)}
.vote-bar-pct{font-size:12px;font-weight:600;color:var(--gray-400)}
.my-battle-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:var(--border-subtle);font-size:13px;color:var(--gray-500)}
.my-battle-footer span{display:flex;align-items:center;gap:4px}
.my-battle-footer .material-icons{font-size:16px;color:var(--gray-400)}
.battle-page{max-width:600px;margin:0 auto;padding:40px 24px 80px}
.battle-view-card{background:var(--surface);border:var(--border-subtle);border-radius:var(--radius-2xl);padding:32px;box-shadow:var(--shadow-lg);animation:fadeInUp .5s var(--ease-out) both}
.battle-view-creator{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:13px;color:var(--gray-500);font-weight:500}
.battle-view-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.battle-view-title{font-size:22px;font-weight:800;color:var(--gray-900);letter-spacing:-.5px;flex:1;min-width:200px}
.battle-view-meta{flex-shrink:0}
.vote-total-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:rgba(124,58,237,.08);color:var(--primary);border-radius:var(--radius-full);font-size:14px;font-weight:700}
.vote-total-badge .material-icons{font-size:18px}
.battle-view-options{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.vote-option{position:relative;display:flex;align-items:center;border:2px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;background:var(--surface);font-family:var(--font);text-align:left;min-height:60px;transition:all var(--duration-normal) var(--ease-out)}
.vote-option:hover:not(.vote-disabled){border-color:var(--primary-light);transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 0 4px rgba(124,58,237,.06)}
.vote-option:active:not(.vote-disabled){transform:scale(.98);transition-duration:80ms}
.vote-disabled{opacity:.7;cursor:default}
.vote-option-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,rgba(124,58,237,.06),rgba(124,58,237,.14));transition:width .6s var(--ease-out)}
.vote-option-content{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;flex:1;padding:16px 20px}
.vote-option-label{font-size:15px;font-weight:600;color:var(--gray-800)}
.vote-option-stats{display:flex;align-items:center;gap:12px}
.vote-option-count{font-size:18px;font-weight:800;color:var(--primary)}
.vote-option-pct{font-size:13px;font-weight:600;color:var(--gray-400);min-width:36px;text-align:right}
.vote-click-indicator{position:relative;z-index:1;padding-right:16px;color:var(--gray-300);transition:color var(--duration-fast)}
.vote-option:hover:not(.vote-disabled) .vote-click-indicator{color:var(--primary);animation:tap-hint 1s ease-in-out infinite}
.vote-click-indicator .material-icons{font-size:22px}
@keyframes tap-hint{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
.battle-view-footer{display:flex;align-items:center;justify-content:space-between;padding-top:20px;border-top:var(--border-subtle)}
.battle-timer{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--gray-500)}
.battle-timer .material-icons{font-size:18px}
.timer-expired{color:var(--accent)}
.battle-live{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--gray-500)}
.live-dot{width:8px;height:8px;background:var(--success);border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(16,185,129,.4)}50%{opacity:.8;box-shadow:0 0 0 6px rgba(16,185,129,0)}}
.modal-overlay{position:fixed;inset:0;background:var(--backdrop);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}
.fade-in{animation:fadeIn var(--duration-normal) var(--ease-out)}
.fade-out{animation:fadeOut var(--duration-fast) ease-in}
.modal-card{background:var(--surface);border-radius:var(--radius-2xl);padding:40px 32px;max-width:420px;width:100%;position:relative;box-shadow:var(--shadow-xl)}
.modal-pop-in{transition:all var(--duration-slow) var(--ease-bounce)}
.modal-pop-start{opacity:0;transform:scale(.9) translateY(20px)}
.modal-pop-end{opacity:1;transform:scale(1) translateY(0)}
.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;background:var(--gray-100);border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-400);transition:all var(--duration-fast)}
.modal-close:hover{background:var(--gray-200);color:var(--gray-700)}
.modal-close .material-icons{font-size:20px}
.modal-body-login{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}
.modal-icon-wrap{width:64px;height:64px;background:var(--gradient-primary);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.modal-icon-wrap .material-icons{font-size:32px;color:var(--white)}
.modal-title{font-size:22px;font-weight:800;color:var(--gray-900);letter-spacing:-.5px}
.modal-subtitle{font-size:15px;color:var(--gray-500);line-height:1.6}
.modal-hint{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-400);margin-top:8px}
.modal-hint .material-icons{font-size:16px;color:var(--success)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeOut{from{opacity:1}to{opacity:0}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}
.fade-in-up{animation:fadeInUp .5s var(--ease-out) both;animation-delay:calc(var(--delay,0)*80ms)}
@keyframes vote-pulse{0%{box-shadow:0 0 0 0 rgba(124,58,237,.3)}70%{box-shadow:0 0 0 12px rgba(124,58,237,0)}100%{box-shadow:0 0 0 0 rgba(124,58,237,0)}}
.vote-option:active:not(.vote-disabled){animation:vote-pulse .4s ease-out}
@media (max-width:768px){.header-inner{padding:10px 16px}.logo-text{font-size:17px}.logo-icon{width:36px;height:36px}.logo-icon .material-icons{font-size:20px}.btn-create-nav span,.btn-login span{display:none}.btn-create-nav,.btn-login{padding:10px;border-radius:var(--radius-md)}.btn-create-nav .material-icons,.btn-login .material-icons{margin:0}.user-name{display:none}.user-trigger{padding:4px}.chevron{display:none}.hero{padding:40px 20px 24px}.hero-badge{font-size:12px;padding:6px 14px;margin-bottom:20px}.hero-title{font-size:26px;letter-spacing:-.8px;margin-bottom:16px}.hero-description{font-size:15px;margin-bottom:24px;line-height:1.6}.hero-actions{flex-direction:column;margin-bottom:28px;gap:10px}.btn-hero-primary,.btn-hero-secondary{width:100%;padding:14px 24px}.hero-stats{flex-direction:column;gap:16px;padding:20px;margin-bottom:48px;border-radius:var(--radius-lg)}.hero-stat-divider{width:60%;height:1px}.hero-stat{flex-direction:column;text-align:center;gap:8px}.hero-stat-icon{width:44px;height:44px}.hero-stat-value{font-size:22px}.hero-stat-label{font-size:12px}.hero-stats-label{font-size:12px;margin-bottom:8px}.features-grid{grid-template-columns:1fr;gap:12px}.feature-card{padding:20px}.popular-section{padding:0 16px 48px}.section-title{font-size:18px}.section-title .material-icons{font-size:22px}.section-subtitle{font-size:13px;margin-left:0;margin-top:4px}.battles-grid{gap:10px}.battle-list-card{padding:16px;border-radius:var(--radius-lg)}.battle-rank{width:36px;height:36px;font-size:14px}.battle-list-title{font-size:14px}.battle-list-arrow .material-icons{font-size:18px}.page-container{padding:24px 16px 48px}.page-title{font-size:20px}.form-card{padding:24px 20px;border-radius:var(--radius-xl)}.form-input{padding:12px 14px;font-size:14px}.duration-grid{grid-template-columns:repeat(2,1fr)}.duration-value{font-size:18px}.battle-page{padding:20px 16px 48px}.battle-view-card{padding:20px;border-radius:var(--radius-lg)}.battle-view-title{font-size:18px}.vote-option-content{padding:14px 16px}.vote-option-label{font-size:14px}.vote-option-count{font-size:16px}.my-battle-card{padding:20px;border-radius:var(--radius-lg)}.my-battle-header{gap:12px;margin-bottom:12px}.modal-card{padding:28px 22px}.dropdown{right:-12px;min-width:220px}.preview-card{padding:20px;border-radius:var(--radius-lg)}.preview-inner{padding:16px}.preview-title{font-size:16px}}
@media (max-width:480px){.header-inner{padding:8px 12px}.logo-text{font-size:15px}.logo-icon{width:32px;height:32px}.logo-icon .material-icons{font-size:18px}.header-actions{gap:6px}.hero{padding:32px 16px 20px}.hero-badge{font-size:11px;padding:4px 10px;margin-bottom:16px}.hero-title{font-size:22px;letter-spacing:-.5px;margin-bottom:12px}.hero-description{font-size:14px;line-height:1.5}.hero-actions{margin-bottom:24px;gap:8px}.btn-hero-primary,.btn-hero-secondary{padding:12px 20px;font-size:14px}.hero-stats{padding:16px;gap:12px;border-radius:var(--radius-md)}.hero-stat{flex-direction:row;justify-content:center;gap:10px}.hero-stat-icon{width:36px;height:36px}.hero-stat-icon .material-icons{font-size:18px}.hero-stat-value{font-size:18px}.hero-stat-label{font-size:11px}.hero-stat-divider{display:none}.hero-stats-label{font-size:11px;margin-bottom:6px}.features-section{padding:20px 16px 32px}.feature-icon-wrap{width:40px;height:40px}.feature-icon-wrap .material-icons{font-size:20px}.feature-title{font-size:14px}.feature-desc{font-size:13px}.popular-section{padding:0 12px 40px}.section-title{font-size:17px}.section-title .material-icons{font-size:20px}.battles-grid{gap:8px}.battle-list-card{padding:14px 12px;border-radius:var(--radius-md);gap:12px}.battle-rank{width:32px;height:32px;font-size:13px}.battle-list-creator{margin-bottom:2px}.battle-list-title{font-size:13px}.vote-count-badge{font-size:12px}.battle-list-arrow{display:none}.page-container{padding:20px 12px 40px}.page-header{margin-bottom:20px;gap:12px}.page-icon-wrap{width:36px;height:36px}.page-icon-wrap .material-icons{font-size:20px}.page-title{font-size:18px}.form-card{padding:16px 14px;border-radius:var(--radius-lg)}.form-group{margin-bottom:20px}.form-label{font-size:13px;margin-bottom:8px}.form-input{padding:10px 12px;font-size:14px}.option-num{width:26px;height:26px;font-size:12px}.option-input{padding:10px 12px}.btn-remove{width:26px;height:26px}.btn-add-option{padding:10px;font-size:13px}.duration-grid{gap:8px}.duration-btn{padding:10px 6px;border-radius:var(--radius-sm)}.duration-value{font-size:16px}.duration-unit{font-size:11px}.preview-card{padding:16px;border-radius:var(--radius-md)}.preview-label{font-size:11px;margin-bottom:12px}.preview-inner{padding:14px}.preview-title{font-size:15px}.preview-option{padding:10px 12px}.preview-option span:first-child{font-size:13px}.preview-votes{font-size:12px}.battle-page{padding:16px 12px 40px}.battle-view-card{padding:16px 14px;border-radius:var(--radius-md)}.battle-view-creator{font-size:12px;margin-bottom:10px}.battle-view-header{flex-direction:column;gap:8px;margin-bottom:16px}.battle-view-title{font-size:17px}.battle-view-meta{width:100%}.vote-total-badge{font-size:13px;padding:5px 12px}.battle-view-options{gap:8px;margin-bottom:16px}.vote-option{min-height:48px;border-radius:var(--radius-md)}.vote-option-content{padding:10px 12px}.vote-option-label{font-size:13px}.vote-option-count{font-size:14px}.vote-option-pct{font-size:11px;min-width:32px}.vote-click-indicator{padding-right:10px}.vote-click-indicator .material-icons{font-size:16px}.battle-view-footer{padding-top:14px;flex-direction:column;align-items:flex-start;gap:8px}.battle-timer{font-size:13px}.battle-live{font-size:12px}.my-battle-card{padding:14px;border-radius:var(--radius-md)}.my-battle-header{margin-bottom:10px}.my-battle-title{font-size:14px}.my-battle-status{font-size:12px;gap:6px}.btn-delete{width:32px;height:32px}.my-battle-options{margin-bottom:12px;gap:6px}.vote-bar{min-height:40px}.vote-bar-content{padding:8px 12px}.vote-bar-label{font-size:13px}.vote-bar-stats{gap:8px}.vote-bar-count{font-size:13px}.vote-bar-pct{font-size:11px}.my-battle-footer{flex-direction:column;align-items:flex-start;gap:8px;padding-top:12px;font-size:12px}.modal-card{padding:24px 16px;border-radius:var(--radius-lg)}.modal-icon-wrap{width:48px;height:48px}.modal-icon-wrap .material-icons{font-size:26px}.modal-title{font-size:18px}.modal-subtitle{font-size:14px}.modal-hint{font-size:12px}.footer{padding:24px 16px}.footer-logo{font-size:14px}}
@media (max-width:360px){.hero{padding:28px 12px 16px}.hero-title{font-size:20px}.hero-description{font-size:13px}.hero-badge{font-size:10px}.btn-hero-primary,.btn-hero-secondary{padding:11px 16px;font-size:13px}.hero-stats{padding:14px}.page-container{padding:16px 10px 32px}.form-card{padding:14px 12px}.battles-grid{gap:6px}.battle-list-card{padding:12px 10px;gap:10px}.battle-rank{width:28px;height:28px;font-size:12px}.battle-list-title{font-size:12px}}
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:0 0}
::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}
.darkmode ::-webkit-scrollbar-thumb{background:var(--gray-600)}
.darkmode ::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}
::selection{background:rgba(124,58,237,.15);color:var(--primary-dark)}
