.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:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:100}.logo{font-size:1.5rem;font-weight:800;color:#6366f1;text-decoration:none}.nav{display:flex;align-items:center;gap:1rem}.nav a{color:#374151;text-decoration:none;font-size:.9rem;font-weight:500}.nav a:hover{color:#6366f1}.sign-in-btn{background:#6366f1;color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500}.sign-in-btn:hover{background:#4f46e5}.app-main{flex:1;max-width:640px;margin:0 auto;padding:1.5rem 1rem;width:100%}.category-tabs{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:1rem;-webkit-overflow-scrolling:touch}.category-tab{background:#f3f4f6;border:none;padding:.5rem 1rem;border-radius:9999px;font-size:.85rem;cursor:pointer;white-space:nowrap;color:#374151}.category-tab.active{background:#6366f1;color:#fff}.poll-list{display:flex;flex-direction:column;gap:1rem}.load-more{display:block;width:100%;margin-top:1rem;padding:.75rem;background:#f3f4f6;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;color:#374151}.load-more:hover{background:#e5e7eb}.poll-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.25rem}.poll-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.poll-category{font-size:.75rem;background:#eef2ff;color:#6366f1;padding:.2rem .6rem;border-radius:9999px}.poll-responses{font-size:.75rem;color:#9ca3af}.poll-question{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:#111827;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:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;font-size:.95rem;text-align:left;overflow:hidden;transition:border-color .2s}.poll-option:hover:not(:disabled){border-color:#6366f1}.poll-option.voted{cursor:default}.poll-option.selected{border-color:#6366f1;background:#eef2ff}.option-text{position:relative;z-index:1}.option-result{display:flex;align-items:center;gap:.5rem}.option-bar{position:absolute;left:0;top:0;height:100%;background:#e0e7ff;border-radius:8px;transition:width .6s ease;z-index:0}.option-percentage{position:relative;z-index:1;font-weight:600;font-size:.9rem;color:#4f46e5}.create-poll{max-width:480px;margin:0 auto}.create-poll h2{margin-bottom:1.5rem;font-size:1.3rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.85rem;font-weight:600;color:#374151;margin-bottom:.4rem}.form-group input[type=text],.form-group select{width:100%;padding:.65rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.char-count{display:block;text-align:right;font-size:.75rem;color:#9ca3af;margin-top:.25rem}.option-input{display:flex;gap:.5rem;margin-bottom:.5rem}.option-input input{flex:1}.remove-option{background:none;border:1px solid #ef4444;color:#ef4444;padding:.4rem .75rem;border-radius:8px;cursor:pointer;font-size:.8rem}.add-option{width:100%;padding:.6rem;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;cursor:pointer;font-size:.85rem;color:#6b7280}.add-option:hover{border-color:#6366f1;color:#6366f1}.submit-btn{width:100%;padding:.75rem;background:#6366f1;color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.5rem}.submit-btn:hover:not(:disabled){background:#4f46e5}.submit-btn:disabled{background:#9ca3af;cursor:not-allowed}.profile{max-width:480px;margin:0 auto}.profile h2{margin-bottom:1.5rem;font-size:1.3rem}.checkbox-label{display:flex!important;align-items:center;gap:.5rem;font-weight:400!important;font-size:.85rem!important;color:#6b7280!important;margin-top:.4rem}.checkbox-label input[type=checkbox]{width:auto}.privacy-notice{font-size:.8rem;color:#9ca3af;background:#f9fafb;padding:.75rem;border-radius:8px;line-height:1.5;margin-bottom:1rem}.poll-detail{max-width:640px;margin:0 auto}.back-link{display:inline-block;color:#6b7280;text-decoration:none;font-size:.9rem;margin-bottom:1rem}.back-link:hover{color:#6366f1}.poll-question-link{text-decoration:none;color:inherit}.poll-question-link:hover .poll-question{color:#6366f1}.poll-expires{font-size:.8rem;color:#9ca3af;margin-bottom:1rem}.feed-controls{margin-bottom:.5rem}.sort-options{display:flex;gap:.5rem;margin-bottom:1rem}.sort-btn{background:none;border:none;padding:.25rem 0;font-size:.85rem;cursor:pointer;color:#9ca3af;font-weight:500}.sort-btn.active{color:#111827;border-bottom:2px solid #6366f1}.results{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.25rem;margin-top:1rem}.results-header{margin-bottom:1rem}.results-total{font-size:.85rem;font-weight:600;color:#374151}.results-tabs{display:flex;gap:.25rem;margin-bottom:1rem;background:#f3f4f6;border-radius:8px;padding:.2rem}.results-tab{flex:1;padding:.5rem;border:none;background:none;border-radius:6px;font-size:.85rem;cursor:pointer;color:#6b7280;font-weight:500}.results-tab.active{background:#fff;color:#111827;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:#374151;flex-shrink:0}.result-bar-wrapper{flex:1;height:24px;background:#f3f4f6;border-radius:6px;overflow:hidden}.result-bar-fill{height:100%;background:linear-gradient(90deg,#818cf8,#6366f1);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:#4f46e5;flex-shrink:0}.result-count{font-weight:400;color:#9ca3af;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:#374151;margin-bottom:.5rem}.segment-count{font-weight:400;color:#9ca3af;font-size:.8rem;margin-left:.3rem}.results-empty{text-align:center;padding:2rem 1rem;color:#9ca3af;font-size:.85rem}.share-buttons{display:flex;gap:.5rem;margin-top:1rem}.share-btn{flex:1;padding:.6rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;background:#fff;color:#374151;transition:all .15s}.share-btn:hover{background:#f9fafb}.share-btn.copy{border-color:#6366f1;color:#6366f1}.share-btn.kakao{border-color:#fee500;background:#fee500;color:#3c1e1e}.share-btn.twitter{border-color:#1d9bf0;color:#1d9bf0}.skeleton{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb,#f3f4f6 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,#f3f4f6 25%,#e5e7eb,#f3f4f6 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:#ef4444;font-size:.95rem;margin-bottom:1rem}.retry-btn{background:#6366f1;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;margin-bottom:.5rem}.retry-btn:hover{background:#4f46e5}.comments-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.25rem;margin-top:1rem}.comments-title{font-size:1rem;font-weight:600;margin:0 0 1rem;color:#111827}.comments-count{font-weight:400;color:#9ca3af;font-size:.85rem}.comment-form{margin-bottom:1.25rem}.comment-input{width:100%;padding:.65rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;font-family:inherit;resize:vertical;min-height:60px;box-sizing:border-box}.comment-input:focus{outline:none;border-color:#6366f1;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:#9ca3af}.comment-submit{background:#6366f1;color:#fff;border:none;padding:.4rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer}.comment-submit:hover:not(:disabled){background:#4f46e5}.comment-submit:disabled{background:#9ca3af;cursor:not-allowed}.comment-login-notice{font-size:.85rem;color:#9ca3af;text-align:center;padding:1rem;background:#f9fafb;border-radius:8px;margin-bottom:1rem}.comment-list{display:flex;flex-direction:column;gap:.75rem}.comment-item{padding:.75rem 0;border-bottom:1px solid #f3f4f6}.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:#374151}.comment-time{font-size:.75rem;color:#9ca3af}.comment-delete{margin-left:auto;background:none;border:none;color:#ef4444;font-size:.75rem;cursor:pointer;padding:0}.comment-delete:hover{text-decoration:underline}.comment-content{font-size:.9rem;color:#374151;margin:0;line-height:1.5;word-break:break-word}.comment-empty{text-align:center;padding:1.5rem 1rem;color:#9ca3af;font-size:.85rem}.comment-load-more{display:block;width:100%;margin-top:.5rem;padding:.5rem;background:none;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:.85rem;color:#6b7280}.comment-load-more:hover{background:#f9fafb}.loading,.empty{text-align:center;padding:3rem 1rem;color:#9ca3af;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%}}*,*:before,*:after{box-sizing:border-box}:root{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:#111827;background-color:#f9fafb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}
