*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;min-height:100vh}#root{min-height:100vh}.layout{min-height:100vh;display:flex;flex-direction:column}.navbar{background-color:#f8f9fa;border-bottom:1px solid #dee2e6;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.nav-brand a{font-size:1.25rem;font-weight:600;text-decoration:none;color:#495057}.nav-links{display:flex;gap:1rem;align-items:center}.nav-links a{text-decoration:none;color:#6c757d;padding:.5rem 1rem;border-radius:4px;transition:background-color .2s}.nav-links a:hover{background-color:#e9ecef;color:#495057}.logout-btn{background-color:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:background-color .2s}.logout-btn:hover{background-color:#c82333}.main-content{flex:1;padding:2rem}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f8f9fa}.login-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px}.login-form h1{text-align:center;margin-bottom:2rem;color:#495057}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#495057}.form-group input{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem}.form-group input:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.error-message{color:#dc3545;margin-bottom:1rem;padding:.5rem;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px}.login-hint{text-align:center;margin-top:1rem;color:#6c757d;font-size:.875rem}button{background-color:#007bff;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s;width:100%}button:hover:not(:disabled){background-color:#0056b3}button:disabled{background-color:#6c757d;cursor:not-allowed}.dashboard,.templates,.personal-links{max-width:1200px;margin:0 auto}.dashboard h1,.templates h1,.personal-links h1{margin-bottom:2rem;color:#495057}.text-center{text-align:center}.mb-2{margin-bottom:1rem}.mb-4{margin-bottom:2rem}.personal-link-form{max-width:600px;margin:0 auto;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a}.personal-link-form .form-group{margin-bottom:1.5rem}.personal-link-form select{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;background-color:#fff}.personal-link-form select:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.success-message{color:#155724;background-color:#d4edda;border:1px solid #c3e6cb;padding:.75rem;border-radius:4px;margin-bottom:1rem}.generated-link{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.generated-link h3{margin-bottom:1rem;color:#495057}.link-container{display:flex;gap:.5rem}.link-input{flex:1;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;background-color:#f8f9fa}.copy-btn{background-color:#28a745;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s;width:auto}.copy-btn:hover{background-color:#218838}.form-container{margin-top:2rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.create-btn{background-color:#28a745;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s;width:auto}.create-btn:hover{background-color:#218838}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.template-card{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.template-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.template-header h3{margin:0;color:#495057}.template-actions{display:flex;gap:.5rem}.template-actions button{padding:.25rem .5rem;font-size:.875rem;border-radius:4px;border:none;cursor:pointer;width:auto}.preview-btn{background-color:#17a2b8;color:#fff}.preview-btn:hover{background-color:#138496}.edit-btn{background-color:#ffc107;color:#212529}.edit-btn:hover{background-color:#e0a800}.delete-btn{background-color:#dc3545;color:#fff}.delete-btn:hover{background-color:#c82333}.template-description{color:#6c757d;margin-bottom:1rem}.template-stats{display:flex;gap:1rem;margin-bottom:1rem}.template-stats span{background-color:#f8f9fa;padding:.25rem .5rem;border-radius:4px;font-size:.875rem;color:#495057}.template-dates{display:flex;justify-content:space-between;color:#6c757d;font-size:.75rem}.no-templates{text-align:center;padding:3rem;color:#6c757d}.template-form{max-width:800px;margin:0 auto}.form-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.form-section h3{margin-top:0;margin-bottom:1.5rem;color:#495057}.form-section textarea{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;resize:vertical}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.add-btn{background-color:#007bff;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.875rem;width:auto}.add-btn:hover{background-color:#0056b3}.no-questions{text-align:center;color:#6c757d;padding:2rem;background-color:#f8f9fa;border-radius:4px}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.cancel-btn{background-color:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;width:auto}.cancel-btn:hover{background-color:#5a6268}.question-editor{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:1.5rem;margin-bottom:1rem}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.question-header h4{margin:0;color:#495057}.option-row,.validation-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.option-row input,.validation-row input,.validation-row select{flex:1}.remove-btn{background-color:#dc3545;color:#fff;border:none;padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.75rem;width:auto}.remove-btn:hover{background-color:#c82333}.template-preview-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.template-preview{background:#fff;border-radius:8px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.preview-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #dee2e6}.preview-header h2{margin:0;color:#495057}.close-btn{background:none;border:none;font-size:2rem;cursor:pointer;color:#6c757d;width:auto;padding:0}.close-btn:hover{color:#495057}.preview-content{padding:1.5rem}.template-info{background:#f8f9fa;padding:1rem;border-radius:4px;margin-bottom:2rem}.template-info h3{margin-top:0;margin-bottom:1rem;color:#495057}.template-info p{margin:.5rem 0}.questionnaire-preview{max-width:600px}.preview-form{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:2rem}.preview-question{margin-bottom:1.5rem}.question-label{display:block;margin-bottom:.5rem;font-weight:500;color:#495057}.required{color:#dc3545}.preview-input{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;background-color:#f8f9fa}.radio-group,.checkbox-group{display:flex;flex-direction:column;gap:.5rem}.radio-option,.checkbox-option{display:flex;align-items:center;gap:.5rem;font-weight:400}.validation-info{margin-top:.25rem;color:#6c757d}.upload-area{border:2px dashed #ced4da;border-radius:4px;padding:2rem;text-align:center;background-color:#f8f9fa;color:#6c757d}.preview-submit{background-color:#6c757d;color:#fff;border:none;padding:.75rem 2rem;border-radius:4px;font-size:1rem;cursor:not-allowed;width:auto;margin-top:1rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.refresh-all-btn{background-color:#17a2b8;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s;width:auto}.refresh-all-btn:hover{background-color:#138496}.dashboard-content{display:flex;flex-direction:column;gap:2rem}.dashboard-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.dashboard-section h2{margin:0;padding:1.5rem;background-color:#f8f9fa;border-bottom:1px solid #dee2e6;color:#495057}.dashboard-stats{padding:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:#f8f9fa;border-radius:8px;padding:1.5rem;text-align:center;border-left:4px solid #dee2e6}.stat-card.total{border-left-color:#007bff}.stat-card.completed{border-left-color:#28a745}.stat-card.pending{border-left-color:#ffc107}.stat-card.expired{border-left-color:#dc3545}.stat-card.completion-rate{border-left-color:#17a2b8}.stat-number{font-size:2rem;font-weight:700;color:#495057;margin-bottom:.5rem}.stat-label{color:#6c757d;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.personal-links-table{padding:1.5rem}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.table-header h3{margin:0;color:#495057}.refresh-btn{background-color:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.875rem;width:auto}.refresh-btn:hover{background-color:#5a6268}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse;margin-top:1rem}th,td{padding:.75rem;text-align:left;border-bottom:1px solid #dee2e6}th{background-color:#f8f9fa;font-weight:600;color:#495057}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;color:#fff;font-size:.75rem;font-weight:500;text-transform:uppercase}.action-buttons{display:flex;gap:.5rem}.action-btn{padding:.25rem .5rem;font-size:.75rem;border-radius:4px;border:none;cursor:pointer;width:auto}.copy-btn{background-color:#17a2b8;color:#fff}.copy-btn:hover{background-color:#138496}.view-btn{background-color:#28a745;color:#fff}.view-btn:hover{background-color:#218838}.no-data{text-align:center;padding:2rem;color:#6c757d}.response-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.response-modal{background:#fff;border-radius:8px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #dee2e6}.modal-header h3{margin:0;color:#495057}.modal-content{padding:1.5rem}.response-info{background:#f8f9fa;padding:1rem;border-radius:4px;margin-bottom:1.5rem}.response-info p{margin:.5rem 0}.responses-section,.images-section{margin-bottom:1.5rem}.responses-section h4,.images-section h4{margin-bottom:1rem;color:#495057}.response-item{background:#f8f9fa;padding:1rem;border-radius:4px;margin-bottom:.5rem}.response-answer{margin-top:.5rem;padding:.5rem;background:#fff;border-radius:4px;border:1px solid #dee2e6}.image-item{background:#f8f9fa;padding:1rem;border-radius:4px;margin-bottom:.5rem}.image-item p{margin:.25rem 0}.error-notifications{padding:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h3{margin:0;color:#495057}.error-section{margin-bottom:2rem}.error-section-title{color:#495057;margin-bottom:1rem;font-size:1.1rem}.error-item{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem;border-radius:4px;margin-bottom:.5rem}.error-item.unresolved{background-color:#f8d7da;border:1px solid #f5c6cb}.error-item.resolved{background-color:#d4edda;border:1px solid #c3e6cb}.error-message{font-weight:500;margin-bottom:.5rem;color:#495057}.error-meta{display:flex;gap:1rem;font-size:.875rem;color:#6c757d}.error-actions{margin-left:1rem}.resolve-btn{background-color:#28a745;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.875rem;width:auto}.resolve-btn:hover:not(:disabled){background-color:#218838}.resolve-btn:disabled{background-color:#6c757d;cursor:not-allowed}.error-status{margin-left:1rem}.resolved-badge{background-color:#28a745;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.no-errors{text-align:center;padding:2rem;color:#6c757d}.questionnaire-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem 1rem}.questionnaire-container{max-width:800px;margin:0 auto}.questionnaire-card{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;overflow:hidden;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.questionnaire-header{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:3rem 2rem;text-align:center;position:relative;overflow:hidden}.questionnaire-header:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="white" opacity="0.1"/><circle cx="75" cy="75" r="1" fill="white" opacity="0.1"/><circle cx="50" cy="10" r="0.5" fill="white" opacity="0.1"/><circle cx="10" cy="60" r="0.5" fill="white" opacity="0.1"/><circle cx="90" cy="40" r="0.5" fill="white" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');animation:float 20s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) translateY(0)}25%{transform:translate(-10px) translateY(-10px)}50%{transform:translate(10px) translateY(-5px)}75%{transform:translate(-5px) translateY(10px)}}.header-content{position:relative;z-index:1}.questionnaire-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-shadow:0 2px 4px rgba(0,0,0,.1)}.questionnaire-description{font-size:1.1rem;opacity:.9;margin-bottom:2rem;line-height:1.6}.welcome-message{display:flex;align-items:center;justify-content:center;gap:.75rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 1.5rem;border-radius:50px;border:1px solid rgba(255,255,255,.2)}.welcome-icon{font-size:1.5rem;animation:wave 2s ease-in-out infinite}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}75%{transform:rotate(-10deg)}}.welcome-message p{margin:0;font-size:1rem}.questionnaire-form{padding:2.5rem}.progress-section{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:16px;padding:1.5rem;margin-bottom:2rem;border:1px solid #e2e8f0}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.progress-label{font-weight:600;color:#475569;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.progress-stats{font-size:.85rem;color:#64748b}.progress-bar-container{background:#e2e8f0;height:8px;border-radius:50px;overflow:hidden;margin-bottom:.5rem;box-shadow:inset 0 2px 4px #0000001a}.progress-bar{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:50px;transition:width .6s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.progress-bar:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-percentage{text-align:center;font-size:.8rem;color:#64748b;font-weight:500}.error-alert{display:flex;align-items:flex-start;gap:1rem;background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;border-radius:12px;padding:1rem 1.5rem;margin-bottom:1.5rem;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-icon{font-size:1.2rem;margin-top:.1rem}.error-content{flex:1}.error-title{font-weight:600;color:#dc2626;margin-bottom:.25rem}.error-message{color:#b91c1c;font-size:.9rem;line-height:1.4}.questions-container{display:flex;flex-direction:column;gap:2rem}.question-container{background:#fafafa;border-radius:16px;padding:1.5rem;border:2px solid transparent;transition:all .3s ease;position:relative}.question-container:hover{border-color:#e2e8f0;box-shadow:0 4px 12px #0000000d}.question-container:focus-within{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.question-header{margin-bottom:1rem}.question-label{display:flex;align-items:center;gap:.75rem;font-weight:600;color:#374151;font-size:1.1rem;line-height:1.4}.question-number{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:700;min-width:2.5rem;text-align:center;box-shadow:0 2px 4px #4f46e54d}.question-text{flex:1}.required-indicator{color:#ef4444;font-size:1.2rem;margin-left:.25rem}.question-field{margin-bottom:.5rem}.form-input{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;background:#fff;transition:all .3s ease;box-shadow:0 1px 3px #0000001a}.form-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;transform:translateY(-1px)}.form-input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-input::placeholder{color:#9ca3af}.select-wrapper{position:relative}.select-arrow{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#6b7280;pointer-events:none;font-size:.8rem}.radio-group{display:flex;flex-direction:column;gap:.75rem}.radio-option{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:12px;cursor:pointer;transition:all .3s ease;background:#fff;border:2px solid #e5e7eb}.radio-option:hover{background:#f8fafc;border-color:#cbd5e1}.radio-input{display:none}.radio-custom{width:20px;height:20px;border:2px solid #d1d5db;border-radius:50%;position:relative;transition:all .3s ease;background:#fff}.radio-input:checked+.radio-custom{border-color:#4f46e5;background:#4f46e5}.radio-input:checked+.radio-custom:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:#fff;border-radius:50%}.radio-input:checked~.radio-text{color:#4f46e5;font-weight:600}.radio-text{flex:1;color:#374151;transition:all .3s ease}.checkbox-group{display:flex;flex-direction:column;gap:.75rem}.checkbox-option{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:12px;cursor:pointer;transition:all .3s ease;background:#fff;border:2px solid #e5e7eb}.checkbox-option:hover{background:#f8fafc;border-color:#cbd5e1}.checkbox-input{display:none}.checkbox-custom{width:20px;height:20px;border:2px solid #d1d5db;border-radius:6px;position:relative;transition:all .3s ease;background:#fff;display:flex;align-items:center;justify-content:center}.checkbox-input:checked+.checkbox-custom{border-color:#4f46e5;background:#4f46e5}.checkbox-check{color:#fff;font-size:12px;opacity:0;transition:opacity .3s ease}.checkbox-input:checked+.checkbox-custom .checkbox-check{opacity:1}.checkbox-input:checked~.checkbox-text{color:#4f46e5;font-weight:600}.checkbox-text{flex:1;color:#374151;transition:all .3s ease}.question-error{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.question-error .error-icon{font-size:.9rem}.error-text{color:#dc2626;font-size:.85rem;margin:0;font-weight:500}.upload-section{background:#f8fafc;border-radius:16px;padding:1.5rem;border-top:3px solid #e2e8f0;margin-top:2rem}.submit-section{margin-top:2.5rem;padding-top:2rem;border-top:2px solid #e2e8f0;text-align:center}.submit-button{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;padding:1rem 2.5rem;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #4f46e566;position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:.75rem;min-width:200px;justify-content:center}.submit-button:hover:not(.submitting){transform:translateY(-2px);box-shadow:0 8px 25px #4f46e580}.submit-button:active{transform:translateY(0)}.submit-button.submitting{background:#9ca3af;cursor:not-allowed;box-shadow:none}.submit-text{transition:all .3s ease}.submit-arrow{font-size:1.2rem;transition:transform .3s ease}.submit-button:hover:not(.submitting) .submit-arrow{transform:translate(3px)}.submit-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-container{padding:3rem 2rem;text-align:center;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.success-animation{margin-bottom:2rem}.success-checkmark{width:80px;height:80px;border-radius:50%;display:inline-block;stroke-width:2;stroke:#22c55e;stroke-miterlimit:10;margin:10px auto;box-shadow:inset 0 0 #22c55e;animation:fill .4s ease-in-out .4s forwards,scale .3s ease-in-out .9s both;position:relative}.success-checkmark .check-icon{width:56px;height:56px;position:absolute;left:12px;top:12px;background:#22c55e;border-radius:50%}.icon-line{height:3px;background-color:#fff;display:block;border-radius:2px;position:absolute;z-index:10}.icon-line.line-tip{top:46px;left:14px;width:25px;transform:rotate(45deg);animation:icon-line-tip .75s}.icon-line.line-long{top:38px;right:8px;width:47px;transform:rotate(-45deg);animation:icon-line-long .75s}.icon-circle{top:-4px;left:-4px;z-index:10;width:80px;height:80px;border-radius:50%;position:absolute;box-sizing:content-box;border:4px solid rgba(34,197,94,.2)}.icon-fix{top:8px;width:5px;left:26px;z-index:1;height:85px;position:absolute;transform:rotate(-45deg)}@keyframes icon-line-tip{0%{width:0;left:1px;top:19px}54%{width:0;left:1px;top:19px}70%{width:50px;left:-8px;top:37px}84%{width:17px;left:21px;top:48px}to{width:25px;left:14px;top:45px}}@keyframes icon-line-long{0%{width:0;right:46px;top:54px}65%{width:0;right:46px;top:54px}84%{width:55px;right:0;top:35px}to{width:47px;right:8px;top:38px}}@keyframes fill{to{box-shadow:inset 0 0 0 60px #22c55e}}@keyframes scale{0%,to{transform:none}50%{transform:scale3d(1.1,1.1,1)}}.success-title{font-size:2.5rem;font-weight:700;color:#166534;margin-bottom:1rem}.success-message{font-size:1.1rem;color:#15803d;margin-bottom:2rem;line-height:1.6}.success-info{display:flex;align-items:flex-start;gap:1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:12px;padding:1.5rem;max-width:500px;margin:0 auto;text-align:left}.info-icon{font-size:1.2rem;margin-top:.1rem}.info-content{flex:1;color:#166534;line-height:1.5}@media(max-width:768px){.questionnaire-page{padding:1rem .5rem}.questionnaire-header{padding:2rem 1.5rem}.questionnaire-title{font-size:2rem}.questionnaire-form{padding:1.5rem}.question-label{flex-direction:column;align-items:flex-start;gap:.5rem}.question-number{align-self:flex-start}.submit-button{width:100%;padding:1rem}.success-title{font-size:2rem}.success-checkmark{width:60px;height:60px}.success-checkmark .check-icon{width:42px;height:42px;left:9px;top:9px}}.image-upload-container{background:#fff;border-radius:16px;padding:1.5rem;border:2px solid #e5e7eb}.upload-header{margin-bottom:1.5rem}.upload-title{font-size:1.2rem;font-weight:600;color:#374151;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.upload-description{color:#6b7280;font-size:.9rem;margin:0}.upload-dropzone{border:3px dashed #d1d5db;border-radius:16px;padding:2rem;text-align:center;background:#fafafa;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden}.upload-dropzone:hover{border-color:#9ca3af;background:#f3f4f6}.upload-dropzone.drag-active{border-color:#4f46e5;background:linear-gradient(135deg,#eef2ff,#e0e7ff);transform:scale(1.02)}.upload-dropzone.error{border-color:#ef4444;background:#fef2f2}.upload-content{position:relative;z-index:1}.upload-icon{font-size:3rem;margin-bottom:1rem;transition:all .3s ease;display:inline-block}.upload-dropzone.drag-active .upload-icon{transform:scale(1.2);animation:bounce .6s ease-in-out}@keyframes bounce{0%,to{transform:scale(1.2)}50%{transform:scale(1.4)}}.upload-text{margin-bottom:.75rem}.upload-button{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;padding:.5rem 1.25rem;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #4f46e54d}.upload-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4f46e566}.upload-or{color:#6b7280;margin-left:.5rem}.upload-formats{color:#9ca3af;font-size:.8rem;margin:0}.drop-message{color:#4f46e5;font-weight:600;margin:.5rem 0 0;animation:pulse 1.5s ease-in-out infinite}.upload-error{display:flex;align-items:center;gap:.5rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.75rem;margin-bottom:1rem}.upload-error .error-icon{font-size:1rem}.upload-error p{color:#dc2626;font-size:.85rem;margin:0;font-weight:500}.uploaded-files{margin-top:1.5rem}.files-title{font-weight:600;color:#374151;margin-bottom:1rem;font-size:.95rem}.file-item{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:12px;margin-bottom:.75rem;transition:all .3s ease;overflow:hidden}.file-item:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.file-header{display:flex;align-items:center;justify-content:space-between;padding:1rem}.file-info{display:flex;align-items:center;gap:.75rem;flex:1}.file-preview{width:40px;height:40px;object-fit:cover;border-radius:8px;border:2px solid #e5e7eb}.file-icon{width:40px;height:40px;background:#f3f4f6;border-radius:8px;border:2px solid #e5e7eb;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.file-details{flex:1;min-width:0}.file-name{font-weight:500;color:#374151;margin:0 0 .25rem;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.file-size{color:#6b7280;font-size:.8rem;margin:0}.file-progress{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin:0 1rem;min-width:80px}.progress-bar-bg{width:100%;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:3px;transition:width .3s ease}.progress-text{font-size:.7rem;color:#6b7280;font-weight:500;margin:0}.remove-file-btn{background:#ef4444;color:#fff;border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}.remove-file-btn:hover{background:#dc2626;transform:scale(1.1)}.file-count{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.count-text{display:block;color:#6b7280;font-size:.8rem;margin-bottom:.5rem;text-align:center}.count-bar{width:100%;height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden}.count-fill{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:2px;transition:width .3s ease}@media(max-width:768px){.upload-dropzone{padding:1.5rem 1rem}.upload-icon{font-size:2.5rem}.file-item{flex-direction:column;align-items:stretch;gap:.75rem}.file-info{justify-content:flex-start}.file-name{max-width:none}.file-progress{margin:0;width:100%}.remove-file-btn{align-self:flex-end}}.file-comment-section{padding:0 1rem 1rem;border-top:1px solid #e5e7eb;background:#ffffff80}.comment-input-container{margin-top:.75rem}.comment-label{display:block;font-size:.85rem;font-weight:500;color:#374151;margin-bottom:.5rem}.comment-input-wrapper{position:relative;border-radius:8px;transition:all .3s ease}.comment-input-wrapper.focused{transform:translateY(-1px);box-shadow:0 2px 8px #4f46e526}.comment-input-wrapper.error{box-shadow:0 2px 8px #ef444426}.comment-textarea{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.9rem;font-family:inherit;resize:vertical;min-height:80px;transition:all .3s ease;background:#fff}.comment-textarea:focus{outline:none;border-color:#4f46e5;background:#fefefe}.comment-input-wrapper.error .comment-textarea{border-color:#ef4444}.comment-textarea::placeholder{color:#9ca3af;font-style:italic}.comment-counter{display:flex;justify-content:flex-end;margin-top:.5rem;font-size:.75rem}.comment-counter .counter-text{color:#6b7280;transition:color .3s ease}.comment-counter.warning .counter-text{color:#f59e0b;font-weight:500}.comment-counter.error .counter-text,.comment-counter .error-text{color:#ef4444;font-weight:500}@media(max-width:768px){.file-comment-section{padding:.75rem}.comment-textarea{font-size:16px;min-height:70px}.file-item{flex-direction:column;align-items:stretch;gap:0}.file-header{flex-direction:column;align-items:stretch;gap:.75rem}.file-info{justify-content:flex-start}.file-name{max-width:none}.file-progress{margin:0;width:100%}.remove-file-btn{align-self:flex-end;margin-top:.5rem}}.image-preview-container{position:relative;display:inline-block}.thumbnail-info-container{display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem}.status-indicator-inline{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .5rem;border-radius:8px;font-size:.7rem;font-weight:600;white-space:nowrap;border:1px solid;width:fit-content}.status-indicator-inline.pending{background:#3b82f61a;color:#1d4ed8;border-color:#3b82f64d}.status-indicator-inline.success{background:#22c55e1a;color:#15803d;border-color:#22c55e4d}.status-indicator-inline.error{background:#ef44441a;color:#dc2626;border-color:#ef44444d}.status-indicator-inline.info{background:#6b72801a;color:#374151;border-color:#6b72804d}.status-indicator-inline .status-icon{font-size:.8rem;line-height:1}.status-indicator-inline .status-text{font-size:.7rem;line-height:1.2;font-weight:600}.status-indicator-inline .spinner{animation:spin 1s linear infinite}.thumbnail-status{position:absolute;top:-8px;right:-8px;z-index:10}.status-indicator{display:flex;align-items:center;gap:.3rem;padding:.4rem .7rem;border-radius:14px;font-size:.75rem;font-weight:600;white-space:nowrap;box-shadow:0 3px 6px #00000026;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.3);min-height:24px}.status-indicator.pending{background:#3b82f6f2;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4)}.status-indicator.success{background:#22c55ef2;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4)}.status-indicator.error{background:#ef4444f2;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4)}.status-indicator.info{background:#6b7280f2;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4)}.status-indicator .spinner{animation:spin 1s linear infinite}.status-indicator .status-icon{font-size:.9rem;line-height:1}.status-indicator .status-text{font-size:.75rem;line-height:1.2;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3)}.thumbnail-info{color:#f59e0b;font-size:.75rem;margin:.25rem 0 0;font-weight:500}@media(max-width:768px){.thumbnail-status{position:static;margin-top:.5rem}.status-indicator{font-size:.8rem;padding:.5rem .8rem;min-height:28px}.status-indicator .status-text{font-size:.8rem}.status-indicator .status-icon{font-size:1rem}.thumbnail-info{font-size:.85rem}}.character-count-inline{font-size:.75rem;color:#6b7280;font-weight:400;margin-left:.5rem}.comment-input-wrapper.warning{box-shadow:0 2px 8px #f59e0b26}.comment-input-wrapper.warning .comment-textarea{border-color:#f59e0b}.comment-counter.very-near .counter-text{color:#dc2626;font-weight:600;animation:pulse 1.5s ease-in-out infinite}.limit-reached{color:#dc2626;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.character-progress-bar{width:100%;height:3px;background:#e5e7eb;border-radius:2px;overflow:hidden;margin-top:.25rem;transition:all .3s ease}.character-progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);border-radius:2px;transition:all .3s ease}.character-progress-fill.warning{background:linear-gradient(90deg,#f59e0b,#d97706)}.character-progress-fill.danger{background:linear-gradient(90deg,#ef4444,#dc2626);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media(max-width:768px){.character-count-inline{display:block;margin-left:0;margin-top:.25rem}.comment-counter{font-size:.8rem}.character-progress-bar{height:4px}}.confirmation-dialog-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirmation-dialog{background:#fff;border-radius:16px;max-width:500px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dialog-header{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:1.5rem 2rem;border-bottom:none}.dialog-header h3{margin:0;font-size:1.5rem;font-weight:600;text-align:center}.dialog-content{padding:2rem;text-align:center}.dialog-content p{color:#374151;font-size:1.05rem;line-height:1.6;margin:0}.dialog-actions{display:flex;gap:1rem;padding:1.5rem 2rem 2rem;justify-content:center}.dialog-actions button{flex:1;max-width:180px;padding:.875rem 1.5rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.cancel-btn{background:#f3f4f6;color:#374151;border:2px solid #e5e7eb}.cancel-btn:hover{background:#e5e7eb;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.confirm-btn{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;box-shadow:0 4px 15px #4f46e566}.confirm-btn:hover{transform:translateY(-1px);box-shadow:0 8px 25px #4f46e580}.confirm-btn.destructive{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 15px #ef444466}.confirm-btn.destructive:hover{box-shadow:0 8px 25px #ef444480}
