@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes ripple{to{transform:scale(4);opacity:0}}@keyframes celebrate{0%{transform:scale(1)}25%{transform:scale(1.02)}50%{transform:scale(.98)}to{transform:scale(1)}}@keyframes numberPop{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes glow{0%,to{box-shadow:0 0 #6366f100}50%{box-shadow:0 0 20px 4px #6366f14d}}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:var(--color-bg-card);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100}.logo{font-size:1.5rem;font-weight:800;color:var(--color-primary);text-decoration:none;transition:transform .2s ease,color .2s ease}.logo:hover{transform:scale(1.05)}.logo:active{transform:scale(.98)}.desktop-nav{display:flex;align-items:center;gap:1rem}.nav a{color:var(--color-text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;position:relative;transition:color .2s ease,transform .2s ease}.nav a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--color-primary);transition:width .2s ease}.nav a:hover{color:var(--color-primary);transform:translateY(-1px)}.nav a:hover:after{width:100%}.sign-in-btn{background:var(--color-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;position:relative;overflow:hidden}.sign-in-btn:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.sign-in-btn:active{transform:translateY(0);box-shadow:0 2px 4px #6366f133}.mobile-header-actions{display:none;align-items:center;gap:.75rem}.mobile-insights-link{display:flex;align-items:center;justify-content:center;text-decoration:none;color:var(--color-text-secondary);padding:.25rem}.mobile-insights-link svg{width:22px;height:22px;stroke:currentColor}.mobile-insights-link:hover{color:var(--color-primary)}.mobile-admin{font-size:.8rem!important;padding:.3rem .6rem;background:var(--color-primary-light);border-radius:6px}.theme-toggle{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--color-text-muted);border-radius:8px;transition:background .2s,color .2s;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.theme-toggle svg{width:20px;height:20px;stroke:currentColor}.theme-toggle:hover{background:var(--color-bg-secondary);color:var(--color-primary)}.app-main{flex:1;max-width:640px;margin:0 auto;padding:1.5rem 1rem;width:100%}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--color-bg-card);border-top:1px solid var(--color-border);padding:.5rem 0;padding-bottom:max(.5rem,env(safe-area-inset-bottom));z-index:100}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:.5rem;text-decoration:none;color:var(--color-text-secondary);transition:color .2s ease,transform .2s ease;min-height:56px}.mobile-nav-item:active{transform:scale(.9)}.mobile-nav-item.active{color:var(--color-primary)}.mobile-nav-item.active .mobile-nav-icon{animation:bounce .4s ease}.mobile-nav-icon{display:flex;align-items:center;justify-content:center;margin-bottom:.2rem}.mobile-nav-icon svg{width:24px;height:24px;stroke:currentColor;transition:stroke .2s}.nav-user-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:2px solid transparent;transition:border-color .2s}.mobile-nav-item.active .nav-user-avatar{border-color:var(--color-primary)}.mobile-nav-label{font-size:.65rem;font-weight:500}@media(max-width:768px){.desktop-nav{display:none}.mobile-header-actions,.mobile-nav{display:flex}.app-main{padding:1rem .75rem;padding-bottom:80px}.app-header{padding:.6rem 1rem}.logo{font-size:1.25rem}}.category-tabs{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:1rem;-webkit-overflow-scrolling:touch}.category-tab{background:var(--color-bg-secondary);border:none;padding:.5rem 1rem;border-radius:9999px;font-size:.85rem;cursor:pointer;white-space:nowrap;color:var(--color-text-secondary);transition:all .2s}.category-tab:hover{background:var(--color-bg-tertiary)}.category-tab.active{background:var(--color-primary);color:#fff}.poll-list{display:flex;flex-direction:column;gap:1rem}.swipeable-stack-container{position:relative;width:100%;touch-action:pan-y}.swipe-progress{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.swipe-progress-text{font-size:.85rem;font-weight:600;color:var(--color-text-secondary);white-space:nowrap}.swipe-progress-bar{flex:1;height:4px;background:var(--color-bg-secondary);border-radius:9999px;overflow:hidden}.swipe-progress-fill{height:100%;background:var(--color-primary);border-radius:9999px;transition:width .3s ease-out}.swipeable-stack{position:relative;width:100%;overflow:hidden;border-radius:12px;cursor:grab;outline:none}.swipeable-stack:active{cursor:grabbing}.swipeable-track{display:flex;width:100%}.swipeable-card{flex:0 0 100%;width:100%;box-sizing:border-box}.swipeable-card .poll-card{margin:0;height:100%;-webkit-user-select:none;user-select:none}.swipe-hint{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:10}.swipe-hint-text{padding:.5rem 1rem;background:var(--color-primary);color:#fff;border-radius:9999px;font-size:.85rem;font-weight:600;animation:fadeIn .15s ease-out}.swipe-nav{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.swipe-nav-btn{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:50%;font-size:1.25rem;cursor:pointer;color:var(--color-text);transition:all .2s ease}.swipe-nav-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);transform:scale(1.05)}.swipe-nav-btn:active:not(:disabled){transform:scale(.95)}.swipe-nav-btn:disabled{opacity:.3;cursor:not-allowed}.swipeable-card.active .poll-card{animation:none}.swipe-instructions{text-align:center;font-size:.8rem;color:var(--color-text-dimmed);margin-top:.75rem}@media(max-width:768px){.swipe-nav{gap:2rem}.swipe-nav-btn{width:52px;height:52px;font-size:1.5rem}.swipeable-stack{touch-action:pan-y pinch-zoom}}.load-more{display:block;width:100%;margin-top:1rem;padding:.75rem;background:var(--color-bg-secondary);border:none;border-radius:8px;cursor:pointer;font-size:.9rem;color:var(--color-text-secondary);transition:all .2s ease}.load-more:hover{background:var(--color-bg-tertiary);transform:translateY(-2px);box-shadow:0 4px 8px #0000000d}.load-more:active{transform:translateY(0)}.poll-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;animation:fadeInUp .4s ease-out;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.poll-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a;border-color:var(--color-primary-light)}.poll-card:active{transform:translateY(-2px)}.poll-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.poll-tags{display:flex;flex-wrap:wrap;gap:.4rem}.poll-tag{font-size:.75rem;background:var(--color-primary-light);color:var(--color-primary);padding:.2rem .6rem;border-radius:9999px;white-space:nowrap;transition:transform .2s ease,background .2s ease;cursor:pointer}.poll-tag:hover{transform:scale(1.05);background:#6366f140}.poll-responses{font-size:.75rem;color:var(--color-text-dimmed)}.poll-question{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:var(--color-text);line-height:1.5}.poll-options{display:flex;flex-direction:column;gap:.5rem}.poll-option{position:relative;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:10px;cursor:pointer;font-size:.95rem;text-align:left;overflow:hidden;transition:all .25s cubic-bezier(.4,0,.2,1)}.poll-option:hover:not(:disabled):not(.voted){border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #6366f126}.poll-option:active:not(:disabled):not(.voted){transform:scale(.97);box-shadow:0 2px 4px #6366f11a}.poll-option.voted{cursor:default}.poll-option.selected{border-color:var(--color-primary);background:var(--color-primary-light);animation:celebrate .4s ease-out}.poll-option.just-voted{animation:celebrate .5s ease-out,glow 1s ease-out}.option-text{position:relative;z-index:1;color:var(--color-text)}.option-result{display:flex;align-items:center;gap:.5rem}.option-bar{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,var(--color-primary-light),rgba(99,102,241,.2));border-radius:8px;transition:width .8s cubic-bezier(.4,0,.2,1);z-index:0}.option-percentage{position:relative;z-index:1;font-weight:600;font-size:.9rem;color:var(--color-primary);animation:fadeIn .3s ease-out .3s both}.poll-options.with-images{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.poll-option.has-image{flex-direction:column;align-items:stretch;padding:0;overflow:hidden}.poll-option.has-image .option-image{width:100%;height:120px;overflow:hidden;position:relative}.poll-option.has-image .option-image img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.poll-option.has-image:hover:not(:disabled):not(.voted) .option-image img{transform:scale(1.05)}.poll-option.has-image .option-text{padding:.5rem .75rem;text-align:center;font-size:.85rem}.poll-option.has-image .option-bar{bottom:0;top:auto;height:4px;border-radius:0 0 8px 8px}.poll-option.has-image .option-percentage{position:absolute;bottom:.5rem;right:.5rem;background:#0009;color:#fff;padding:.15rem .4rem;border-radius:4px;font-size:.75rem}.poll-option.has-image .my-vote-badge{margin-right:.25rem}@media(max-width:480px){.poll-options.with-images{grid-template-columns:1fr}.poll-option.has-image .option-image{height:100px}}.my-vote-badge{display:inline-block;background:var(--color-primary);color:#fff;font-size:.65rem;font-weight:600;padding:.15rem .4rem;border-radius:4px;margin-right:.5rem;vertical-align:middle}.similarity-message{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem 1rem;background:linear-gradient(135deg,var(--color-primary-light),rgba(99,102,241,.15));border-radius:10px;font-size:.85rem;color:var(--color-primary);font-weight:500;animation:slideUp .4s ease-out}.similarity-icon{font-size:1.1rem}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.poll-timer{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:var(--color-text-dimmed)}.poll-timer.urgent{color:var(--color-error);font-weight:500}.poll-timer-icon{font-size:.85rem}.create-poll{max-width:480px;margin:0 auto}.create-poll h2{margin-bottom:1.5rem;font-size:1.3rem;color:var(--color-text)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.4rem}.form-group input[type=text],.form-group select,.form-group input[type=datetime-local]{width:100%;padding:.65rem .75rem;border:1px solid var(--color-border);border-radius:8px;font-size:.95rem;box-sizing:border-box;background:var(--color-bg-card);color:var(--color-text);transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #6366f126;transform:translateY(-1px)}.char-count{display:block;text-align:right;font-size:.75rem;color:var(--color-text-dimmed);margin-top:.25rem}.tag-input-wrapper{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg-card);min-height:42px;align-items:center}.tag-input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a}.tag-chip{display:inline-flex;align-items:center;gap:.3rem;background:var(--color-primary-light);color:var(--color-primary);padding:.25rem .5rem;border-radius:9999px;font-size:.85rem}.tag-remove{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:1rem;line-height:1;padding:0;opacity:.7}.tag-remove:hover{opacity:1}.tag-input{flex:1;min-width:100px;border:none;background:transparent;font-size:.95rem;padding:.25rem 0;color:var(--color-text)}.tag-input:focus{outline:none}.tag-input::placeholder{color:var(--color-text-dimmed)}.tag-hint{display:block;font-size:.75rem;color:var(--color-text-dimmed);margin-top:.4rem}.option-input{display:flex;gap:.5rem;margin-bottom:.5rem}.option-input input{flex:1}.remove-option{background:none;border:1px solid var(--color-error);color:var(--color-error);padding:.4rem .75rem;border-radius:8px;cursor:pointer;font-size:.8rem}.add-option{width:100%;padding:.6rem;background:var(--color-bg-secondary);border:2px dashed var(--color-border);border-radius:8px;cursor:pointer;font-size:.85rem;color:var(--color-text-muted);transition:all .2s}.add-option:hover{border-color:var(--color-primary);color:var(--color-primary)}.option-input-group{margin-bottom:.75rem}.option-image-upload{margin-top:.5rem;border-radius:8px;overflow:hidden}.image-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;background:var(--color-bg-secondary);border:2px dashed var(--color-border);border-radius:8px;cursor:pointer;transition:all .2s}.image-dropzone:hover{border-color:var(--color-primary);background:var(--color-bg-card)}.dropzone-icon{font-size:1.5rem;margin-bottom:.25rem}.dropzone-text{font-size:.85rem;color:var(--color-text-secondary)}.dropzone-hint{font-size:.75rem;color:var(--color-text-dimmed);margin-top:.25rem}.image-uploading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background:var(--color-bg-secondary);border-radius:8px;color:var(--color-text-muted);font-size:.85rem}.image-uploading .spinner{width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.image-preview{position:relative;display:inline-block;max-width:100%}.image-preview img{max-width:100%;max-height:150px;border-radius:8px;object-fit:cover}.image-remove{position:absolute;top:.25rem;right:.25rem;width:24px;height:24px;background:#0009;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center}.image-remove:hover{background:#000c}.upload-error{color:var(--color-error);font-size:.8rem;margin-top:.5rem}.submit-btn{width:100%;padding:.75rem;background:var(--color-primary);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:all .2s ease;position:relative;overflow:hidden}.submit-btn:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 6px 20px #6366f159}.submit-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #6366f140}.submit-btn:disabled{background:var(--color-text-dimmed);cursor:not-allowed}.profile{max-width:480px;margin:0 auto}.profile h2{margin-bottom:1.5rem;font-size:1.3rem;color:var(--color-text)}.profile-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.profile-tab{background:none;border:none;padding:.75rem 1rem;font-size:.9rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s ease;position:relative}.profile-tab:hover{color:var(--color-primary);background:#6366f10d}.profile-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.checkbox-label{display:flex!important;align-items:center;gap:.5rem;font-weight:400!important;font-size:.85rem!important;color:var(--color-text-muted)!important;margin-top:.4rem}.checkbox-label input[type=checkbox]{width:auto}.privacy-notice{font-size:.8rem;color:var(--color-text-dimmed);background:var(--color-bg-secondary);padding:.75rem;border-radius:8px;line-height:1.5;margin-bottom:1rem}.similarity-panel{padding:1rem 0}.similarity-hero{text-align:center;padding:2rem 1rem;background:linear-gradient(135deg,var(--color-primary-light),rgba(99,102,241,.2));border-radius:16px;margin-bottom:1.5rem}.similarity-emoji{font-size:3rem;margin-bottom:.75rem}.similarity-message-text{font-size:1.1rem;font-weight:600;color:var(--color-text);margin:0;line-height:1.5}.similarity-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem}.similarity-stat{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1rem;text-align:center}.similarity-stat.highlight{background:var(--color-primary-light);border-color:var(--color-primary)}.similarity-stat .stat-number{display:block;font-size:1.75rem;font-weight:700;color:var(--color-primary);line-height:1.2}.similarity-stat .stat-label{font-size:.8rem;color:var(--color-text-secondary)}.similarity-tip{background:var(--color-bg-secondary);border-radius:12px;padding:1.25rem;text-align:center}.similarity-tip p{margin:0 0 1rem;font-size:.95rem;color:var(--color-text-secondary)}.go-vote-btn{display:inline-block;background:var(--color-primary);color:#fff;padding:.6rem 1.5rem;border-radius:9999px;text-decoration:none;font-weight:600;font-size:.9rem;transition:opacity .2s}.go-vote-btn:hover{opacity:.9}.similarity-explanation{margin-top:1.5rem;padding:1rem;background:var(--color-bg-secondary);border-radius:10px;font-size:.85rem;color:var(--color-text-secondary);line-height:1.6}.similarity-explanation p{margin:0}.similarity-explanation strong{color:var(--color-text)}.statistics-panel{padding:1rem 0;animation:fadeInUp .4s ease-out}.statistics-empty{text-align:center;padding:3rem 1rem}.statistics-empty .empty-icon{font-size:3rem;margin-bottom:1rem}.statistics-empty p{color:var(--color-text-secondary);margin-bottom:1.5rem}.new-achievements-banner{display:flex;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1f2937;padding:.75rem 1rem;border-radius:12px;font-weight:600;margin-bottom:1.5rem;animation:pulse 1.5s ease-in-out infinite}.voting-heatmap{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.voting-heatmap h4{margin:0 0 1rem;font-size:.95rem;color:var(--color-text)}.heatmap-grid{display:flex;flex-direction:column;gap:3px}.heatmap-header,.heatmap-row{display:flex;gap:3px}.heatmap-corner,.heatmap-day-label{width:28px;flex-shrink:0;font-size:.7rem;color:var(--color-text-dimmed);display:flex;align-items:center;justify-content:center}.heatmap-hour-label{flex:1;font-size:.65rem;color:var(--color-text-dimmed);text-align:center}.heatmap-cell{flex:1;aspect-ratio:1;min-height:24px;border-radius:3px;background:var(--color-bg-secondary);transition:transform .1s ease}.heatmap-cell:hover{transform:scale(1.1)}.heatmap-cell.intensity-0{background:var(--color-bg-secondary)}.heatmap-cell.intensity-1{background:#6366f133}.heatmap-cell.intensity-2{background:#6366f166}.heatmap-cell.intensity-3{background:#6366f199}.heatmap-cell.intensity-4{background:var(--color-primary)}.heatmap-legend{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;margin-top:.75rem;font-size:.7rem;color:var(--color-text-dimmed)}.legend-cells{display:flex;gap:2px}.legend-cells .heatmap-cell{width:12px;height:12px;min-height:auto}.category-chart{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.category-chart h4{margin:0 0 1rem;font-size:.95rem;color:var(--color-text)}.category-chart.empty{text-align:center;padding:2rem}.category-chart.empty p{margin:0;color:var(--color-text-dimmed)}.category-bars{display:flex;flex-direction:column;gap:.5rem}.category-bar-row{display:flex;align-items:center;gap:.75rem}.category-label{width:80px;flex-shrink:0;font-size:.8rem;color:var(--color-primary);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-label:hover{text-decoration:underline}.category-bar-wrapper{flex:1;height:8px;background:var(--color-bg-secondary);border-radius:4px;overflow:hidden}.category-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),#8b5cf6);border-radius:4px;transition:width .5s ease-out}.category-count{width:32px;flex-shrink:0;font-size:.75rem;color:var(--color-text-muted);text-align:right}.achievements-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.achievements-section h4{margin:0 0 1rem;font-size:.95rem;color:var(--color-text)}.achievements-section h5{margin:0 0 .75rem;font-size:.85rem;color:var(--color-text-secondary);font-weight:500}.achievements-earned{margin-bottom:1.25rem}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.achievement-card{display:flex;flex-direction:column;align-items:center;padding:.75rem .5rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;transition:transform .2s ease}.achievement-card:hover{transform:translateY(-2px)}.achievement-card.earned{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fbbf24}.achievement-emoji{font-size:1.5rem;margin-bottom:.25rem}.achievement-name{font-size:.7rem;text-align:center;color:var(--color-text)}.achievements-progress{margin-top:.75rem}.achievements-list{display:flex;flex-direction:column;gap:.75rem}.achievement-progress-item{display:flex;align-items:center;gap:.75rem}.achievement-info{display:flex;align-items:center;gap:.5rem;min-width:100px}.achievement-info .achievement-emoji{font-size:1.2rem;margin-bottom:0}.achievement-info .achievement-name{font-size:.8rem}.achievement-bar-wrapper{flex:1;display:flex;align-items:center;gap:.5rem}.achievement-bar{flex:1;height:6px;background:var(--color-bg-secondary);border-radius:3px;overflow:hidden}.achievement-bar-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width .5s ease-out}.achievement-progress-text{font-size:.7rem;color:var(--color-text-dimmed);min-width:40px;text-align:right}.achievements-empty{text-align:center;padding:1.5rem;color:var(--color-text-dimmed);font-size:.9rem}.activity-panel{padding:1rem 0;animation:fadeInUp .4s ease-out}.activity-section{margin-bottom:2rem}.activity-section:last-child{margin-bottom:0}.activity-section h4{font-size:1rem;font-weight:600;color:var(--color-text);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.xp-panel{padding:1rem 0;animation:fadeInUp .4s ease-out}.xp-hero{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:16px;margin-bottom:1.5rem;color:#fff;transition:transform .2s ease,box-shadow .2s ease}.xp-hero:hover{transform:translateY(-2px);box-shadow:0 8px 24px #6366f166}.xp-level-badge{display:flex;flex-direction:column;align-items:flex-start}.level-number{font-size:2rem;font-weight:800;line-height:1}.level-title{font-size:.9rem;opacity:.9;margin-top:.25rem}.xp-total{text-align:right}.xp-value{display:block;font-size:1.75rem;font-weight:700;line-height:1}.xp-label{font-size:.85rem;opacity:.8}.xp-progress-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin-bottom:1.25rem}.xp-progress-header{display:flex;justify-content:space-between;font-size:.85rem;color:var(--color-text-secondary);margin-bottom:.75rem}.xp-progress-bar{height:10px;background:var(--color-bg-secondary);border-radius:9999px;overflow:hidden}.xp-progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6,#6366f1);background-size:200% 100%;border-radius:9999px;transition:width .8s cubic-bezier(.4,0,.2,1);animation:shimmer 2s infinite linear}.xp-progress-hint{margin:.75rem 0 0;font-size:.8rem;color:var(--color-text-muted);text-align:center}.xp-rewards-info{background:var(--color-bg-secondary);border-radius:12px;padding:1.25rem;margin-bottom:1.25rem}.xp-rewards-info h4{margin:0 0 .75rem;font-size:.9rem;color:var(--color-text)}.xp-rewards-info ul{list-style:none;padding:0;margin:0}.xp-rewards-info li{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.85rem;border-bottom:1px solid var(--color-border)}.xp-rewards-info li:last-child{border-bottom:none}.reward-action{color:var(--color-text-secondary)}.reward-xp{color:var(--color-primary);font-weight:600}.xp-history{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.xp-history h4{margin:0 0 .75rem;font-size:.9rem;color:var(--color-text)}.xp-history-list{list-style:none;padding:0;margin:0}.xp-history-item{display:flex;justify-content:space-between;padding:.6rem 0;font-size:.85rem;border-bottom:1px solid var(--color-border)}.xp-history-item:last-child{border-bottom:none}.history-reason{color:var(--color-text-secondary)}.history-xp{color:#10b981;font-weight:600}.personality-panel{padding:1rem 0;animation:fadeInUp .4s ease-out}.personality-empty{text-align:center;padding:3rem 1rem}.personality-empty .empty-icon{font-size:3rem;margin-bottom:1rem}.personality-empty p{color:var(--color-text-secondary);margin-bottom:1rem}.personality-progress{max-width:200px;margin:0 auto 1.5rem}.personality-progress .progress-bar{height:8px;background:var(--color-bg-secondary);border-radius:9999px;overflow:hidden;margin-bottom:.5rem}.personality-progress .progress-fill{height:100%;background:var(--color-primary);border-radius:9999px;transition:width .4s ease-out}.personality-progress .progress-text{font-size:.8rem;color:var(--color-text-secondary)}.personality-type-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:16px;margin-bottom:1.5rem;color:#fff;animation:scaleIn .4s ease-out}.personality-type-card.mbti-style{flex-direction:column;align-items:stretch;text-align:center}.type-code-badge{display:inline-block;padding:.25rem .75rem;background:#fff3;border-radius:9999px;font-size:.85rem;font-weight:700;letter-spacing:.15em;margin-bottom:.75rem;align-self:center}.type-main{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.75rem}.type-emoji{font-size:3rem;animation:bounce 1s ease-out}.type-info{text-align:left}.type-name{font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.type-title{font-size:.9rem;opacity:.9;margin:0}.type-description{font-size:.9rem;opacity:.9;margin:0 0 1rem;line-height:1.5}.type-traits{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem}.trait-tag{padding:.25rem .75rem;background:#ffffff26;border-radius:9999px;font-size:.8rem}.personality-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.personality-summary .summary-stat{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1rem;text-align:center;transition:transform .2s ease}.personality-summary .summary-stat:hover{transform:translateY(-2px)}.personality-summary .summary-stat.highlight{background:var(--color-primary-light);border-color:var(--color-primary)}.summary-value{display:block;font-size:1.5rem;font-weight:700;color:var(--color-primary);line-height:1.2}.summary-label{font-size:.75rem;color:var(--color-text-secondary)}.personality-dimensions{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin-bottom:1.25rem}.personality-dimensions h4{margin:0 0 1rem;font-size:.9rem;color:var(--color-text)}.mbti-dimensions .dimension-row{flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.mbti-dimensions .dimension-row:last-child{margin-bottom:0}.dimension-labels{display:flex;justify-content:space-between;align-items:center;width:100%}.dimension-label{font-size:.8rem;color:var(--color-text-muted);transition:color .2s,font-weight .2s}.dimension-label.active{color:var(--color-primary);font-weight:600}.dimension-letter{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-primary);color:#fff;border-radius:6px;font-size:.85rem;font-weight:700}.mbti-dimensions .dimension-bar-container{display:flex;align-items:center;gap:.75rem;width:100%}.dimension-score{font-size:.8rem;font-weight:600;color:var(--color-primary);min-width:40px;text-align:right}.dimension-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.dimension-row:last-child{margin-bottom:0}.dimension-low-label,.dimension-high-label{font-size:.75rem;color:var(--color-text-secondary);width:50px;flex-shrink:0}.dimension-low-label{text-align:right}.dimension-high-label{text-align:left}.dimension-bar-container{flex:1;position:relative}.dimension-bar{height:8px;background:var(--color-bg-secondary);border-radius:9999px;position:relative;overflow:visible;flex:1}.dimension-fill{height:100%;background:linear-gradient(90deg,#a5b4fc,#6366f1);border-radius:9999px;transition:width .8s cubic-bezier(.4,0,.2,1)}.dimension-marker{position:absolute;top:50%;width:16px;height:16px;background:var(--color-primary);border:3px solid white;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #6366f166;transition:left .8s cubic-bezier(.4,0,.2,1)}.personality-recent{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.personality-recent h4{margin:0 0 .5rem;font-size:.9rem;color:var(--color-text)}.recent-summary{font-size:.85rem;color:var(--color-text-secondary);margin:0 0 1rem}.recent-polls-list{list-style:none;padding:0;margin:0}.recent-poll-item{display:flex;align-items:center;gap:.5rem;padding:.6rem 0;border-bottom:1px solid var(--color-border);font-size:.85rem}.recent-poll-item:last-child{border-bottom:none}.recent-poll-item .poll-indicator{font-size:1rem}.recent-poll-item .poll-question-link{color:var(--color-text);text-decoration:none;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-poll-item .poll-question-link:hover{color:var(--color-primary)}.recent-poll-item.with-majority{opacity:.8}.recent-poll-item.unique .poll-indicator{animation:wiggle .5s ease-out}.poll-detail{max-width:640px;margin:0 auto}.back-link{display:inline-block;color:var(--color-text-muted);text-decoration:none;font-size:.9rem;margin-bottom:1rem}.back-link:hover{color:var(--color-primary)}.poll-question-link{text-decoration:none;color:inherit}.poll-question-link:hover .poll-question{color:var(--color-primary)}.poll-expires{font-size:.8rem;color:var(--color-text-dimmed);margin-bottom:1rem}.feed-controls{margin-bottom:.5rem}.feed-actions{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.feed-left-actions{display:flex;align-items:center;gap:.5rem}.view-mode-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;color:var(--color-text-muted);transition:all .2s}.view-mode-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.view-mode-btn.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.hide-voted-btn{display:flex;align-items:center;gap:.4rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);padding:.4rem .75rem;border-radius:9999px;font-size:.8rem;cursor:pointer;color:var(--color-text-muted);transition:all .2s;white-space:nowrap}.hide-voted-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.hide-voted-btn.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.voted-count{background:var(--color-primary);color:#fff;font-size:.7rem;padding:.1rem .4rem;border-radius:9999px;font-weight:600}.voted-count-label{font-size:.8rem;color:var(--color-text-muted);padding:.35rem .6rem;background:var(--color-bg-secondary);border-radius:8px}.sort-options{display:flex;gap:.5rem}.sort-btn{background:none;border:none;padding:.25rem 0;font-size:.85rem;cursor:pointer;color:var(--color-text-dimmed);font-weight:500;transition:color .2s}.sort-btn.active{color:var(--color-text);border-bottom:2px solid var(--color-primary)}.results{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin-top:1rem}.results-header{margin-bottom:1rem}.results-total{font-size:.85rem;font-weight:600;color:var(--color-text-secondary)}.results-tabs{display:flex;gap:.25rem;margin-bottom:1rem;background:var(--color-bg-secondary);border-radius:8px;padding:.2rem}.results-tab{flex:1;padding:.5rem;border:none;background:none;border-radius:6px;font-size:.85rem;cursor:pointer;color:var(--color-text-muted);font-weight:500;transition:all .2s}.results-tab.active{background:var(--color-bg-card);color:var(--color-text);box-shadow:0 1px 2px #0000000d}.results-tab:disabled{opacity:.4;cursor:not-allowed}.results-bars{display:flex;flex-direction:column;gap:.75rem}.result-row{display:flex;align-items:center;gap:.75rem}.result-row.compact{gap:.5rem}.result-label{min-width:80px;font-size:.85rem;color:var(--color-text-secondary);flex-shrink:0}.result-bar-wrapper{flex:1;height:24px;background:var(--color-bg-secondary);border-radius:6px;overflow:hidden}.result-bar-fill{height:100%;background:var(--color-primary-gradient);border-radius:6px;transition:width .6s ease;min-width:2px}.result-value{min-width:70px;text-align:right;font-size:.85rem;font-weight:600;color:var(--color-primary);flex-shrink:0}.result-count{font-weight:400;color:var(--color-text-dimmed);font-size:.75rem;margin-left:.2rem}.results-segments{display:flex;flex-direction:column;gap:1.25rem}.segment-group{padding-top:.5rem}.segment-title{font-size:.9rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.5rem}.segment-count{font-weight:400;color:var(--color-text-dimmed);font-size:.8rem;margin-left:.3rem}.results-comparison{padding:1rem 0}.comparison-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.legend-item{display:flex;align-items:center;gap:.4rem}.legend-color{width:12px;height:12px;border-radius:3px}.legend-label{font-size:.8rem;color:var(--color-text-secondary)}.legend-count{color:var(--color-text-dimmed);margin-left:.25rem}.comparison-chart{display:flex;flex-direction:column;gap:1rem}.comparison-row{display:flex;flex-direction:column;gap:.5rem}.comparison-label{font-size:.85rem;font-weight:500;color:var(--color-text)}.comparison-bars{display:flex;flex-direction:column;gap:.35rem}.comparison-bar-container{display:flex;align-items:center;gap:.5rem;height:20px}.comparison-bar{height:100%;border-radius:4px;min-width:4px;transition:width .3s ease}.comparison-value{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);min-width:35px}.results-empty{text-align:center;padding:2rem 1rem;color:var(--color-text-dimmed);font-size:.85rem}.share-buttons{display:flex;gap:.5rem;margin-top:1rem}.share-btn{flex:1;padding:.6rem;border:1px solid var(--color-border);border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;background:var(--color-bg-card);color:var(--color-text-secondary);transition:all .15s}.share-btn:hover{background:var(--color-bg-secondary)}.share-btn.copy{border-color:var(--color-primary);color:var(--color-primary)}.share-btn.kakao{border-color:#fee500;background:#fee500;color:#3c1e1e}.share-btn.twitter{border-color:#1d9bf0;color:#1d9bf0}.skeleton{background:linear-gradient(90deg,var(--color-bg-secondary) 25%,var(--color-bg-tertiary) 50%,var(--color-bg-secondary) 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s infinite;border-radius:6px}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{pointer-events:none}.skeleton-badge{width:50px;height:20px}.skeleton-text-sm{width:60px;height:14px}.skeleton-title{width:80%;height:22px;margin:0 0 1rem}.skeleton-option{height:44px;border:none!important;background:linear-gradient(90deg,var(--color-bg-secondary) 25%,var(--color-bg-tertiary) 50%,var(--color-bg-secondary) 75%)!important;background-size:200% 100%!important;animation:skeleton-pulse 1.5s infinite;border-radius:10px}.skeleton-results-block{height:200px;margin-top:1rem;border-radius:12px}.error-state{text-align:center;padding:3rem 1rem}.error-state p{color:var(--color-error);font-size:.95rem;margin-bottom:1rem}.retry-btn{background:var(--color-primary);color:#fff;border:none;padding:.5rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;margin-bottom:.5rem}.retry-btn:hover{background:var(--color-primary-hover)}.comments-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin-top:1rem}.comments-title{font-size:1rem;font-weight:600;margin:0 0 1rem;color:var(--color-text)}.comments-count{font-weight:400;color:var(--color-text-dimmed);font-size:.85rem}.comment-form{margin-bottom:1.25rem}.comment-input{width:100%;padding:.65rem .75rem;border:1px solid var(--color-border);border-radius:8px;font-size:.9rem;font-family:inherit;resize:vertical;min-height:60px;box-sizing:border-box;background:var(--color-bg-card);color:var(--color-text)}.comment-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a}.comment-form-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem}.comment-char-count{font-size:.75rem;color:var(--color-text-dimmed)}.comment-submit{background:var(--color-primary);color:#fff;border:none;padding:.4rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer}.comment-submit:hover:not(:disabled){background:var(--color-primary-hover)}.comment-submit:disabled{background:var(--color-text-dimmed);cursor:not-allowed}.comment-login-notice{font-size:.85rem;color:var(--color-text-dimmed);text-align:center;padding:1rem;background:var(--color-bg-secondary);border-radius:8px;margin-bottom:1rem}.comment-list{display:flex;flex-direction:column;gap:.75rem}.comment-item{padding:.75rem 0;border-bottom:1px solid var(--color-border-light)}.comment-item:last-child{border-bottom:none}.comment-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}.comment-author{font-size:.8rem;font-weight:600;color:var(--color-text-secondary)}.comment-time{font-size:.75rem;color:var(--color-text-dimmed)}.comment-actions{margin-left:auto;display:flex;gap:.5rem}.comment-edit,.comment-delete{background:none;border:none;font-size:.75rem;cursor:pointer;padding:0}.comment-edit{color:var(--color-text-muted)}.comment-delete{color:var(--color-error)}.comment-edit:hover,.comment-delete:hover{text-decoration:underline}.comment-edit:disabled,.comment-delete:disabled{opacity:.5;cursor:not-allowed}.comment-item.editing{padding:.75rem;background:var(--color-bg-secondary);border-radius:8px}.comment-edit-input{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.9rem;resize:none;background:var(--color-bg-card);color:var(--color-text);box-sizing:border-box}.comment-edit-input:focus{outline:none;border-color:var(--color-primary)}.comment-edit-actions{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.comment-edit-actions .comment-char-count{margin-right:auto;font-size:.75rem;color:var(--color-text-dimmed)}.comment-cancel,.comment-save{padding:.35rem .75rem;border-radius:6px;font-size:.8rem;cursor:pointer;border:none}.comment-cancel{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.comment-save{background:var(--color-primary);color:#fff}.comment-cancel:hover{background:var(--color-border)}.comment-save:hover{background:var(--color-primary-hover)}.comment-save:disabled,.comment-cancel:disabled{opacity:.5;cursor:not-allowed}.comment-content{font-size:.9rem;color:var(--color-text-secondary);margin:0;line-height:1.5;word-break:break-word}.comment-empty{text-align:center;padding:1.5rem 1rem;color:var(--color-text-dimmed);font-size:.85rem}.comment-load-more{display:block;width:100%;margin-top:.5rem;padding:.5rem;background:none;border:1px solid var(--color-border);border-radius:8px;cursor:pointer;font-size:.85rem;color:var(--color-text-muted)}.comment-load-more:hover{background:var(--color-bg-secondary)}.comment-footer{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.comment-like-btn{display:flex;align-items:center;gap:.25rem;background:none;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;color:var(--color-text-dimmed);transition:all .15s ease}.comment-like-btn:hover:not(:disabled){background:var(--color-bg-secondary)}.comment-like-btn:disabled{cursor:default;opacity:.7}.comment-like-btn.liked{color:#e53e3e}.comment-like-btn .like-icon{font-size:.9rem}.comment-like-btn .like-count{min-width:.75rem}.comment-replies-toggle,.comment-reply-btn{background:none;border:none;cursor:pointer;font-size:.75rem;color:var(--color-text-muted);padding:.25rem .5rem;border-radius:4px}.comment-replies-toggle:hover,.comment-reply-btn:hover{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.reply-item{margin-left:1.5rem;padding-left:1rem;border-left:2px solid var(--color-border-light)}.reply-form{margin-top:.75rem;margin-left:1.5rem;padding-left:1rem;border-left:2px solid var(--color-primary)}.reply-input{min-height:50px;font-size:.85rem}.reply-form-footer{display:flex;justify-content:flex-end;align-items:center;gap:.5rem;margin-top:.5rem}.reply-form-footer .comment-char-count{margin-right:auto}.replies-list{margin-top:.75rem}.replies-loading{margin-left:1.5rem;padding:.5rem;color:var(--color-text-dimmed);font-size:.8rem}.replies-load-more{display:block;margin-left:1.5rem;margin-top:.5rem;padding:.35rem .75rem;background:none;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;font-size:.75rem;color:var(--color-text-muted)}.replies-load-more:hover{background:var(--color-bg-secondary)}.loading,.empty{text-align:center;padding:3rem 1rem;color:var(--color-text-dimmed);font-size:.95rem}@media(max-width:640px){.app-header{padding:.5rem 1rem}.logo{font-size:1.25rem}.nav{gap:.5rem}.nav a{font-size:.8rem}.app-main{padding:1rem .75rem}.poll-question{font-size:1rem}.category-tabs{padding-bottom:.75rem}.category-tab{padding:.4rem .75rem;font-size:.8rem}.result-label{min-width:60px;font-size:.8rem}.result-value{min-width:55px;font-size:.8rem}.share-buttons{flex-direction:column}.create-poll,.profile{max-width:100%}}.admin-link{color:var(--color-primary)!important;font-weight:600!important}.admin-page{max-width:1200px;margin:0 auto;padding:1.5rem}.admin-page h1{font-size:1.75rem;margin-bottom:1.5rem;color:var(--color-text)}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-border);padding-bottom:.5rem}.admin-tab{padding:.75rem 1.5rem;border:none;background:transparent;color:var(--color-text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;border-radius:.5rem;transition:all .2s}.admin-tab:hover{background:var(--color-bg-hover);color:var(--color-text)}.admin-tab.active{background:var(--color-primary);color:#fff}.admin-content{background:var(--color-bg-card);border-radius:1rem;padding:1.5rem;border:1px solid var(--color-border)}.admin-loading,.admin-error{padding:2rem;text-align:center;color:var(--color-text-secondary)}.admin-error{color:var(--color-danger)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--color-bg);border-radius:.75rem;padding:1.5rem;text-align:center;border:1px solid var(--color-border)}.stat-value{font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:.25rem}.stat-label{font-size:.9rem;color:var(--color-text-secondary)}.stats-section{margin-top:1.5rem}.stats-section h3{font-size:1.1rem;margin-bottom:1rem;color:var(--color-text)}.stats-row{display:flex;gap:2rem;color:var(--color-text-secondary)}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border)}.admin-table th{font-weight:600;color:var(--color-text-secondary);font-size:.85rem;text-transform:uppercase}.admin-table td{color:var(--color-text)}.admin-table .poll-question,.admin-table .comment-content{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-table .poll-count,.admin-table .poll-date,.admin-table .comment-date{white-space:nowrap;color:var(--color-text-secondary)}.admin-table .inactive-row{opacity:.6}.status-badge{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.status-badge.active{background:var(--color-success-bg, #dcfce7);color:var(--color-success, #16a34a)}.status-badge.inactive{background:var(--color-danger-bg, #fee2e2);color:var(--color-danger, #dc2626)}.poll-actions,.comment-actions{display:flex;gap:.5rem;white-space:nowrap}.btn-toggle,.btn-delete{padding:.4rem .75rem;border:none;border-radius:.375rem;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-toggle{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border)}.btn-toggle:hover{background:var(--color-bg-hover)}.btn-delete{background:var(--color-danger, #dc2626);color:#fff}.btn-delete:hover{opacity:.9}.btn-toggle:disabled,.btn-delete:disabled{opacity:.5;cursor:not-allowed}.panel-controls{margin-bottom:1rem}.panel-controls select{padding:.5rem 1rem;border-radius:.5rem;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-size:.9rem}.empty-state{padding:2rem;text-align:center;color:var(--color-text-secondary)}@media(max-width:768px){.admin-page{padding:1rem}.admin-tabs{flex-wrap:wrap}.admin-tab{padding:.5rem 1rem;font-size:.85rem}.admin-table{font-size:.85rem}.admin-table th,.admin-table td{padding:.5rem}.admin-table .poll-question,.admin-table .comment-content,.admin-table .comment-poll{max-width:150px}.poll-actions,.comment-actions{flex-direction:column}}.ranking-page{max-width:640px;margin:0 auto;padding:1rem}.ranking-page h1{font-size:1.5rem;margin-bottom:1rem}.ranking-filters{margin-bottom:1.5rem}.ranking-types{display:flex;gap:.5rem;margin-bottom:.75rem}.ranking-type-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.75rem;border:2px solid var(--color-border);border-radius:10px;background:var(--color-bg-card);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.ranking-type-btn:hover{border-color:var(--color-primary)}.ranking-type-btn.active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.type-emoji{font-size:1.1rem}.ranking-periods{display:flex;gap:.5rem}.period-btn{flex:1;padding:.5rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-card);font-size:.8rem;cursor:pointer;transition:all .2s}.period-btn:hover{background:var(--color-bg-hover)}.period-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.ranking-description{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:1.5rem;padding:.75rem;background:var(--color-bg-secondary);border-radius:8px}.ranking-list{display:flex;flex-direction:column;gap:.75rem}.ranking-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;text-decoration:none;transition:all .2s}.ranking-item:hover{border-color:var(--color-primary);transform:translateY(-2px)}.ranking-rank{font-size:1.5rem;width:40px;text-align:center}.rank-number{font-size:1rem;font-weight:700;color:var(--color-text-secondary)}.ranking-content{flex:1;min-width:0}.ranking-question{font-size:.95rem;font-weight:600;color:var(--color-text);margin:0 0 .4rem;line-height:1.4}.ranking-meta{display:flex;gap:.75rem;font-size:.8rem;color:var(--color-text-secondary)}.ranking-controversy{color:var(--color-primary);font-weight:500}.explore-page{max-width:640px;margin:0 auto;padding:1rem}.explore-page h1{font-size:1.5rem;margin-bottom:1rem}.explore-page h2{font-size:1.1rem;margin:1.5rem 0 .75rem;color:var(--color-text)}.search-form{display:flex;gap:.5rem;margin-bottom:1.5rem}.search-input{flex:1;padding:.75rem 1rem;border:2px solid var(--color-border);border-radius:10px;font-size:1rem;background:var(--color-bg-card);color:var(--color-text)}.search-input:focus{outline:none;border-color:var(--color-primary)}.search-btn{padding:.75rem 1.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:opacity .2s}.search-btn:hover{opacity:.9}.tags-cloud{display:flex;flex-wrap:wrap;gap:.5rem}.tag-cloud-item{display:inline-flex;align-items:center;gap:.3rem;padding:.5rem .75rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:9999px;font-size:.85rem;cursor:pointer;transition:all .2s}.tag-cloud-item:hover{border-color:var(--color-primary)}.tag-cloud-item.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.tag-count{font-size:.7rem;opacity:.7}.active-filter{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-primary-light);border-radius:10px;margin:1rem 0;font-size:.9rem;color:var(--color-primary)}.clear-filter{background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer}.search-results,.tag-polls{margin-top:1rem}.search-result-item{display:block;padding:1rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;margin-bottom:.75rem;text-decoration:none;transition:all .2s}.search-result-item:hover{border-color:var(--color-primary)}.result-question{font-size:.95rem;font-weight:600;color:var(--color-text);margin:0 0 .5rem}.result-meta{display:flex;gap:1rem;font-size:.8rem;color:var(--color-text-secondary)}.result-options{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-polls-grid{display:flex;flex-direction:column;gap:.5rem}.recent-poll-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;text-decoration:none;transition:all .2s}.recent-poll-item:hover{border-color:var(--color-primary)}.recent-poll-question{font-size:.9rem;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.recent-poll-count{font-size:.8rem;color:var(--color-text-secondary);margin-left:1rem}.insights-page{max-width:640px;margin:0 auto;padding:1rem}.insights-page h1{font-size:1.5rem;margin-bottom:.25rem}.insights-subtitle{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:1.5rem}.insights-section{margin-bottom:1.5rem}.insights-section h2{font-size:1rem;margin-bottom:.75rem;color:var(--color-text)}.section-header-with-selector{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.section-header-with-selector h2{margin-bottom:0}.section-header-with-selector .trend-period-selector{margin:0}.section-description{font-size:.85rem;color:var(--color-text-secondary);margin:-.5rem 0 1rem}.insights-totals{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.insight-stat-card{display:flex;flex-direction:column;align-items:center;padding:1.25rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;text-align:center}.insight-stat-card .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.insight-stat-card .stat-label{font-size:.75rem;color:var(--color-text-secondary)}.hourly-chart{display:flex;align-items:flex-end;justify-content:space-between;height:120px;padding:.5rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px}.hour-bar-container{display:flex;flex-direction:column;align-items:center;flex:1;height:100%}.hour-bar{width:60%;max-width:20px;background:var(--color-primary);border-radius:4px 4px 0 0;margin-top:auto;transition:height .3s}.hour-label{font-size:.6rem;color:var(--color-text-secondary);margin-top:.25rem}.chart-hint{font-size:.8rem;color:var(--color-text-dimmed);text-align:center;margin-top:.5rem}.divisive-list{display:flex;flex-direction:column;gap:.5rem}.divisive-item{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;text-decoration:none;transition:all .2s}.divisive-item:hover{border-color:var(--color-primary)}.divisive-content{flex:1;min-width:0}.divisive-question{display:block;font-size:.9rem;font-weight:500;color:var(--color-text);margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.divisive-meta{font-size:.75rem;color:var(--color-text-secondary)}.divisive-gap{display:flex;flex-direction:column;align-items:center;padding:.5rem;background:var(--color-primary-light);border-radius:8px;min-width:60px}.gap-value{font-size:1.1rem;font-weight:700;color:var(--color-primary)}.gap-label{font-size:.65rem;color:var(--color-primary)}.category-trends{display:flex;flex-direction:column;gap:.5rem}.category-trend-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px}.trend-rank{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);color:var(--color-primary);font-weight:700;font-size:.8rem;border-radius:50%}.trend-category{flex:1;font-weight:500;color:var(--color-text)}.trend-count{font-size:.85rem;color:var(--color-text-secondary)}.fun-facts{display:flex;flex-direction:column;gap:.75rem}.fun-fact{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px}.fact-emoji{font-size:1.5rem}.fact-text{font-size:.9rem;color:var(--color-text)}.fact-text strong{color:var(--color-primary)}.trend-period-selector{display:flex;gap:.25rem;background:var(--color-bg-secondary);padding:.2rem;border-radius:6px}.trend-period-selector .period-btn{padding:.35rem .6rem;border:none;border-radius:4px;background:transparent;font-size:.75rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:all .2s ease;white-space:nowrap}.trend-period-selector .period-btn:hover{color:var(--color-text)}.trend-period-selector .period-btn.active{background:var(--color-bg-card);color:var(--color-primary);box-shadow:0 1px 2px #00000014}.realtime-section{background:linear-gradient(135deg,#ef44440d,#ef44441a);border:1px solid rgba(239,68,68,.2);border-radius:12px;padding:1rem}.realtime-section h2{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.live-indicator{display:inline-block;width:8px;height:8px;background:#ef4444;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}.realtime-list{display:flex;flex-direction:column;gap:.5rem}.realtime-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;text-decoration:none;transition:all .2s ease}.realtime-item:hover{border-color:var(--color-primary);transform:translate(4px)}.realtime-rank{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-primary-light);color:var(--color-primary);font-weight:700;font-size:.9rem;border-radius:50%;flex-shrink:0}.realtime-question{flex:1;font-size:.9rem;font-weight:500;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.realtime-votes{font-size:.8rem;font-weight:600;color:#ef4444;flex-shrink:0}.trend-chart{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.trend-chart.empty{text-align:center;padding:2rem;color:var(--color-text-dimmed)}.chart-legend{display:flex;gap:1.5rem;margin-bottom:1rem}.legend-item{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--color-text-secondary)}.legend-item .legend-dot{width:10px;height:10px;border-radius:50%}.legend-item.votes .legend-dot{background:#6366f1}.legend-item.polls .legend-dot{background:#22c55e}.chart-container{position:relative;margin-bottom:1rem}.line-chart-svg{width:100%;height:120px;display:block}.chart-x-axis{display:flex;justify-content:space-between;font-size:.7rem;color:var(--color-text-dimmed);margin-top:.5rem}.chart-tooltip{position:absolute;top:0;transform:translate(-50%);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:6px;padding:.4rem .6rem;font-size:.7rem;box-shadow:0 2px 8px #00000026;pointer-events:none;z-index:10;white-space:nowrap}.tooltip-date{font-weight:600;color:var(--color-text);margin-bottom:.2rem}.tooltip-row{color:var(--color-text-secondary)}.tooltip-row.votes{color:#6366f1}.tooltip-row.polls{color:#22c55e}.demo-type-selector{display:flex;gap:.5rem;margin-bottom:1rem}.demo-type-btn{flex:1;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg-card);font-size:.85rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:all .2s ease}.demo-type-btn:hover{border-color:var(--color-primary);color:var(--color-text)}.demo-type-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.demographic-chart{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem}.demographic-chart.empty{text-align:center;padding:2rem;color:var(--color-text-dimmed)}.demographic-bars{display:flex;flex-direction:column;gap:.75rem}.demographic-bar-row{display:flex;align-items:center;gap:.75rem}.demographic-label{display:flex;align-items:center;gap:.4rem;min-width:60px;font-size:.85rem;color:var(--color-text-secondary)}.demographic-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.demographic-bar-wrapper{flex:1;height:24px;background:var(--color-bg-secondary);border-radius:6px;overflow:hidden}.demographic-bar-fill{height:100%;border-radius:6px;transition:width .6s ease;min-width:4px}.demographic-value{display:flex;align-items:center;gap:.25rem;min-width:80px;text-align:right}.demographic-value .pct{font-size:.9rem;font-weight:600;color:var(--color-text)}.demographic-value .count{font-size:.75rem;color:var(--color-text-dimmed)}.demographic-footer{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--color-border);text-align:center;font-size:.8rem;color:var(--color-text-secondary)}.tag-trends{display:flex;flex-wrap:wrap;gap:.5rem}.tag-trend-item{display:flex;align-items:center;gap:.5rem;padding:.6rem .9rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:9999px;text-decoration:none;transition:all .2s ease}.tag-trend-item:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.tag-name{font-size:.85rem;font-weight:500;color:var(--color-text)}.tag-stats{display:flex;align-items:center;gap:.4rem}.tag-count{font-size:.75rem;color:var(--color-text-secondary)}.tag-change{font-size:.7rem;font-weight:600;padding:.15rem .35rem;border-radius:4px}.tag-change.up{background:#22c55e26;color:#22c55e}.tag-change.down{background:#ef444426;color:#ef4444}.tag-change.stable{background:var(--color-bg-secondary);color:var(--color-text-dimmed)}.chart-loading{text-align:center;padding:2rem;color:var(--color-text-dimmed);font-size:.9rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px}.no-data{text-align:center;padding:1.5rem;color:var(--color-text-dimmed);font-size:.9rem;background:var(--color-bg-secondary);border-radius:8px;margin:0}@media(max-width:480px){.poll-option{min-height:52px;padding:.85rem 1rem}.category-tab{min-height:44px;padding:.6rem 1rem}.submit-btn,.load-more,.retry-btn{min-height:48px;font-size:1rem}.ranking-types{flex-wrap:wrap}.ranking-type-btn{flex:1 1 45%;min-height:52px}.period-btn{min-height:44px}.ranking-item{padding:.85rem}.insights-totals{grid-template-columns:repeat(3,1fr);gap:.5rem}.insight-stat-card{padding:.75rem .5rem}.insight-stat-card .stat-value{font-size:1.25rem}.hour-label{display:none}.hour-bar-container:nth-child(2n) .hour-label{display:block}.trend-period-selector .period-btn{padding:.3rem .5rem;font-size:.7rem}.section-header-with-selector{flex-wrap:wrap}.demo-type-selector{gap:.25rem}.demo-type-btn{padding:.5rem;font-size:.8rem;min-height:40px}.realtime-item{padding:.6rem}.realtime-question{font-size:.85rem}.demographic-label{min-width:50px;font-size:.8rem}.demographic-value{min-width:70px}.demographic-value .pct{font-size:.85rem}.tag-trend-item{padding:.5rem .75rem}.tag-name{font-size:.8rem}.line-chart-svg{height:100px}.search-form{flex-direction:column}.search-btn{min-height:48px}.tag-cloud-item{min-height:40px}.profile-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.profile-tabs::-webkit-scrollbar{display:none}.profile-tab{white-space:nowrap;min-height:44px}.similarity-stats{grid-template-columns:repeat(2,1fr)}.admin-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.admin-tab{white-space:nowrap;min-height:44px}.feed-controls{flex-direction:column;gap:.75rem}.feed-actions{flex-direction:row;justify-content:space-between;width:100%}.sort-options{gap:.25rem}.sort-btn{padding:.4rem .6rem;font-size:.8rem;min-height:36px}.hide-voted-btn{font-size:.8rem;padding:.4rem .6rem}.poll-card{border-radius:10px;padding:1rem}.poll-question{font-size:1rem;line-height:1.4}.comment-input-wrapper{flex-direction:column;gap:.5rem}.comment-input-wrapper button{min-height:44px;width:100%}.share-buttons{flex-direction:row;flex-wrap:wrap}.share-btn{flex:1;min-width:80px;min-height:44px}input,select,textarea{font-size:16px!important;min-height:44px}.comparison-charts{gap:1.5rem}.chart-bars{gap:.35rem}.empty{padding:2rem 1rem;font-size:.95rem}}@media(max-width:360px){.logo{font-size:1.1rem}.mobile-nav-label{font-size:.6rem}.mobile-nav-icon svg{width:20px;height:20px}.poll-option{font-size:.9rem}.insight-stat-card .stat-value{font-size:1.1rem}.ranking-type-btn{font-size:.85rem;padding:.6rem}}@supports (padding-bottom: env(safe-area-inset-bottom)){.app-main{padding-bottom:calc(80px + env(safe-area-inset-bottom))}}.static-page{max-width:640px;margin:0 auto;padding:1rem;animation:fadeInUp .4s ease-out}.static-page h1{font-size:1.75rem;margin-bottom:1rem;color:var(--color-text)}.static-page h2{font-size:1.2rem;margin:1.5rem 0 .75rem;color:var(--color-text)}.static-page h3{font-size:1rem;margin:1rem 0 .5rem;color:var(--color-text-secondary)}.static-page p{font-size:.95rem;line-height:1.7;color:var(--color-text-secondary);margin-bottom:1rem}.static-page ul,.static-page ol{padding-left:1.5rem;margin-bottom:1rem}.static-page li{font-size:.95rem;line-height:1.7;color:var(--color-text-secondary);margin-bottom:.5rem}.static-page a{color:var(--color-primary);text-decoration:none}.static-page a:hover{text-decoration:underline}.about-hero{text-align:center;padding:2rem 1rem;background:linear-gradient(135deg,var(--color-primary-light),rgba(99,102,241,.15));border-radius:16px;margin-bottom:2rem}.about-tagline{font-size:1.5rem;font-weight:700;color:var(--color-primary);margin-bottom:.5rem}.about-description{font-size:1rem;color:var(--color-text-secondary);margin:0}.about-section{margin-bottom:2rem}.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.feature-card{padding:1.25rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001a}.feature-icon{display:block;font-size:1.5rem;font-weight:700;color:var(--color-primary);margin-bottom:.5rem}.feature-card h3{font-size:1rem;margin:0 0 .5rem;color:var(--color-text)}.feature-card p{font-size:.85rem;margin:0;color:var(--color-text-secondary)}.target-list{list-style:none;padding:0}.target-list li{position:relative;padding-left:1.5rem;margin-bottom:.75rem}.target-list li:before{content:"✓";position:absolute;left:0;color:var(--color-primary);font-weight:700}.about-contact{text-align:center;padding:2rem;background:var(--color-bg-secondary);border-radius:12px}.contact-link{display:inline-block;margin-top:1rem;padding:.75rem 2rem;background:var(--color-primary);color:#fff!important;border-radius:9999px;font-weight:600;text-decoration:none!important;transition:opacity .2s}.contact-link:hover{opacity:.9}.legal-page h1{margin-bottom:.5rem}.legal-updated{font-size:.85rem;color:var(--color-text-dimmed);margin-bottom:2rem}.legal-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.legal-section:last-child{border-bottom:none}.legal-section h2{font-size:1.1rem;margin-top:0}.legal-table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.9rem}.legal-table th,.legal-table td{padding:.75rem;text-align:left;border:1px solid var(--color-border)}.legal-table th{background:var(--color-bg-secondary);font-weight:600;color:var(--color-text)}.legal-table td{color:var(--color-text-secondary)}.legal-footer{text-align:center;font-weight:500;color:var(--color-text);margin:0}.faq-page h1{margin-bottom:.5rem}.faq-intro,.faq-category{margin-bottom:2rem}.faq-category h2{font-size:1.1rem;color:var(--color-primary);margin-bottom:.75rem}.faq-list{display:flex;flex-direction:column;gap:.5rem}.faq-item{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;overflow:hidden;transition:border-color .2s}.faq-item.open{border-color:var(--color-primary)}.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1rem;background:none;border:none;text-align:left;font-size:.95rem;font-weight:500;color:var(--color-text);cursor:pointer;transition:background .2s}.faq-question:hover{background:var(--color-bg-secondary)}.faq-icon{font-size:1.25rem;color:var(--color-primary);font-weight:700}.faq-answer{padding:0 1rem 1rem;animation:fadeIn .2s ease-out}.faq-answer p{margin:0;font-size:.9rem;line-height:1.6}.contact-intro{margin-bottom:2rem}.contact-form{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.contact-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:.5rem}.contact-type-btn{display:flex;flex-direction:column;align-items:flex-start;padding:.75rem;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .2s}.contact-type-btn:hover{border-color:var(--color-primary)}.contact-type-btn.active{border-color:var(--color-primary);background:var(--color-primary-light)}.type-label{font-weight:600;font-size:.9rem;color:var(--color-text)}.type-desc{font-size:.75rem;color:var(--color-text-secondary)}.contact-form .form-group label{display:block;font-size:.9rem;font-weight:600;color:var(--color-text);margin-bottom:.5rem}.contact-form input,.contact-form textarea{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:8px;font-size:.95rem;background:var(--color-bg-card);color:var(--color-text);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a}.contact-form textarea{resize:vertical;min-height:120px}.contact-info{background:var(--color-bg-secondary);border-radius:12px;padding:1.5rem}.contact-info h2{margin-top:0;font-size:1rem}.contact-info ul{list-style:none;padding:0;margin:0}.contact-info li{margin-bottom:.5rem}.contact-success{text-align:center;padding:3rem 1rem}.success-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;background:var(--color-primary);color:#fff;font-size:2rem;font-weight:700;border-radius:50%;animation:scaleIn .4s ease-out}.contact-success h1{font-size:1.5rem;margin-bottom:1rem}.contact-success p{margin-bottom:2rem}.back-home-btn{display:inline-block;padding:.75rem 2rem;background:var(--color-primary);color:#fff!important;border-radius:9999px;font-weight:600;text-decoration:none!important}.announcements-container{display:grid;grid-template-columns:1fr 2fr;gap:1rem;min-height:400px}.announcements-list{display:flex;flex-direction:column;gap:.5rem}.announcement-item{display:block;width:100%;padding:.75rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;text-align:left;cursor:pointer;transition:all .2s}.announcement-item:hover{border-color:var(--color-primary)}.announcement-item.active{border-color:var(--color-primary);background:var(--color-primary-light)}.announcement-item.pinned{border-left:3px solid var(--color-primary)}.announcement-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.announcement-type{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:9999px}.announcement-type.type-notice{background:#fee2e2;color:#dc2626}.announcement-type.type-update{background:#dbeafe;color:#2563eb}.announcement-type.type-event{background:#fef3c7;color:#d97706}.pinned-badge{font-size:.65rem;background:var(--color-primary);color:#fff;padding:.1rem .4rem;border-radius:4px}.announcement-title{font-size:.9rem;font-weight:500;color:var(--color-text);margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.announcement-date{font-size:.75rem;color:var(--color-text-dimmed)}.announcement-detail{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem}.detail-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.detail-header h2{font-size:1.25rem;margin:.5rem 0 .25rem}.detail-date{font-size:.85rem;color:var(--color-text-dimmed)}.detail-content p{margin:0 0 .75rem;font-size:.95rem;line-height:1.7}.no-selection{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-dimmed)}.not-found-page{display:flex;align-items:center;justify-content:center;min-height:60vh}.not-found-content{text-align:center;animation:fadeInUp .4s ease-out}.not-found-code{font-size:6rem;font-weight:800;color:var(--color-primary);line-height:1;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}.not-found-content h1{font-size:1.5rem;margin-bottom:.75rem}.not-found-content p{color:var(--color-text-secondary);margin-bottom:2rem}.not-found-actions{display:flex;gap:1rem;justify-content:center}.home-btn,.explore-btn{padding:.75rem 1.5rem;border-radius:9999px;font-weight:600;text-decoration:none;transition:all .2s}.home-btn{background:var(--color-primary);color:#fff}.home-btn:hover{opacity:.9}.explore-btn{background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border)}.explore-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}@media(max-width:640px){.feature-grid,.contact-type-grid,.announcements-container{grid-template-columns:1fr}.announcements-list{flex-direction:row;overflow-x:auto;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}.announcement-item{min-width:200px;flex-shrink:0}.not-found-code{font-size:4rem}.not-found-actions{flex-direction:column}.home-btn,.explore-btn{width:100%;text-align:center}}.landing-hero{text-align:center;padding:2rem 1rem 2.5rem;margin-bottom:2rem;background:linear-gradient(180deg,var(--color-primary-light) 0%,transparent 100%);border-radius:0 0 24px 24px;animation:fadeInUp .5s ease-out}.hero-main{max-width:400px;margin:0 auto 2rem}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .9rem;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:9999px;font-size:.8rem;font-weight:500;color:var(--color-primary);margin-bottom:1.25rem}.badge-pulse{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}.hero-title{font-size:2rem;font-weight:800;line-height:1.3;color:var(--color-text);margin:0 0 .75rem;letter-spacing:-.02em}.title-accent{color:var(--color-primary);position:relative}.title-accent:after{content:"";position:absolute;bottom:2px;left:0;right:0;height:8px;background:#6366f133;border-radius:4px;z-index:-1}.hero-subtitle{font-size:1rem;color:var(--color-text-secondary);margin:0 0 1.5rem}.hero-cta{display:flex;gap:.75rem;justify-content:center}.cta-primary{padding:.85rem 1.75rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 14px #6366f159}.cta-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f173}.cta-primary:active{transform:translateY(0)}.cta-secondary{padding:.85rem 1.75rem;background:var(--color-bg-card);color:var(--color-text);border:2px solid var(--color-border);border-radius:12px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s ease}.cta-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.hero-stats{display:flex;justify-content:center;align-items:center;gap:1.5rem;padding:1.25rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:16px;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000000a}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.2rem}.stat-number{font-size:1.5rem;font-weight:700;color:var(--color-primary);line-height:1}.hero-stats .stat-label{font-size:.75rem;color:var(--color-text-secondary)}.stat-divider{width:1px;height:32px;background:var(--color-border)}.hero-features{display:flex;flex-direction:column;gap:.75rem;max-width:360px;margin:0 auto 1.5rem}.feature-item{display:flex;align-items:center;gap:.85rem;padding:.85rem 1rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;transition:all .2s ease}.feature-item:hover{border-color:var(--color-primary-light);transform:translate(4px)}.feature-icon{font-size:1.5rem;flex-shrink:0}.feature-text{display:flex;flex-direction:column;text-align:left}.feature-title{font-size:.9rem;font-weight:600;color:var(--color-text)}.feature-desc{font-size:.8rem;color:var(--color-text-secondary)}.scroll-indicator{display:inline-flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem 1rem;background:none;border:none;color:var(--color-text-muted);font-size:.8rem;cursor:pointer;transition:all .2s ease}.scroll-indicator:hover{color:var(--color-primary)}.scroll-indicator svg{animation:bounce 2s ease-in-out infinite}@media(max-width:480px){.landing-hero{padding:1.5rem 1rem 2rem}.hero-title{font-size:1.6rem}.hero-subtitle{font-size:.9rem}.hero-cta{flex-direction:column;gap:.5rem}.cta-primary,.cta-secondary{width:100%;text-align:center}.hero-stats{gap:1rem;padding:1rem}.stat-number{font-size:1.25rem}.hero-features{gap:.5rem}.feature-item{padding:.75rem}.feature-icon{font-size:1.25rem}.feature-title{font-size:.85rem}.feature-desc{font-size:.75rem}}.landing-page{max-width:800px;margin:0 auto;padding:0 1rem;animation:fadeIn .5s ease-out}.landing-hero-full{position:relative;text-align:center;padding:3rem 1rem 2.5rem;margin-bottom:3rem;overflow:hidden}.hero-bg-pattern{position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(99,102,241,.15) 0%,transparent 60%);z-index:-1}.hero-content{max-width:500px;margin:0 auto 2.5rem}.hero-title-large{font-size:2.5rem;font-weight:800;line-height:1.25;color:var(--color-text);margin:0 0 1rem;letter-spacing:-.03em}.hero-subtitle-large{font-size:1.1rem;color:var(--color-text-secondary);margin:0 0 2rem;line-height:1.6}.hero-cta-large{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.cta-primary-large{padding:1rem 2rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:14px;font-size:1.1rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s ease;box-shadow:0 4px 20px #6366f166}.cta-primary-large:hover{transform:translateY(-3px);box-shadow:0 8px 30px #6366f180}.cta-secondary-large{padding:1rem 2rem;background:var(--color-bg-card);color:var(--color-text);border:2px solid var(--color-border);border-radius:14px;font-size:1.1rem;font-weight:600;text-decoration:none;transition:all .2s ease}.cta-secondary-large:hover{border-color:var(--color-primary);color:var(--color-primary)}.hero-stats-large{display:flex;justify-content:center;align-items:center;gap:2.5rem;padding:1.5rem 2rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:20px;max-width:400px;margin:0 auto;box-shadow:0 4px 20px #0000000d}.stat-item-large{display:flex;flex-direction:column;align-items:center;gap:.3rem}.stat-number-large{font-size:2rem;font-weight:700;color:var(--color-primary);line-height:1}.stat-label-large{font-size:.85rem;color:var(--color-text-secondary)}.stat-divider-large{width:1px;height:40px;background:var(--color-border)}.landing-features{margin-bottom:3rem}.section-title{font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:1.5rem;color:var(--color-text)}.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.feature-card-large{padding:1.5rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:16px;text-align:center;transition:all .2s ease}.feature-card-large:hover{border-color:var(--color-primary-light);transform:translateY(-4px);box-shadow:0 8px 24px #00000014}.feature-icon-large{font-size:2.5rem;display:block;margin-bottom:.75rem}.feature-card-large h3{font-size:1rem;font-weight:600;margin:0 0 .5rem;color:var(--color-text)}.feature-card-large p{font-size:.85rem;color:var(--color-text-secondary);margin:0;line-height:1.5}.landing-how{margin-bottom:3rem}.steps-container{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.step-item{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:16px;min-width:140px;transition:all .2s ease}.step-item:hover{border-color:var(--color-primary)}.step-number{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:1.25rem;font-weight:700;border-radius:50%}.step-content{text-align:center}.step-content h3{font-size:.95rem;font-weight:600;margin:0 0 .25rem;color:var(--color-text)}.step-content p{font-size:.8rem;color:var(--color-text-secondary);margin:0}.step-arrow{font-size:1.5rem;color:var(--color-text-dimmed)}.landing-final-cta{text-align:center;padding:3rem 1.5rem;background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border-radius:24px;margin-bottom:2rem}.landing-final-cta h2{font-size:1.5rem;font-weight:700;margin:0 0 .5rem;color:var(--color-text)}.landing-final-cta p{font-size:1rem;color:var(--color-text-secondary);margin:0 0 1.5rem}@media(max-width:640px){.landing-hero-full{padding:2rem .5rem}.hero-title-large{font-size:1.8rem}.hero-subtitle-large{font-size:1rem}.hero-cta-large{flex-direction:column;gap:.75rem}.cta-primary-large,.cta-secondary-large{width:100%;text-align:center}.hero-stats-large{gap:1.5rem;padding:1.25rem}.stat-number-large{font-size:1.5rem}.features-grid{grid-template-columns:1fr}.steps-container{flex-direction:column;gap:.5rem}.step-arrow{transform:rotate(90deg)}.step-item{width:100%;flex-direction:row;gap:1rem}.step-content{text-align:left}.landing-final-cta{padding:2rem 1rem;border-radius:16px}.landing-final-cta h2{font-size:1.25rem}}.trending-section{margin-bottom:1.5rem;animation:fadeInUp .4s ease-out}.trending-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:0 .25rem}.trending-title{font-size:1rem;font-weight:700;color:var(--color-text)}.trending-more{font-size:.85rem;color:var(--color-primary);text-decoration:none;font-weight:500}.trending-more:hover{text-decoration:underline}.trending-cards{display:flex;gap:.75rem;overflow-x:auto;padding:.25rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.trending-cards::-webkit-scrollbar{display:none}.trending-card{flex-shrink:0;width:240px;padding:1rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;text-decoration:none;scroll-snap-align:start;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.trending-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001a;border-color:var(--color-primary-light)}.trending-card.skeleton{height:100px}.trending-card .skeleton-text{height:1rem;width:80%;background:var(--color-bg-secondary);border-radius:4px;margin-bottom:.5rem}.trending-card .skeleton-count{height:.75rem;width:50%;background:var(--color-bg-secondary);border-radius:4px}.trending-card-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:var(--color-primary-light);border-radius:9999px;margin-bottom:.5rem}.badge-icon{font-size:.8rem}.badge-text{font-size:.7rem;font-weight:600;color:var(--color-primary)}.trending-question{font-size:.9rem;font-weight:600;color:var(--color-text);margin:0 0 .5rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.trending-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.trending-count{font-size:.75rem;color:var(--color-text-dimmed)}.trending-controversy{font-size:.7rem;padding:.15rem .4rem;background:#ef44441a;color:#ef4444;border-radius:4px;font-weight:600}.live-dot{display:inline-block;width:6px;height:6px;background:#ef4444;border-radius:50%;margin-right:.35rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.poll-option.preview{cursor:pointer}.poll-option .option-bar.preview{opacity:.3;background:linear-gradient(90deg,var(--color-bg-secondary),rgba(99,102,241,.15))}.poll-option .option-percentage.preview{opacity:.5;font-weight:500}.vote-cta{margin:.75rem 0 0;padding:.5rem;text-align:center;font-size:.85rem;color:var(--color-primary);font-weight:500;animation:fadeIn .3s ease-out}.poll-card-footer{margin-top:1rem;animation:fadeIn .3s ease-out}.poll-actions{display:flex;gap:.5rem;margin-top:.75rem}.poll-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.6rem .75rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;font-size:.85rem;font-weight:500;color:var(--color-text-secondary);text-decoration:none;cursor:pointer;transition:all .2s ease}.poll-action-btn:hover{background:var(--color-bg-card);border-color:var(--color-primary-light);color:var(--color-primary)}.poll-action-btn.share:hover{background:var(--color-primary-light)}.share-card-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}.share-card{position:relative;width:100%;max-width:360px;background:var(--color-bg-card);border-radius:16px;padding:1.5rem;animation:slideUp .3s ease-out}.share-card-close{position:absolute;top:.75rem;right:.75rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border:none;border-radius:50%;font-size:1.25rem;color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.share-card-close:hover{background:var(--color-border);color:var(--color-text)}.share-card-result{text-align:center;margin-bottom:1.5rem}.position-badge{display:inline-block;padding:.35rem 1rem;border-radius:9999px;font-size:.85rem;font-weight:700;margin-bottom:.75rem}.position-badge.majority{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.position-badge.minority{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff}.share-card-question{font-size:1rem;font-weight:600;color:var(--color-text);margin:0 0 1rem;line-height:1.5}.share-card-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:.75rem}.stat-percentage{font-size:2rem;font-weight:800;color:var(--color-primary)}.stat-label{font-size:.8rem;color:var(--color-text-secondary)}.share-card-choice{font-size:.9rem;color:var(--color-text-secondary);margin:0}.share-card-choice strong{color:var(--color-text)}.share-card-actions{display:flex;flex-direction:column;gap:.5rem}.share-card-actions .share-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.share-card-actions .share-btn.kakao{background:#fee500;color:#000}.share-card-actions .share-btn.kakao:hover{background:#fada0a}.share-card-actions .share-btn.twitter{background:#000;color:#fff}.share-card-actions .share-btn.twitter:hover{background:#1a1a1a}.share-card-actions .share-btn.link{background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border)}.share-card-actions .share-btn.link:hover{background:var(--color-bg-card);border-color:var(--color-primary)}.share-card-actions .share-btn.link.copied{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}@media(max-width:640px){.trending-card{width:200px}.trending-question{font-size:.85rem}.poll-actions{flex-direction:column}}*,*:before,*:after{box-sizing:border-box}:root{--color-bg: #f9fafb;--color-bg-card: #ffffff;--color-bg-secondary: #f3f4f6;--color-bg-tertiary: #e5e7eb;--color-text: #111827;--color-text-secondary: #374151;--color-text-muted: #6b7280;--color-text-dimmed: #9ca3af;--color-border: #e5e7eb;--color-border-light: #f3f4f6;--color-primary: #6366f1;--color-primary-hover: #4f46e5;--color-primary-light: #eef2ff;--color-primary-gradient: linear-gradient(90deg, #818cf8, #6366f1);--color-error: #ef4444;--color-success: #10b981;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,Helvetica Neue,Segoe UI,Apple SD Gothic Neo,Noto Sans KR,Malgun Gothic,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark]{--color-bg: #0f172a;--color-bg-card: #1e293b;--color-bg-secondary: #334155;--color-bg-tertiary: #475569;--color-text: #f1f5f9;--color-text-secondary: #e2e8f0;--color-text-muted: #94a3b8;--color-text-dimmed: #64748b;--color-border: #334155;--color-border-light: #1e293b;--color-primary: #818cf8;--color-primary-hover: #6366f1;--color-primary-light: #312e81;--color-primary-gradient: linear-gradient(90deg, #a5b4fc, #818cf8)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--color-bg: #0f172a;--color-bg-card: #1e293b;--color-bg-secondary: #334155;--color-bg-tertiary: #475569;--color-text: #f1f5f9;--color-text-secondary: #e2e8f0;--color-text-muted: #94a3b8;--color-text-dimmed: #64748b;--color-border: #334155;--color-border-light: #1e293b;--color-primary: #818cf8;--color-primary-hover: #6366f1;--color-primary-light: #312e81;--color-primary-gradient: linear-gradient(90deg, #a5b4fc, #818cf8)}}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes celebrate{0%{transform:scale(1)}25%{transform:scale(1.1) rotate(-2deg)}50%{transform:scale(1.15)}75%{transform:scale(1.1) rotate(2deg)}to{transform:scale(1)}}.animate-fadeIn{animation:fadeIn .3s ease-out}.animate-pulse{animation:pulse .3s ease-out}.animate-celebrate{animation:celebrate .5s ease-out}
