*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#111827;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8f9fb;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6}#root{justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.survey-wrapper{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:100vh;display:flex}.survey-logo{justify-content:center;align-items:center;display:flex}.survey-logo img{width:auto;height:36px}.survey-card{background:#fff;border-radius:16px;width:100%;max-width:640px;position:relative;overflow:hidden;box-shadow:0 1px 3px #0000000a,0 6px 24px #0000000f}.progress-bar{background:#f3f4f6;width:100%;height:4px}.progress-fill{background:#f56104;border-radius:0 2px 2px 0;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}form{padding:2.5rem 3rem 2rem}@media (width<=600px){form{padding:2rem 1.5rem 1.5rem}}.step-header{margin-bottom:.25rem}.step-counter{color:#f56104;letter-spacing:.02em;font-size:.8rem;font-weight:500}.step-content{flex-direction:column;justify-content:center;min-height:200px;display:flex}.step-label{color:#111827;margin-bottom:1.5rem;font-size:1.375rem;font-weight:600;line-height:1.35;display:block}.enter-forward{animation:.35s cubic-bezier(.16,1,.3,1) forwards slideInRight}.enter-backward{animation:.35s cubic-bezier(.16,1,.3,1) forwards slideInLeft}.exit-forward{animation:.2s ease-in forwards slideOutLeft}.exit-backward{animation:.2s ease-in forwards slideOutRight}.visible{opacity:1;transform:translate(0)}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-20px)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(20px)}}:focus{outline:none}:focus-visible{outline-offset:2px;border-radius:8px;outline:2px solid #f56104}.input-wrapper{width:100%}.input-wrapper input,.input-wrapper textarea{color:#111827;background:#fafafa;border:1.5px solid #e5e7eb;border-radius:10px;outline:none;width:100%;padding:.875rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.input-wrapper input::placeholder,.input-wrapper textarea::placeholder{color:#9ca3af}.input-wrapper input:focus,.input-wrapper textarea:focus{background:#fff;border-color:#f56104;box-shadow:0 0 0 3px #f561041a}.input-wrapper input.input-error,.input-wrapper textarea.input-error{border-color:#ef4444;box-shadow:0 0 0 3px #ef444414}.input-wrapper textarea{resize:vertical;min-height:90px;line-height:1.5}.select-options{flex-direction:column;gap:.5rem;display:flex}.option-btn{color:#374151;cursor:pointer;text-align:left;background:#fafafa;border:1.5px solid #e5e7eb;border-radius:10px;align-items:center;gap:.75rem;width:100%;padding:.8rem 1rem;font-family:inherit;font-size:.95rem;transition:all .15s;display:flex}.option-btn:hover{background:#fff;border-color:#f56104}.option-btn.selected{color:#111827;background:#f561040a;border-color:#f56104;font-weight:500}.option-radio{border:2px solid #d1d5db;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:border-color .15s;display:flex}.option-btn.selected .option-radio{border-color:#f56104}.option-radio-dot{background:#f56104;border-radius:50%;width:8px;height:8px}.error-msg{color:#ef4444;margin-top:.5rem;font-size:.825rem;font-weight:500;display:block}.step-actions{border-top:1px solid #f3f4f6;justify-content:space-between;align-items:center;margin-top:2rem;padding-top:1.5rem;display:flex}.btn-back{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.35rem;padding:.6rem 1rem;font-family:inherit;font-size:.9rem;font-weight:500;transition:color .15s,background .15s;display:inline-flex}.btn-back:hover{color:#374151;background:#f3f4f6}.btn-next{color:#fff;cursor:pointer;background:#f56104;border:none;border-radius:10px;align-items:center;gap:.4rem;margin-left:auto;padding:.7rem 1.5rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.btn-next:hover{background:#e05500}.btn-next:active{transform:scale(.97)}.success-container{text-align:center;padding:3rem 2rem}.success-check{margin-bottom:1.25rem}.success-title{color:#111827;margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.success-text{color:#6b7280;margin-bottom:1.5rem;font-size:1rem;line-height:1.5}.btn-redirect{color:#fff;background:#f56104;border:none;border-radius:10px;align-items:center;gap:.4rem;padding:.7rem 1.5rem;font-family:inherit;font-size:.95rem;font-weight:600;text-decoration:none;transition:background .15s,transform .1s;display:inline-flex}.btn-redirect:hover{background:#e05500}.btn-redirect:active{transform:scale(.97)}.survey-footer{text-align:center}.powered-by{color:#9ca3af;letter-spacing:.02em;font-size:.8rem;font-weight:500}.admin-wrapper{width:100%;max-width:960px;min-height:100vh;margin:0 auto;padding:2rem 1.5rem 3rem}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.admin-header-left{align-items:center;gap:.75rem;display:flex}.admin-header h1{color:#111827;font-size:1.5rem;font-weight:700}.admin-badge{color:#f56104;background:#f5610414;border-radius:20px;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.btn-export{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .15s;display:inline-flex}.btn-export:hover{color:#f56104;border-color:#f56104}.btn-export:disabled{opacity:.4;cursor:not-allowed}.stats-grid{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.75rem;display:grid}@media (width<=768px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:#fff;border:1px solid #f0f0f2;border-radius:12px;flex-direction:column;gap:.25rem;padding:1.25rem;display:flex}.stat-value{color:#111827;white-space:nowrap;text-overflow:ellipsis;font-size:1.25rem;font-weight:700;overflow:hidden}.stat-label{color:#6b7280;font-size:.8rem;font-weight:500}.toolbar{align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.admin-search{flex:1;position:relative}.admin-search .search-icon{color:#9ca3af;pointer-events:none;position:absolute;top:50%;left:.9rem;transform:translateY(-50%)}.admin-search input{color:#111827;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;outline:none;width:100%;padding:.75rem 1rem .75rem 2.75rem;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.admin-search input::placeholder{color:#9ca3af}.admin-search input:focus{border-color:#f56104;box-shadow:0 0 0 3px #f5610414}.empty-state{text-align:center;color:#9ca3af;padding:4rem 2rem;font-size:.95rem}.submissions-list{flex-direction:column;gap:.5rem;display:flex}.submission-card{cursor:pointer;background:#fff;border:1px solid #f0f0f2;border-radius:12px;transition:border-color .15s,box-shadow .15s;overflow:hidden}.submission-card:hover{border-color:#e0e0e4;box-shadow:0 2px 8px #00000008}.submission-card.expanded{border-color:#f56104;box-shadow:0 0 0 3px #f561040f}.submission-summary{align-items:center;gap:.875rem;padding:1rem 1.25rem;display:flex}.submission-avatar{color:#fff;background:linear-gradient(135deg,#f56104,#ff8a3d);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.875rem;font-weight:700;display:flex}.submission-info{flex-direction:column;flex:1;min-width:0;display:flex}.submission-name{color:#111827;white-space:nowrap;text-overflow:ellipsis;font-size:.925rem;font-weight:600;overflow:hidden}.submission-meta{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.submission-right{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.submission-date{color:#9ca3af;white-space:nowrap;font-size:.75rem}.chevron{color:#9ca3af;transition:transform .2s}.chevron.open{transform:rotate(180deg)}.submission-details{border-top:1px solid #f3f4f6;padding:0 1.25rem 1.25rem;animation:.2s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.detail-grid{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem;padding-top:1rem;display:grid}@media (width<=600px){.detail-grid{grid-template-columns:repeat(2,1fr)}}.detail-item{flex-direction:column;gap:.15rem;display:flex}.detail-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.04em;font-size:.7rem;font-weight:600}.detail-value{color:#111827;font-size:.875rem;font-weight:500}.detail-full{margin-bottom:.75rem}.detail-full:last-child{margin-bottom:0}.detail-text{color:#374151;margin-top:.2rem;font-size:.875rem;line-height:1.5}.login-wrapper{justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.login-card{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:380px;padding:2.5rem 2rem;box-shadow:0 1px 3px #0000000a,0 6px 24px #0000000f}.login-logo{margin-bottom:1.25rem}.login-card h1{color:#111827;margin-bottom:.35rem;font-size:1.25rem;font-weight:700}.login-card p{color:#6b7280;margin-bottom:1.5rem;font-size:.9rem}.login-error{color:#dc2626;background:#ef44440f;border-radius:8px;margin-bottom:1rem;padding:.65rem 1rem;font-size:.85rem;font-weight:500}.btn-google{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;justify-content:center;align-items:center;gap:.6rem;width:100%;padding:.75rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:600;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:inline-flex}.btn-google:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000f}.login-hint{color:#9ca3af;margin-top:1rem;font-size:.8rem;display:block}.admin-header-right{align-items:center;gap:.75rem;display:flex}.user-menu{align-items:center;gap:.5rem;display:flex}.user-avatar{object-fit:cover;border-radius:50%;width:32px;height:32px}.user-avatar-fallback{color:#fff;background:linear-gradient(135deg,#f56104,#ff8a3d);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:700;display:flex}.btn-logout{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.3rem .5rem;font-family:inherit;font-size:.8rem;font-weight:500;transition:color .15s,background .15s}.btn-logout:hover{color:#ef4444;background:#ef44440f}.view-toggle{background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;flex-shrink:0;display:flex;overflow:hidden}.toggle-btn{cursor:pointer;color:#9ca3af;background:0 0;border:none;justify-content:center;align-items:center;width:36px;height:36px;transition:all .15s;display:flex}.toggle-btn:first-child{border-right:1px solid #e5e7eb}.toggle-btn:hover{color:#374151;background:#f9fafb}.toggle-btn.active{color:#f56104;background:#f561040f}.table-wrapper{background:#fff;border:1px solid #f0f0f2;border-radius:12px;overflow-x:auto}.submissions-table{border-collapse:collapse;white-space:nowrap;width:100%;font-size:.85rem}.submissions-table thead{background:#fafafa;border-bottom:1px solid #f0f0f2}.submissions-table th{text-align:left;color:#9ca3af;text-transform:uppercase;letter-spacing:.04em;padding:.75rem 1rem;font-size:.7rem;font-weight:600}.submissions-table td{color:#374151;border-bottom:1px solid #f7f7f8;padding:.7rem 1rem}.submissions-table tbody tr:last-child td{border-bottom:none}.submissions-table tbody tr:hover{background:#fafafa}.submissions-table .cell-name{color:#111827;font-weight:600}.submissions-table .cell-date{color:#9ca3af;font-size:.8rem}
