:root{--primary: #8b5cf6;--primary-dark: #7c3aed;--primary-light: #a78bfa;--secondary: #f472b6;--success: #34d399;--warning: #fbbf24;--danger: #f87171;--dark: #1e293b;--gray-50: #fefce8;--gray-100: #fef9c3;--gray-200: #fef08a;--gray-300: #fde047;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--gradient: linear-gradient(135deg, #ff6b6b 0%, #feca57 25%, #48dbfb 50%, #ff9ff3 75%, #54a0ff 100%);--gradient-2: linear-gradient(135deg, #a29bfe 0%, #fd79a8 50%, #fdcb6e 100%);--gradient-fun: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-candy: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-sunset: linear-gradient(135deg, #fa709a 0%, #fee140 100%);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 4px 15px -1px rgb(139 92 246 / .2);--shadow-md: 0 10px 25px -3px rgb(139 92 246 / .25);--shadow-lg: 0 20px 40px -5px rgb(139 92 246 / .3);--shadow-xl: 0 25px 50px -12px rgb(139 92 246 / .4);--shadow-glow: 0 0 30px rgb(139 92 246 / .4);--radius: 16px;--radius-lg: 24px;--radius-xl: 32px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Prompt,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(180deg,#fef9c3,#fce7f3,#ddd6fe);background-attachment:fixed;color:var(--gray-800);line-height:1.6;min-height:100vh;min-height:100dvh;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent}#root{min-height:100vh}.app-container{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1200px;margin:0 auto;padding:24px}.container-sm{max-width:600px}.container-md{max-width:800px}.header{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:3px solid transparent;border-image:linear-gradient(90deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3,#54a0ff) 1;padding:16px 24px;position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.75rem;font-weight:900;background:linear-gradient(90deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;animation:gradientShift 3s ease infinite;text-shadow:2px 2px 4px rgba(0,0,0,.1)}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.hero{background:var(--gradient);padding:80px 24px;text-align:center;color:#fff}.hero h1{font-size:3rem;font-weight:800;margin-bottom:16px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.hero p{font-size:1.25rem;opacity:.9;max-width:600px;margin:0 auto 32px}.disco-ball{width:120px;height:120px;margin:0 auto 24px;position:relative;perspective:1000px;animation:disco-float 3s ease-in-out infinite}.disco-ball-inner{width:100%;height:100%;position:relative;transform-style:preserve-3d;animation:disco-spin 8s linear infinite}.disco-tile{position:absolute;width:16px;height:16px;left:50%;top:50%;margin:-8px;background:linear-gradient(135deg,#fff,#e0e0e0,silver);border-radius:2px;box-shadow:inset 0 0 4px #fffc,0 0 8px #ffffff80;animation:disco-sparkle .5s ease-in-out infinite alternate}.disco-tile:nth-child(odd){animation-delay:.25s}.disco-tile:nth-child(3n){background:linear-gradient(135deg,#ff9ff3,#f368e0)}.disco-tile:nth-child(5n){background:linear-gradient(135deg,#48dbfb,#0abde3)}.disco-tile:nth-child(7n){background:linear-gradient(135deg,#feca57,#ff9f43)}.disco-shine{position:absolute;top:10%;left:20%;width:30px;height:30px;background:radial-gradient(circle,rgba(255,255,255,.9) 0%,transparent 70%);border-radius:50%;animation:disco-shine 2s ease-in-out infinite}@keyframes disco-spin{0%{transform:rotateY(0)}to{transform:rotateY(360deg)}}@keyframes disco-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes disco-sparkle{0%{opacity:.7;box-shadow:inset 0 0 4px #fffc,0 0 8px #ffffff4d}to{opacity:1;box-shadow:inset 0 0 8px #fff,0 0 20px #fffc}}@keyframes disco-shine{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:24px;margin-bottom:20px;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);border:2px solid transparent}.card:hover{transform:translateY(-6px) rotate(.5deg);box-shadow:var(--shadow-lg);border-color:#8b5cf633}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-title{font-size:1.25rem;font-weight:700;color:var(--gray-800)}.page-header{background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);background-size:200% 200%;animation:gradientBG 5s ease infinite;padding:48px 24px;margin-bottom:32px;text-align:center;color:#fff;position:relative;overflow:hidden}.page-header:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 50%);animation:floatBubble 10s linear infinite}@keyframes gradientBG{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes floatBubble{0%{transform:translate(0) rotate(0)}to{transform:translate(50px,50px) rotate(360deg)}}.page-header h1{font-size:2rem;font-weight:700;margin-bottom:8px}.page-header p{opacity:.9}.form-group{margin-bottom:20px}.form-label{display:block;font-weight:600;color:var(--gray-700);margin-bottom:8px;font-size:.875rem}.form-input,.form-textarea,.form-select{width:100%;padding:12px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);font-size:1rem;transition:border-color .2s,box-shadow .2s;background:#fff}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.form-textarea{min-height:100px;resize:vertical}.form-hint{font-size:.875rem;color:var(--gray-500);margin-top:4px}.form-error{font-size:.875rem;color:var(--danger);margin-top:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.68,-.55,.265,1.55)}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:.5s}.btn-primary:hover:before{left:100%}.btn-primary:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 10px 30px #667eea66}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover{background:var(--gray-200)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.btn-lg{padding:16px 32px;font-size:1.125rem}.btn-sm{padding:8px 16px;font-size:.875rem}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.candidates-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:24px}.candidate-card{background:#fff;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow);transition:all .4s cubic-bezier(.68,-.55,.265,1.55);cursor:pointer;position:relative;border:3px solid transparent}.candidate-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #8b5cf640;border-color:#8b5cf64d}.candidate-card.selected{border:4px solid #667eea;transform:scale(1.05);box-shadow:0 0 30px #667eea80;animation:selectedPulse 1.5s ease-in-out infinite}@keyframes selectedPulse{0%,to{box-shadow:0 0 20px #667eea66}50%{box-shadow:0 0 40px #667eea99}}.candidate-image{width:100%;aspect-ratio:1;object-fit:cover;background:var(--gray-100)}.candidate-image-placeholder{width:100%;aspect-ratio:1;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);background-size:200% 200%;animation:gradientBG 3s ease infinite;display:flex;align-items:center;justify-content:center;font-size:4rem;color:#fff;text-shadow:2px 2px 8px rgba(0,0,0,.2)}.candidate-info{padding:20px}.candidate-name{font-size:1.25rem;font-weight:700;color:var(--gray-800);margin-bottom:8px}.candidate-description{color:var(--gray-500);font-size:.875rem;line-height:1.5}.candidate-votes{display:flex;align-items:center;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--gray-100)}.vote-count{font-size:1.5rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.vote-label{color:var(--gray-500);font-size:.875rem}.leaderboard{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}.leaderboard-header{background:var(--gradient);color:#fff;padding:24px;text-align:center}.leaderboard-header h2{font-size:1.5rem;font-weight:700}.leaderboard-item{display:flex;align-items:center;padding:16px 24px;border-bottom:1px solid var(--gray-100);transition:background .2s}.leaderboard-item:hover{background:var(--gray-50)}.leaderboard-item:last-child{border-bottom:none}.leaderboard-rank{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.25rem;margin-right:16px;flex-shrink:0}.rank-1{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.rank-2{background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff}.rank-3{background:linear-gradient(135deg,#d97706,#b45309);color:#fff}.rank-other{background:var(--gray-100);color:var(--gray-600)}.leaderboard-avatar{width:56px;height:56px;border-radius:var(--radius);object-fit:cover;margin-right:16px;flex-shrink:0}.leaderboard-avatar-placeholder{width:56px;height:56px;border-radius:var(--radius);background:var(--gradient-2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.25rem;margin-right:16px;flex-shrink:0}.leaderboard-info{flex:1;min-width:0}.leaderboard-name{font-weight:700;color:var(--gray-800);margin-bottom:4px}.leaderboard-desc{font-size:.875rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-votes{text-align:right;flex-shrink:0}.leaderboard-votes-count{font-size:1.5rem;font-weight:800;color:var(--primary)}.leaderboard-votes-label{font-size:.75rem;color:var(--gray-500);text-transform:uppercase}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:24px;text-align:center;box-shadow:var(--shadow);transition:all .3s cubic-bezier(.68,-.55,.265,1.55);border:2px solid transparent}.stat-card:hover{transform:translateY(-4px) scale(1.02);border-color:#8b5cf633;box-shadow:var(--shadow-md)}.stat-value{font-size:2.5rem;font-weight:900;background:linear-gradient(135deg,#667eea,#f093fb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:countPop .5s ease-out}@keyframes countPop{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.stat-label{font-size:.875rem;color:var(--gray-500);margin-top:4px}.qr-section{text-align:center;padding:32px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow)}.qr-code{padding:16px;background:#fff;border-radius:var(--radius);display:inline-block;margin-bottom:16px}.vote-code{font-size:3rem;font-weight:800;letter-spacing:8px;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-top:8px}.vote-url{color:var(--gray-500);font-size:.875rem;margin-top:8px;word-break:break-all}.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge-draft{background:var(--gray-100);color:var(--gray-600)}.badge-active{background:#dcfce7;color:#166534}.badge-ended{background:#fee2e2;color:#991b1b}.countdown{display:flex;gap:16px;justify-content:center;margin:24px 0}.countdown-item{text-align:center}.countdown-value{font-size:2.5rem;font-weight:800;color:var(--primary);background:#fff;border-radius:var(--radius);padding:16px 24px;box-shadow:var(--shadow);min-width:80px}.countdown-label{font-size:.75rem;color:var(--gray-500);margin-top:8px;text-transform:uppercase}.vote-form{background:#fff;border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow);max-width:400px;margin:0 auto}.vote-form h2{text-align:center;margin-bottom:24px;color:var(--gray-800)}.success-message{text-align:center;padding:48px 24px}.success-icon{width:100px;height:100px;background:linear-gradient(135deg,#34d399,#10b981);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:#fff;font-size:3rem;animation:successBounce .6s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 10px 30px #10b98166}@keyframes successBounce{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.success-title{font-size:1.5rem;font-weight:700;color:var(--gray-800);margin-bottom:8px}.success-subtitle{color:var(--gray-500)}.alert{padding:16px 20px;border-radius:var(--radius);margin-bottom:16px}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.alert-warning{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.loading{display:flex;align-items:center;justify-content:center;min-height:200px}.spinner{width:40px;height:40px;border:4px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.campaign-list{display:grid;gap:16px}.campaign-item{background:#fff;border-radius:var(--radius);padding:20px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);transition:box-shadow .2s}.campaign-item:hover{box-shadow:var(--shadow)}.campaign-item-info h3{font-weight:600;color:var(--gray-800);margin-bottom:4px}.campaign-item-meta{font-size:.875rem;color:var(--gray-500)}.campaign-item-actions{display:flex;gap:8px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-4{gap:16px}.hidden{display:none}@media (max-width: 768px){.container{padding:16px}.hero h1{font-size:2rem}.hero p{font-size:1rem}.page-header{padding:32px 16px}.page-header h1{font-size:1.5rem}.candidates-grid{grid-template-columns:repeat(2,1fr);gap:12px}.candidate-card{border-radius:var(--radius-lg)}.candidate-image-placeholder{font-size:2.5rem}.candidate-info{padding:12px}.candidate-name{font-size:1rem}.stats-grid{grid-template-columns:repeat(3,1fr);gap:8px}.stat-card{padding:16px 8px}.stat-value{font-size:1.75rem}.stat-label{font-size:.75rem}.countdown-value{font-size:1.5rem;padding:12px 16px;min-width:60px}.vote-code{font-size:2rem;letter-spacing:4px}.btn{padding:14px 20px;font-size:1rem}.btn-lg{padding:16px 28px;font-size:1.1rem;width:100%}.btn-sm{padding:10px 16px}.form-input,.form-textarea,.form-select{padding:16px;font-size:16px;border-radius:var(--radius-lg)}.vote-form{padding:24px 20px;margin:0 -8px;border-radius:var(--radius-lg)}}@media (max-width: 480px){.header{padding:12px 16px}.logo{font-size:1.5rem}.page-header{padding:24px 16px;margin-bottom:20px}.page-header h1{font-size:1.35rem;line-height:1.3}.page-header p{font-size:.9rem}.container{padding:12px}.candidates-grid{grid-template-columns:repeat(2,1fr);gap:10px}.candidate-card{border-radius:var(--radius);border-width:2px}.candidate-image,.candidate-image-placeholder{aspect-ratio:1}.candidate-image-placeholder{font-size:1.5rem}.candidate-info{padding:8px}.candidate-name{font-size:.8rem;line-height:1.2;margin-bottom:4px}.candidate-description{display:none}.candidate-votes{margin-top:8px;padding-top:8px}.vote-count{font-size:1.1rem}.vote-label{font-size:.75rem}.stats-grid{grid-template-columns:repeat(3,1fr);gap:6px}.stat-card{padding:12px 6px;border-radius:var(--radius)}.stat-value{font-size:1.5rem}.stat-label{font-size:.7rem}.vote-form{padding:20px 16px;margin:0;border-radius:var(--radius)}.vote-form h2{font-size:1.25rem;margin-bottom:20px}.form-group{margin-bottom:16px}.form-label{font-size:.9rem;margin-bottom:6px}.form-input{padding:14px;font-size:16px;border-radius:var(--radius)}.form-hint{font-size:.8rem}.btn{padding:16px 20px;font-size:1rem;border-radius:var(--radius);min-height:52px}.btn-lg{padding:18px 24px;font-size:1.1rem;width:100%;min-height:56px}.btn-sm{padding:12px 16px;min-height:44px}.flex.gap-2{gap:10px}.leaderboard-item{padding:12px}.leaderboard-avatar,.leaderboard-avatar-placeholder{width:40px;height:40px;margin-right:10px}.leaderboard-rank{width:32px;height:32px;font-size:.9rem;margin-right:10px}.leaderboard-name{font-size:.9rem}.leaderboard-votes-count{font-size:1.25rem}.success-message{padding:32px 16px}.success-icon{width:80px;height:80px;font-size:2.5rem}.success-title{font-size:1.25rem}.alert{padding:12px 16px;font-size:.9rem;border-radius:var(--radius)}.card.mb-4{padding:16px}.card.mb-4 img,.card.mb-4>div:first-child>div:first-child{width:50px!important;height:50px!important}.card.mb-4 h3{font-size:1rem}.card.mb-4 p{font-size:.8rem}}@media (max-width: 360px){.candidates-grid{gap:8px}.candidate-info{padding:8px}.candidate-name{font-size:.85rem}.stat-value{font-size:1.25rem}.page-header h1{font-size:1.2rem}}@media (hover: none) and (pointer: coarse){.candidate-card:hover{transform:none;box-shadow:var(--shadow)}.candidate-card:active{transform:scale(.98);box-shadow:var(--shadow-lg)}.btn:hover{transform:none}.btn:active{transform:scale(.98)}.card:hover,.stat-card:hover{transform:none}}.podium-container{background:linear-gradient(180deg,#fff,#fef9c3);border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-lg);overflow:hidden;border:3px solid transparent;border-image:linear-gradient(135deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3) 1;position:relative}.podium-container:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3,#54a0ff);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.podium-empty{text-align:center;padding:80px 24px;color:var(--gray-400);font-size:1.25rem}.podium-chart{display:flex;justify-content:center;align-items:flex-end;gap:16px;min-height:400px;padding:24px 0;overflow-x:auto}.podium-bar-wrapper{display:flex;flex-direction:column;align-items:center;min-width:80px;max-width:120px;animation:podiumEnter .6s ease-out backwards}@keyframes podiumEnter{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.podium-medal{margin-bottom:8px;animation:medalBounce .5s ease-out .3s backwards}@keyframes medalBounce{0%{opacity:0;transform:scale(0) rotate(-180deg)}50%{transform:scale(1.3) rotate(10deg)}to{opacity:1;transform:scale(1) rotate(0)}}.medal-emoji{font-size:2.5rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.podium-votes{font-size:1.75rem;font-weight:800;color:var(--gray-800);margin-bottom:8px;transition:all .5s cubic-bezier(.34,1.56,.64,1)}.podium-bar{width:100%;border-radius:var(--radius) var(--radius) 0 0;position:relative;display:flex;align-items:flex-start;justify-content:center;padding-top:12px;transition:height .8s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(180deg,var(--gray-200) 0%,var(--gray-300) 100%)}.medal-gold .podium-bar{background:linear-gradient(180deg,gold,#ffb800,#c90);box-shadow:0 0 30px #ffd70080,inset 0 2px 10px #ffffff80}.medal-silver .podium-bar{background:linear-gradient(180deg,#e8e8e8,silver,#a0a0a0);box-shadow:0 0 20px #c0c0c080,inset 0 2px 10px #ffffff80}.medal-bronze .podium-bar{background:linear-gradient(180deg,#cd7f32,#b87333,#8b5a2b);box-shadow:0 0 20px #cd7f3280,inset 0 2px 10px #ffffff4d}.podium-avatar-container{position:absolute;top:-32px;left:50%;transform:translate(-50%)}.podium-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;border:4px solid white;box-shadow:var(--shadow-md);transition:transform .3s ease}.podium-bar-wrapper:hover .podium-avatar{transform:scale(1.1)}.podium-avatar-placeholder{width:64px;height:64px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.5rem;border:4px solid white;box-shadow:var(--shadow-md)}.podium-rank{width:36px;height:36px;border-radius:50%;background:var(--gray-600);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;margin-top:12px;box-shadow:var(--shadow)}.medal-gold .podium-rank{background:linear-gradient(135deg,gold,#ffb800);color:#7a5c00}.medal-silver .podium-rank{background:linear-gradient(135deg,#e8e8e8,silver);color:#4a4a4a}.medal-bronze .podium-rank{background:linear-gradient(135deg,#cd7f32,#b87333);color:#3d2817}.podium-name{margin-top:8px;font-weight:600;color:var(--gray-700);text-align:center;font-size:.875rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.podium-legend{display:flex;justify-content:center;gap:24px;margin-top:32px;padding-top:24px;border-top:1px solid var(--gray-200)}.legend-item{display:flex;align-items:center;gap:8px;color:var(--gray-600);font-size:.875rem}.legend-item .medal-emoji{font-size:1.5rem}.medal-gold .podium-bar:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 40%,rgba(255,255,255,.3) 45%,rgba(255,255,255,.3) 55%,transparent 60%);background-size:300% 300%;animation:shimmer 3s infinite}@keyframes shimmer{0%{background-position:100% 100%}to{background-position:0% 0%}}.podium-votes.updated{animation:voteUpdate .5s ease-out}@keyframes voteUpdate{0%{transform:scale(1)}50%{transform:scale(1.3);color:var(--success)}to{transform:scale(1)}}.medal-gold .podium-medal:after{content:"✨";position:absolute;font-size:1rem;animation:sparkle 1.5s infinite}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}@media (max-width: 768px){.podium-container{padding:20px 12px;border-radius:var(--radius-lg)}.podium-chart{gap:8px;min-height:280px;padding:16px 0}.podium-bar-wrapper{min-width:55px;max-width:75px}.medal-emoji{font-size:1.75rem}.podium-votes{font-size:1.1rem}.podium-avatar,.podium-avatar-placeholder{width:44px;height:44px;font-size:1rem;border-width:3px}.podium-avatar-container{top:-22px}.podium-name{font-size:.7rem;max-width:60px}.podium-rank{width:28px;height:28px;font-size:.8rem;margin-top:8px}.podium-legend{gap:12px;flex-wrap:wrap;margin-top:20px;padding-top:16px}.legend-item{font-size:.75rem}.legend-item .medal-emoji{font-size:1.25rem}}@media (max-width: 480px){.podium-container{padding:12px 8px;border-radius:var(--radius);margin:0}.podium-chart{gap:8px;min-height:180px;padding:8px 0;overflow-x:visible;justify-content:space-around}.podium-bar-wrapper{min-width:50px;max-width:65px;flex-shrink:0}.medal-emoji{font-size:1.25rem}.podium-votes{font-size:.85rem;margin-bottom:2px;font-weight:700}.podium-avatar,.podium-avatar-placeholder{width:32px;height:32px;font-size:.8rem;border-width:2px}.podium-avatar-container{top:-16px}.podium-bar{padding-top:6px;border-radius:8px 8px 0 0}.podium-name{font-size:.6rem;max-width:55px;margin-top:4px}.podium-rank{width:20px;height:20px;font-size:.65rem;margin-top:4px}.podium-medal{margin-bottom:4px}.podium-empty{padding:30px 16px;font-size:.9rem}}@media (max-width: 480px){.podium-chart:after{content:"";position:absolute;right:0;top:0;bottom:0;width:30px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8));pointer-events:none;opacity:0;transition:opacity .3s}.podium-chart.scrollable:after{opacity:1}}
