.validation-feedback{width:100%;max-width:320px}.validation-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.validation-item{display:flex;align-items:flex-start;gap:10px;padding:8px 12px;border-radius:6px;border-left:3px solid transparent;background-color:#f8f9fa;transition:background-color .3s ease,border-color .3s ease,transform .2s ease}.validation-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;border-radius:50%;transition:background-color .3s ease,color .3s ease}.validation-content{display:flex;flex-direction:column;gap:2px;min-width:0}.validation-label{font-size:13px;font-weight:600;color:#333;line-height:1.3}.validation-message{font-size:11px;color:#666;line-height:1.3}.validation-item--pass{background-color:#e8f5e9;border-left-color:#4caf50}.validation-item--pass .validation-icon{background-color:#4caf50;color:#fff}.validation-item--pass .validation-message{color:#2e7d32}.validation-item--warning{background-color:#fff8e1;border-left-color:#ff9800}.validation-item--warning .validation-icon{background-color:#ff9800;color:#fff}.validation-item--warning .validation-message{color:#e65100}.validation-item--fail{background-color:#ffebee;border-left-color:#f44336}.validation-item--fail .validation-icon{background-color:#f44336;color:#fff}.validation-item--fail .validation-message{color:#c62828}.validation-item--disabled{background-color:#f5f5f5;border-left-color:#9e9e9e;opacity:.7}.validation-item--disabled .validation-icon{background-color:#bdbdbd;color:#fff}.validation-item--disabled .validation-message{color:#9e9e9e}.validation-label--disabled{text-decoration:line-through;color:#9e9e9e}.validation-disabled-badge{font-size:9px;font-weight:600;color:#757575;background-color:#e0e0e0;padding:2px 6px;border-radius:3px;margin-left:auto;text-transform:uppercase;letter-spacing:.5px}.validation-item--clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.validation-item--clickable:hover{transform:translate(2px);box-shadow:0 2px 4px #0000001a}.validation-item--clickable:focus{outline:2px solid #2196f3;outline-offset:2px}.validation-item--clickable:active{transform:translate(1px)}.validation-feedback--loading .validation-item{background-color:#f0f0f0}.validation-item--skeleton{pointer-events:none}.skeleton-icon{width:20px;height:20px;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}.skeleton-text{display:block;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:3px}.skeleton-label{width:80px;height:14px}.skeleton-message{width:120px;height:12px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.validation-item{animation:fade-in .3s ease}@keyframes fade-in{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@media(max-width:480px){.validation-feedback{max-width:100%}.validation-item{padding:6px 10px;gap:8px}.validation-icon{width:18px;height:18px;font-size:12px}.validation-label{font-size:12px}.validation-message{font-size:10px}.validation-list{gap:4px}}.camera-view{display:flex;flex-direction:column;align-items:center;width:100%;max-width:640px;margin:0 auto;padding:1rem}.camera-view__video-container{position:relative;width:100%;aspect-ratio:4 / 3;background-color:#1f2937;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.camera-view__video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.camera-view__canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.camera-view__loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#000000b3;z-index:10}.camera-view__loading-content{text-align:center;padding:1.5rem}.camera-view__loading-text{color:#fff;font-size:1rem;margin-bottom:1rem}.camera-view__progress-bar{width:200px;height:8px;background-color:#374151;border-radius:4px;overflow:hidden;margin:0 auto}.camera-view__progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:4px;transition:width .3s ease}.camera-view__progress-text{color:#9ca3af;font-size:.875rem;margin-top:.5rem}.camera-view__error-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#000c;z-index:10}.camera-view__error-text{color:#ef4444;font-size:1rem;text-align:center;padding:1rem;max-width:80%}.camera-view__feedback{width:100%;margin-top:1rem}.camera-view__controls{display:flex;flex-direction:column;align-items:center;margin-top:1.5rem;gap:.75rem}.camera-view__capture-button{width:72px;height:72px;border-radius:50%;border:4px solid #6b7280;background-color:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative}.camera-view__capture-button:disabled{cursor:not-allowed;opacity:.5}.camera-view__capture-button--ready{border-color:#22c55e}.camera-view__capture-button--ready:hover{border-color:#16a34a;transform:scale(1.05)}.camera-view__capture-button--ready:active{transform:scale(.95)}.camera-view__capture-icon{width:56px;height:56px;border-radius:50%;background-color:#6b7280;transition:background-color .2s ease}.camera-view__capture-button--ready .camera-view__capture-icon{background-color:#22c55e}.camera-view__capture-button--ready:hover .camera-view__capture-icon{background-color:#16a34a}.camera-view__status-text{color:#9ca3af;font-size:.875rem;text-align:center}.camera-view__status-text--ready{color:#22c55e;font-weight:500}@media(max-width:480px){.camera-view{padding:.5rem}.camera-view__video-container{border-radius:8px}.camera-view__capture-button{width:64px;height:64px}.camera-view__capture-icon{width:48px;height:48px}.camera-view__loading-text,.camera-view__error-text{font-size:.875rem}.camera-view__progress-bar{width:160px}}@media(min-width:768px){.camera-view{max-width:720px}.camera-view__capture-button{width:80px;height:80px}.camera-view__capture-icon{width:64px;height:64px}}@media(min-width:1024px){.camera-view{max-width:800px}}.photo-preview{width:100%;display:flex;justify-content:center;padding:20px 0}.photo-preview-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:32px;max-width:500px;width:100%;display:flex;flex-direction:column;align-items:center}.photo-preview-title{color:var(--primary);font-size:1.5rem;font-weight:700;margin-bottom:24px;text-align:center}.photo-preview-main{width:300px;height:300px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:var(--bg-dark);display:flex;align-items:center;justify-content:center}.photo-preview-image{width:100%;height:100%;object-fit:cover}.photo-dimensions{margin-top:12px;color:var(--text-light);font-size:.9rem;text-align:center}.download-buttons{display:flex;flex-direction:column;gap:12px;width:100%;margin-top:24px}.download-btn{width:100%}.btn-icon{font-size:1.1em}.print-layout-section{margin-top:32px;padding-top:24px;border-top:1px solid var(--bg-dark);width:100%;display:flex;flex-direction:column;align-items:center}.print-layout-title{color:var(--text);font-size:1rem;font-weight:600;margin-bottom:16px}.print-layout-preview{background:var(--white);border:2px solid var(--bg-dark);border-radius:var(--radius);padding:8px;display:flex;align-items:center;justify-content:center}.print-layout-canvas{display:block;border-radius:4px}.print-layout-hint{margin-top:12px;color:var(--text-light);font-size:.85rem;text-align:center;font-style:italic}.retake-btn{margin-top:24px;width:100%}@media(max-width:600px){.photo-preview{padding:12px 0}.photo-preview-card{padding:20px;border-radius:var(--radius)}.photo-preview-title{font-size:1.25rem;margin-bottom:20px}.photo-preview-main{width:250px;height:250px}.photo-dimensions{font-size:.85rem}.download-buttons{margin-top:20px}.print-layout-section{margin-top:24px;padding-top:20px}.print-layout-title{font-size:.95rem}.print-layout-hint{font-size:.8rem}}@media(max-width:400px){.photo-preview-card{padding:16px}.photo-preview-main{width:220px;height:220px}.photo-preview-title{font-size:1.1rem}.download-buttons{gap:10px}}:root{--primary: #1a365d;--primary-light: #2c5282;--success: #38a169;--success-light: #48bb78;--warning: #d69e2e;--warning-light: #ecc94b;--error: #e53e3e;--error-light: #fc8181;--bg: #f7fafc;--bg-dark: #edf2f7;--text: #2d3748;--text-light: #718096;--white: #ffffff;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius: 8px;--radius-lg: 12px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}.app{max-width:800px;margin:0 auto;padding:20px;min-height:100vh;display:flex;flex-direction:column}.app-header{text-align:center;padding:20px 0 30px}.app-header h1{color:var(--primary);font-size:2rem;font-weight:700;margin-bottom:8px}.subtitle{color:var(--text-light);font-size:1rem}.app-main{flex:1;display:flex;flex-direction:column;align-items:center}.loading-indicator{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--white);padding:12px 24px;border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px;z-index:100}.loading-spinner{width:20px;height:20px;border:2px solid var(--bg-dark);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-container .loading-spinner{width:48px;height:48px;border-width:3px;margin-bottom:20px}.loading-container p{color:var(--text-light);font-size:1.1rem}.loading-progress{margin-top:8px;font-weight:600;color:var(--primary)}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);max-width:500px;width:100%}.error-icon{font-size:4rem;margin-bottom:20px;opacity:.8}.error-container h2{color:var(--error);margin-bottom:12px;font-size:1.5rem}.error-container p{color:var(--text);margin-bottom:8px}.error-hint{color:var(--text-light);font-size:.9rem;margin-top:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;transition:all .2s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--primary);color:var(--white)}.btn-primary:hover:not(:disabled){background-color:var(--primary-light)}.btn-success{background-color:var(--success);color:var(--white)}.btn-success:hover:not(:disabled){background-color:var(--success-light)}.btn-secondary{background-color:var(--bg-dark);color:var(--text)}.btn-secondary:hover:not(:disabled){background-color:#e2e8f0}.btn-lg{padding:16px 32px;font-size:1.1rem}@media(max-width:600px){.app{padding:12px}.app-header{padding:12px 0 20px}.app-header h1{font-size:1.5rem}.subtitle{font-size:.9rem}.loading-indicator{bottom:12px;padding:10px 16px;font-size:.9rem}.error-container{padding:40px 16px}.error-icon{font-size:3rem}.error-container h2{font-size:1.25rem}.btn{padding:10px 20px;font-size:.95rem}.btn-lg{padding:14px 28px;font-size:1rem}}@media(max-width:400px){.app-header h1{font-size:1.3rem}.subtitle{font-size:.85rem}}
