:root{--purple-dark: #5B3A8C;--purple-mid: #7B5EA7;--purple-light: #8B6DB0;--green-dark: #2D6A4F;--green-mid: #40916C;--green-light: #52B788;--earth-warm: #D4A373;--earth-light: #FEFAE0;--neutral-dark: #1E1E2E;--neutral-mid: #2B2D42;--neutral-light: #EDF2F4;--white: #FFFFFF;--text-primary: #2B2D42;--text-secondary: #6B7280;--text-light: #EDF2F4;--danger: #C1292E}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--text-primary);background:var(--white);line-height:1.5;-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:inherit}input{font-family:inherit}.survey-container{max-width:480px;margin:0 auto;padding:1.5rem 1rem;min-height:100dvh;display:flex;flex-direction:column}.survey-header{text-align:center;margin-bottom:1.5rem}.survey-header h1{font-size:1.4rem;color:var(--purple-dark);margin-bottom:.25rem}.survey-header .subtitle{font-size:.85rem;color:var(--text-secondary)}.anonymous-notice{font-size:.75rem;color:var(--text-secondary);text-align:center;padding:.5rem;background:var(--earth-light);border-radius:8px;margin-bottom:1rem}.progress-bar{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.progress-bar .track{flex:1;height:6px;background:var(--neutral-light);border-radius:3px;overflow:hidden}.progress-bar .fill{height:100%;background:var(--purple-dark);border-radius:3px;transition:width .3s ease}.progress-bar .step-label{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.question-card{flex:1;display:flex;flex-direction:column;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.question-card h2{font-size:1.2rem;color:var(--text-primary);margin-bottom:1.25rem;line-height:1.4}.options-list{display:flex;flex-direction:column;gap:.75rem;list-style:none}.option-btn{display:block;width:100%;padding:1rem 1.25rem;font-size:1.05rem;text-align:left;background:var(--white);border:2px solid var(--neutral-light);border-radius:12px;color:var(--text-primary);transition:all .15s ease;min-height:56px}.option-btn:hover{border-color:var(--purple-light);background:#f5f0fa}.option-btn.selected{border-color:var(--purple-dark);background:#ede5f5;font-weight:600}.text-input{width:100%;padding:1rem 1.25rem;font-size:1.1rem;border:2px solid var(--neutral-light);border-radius:12px;outline:none;transition:border-color .15s ease}.text-input:focus{border-color:var(--purple-dark)}.char-count{font-size:.75rem;color:var(--text-secondary);text-align:right;margin-top:.5rem}.survey-nav{display:flex;gap:.75rem;margin-top:auto;padding-top:1.5rem}.nav-btn{flex:1;padding:1rem;font-size:1.05rem;font-weight:600;border:none;border-radius:12px;min-height:56px}.nav-btn.next{background:var(--purple-dark);color:var(--white)}.nav-btn.next:disabled{background:var(--purple-light);opacity:.5;cursor:not-allowed}.nav-btn.back{background:var(--neutral-light);color:var(--text-primary)}.nav-btn.submit{background:var(--green-dark);color:var(--white)}.nav-btn.submit:disabled{opacity:.5;cursor:not-allowed}.thankyou{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 1rem;gap:1.25rem;overflow-y:auto}.thankyou h2{font-size:1.6rem;color:var(--green-dark)}.thankyou .stat{font-size:1.1rem;color:var(--text-primary);background:var(--earth-light);padding:1.25rem 1.5rem;border-radius:12px;line-height:1.5;max-width:360px}.thankyou .stat strong{color:var(--purple-dark)}.followup-section{width:100%;max-width:360px;background:var(--neutral-light);border-radius:12px;padding:1.25rem}.followup-section h3{font-size:1.1rem;color:var(--text-primary);margin-bottom:.25rem}.followup-note{font-size:.75rem;color:var(--text-secondary);margin-bottom:.75rem}.followup-form{display:flex;flex-direction:column;gap:.6rem}.followup-form .text-input{font-size:.95rem;padding:.75rem 1rem}.followup-form .nav-btn{min-height:48px;font-size:.95rem}.followup-thanks{font-size:1rem;color:var(--green-dark);font-weight:600;padding:.5rem 0}.followup-link{display:block;width:100%;max-width:360px;padding:.85rem;font-size:1rem;font-weight:600;color:var(--purple-dark);background:var(--white);border:2px solid var(--purple-light);border-radius:12px;text-decoration:none;transition:background .15s ease}.followup-link:hover{background:#f5f0fa}.ranking-card{flex:1;display:flex;flex-direction:column;animation:fadeIn .3s ease}.ranking-card h2{font-size:1.1rem;color:var(--text-primary);margin-bottom:1.25rem;line-height:1.4;text-align:center}.ranking-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.ranking-option{position:relative;display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.75rem .5rem;background:var(--white);border:2px solid var(--neutral-light);border-radius:12px;cursor:pointer;transition:all .15s ease;min-height:100px}.ranking-option:hover{border-color:var(--purple-light);background:#f5f0fa}.ranking-option.ranked{border-color:var(--purple-dark);background:#ede5f5}.rank-badge{position:absolute;top:-8px;right:-8px;background:var(--purple-dark);color:var(--white);font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:10px;z-index:1}.ranking-option-img{width:64px;height:64px;border-radius:8px;object-fit:cover}.ranking-option-label{font-size:.85rem;font-weight:600;color:var(--text-primary);text-align:center;line-height:1.2}.ranking-summary{background:var(--earth-light);border-radius:12px;padding:1rem;margin-top:.5rem}.ranking-summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.ranking-summary-header span{font-weight:600;font-size:.9rem;color:var(--text-primary)}.ranking-clear{background:none;border:none;color:var(--text-secondary);font-size:.8rem;text-decoration:underline;cursor:pointer;padding:0}.ranking-list{padding-left:1.25rem;margin:0;font-size:.9rem;color:var(--text-primary);line-height:1.6}.ranking-hint{font-size:.8rem;color:var(--text-secondary);margin-top:.5rem;text-align:center}.rcv-display{display:flex;flex-direction:column;height:100%;padding:1rem 2rem;color:var(--text-light)}.rcv-round-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.rcv-round-label{font-size:1.4rem;font-weight:700}.rcv-majority-label{font-size:1rem;color:var(--text-secondary)}.rcv-round-dots{display:flex;gap:.5rem;margin-top:.5rem}.rcv-round-dot{width:10px;height:10px;border-radius:50%;background:var(--neutral-mid);transition:background .3s}.rcv-round-dot.active{background:var(--green-light)}.rcv-bars{flex:1;display:flex;flex-direction:column;justify-content:center;gap:1rem;position:relative}.rcv-bar-row{display:flex;align-items:center;gap:1rem;transition:opacity .8s ease}.rcv-bar-row.eliminated{opacity:.35}.rcv-bar-row.eliminated{position:relative}.rcv-bar-row.eliminated:after{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:100%;height:6px;background:#ffe928;border-radius:3px;z-index:2}.rcv-bar-row.just-eliminated:after{animation:markerStrike var(--strike-duration, 5s) ease-out forwards}@keyframes markerStrike{0%{width:0}to{width:100%}}.rcv-bar-info{display:flex;align-items:center;gap:.75rem;min-width:180px;flex-shrink:0}.rcv-bar-photo{width:48px;height:48px;border-radius:8px;object-fit:cover;flex-shrink:0}.rcv-bar-name{font-size:1.1rem;font-weight:600;white-space:nowrap}.rcv-bar-track{flex:1;height:40px;background:var(--neutral-mid);border-radius:8px;overflow:hidden;position:relative}.rcv-bar-fill{height:100%;border-radius:8px;transition:width 1.2s ease;display:flex;align-items:center;justify-content:flex-end;padding-right:.75rem;min-width:0}.rcv-bar-count{font-size:1rem;font-weight:700;color:var(--white);text-shadow:0 1px 2px rgba(0,0,0,.3);white-space:nowrap}.rcv-bar-count-outside{font-size:1rem;font-weight:700;color:var(--text-light);margin-left:.75rem;white-space:nowrap}.rcv-majority-line{position:absolute;top:0;bottom:0;width:2px;background:var(--earth-warm);opacity:.7;z-index:1}.rcv-majority-line:after{content:"majority";position:absolute;top:-1.5rem;left:50%;transform:translate(-50%);font-size:.7rem;color:var(--earth-warm);white-space:nowrap}.rcv-callout{background:var(--neutral-mid);border-radius:12px;padding:1.25rem 2rem;margin-top:1.5rem;font-size:1.35rem;line-height:1.6;color:var(--text-light);min-height:4rem;transition:opacity .5s ease}.rcv-winner-badge{display:inline-block;background:var(--green-dark);color:var(--white);font-weight:700;padding:.25rem .75rem;border-radius:8px;font-size:.9rem;margin-left:.75rem}.rcv-bar-row.winner .rcv-bar-name{color:var(--green-light)}.rcv-waiting{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:var(--text-secondary);font-size:1.2rem}.display-container{min-height:100dvh;background:var(--neutral-dark);color:var(--text-light);padding:1rem 2rem;display:flex;flex-direction:column;overflow:hidden}.display-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;flex-shrink:0}.display-header h1{font-size:1.8rem;color:var(--green-light)}.respondent-count{font-size:1.3rem;color:var(--earth-warm);font-weight:600}.respondent-count .number{font-size:1.6rem}.view-container{flex:1;display:flex;flex-direction:column;justify-content:center;animation:viewFadeIn .6s ease}@keyframes viewFadeIn{0%{opacity:0}to{opacity:1}}.welcome-view{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:1rem;text-align:center;padding:1rem}.welcome-headline{font-size:3.5rem;font-weight:800;color:var(--green-light);line-height:1.1;max-width:800px}.welcome-subtitle{font-size:1.5rem;color:var(--purple-light);max-width:600px;line-height:1.4}.welcome-qr{margin:1rem 0;padding:1.5rem;background:#ffffff14;border-radius:16px}.welcome-cta{font-size:2rem;font-weight:700;color:var(--earth-warm)}.welcome-note{font-size:1.1rem;color:var(--text-secondary)}@media(max-width:768px){.welcome-headline{font-size:2rem}.welcome-subtitle{font-size:1.1rem}.welcome-cta{font-size:1.3rem}.welcome-qr{padding:1rem}.welcome-orglink{font-size:.9rem}}.welcome-orglink{font-size:1.1rem;color:var(--text-secondary);margin-top:.5rem;text-align:center}.welcome-orglink-url{color:var(--green-light);text-decoration:none;font-size:2rem;font-weight:700;display:block;margin-top:.25rem}.welcome-orglink-url:hover{text-decoration:underline}.big-number-view{display:flex;flex-direction:column;align-items:center;gap:.75rem;flex:1}.big-number-view .view-title{font-size:2rem;color:var(--purple-light);text-align:center}.big-stat{text-align:center}.big-stat .percentage{font-size:5rem;font-weight:800;color:var(--green-light);line-height:1}.big-stat .description{font-size:1.4rem;color:var(--text-light);margin-top:.5rem;max-width:700px}.side-by-side-view{display:flex;flex-direction:column;gap:.5rem;flex:1}.side-by-side-view .view-title{font-size:2rem;color:var(--purple-light);text-align:center}.side-by-side-view .view-subtitle{font-size:1.1rem;color:var(--text-secondary);text-align:center;margin-top:-1rem}.comparison-section{margin-bottom:1rem}.comparison-section h3{font-size:1.2rem;color:var(--earth-warm);margin-bottom:1rem}.identity-columns{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.identity-column h4{font-size:1rem;color:var(--purple-light);margin-bottom:.75rem;text-align:center}.bar-item{margin-bottom:.6rem}.bar-label{font-size:.8rem;color:var(--text-light);opacity:.8;margin-bottom:.2rem}.bar-track{height:24px;background:#ffffff1a;border-radius:4px;overflow:hidden;position:relative}.bar-fill{height:100%;border-radius:4px;transition:width .8s ease;display:flex;align-items:center;padding-left:.5rem;min-width:fit-content}.bar-fill.q2{background:var(--green-mid)}.bar-fill.q3{background:var(--purple-mid)}.bar-value{font-size:.75rem;font-weight:700;color:var(--white);white-space:nowrap}.modeled-note{font-size:.8rem;color:var(--text-secondary);text-align:center;margin-top:.5rem;font-style:italic}.pie-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;width:100%;flex:1;align-items:center}.pie-grid-item{display:flex;flex-direction:column;align-items:center}.pie-grid-label{color:var(--earth-warm);font-size:2rem;font-weight:600;margin-bottom:.75rem;text-align:center}@media(max-width:768px){.pie-grid{grid-template-columns:1fr;gap:1.5rem}.pie-grid-label{font-size:1.3rem}.display-header h1{font-size:1.2rem}.big-number-view .view-title,.side-by-side-view .view-title,.wordcloud-view .view-title{font-size:1.3rem}.respondent-count{font-size:1rem}.respondent-count .number{font-size:1.2rem}.display-container{padding:.75rem 1rem}}.wordcloud-view{display:flex;flex-direction:column;align-items:center;flex:1}.wordcloud-view .view-title{font-size:2rem;color:var(--purple-light);text-align:center;margin-bottom:.5rem}.wordcloud-wrapper{flex:1;width:100%;display:flex;align-items:center;justify-content:center}.view-nav{display:flex;justify-content:center;align-items:center;gap:1rem;padding-top:.5rem;flex-shrink:0}.nav-arrow{background:none;border:none;color:#ffffff80;font-size:2rem;cursor:pointer;padding:0 .5rem;line-height:1;transition:color .2s}.nav-arrow:hover{color:var(--green-light)}.view-indicators{display:flex;justify-content:center;gap:.5rem;flex-shrink:0}.view-dot{width:10px;height:10px;border-radius:50%;background:#fff3;transition:background .3s ease;cursor:pointer}.view-dot.active{background:var(--green-light)}.admin-container{max-width:600px;margin:0 auto;padding:2rem 1rem;text-align:center}.admin-container h1{font-size:1.5rem;color:var(--purple-dark);margin-bottom:2rem}.qr-section{margin-bottom:3rem}.qr-section h2{font-size:1.1rem;color:var(--text-primary);margin-bottom:1rem}.qr-section .url-display{font-size:.85rem;color:var(--text-secondary);margin-top:.75rem;word-break:break-all}.reset-section{border-top:1px solid var(--neutral-light);padding-top:2rem}.reset-section h2{font-size:1.1rem;color:var(--text-primary);margin-bottom:.5rem}.reset-section p{font-size:.85rem;color:var(--text-secondary);margin-bottom:1rem}.reset-btn{padding:.75rem 2rem;font-size:1rem;font-weight:600;background:var(--danger);color:var(--white);border:none;border-radius:8px}.reset-btn:disabled{opacity:.5;cursor:not-allowed}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.dashboard-header h1{margin-bottom:0}.dashboard-user{display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:var(--text-secondary)}.sign-out-btn{padding:.4rem .75rem;font-size:.8rem;background:none;border:1px solid var(--text-secondary);border-radius:6px;color:var(--text-secondary);cursor:pointer}.sign-out-btn:hover{border-color:var(--purple-dark);color:var(--purple-dark)}.event-list{display:flex;flex-direction:column;gap:.75rem;text-align:left}.event-card{padding:1rem 1.25rem;border:1px solid var(--neutral-light);border-radius:8px;cursor:pointer;transition:border-color .2s}.event-card:hover{border-color:var(--purple-dark)}.event-card-name{font-weight:600;color:var(--text-primary)}.event-card-id{font-size:.8rem;color:var(--text-secondary);margin-top:.25rem}.admin-form{display:flex;flex-direction:column;gap:.75rem;text-align:left}.admin-list{display:flex;flex-direction:column;gap:.5rem;text-align:left;margin-bottom:1rem}.admin-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border:1px solid var(--neutral-light);border-radius:8px;font-size:.9rem}.admin-role{color:var(--purple-dark);font-size:.8rem}.admin-events{font-size:.8rem;color:var(--text-secondary);margin-top:.2rem}.remove-btn{padding:.3rem .75rem;font-size:.8rem;background:none;border:1px solid var(--danger);border-radius:6px;color:var(--danger);cursor:pointer}.remove-btn:hover{background:var(--danger);color:var(--white)}.empty-state{color:var(--text-secondary);font-size:.9rem}.back-link{display:inline-block;margin-bottom:1.5rem;font-size:.85rem;color:var(--purple-dark);text-decoration:none}.back-link:hover{text-decoration:underline}.toggle-btn{background:none;border:none;font-size:1.1rem;font-weight:600;color:var(--text-primary);cursor:pointer;padding:0}.toggle-btn:hover{color:var(--purple-dark)}.config-editor{width:100%;min-height:400px;padding:1rem;font-family:monospace;font-size:.85rem;line-height:1.5;border:1px solid var(--neutral-light);border-radius:8px;resize:vertical;background:#fafafa;color:var(--text-primary);tab-size:2}.config-editor:focus{border-color:var(--purple-dark);outline:none}
