:root{--color-primary: #0f172a;--color-primary-light: #1e293b;--color-background: #f8fafc;--color-surface: #ffffff;--color-success: #22c55e;--color-accent: #f59e0b;--color-text-primary: #334155;--color-text-secondary: #64748b;--color-border: #e2e8f0;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--color-background);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{cursor:pointer;border:none;font-family:inherit}input,select,textarea{font-family:inherit}.container{max-width:480px;margin:0 auto;min-height:100vh;background-color:var(--color-background);position:relative;overflow-x:hidden;padding-bottom:80px}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.bg-surface{background-color:var(--color-surface)}.client-header{padding:24px 20px;background-color:var(--color-surface);border-bottom:1px solid var(--color-border)}.page-title{font-size:28px;font-weight:700;color:var(--color-primary);margin-bottom:4px}.client-count{font-size:14px;color:var(--color-text-secondary)}.search-bar{margin:16px 20px;position:relative}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary)}.search-input{width:100%;padding:12px 12px 12px 40px;border-radius:8px;border:1px solid var(--color-border);background-color:#fff;font-size:16px;color:var(--color-text-primary)}.client-section{padding:0 20px;margin-bottom:24px}.section-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin-bottom:12px}.recent-client-card{display:flex;align-items:center;gap:12px;background-color:var(--color-surface);padding:12px;border-radius:12px;box-shadow:0 2px 4px #0000000d}.avatar-circle{width:48px;height:48px;border-radius:50%;background-color:var(--color-primary-light);color:#fff;display:flex;justify-content:center;align-items:center;font-weight:700;font-size:18px}.client-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--color-border)}.avatar-small{width:32px;height:32px;border-radius:50%;background-color:#e2e8f0;color:var(--color-text-secondary);display:flex;justify-content:center;align-items:center;font-size:14px;font-weight:600}.alphabet-header{font-size:14px;font-weight:700;color:var(--color-text-secondary);margin-bottom:8px}.fab{position:fixed;bottom:90px;right:20px;width:56px;height:56px;background-color:var(--color-primary);border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 4px 12px #0f172a66;z-index:90}.input-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.input-label{font-size:14px;color:var(--color-text-secondary);font-weight:500}.input-field{padding:14px;border:1px solid var(--color-border);border-radius:6px;font-size:16px;color:var(--color-text-primary);background-color:var(--color-surface);transition:border-color .2s ease}.input-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #0a3d621a}.btn{width:100%;padding:16px;border-radius:8px;font-weight:600;font-size:16px;letter-spacing:.5px;transition:opacity .2s ease,transform .1s ease;display:flex;align-items:center;justify-content:center;gap:8px}.btn:active{transform:scale(.98)}.btn-primary{background-color:var(--color-primary);color:#fff;box-shadow:0 4px 6px #0a3d6233}.btn-secondary{background-color:transparent;border:1px solid var(--color-border);color:var(--color-text-primary)}.btn-success{background-color:var(--color-success);color:#fff}.btn-accent{background-color:var(--color-accent);color:#fff}.form-header{display:flex;align-items:center;gap:16px;padding:20px;background-color:var(--color-surface);position:sticky;top:0;z-index:10}.back-btn{background:none;border:none;color:var(--color-text-primary);padding:4px}.page-title-small{font-size:20px;font-weight:700;color:var(--color-text)}.pending-analysis-banner{margin:0 20px 20px;padding:12px 16px;background-color:#ecfdf5;border:1px solid #10b981;border-radius:12px;display:flex;align-items:center;gap:12px;animation:fadeIn .3s ease-out}.banner-icon{font-size:24px}.banner-content{display:flex;flex-direction:column}.banner-content strong{color:#065f46;font-size:14px}.banner-content span{color:#047857;font-size:12px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.client-form{padding:20px 20px 100px}.form-row{display:grid;grid-template-columns:120px 1fr;gap:16px}.radio-group{display:flex;gap:24px;padding:12px 0}.radio-label{display:flex;align-items:center;gap:8px;font-size:16px;color:var(--color-text-primary)}.form-footer{position:fixed;bottom:70px;left:0;width:100%;padding:20px;background-color:var(--color-surface);border-top:1px solid var(--color-border);z-index:90;padding-bottom:calc(20px + env(safe-area-inset-bottom))}.client-form{padding-bottom:160px}.settings-header{padding:24px 20px;background-color:var(--color-surface);border-bottom:1px solid var(--color-border)}.settings-section{padding:24px 20px;border-bottom:8px solid var(--color-background);background-color:var(--color-surface)}.section-subtitle{font-size:16px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.account-info,.plan-info{display:flex;flex-direction:column;gap:16px}.info-row{display:flex;flex-direction:column;gap:4px}.info-label{font-size:14px;color:var(--color-text-secondary)}.info-value-row{display:flex;justify-content:space-between;align-items:center}.info-value{font-size:16px;font-weight:500;color:var(--color-text-primary)}.switch-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.switch-label{font-size:16px;color:var(--color-text-primary)}.switch{position:relative;display:inline-block;width:50px;height:28px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.4s}.slider:before{position:absolute;content:"";height:24px;width:24px;left:2px;bottom:2px;background-color:#fff;transition:.4s}input:checked+.slider{background-color:var(--color-primary)}input:focus+.slider{box-shadow:0 0 1px var(--color-primary)}input:checked+.slider:before{transform:translate(22px)}.slider.round{border-radius:34px}.slider.round:before{border-radius:50%}.plan-info{margin-bottom:24px}.plan-badge{display:inline-block;background-color:var(--color-primary-light);color:#fff;padding:4px 12px;border-radius:4px;font-size:14px;font-weight:600;width:fit-content}.delete-account-container{display:flex;justify-content:space-between;align-items:center;margin-top:12px}.delete-label{color:#ef4444;font-weight:500}.btn-delete{color:#ef4444!important;border-color:#ef4444!important;width:auto!important;padding:8px 16px!important;font-size:14px!important}.mt-4{margin-top:16px}.branding-config{display:flex;flex-direction:column;gap:16px}.settings-input{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:8px;font-size:16px;background-color:var(--color-background);color:var(--color-text-primary)}.logo-preview-box{border:2px dashed var(--color-border);border-radius:12px;padding:20px;display:flex;justify-content:center;align-items:center;min-height:120px}.logo-preview{max-height:80px;max-width:100%;object-fit:contain}.preview-img-wrapper{display:flex;flex-direction:column;align-items:center;gap:10px}.btn-remove-logo{color:#ef4444;font-size:14px;font-weight:500;background:none;border:none;cursor:pointer}.logo-upload-label{padding:8px 16px;background-color:var(--color-primary-light);color:#fff;border-radius:8px;font-weight:600;cursor:pointer}.hidden{display:none}.block{display:block}.mb-2{margin-bottom:8px}.provider-badges{display:flex;gap:8px}.provider-badge{background:#e1e8f0;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;color:var(--color-primary)}.migration-box{background:#fff8e1;padding:12px;border-radius:8px;border:1px solid #ffe082}.migration-text{font-size:12px;color:#856404;margin-bottom:8px;line-height:1.4}.btn-migrate-account{background:var(--color-primary);color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:opacity .2s}.btn-migrate-account:hover{opacity:.9}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background-color:#fff;border-bottom:1px solid #eee;position:sticky;top:0;z-index:10}.header-actions-group{display:flex;align-items:center;gap:8px}.header-delete-btn,.header-share-btn{background:none;border:none;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,background-color .2s;border-radius:8px}.header-share-btn:hover{background:#f0f8ff}.header-delete-btn:hover{background:snow}.header-delete-btn:active,.header-share-btn:active{transform:scale(.9)}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.confirmation-modal{background-color:#fff;border-radius:20px;width:100%;max-width:400px;padding:30px 24px;text-align:center;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s ease-out}.modal-icon-warning{font-size:48px;margin-bottom:16px}.confirmation-modal h2{color:#1f2937;margin-bottom:12px;font-size:24px;font-weight:700}.modal-message{color:#4b5563;font-size:15px;line-height:1.5;margin-bottom:24px}.modal-message p{margin-bottom:12px}.modal-message strong{color:#dc2626}.modal-actions{display:flex;flex-direction:column;gap:12px}.btn-confirm-delete{background-color:#dc2626;color:#fff;border:none;padding:14px;border-radius:12px;font-weight:700;font-size:16px;cursor:pointer;transition:background-color .2s}.btn-confirm-delete:hover{background-color:#b91c1c}.btn-cancel{background-color:#f3f4f6;color:#4b5563;border:none;padding:14px;border-radius:12px;font-weight:600;font-size:14px;cursor:pointer}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.profile-content{padding:20px 20px 100px}.profile-name{font-size:24px;font-weight:700;color:var(--color-text-primary);margin-bottom:24px}.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.profile-field{display:flex;flex-direction:column;gap:4px}.profile-field.full-width{grid-column:span 2}.profile-field label{font-size:13px;color:var(--color-text-secondary);font-weight:500}.field-value{font-size:16px;color:var(--color-text-primary);font-weight:500}.capitalize{text-transform:capitalize}.empty-dash{color:var(--color-text-tertiary)}.models-section{margin-top:32px}.section-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin-bottom:16px}.empty-state{padding:32px;text-align:center;background-color:var(--color-background);border-radius:8px;color:var(--color-text-secondary);border:1px dashed var(--color-border)}.hidden-input{display:none}.action-buttons{margin-top:24px}.btn{display:inline-flex;justify-content:center;align-items:center;padding:12px 20px;border-radius:8px;font-weight:600;font-size:16px;cursor:pointer;transition:all .2s;border:none;outline:none}.btn-primary{background-color:var(--color-primary);color:#fff}.photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photo-card{aspect-ratio:1;border-radius:8px;overflow:hidden;background-color:#f0f0f0;cursor:pointer;position:relative}.photo-card img{width:100%;height:100%;object-fit:cover}.photo-actions-overlay{position:absolute;top:5px;right:5px;display:flex;flex-direction:column;gap:6px;z-index:5}.delete-photo-btn,.share-photo-btn{color:#fff;border:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 4px #0003;transition:all .2s}.delete-photo-btn{background:#ff3b30cc}.share-photo-btn{background:#007affcc}.delete-photo-btn:hover{background:#ff3b30;transform:scale(1.1)}.share-photo-btn:hover{background:#007aff;transform:scale(1.1)}.model-selection-screen{min-height:100vh;min-height:100dvh;background-color:#f8f9fa;padding-bottom:90px;overflow-y:auto}.selection-header{display:flex;align-items:center;padding:16px 20px;background-color:#fff;gap:16px;border-bottom:1px solid #eee}.close-btn-round{width:36px;height:36px;border-radius:18px;background-color:#f3f4f6;border:none;display:flex;align-items:center;justify-content:center;color:#4b5563;cursor:pointer}.header-title{font-size:18px;font-weight:700;color:#1f2937}.tabs-container{display:flex;justify-content:space-around;padding:20px;background-color:#fff}.tab{font-size:16px;font-weight:600;color:#6b7280;padding:12px 24px;cursor:pointer}.tab.active{background-color:#0056b3;color:#fff;border-radius:25px}.models-grid-v2{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px 16px 32px}.model-card-premium{background-color:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a;display:flex;flex-direction:column}.card-image-container{padding:20px;background-color:#fff;display:flex;justify-content:center;position:relative;border-bottom:1px solid #f3f4f6}.human-outline-visual{height:150px;width:auto;position:relative}.human-outline-visual img{height:100%;width:auto;opacity:.8}.badges-row{position:absolute;bottom:0;left:0;display:flex;gap:4px}.badge-3d{background-color:#ff3b30;color:#fff;font-size:10px;font-weight:800;padding:2px 6px;border-radius:8px}.badge-ia{background-color:#f19b1a;color:#fff;font-size:10px;font-weight:800;padding:2px 6px;border-radius:8px}.card-info-v2{padding:16px;text-align:center}.model-title-v2{font-size:14px;font-weight:800;color:#1f2937;margin-bottom:16px;line-height:1.2}.btn-view-example{width:100%;background-color:#005697;color:#fff;border:none;padding:10px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;box-shadow:0 4px 6px #00569733}.btn-view-example:active{transform:scale(.98)}.selector-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:2000;display:flex;align-items:flex-end;justify-content:center}.selector-modal{background-color:var(--color-surface);width:100%;max-width:500px;height:80vh;border-top-left-radius:20px;border-top-right-radius:20px;display:flex;flex-direction:column;box-shadow:0 -4px 20px #0003;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.selector-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border)}.selector-header h3{margin:0;font-size:18px;font-weight:600}.close-btn{background:none;border:none;cursor:pointer;color:var(--color-text-secondary)}.selector-search{padding:16px 20px;position:relative;border-bottom:1px solid var(--color-border)}.selector-search input{width:100%;padding:10px 10px 10px 40px;border-radius:8px;border:1px solid var(--color-border);background-color:var(--color-background);font-size:16px;outline:none}.selector-search .search-icon{position:absolute;left:30px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary)}.selector-list{flex:1;overflow-y:auto;padding:16px 20px}.list-title{font-size:14px;color:var(--color-text-secondary);margin:12px 0 8px;text-transform:uppercase;letter-spacing:.5px}.selector-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;cursor:pointer;transition:background-color .2s}.new-client-btn{display:flex;align-items:center;gap:12px;padding:14px 12px;border-radius:12px;cursor:pointer;background-color:#f8fafc;border:1px dashed #cbd5e1;margin-bottom:20px;transition:all .2s;color:var(--color-primary);font-weight:600}.new-client-btn:hover{background-color:#f1f5f9;border-color:var(--color-primary)}.avatar-small.add-icon{background-color:#e2e8f0;color:#475569}.new-client-btn:hover .add-icon{background-color:var(--color-primary);color:#fff}.selector-item:active{background-color:var(--color-background)}.avatar-small{width:32px;height:32px;background-color:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.divider{height:1px;background-color:var(--color-border);margin:16px 0}.analysis-container{width:100vw;height:100vh;height:100dvh;padding-bottom:70px;display:flex;flex-direction:column;background-color:#000;overflow:hidden;position:relative}.analysis-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:linear-gradient(to bottom,rgba(0,0,0,.9),transparent);position:absolute;top:0;left:0;width:100%;z-index:100}.view-title-label{color:#fff;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:#007aff4d;padding:4px 12px;border-radius:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-viewport{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background-color:#000;overflow:hidden;padding-top:60px}.image-canvas-wrapper{position:relative;display:inline-block;max-width:100%;cursor:grab;transform-origin:center center}.image-canvas-wrapper.panning{cursor:grabbing!important}.empty-viewport{color:#666;font-size:14px}.analysis-target-img{display:block;max-width:100%;max-height:calc(100vh - 180px);max-height:calc(100dvh - 180px);-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.points-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.vectors-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.ia-point-wrapper{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;cursor:grab;z-index:200;pointer-events:auto;touch-action:none}.ia-point-dot{width:12px;height:12px;background-color:#007aff;border:2px solid white;border-radius:50%;box-shadow:0 0 10px #007aff80}.ia-point-wrapper.active{z-index:250}.ia-point-wrapper.active .ia-point-dot{background-color:#ff3b30;box-shadow:0 0 15px #ff3b30cc}.ia-point-label{background-color:#000c;color:#fc0;font-size:8px;font-weight:700;padding:1px 4px;border-radius:3px;margin-top:5px;white-space:nowrap}.analysis-footer{padding:16px;background-color:#1a1a1a;display:flex;justify-content:center;border-top:1px solid #333;z-index:110;position:absolute;bottom:70px;left:0;width:100%}.back-btn-white,.header-btn{background:#ffffff1a;border:none;color:#fff;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.header-btn.share-btn{background:#007aff66;margin-right:8px}.home-header{padding:24px 20px;background-color:var(--color-surface);border-bottom:1px solid var(--color-border)}.subtitle{font-size:14px;color:var(--color-text-secondary);margin-top:4px}.recent-list-section{padding:20px 20px 80px}.recent-grid{display:flex;flex-direction:column;gap:12px}.recent-card{display:flex;align-items:center;gap:16px;padding:16px;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease}.recent-card:active{transform:scale(.98);background-color:#f1f5f9}.card-icon{width:48px;height:48px;border-radius:50%;background-color:#0f172a0d;display:flex;align-items:center;justify-content:center;flex-shrink:0}.card-info{flex:1;min-width:0}.client-name-card{font-size:16px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-meta{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--color-text-secondary)}.meta-item{display:flex;align-items:center;gap:4px}.gender-tag{text-transform:capitalize}.loading-state,.empty-state{text-align:center;padding:40px 20px;color:var(--color-text-secondary)}.cta-link{display:inline-block;margin-top:16px;color:var(--color-primary);font-weight:600;text-decoration:none}.camera-screen{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;padding-bottom:70px;background-color:#000;z-index:50;display:flex;flex-direction:column}.camera-video{width:100%;height:100%;object-fit:cover}.camera-grid{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.grid-line{position:absolute;background-color:#fff3}.grid-line.horizontal{width:100%;height:1px}.grid-line.vertical{width:1px;height:100%;border-left:1px dashed rgba(255,255,255,.4)}.camera-interface-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:20;display:flex;flex-direction:column}.camera-close-btn{position:absolute;top:20px;left:20px;width:44px;height:44px;border-radius:50%;background-color:#00000080;border:none;display:flex;align-items:center;justify-content:center;pointer-events:auto}.camera-bottom-controls{margin-top:auto;width:100%;padding:20px 0 40px;display:flex;justify-content:center;background:linear-gradient(to top,rgba(0,0,0,.6),transparent);pointer-events:auto}.camera-shutter-btn{width:72px;height:72px;border-radius:50%;border:5px solid white;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer}.shutter-inner-v2{width:54px;height:54px;border-radius:50%;background-color:#fff}.preview-container{width:100%;height:100%;background-color:#000;z-index:30;display:flex;flex-direction:column}.preview-image{flex:1;width:100%;height:calc(100% - 100px);object-fit:contain}.preview-overlay{position:absolute;bottom:70px;left:0;width:100%;padding:16px 20px;background-color:#1a1a1af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;gap:16px;z-index:110}.retake-btn,.save-btn{flex:1;padding:14px;border-radius:12px;font-size:14px;font-weight:700;text-transform:uppercase;border:none}.retake-btn{background-color:#333;color:#fff}.save-btn{background-color:#007aff;color:#fff}.pdf-merge-container{padding-bottom:100px}.upload-section{display:flex;align-items:center;justify-content:space-between;gap:20px;margin:30px 0}.upload-card{flex:1;background:#fff;padding:24px;border-radius:16px;box-shadow:0 4px 12px #0000000d;border:2px dashed #e2e8f0;transition:all .3s ease;text-align:center}.upload-card.done{border-color:#39b3a8;background:#f0fdf4;border-style:solid}.card-header{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:12px}.step-num{background:#39b3a8;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.upload-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px;background:#f8fafc;border:1px solid #e2e8f0;padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:500;color:#475569;transition:all .2s}.upload-btn:hover{background:#f1f5f9;border-color:#cbd5e1}.merge-arrow{color:#94a3b8}.merge-action-btn{width:100%;background:#39b3a8;color:#fff;border:none;padding:16px;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;margin-top:20px;transition:transform .2s,background .2s}.merge-action-btn:hover:not(:disabled){background:#2f669a;transform:translateY(-2px)}.page-title,.card-header h3{color:#2f669a}.merge-action-btn:disabled{background:#94a3b8;cursor:not-allowed}.status-banner{padding:12px;border-radius:8px;margin-top:20px;display:flex;align-items:center;gap:10px;font-weight:500}.status-banner.error{background:#fee2e2;color:#991b1b}.status-banner.success{background:#dcfce7;color:#166534}.status-banner.info{background:#dbeafe;color:#1e40af}.info-box{margin-top:40px;background:#f8fafc;padding:20px;border-radius:12px;border-left:4px solid #39B3A8}.info-box h4{margin-bottom:10px;color:#1e293b}.info-box ul{list-style:disc;padding-left:20px;color:#64748b}.info-box li{margin-bottom:6px}@media(max-width:600px){.upload-section{flex-direction:column}.merge-arrow{transform:rotate(90deg)}}.login-container{height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:20px;z-index:1000;position:fixed;inset:0}.login-card{background:#fff;width:100%;max-width:400px;padding:40px;border-radius:24px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.login-header{text-align:center;margin-bottom:32px}.logo-placeholder{width:64px;height:64px;background:var(--color-primary);color:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;margin:0 auto 16px;box-shadow:0 10px 15px -3px #2563eb4d}.login-header h1{font-size:24px;color:#1e293b;margin-bottom:8px}.login-header p{color:#64748b}.login-form{display:flex;flex-direction:column;gap:16px}.input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:12px;color:#94a3b8}.input-group input{width:100%;padding:12px 12px 12px 42px;border:1px solid #e2e8f0;border-radius:12px;font-size:16px;transition:all .2s;background:#f8fafc}.input-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a;background:#fff}.auth-error{background:#fee2e2;color:#991b1b;padding:12px;border-radius:8px;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500}.login-submit-btn{background:var(--color-primary);color:#fff;border:none;padding:14px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;margin-top:8px;transition:all .2s}.login-submit-btn:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}.login-divider{display:flex;align-items:center;text-align:center;margin:8px 0;color:#94a3b8;font-size:14px}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid #e2e8f0}.login-divider span{padding:0 12px}.google-login-btn{display:flex;align-items:center;justify-content:center;gap:12px;background:#fff;color:#475569;border:1px solid #e2e8f0;padding:12px;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.google-login-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.login-footer{margin-top:24px;text-align:center}.login-footer p{color:#64748b;font-size:14px}.toggle-auth-btn{background:none;border:none;color:var(--color-primary);font-weight:600;margin-left:5px;cursor:pointer;padding:0}.toggle-auth-btn:hover{text-decoration:underline}.dashboard-container{padding:24px;background-color:var(--color-background);min-height:calc(100vh - 70px)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.dashboard-title{font-size:28px;font-weight:800;color:var(--color-text-primary);margin:0}.dashboard-subtitle{font-size:14px;color:var(--color-text-secondary);margin-top:4px}.dashboard-date{background:var(--color-surface);padding:8px 16px;border-radius:12px;font-size:13px;font-weight:600;color:var(--color-primary);border:1px solid var(--color-border)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:var(--color-surface);padding:24px;border-radius:20px;border:1px solid var(--color-border);display:flex;align-items:center;gap:20px;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0000000d}.stat-icon-wrapper{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center}.stat-icon-wrapper.total{background:#2563eb1a;color:#2563eb}.stat-icon-wrapper.male{background:#4f46e51a;color:#4f46e5}.stat-icon-wrapper.female{background:#10b9811a;color:#10b981}.stat-info{flex:1}.stat-label{font-size:13px;font-weight:600;color:var(--color-text-secondary);display:block}.stat-value{font-size:24px;font-weight:800;color:var(--color-text-primary);margin:4px 0}.stat-percentage{font-size:12px;font-weight:700;color:var(--color-primary);background:var(--color-primary-light);padding:2px 8px;border-radius:6px}.chart-card{background:var(--color-surface);padding:28px;border-radius:24px;border:1px solid var(--color-border)}.chart-header{display:flex;align-items:center;gap:12px;margin-bottom:32px}.chart-icon{color:var(--color-primary)}.chart-header h3{margin:0;font-size:18px;font-weight:700;color:var(--color-text-primary)}.pie-chart-wrapper{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:40px}.pie-svg{transform:rotate(-90deg)}.pie-bg{fill:none;stroke:var(--color-border);stroke-width:25}.pie-segment{fill:none;stroke-width:25;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1)}.pie-segment.female{stroke:#10b981}.pie-segment.male{stroke:#4f46e5}.pie-legend{display:flex;flex-direction:column;gap:12px}.legend-item{display:flex;align-items:center;gap:10px}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.male{background-color:#4f46e5}.legend-dot.female{background-color:#10b981}.legend-text{font-size:14px;font-weight:600;color:var(--color-text-secondary)}.dashboard-loading{height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--color-text-secondary)}.loader-pulse{width:40px;height:40px;background-color:var(--color-primary);border-radius:50%;animation:loaderPulse 1s ease-in-out infinite}@keyframes loaderPulse{0%{transform:scale(.8);opacity:.5}50%{transform:scale(1.1);opacity:1}to{transform:scale(.8);opacity:.5}}@media(max-width:600px){.pie-chart-wrapper{flex-direction:column}}.bottom-nav{position:fixed;bottom:0;left:0;width:100%;height:70px;background-color:var(--color-surface);border-top:1px solid var(--color-border);display:flex;justify-content:space-around;align-items:center;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--color-text-secondary);text-decoration:none;background:none;border:none;width:60px;height:100%}.nav-item.active{color:var(--color-primary)}.nav-item-center{position:relative;width:70px;height:70px;display:flex;justify-content:center;align-items:flex-end}.camera-btn{position:absolute;top:-20px;width:64px;height:64px;background-color:var(--color-surface);border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 -4px 10px #0000000d}.camera-inner{width:54px;height:54px;background-color:var(--color-primary);border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 4px 10px #0f172a66}.setup-modal-overlay{position:fixed;inset:0;background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:flex-start;justify-content:center;z-index:99999;padding:40px 20px;overflow-y:auto}.setup-modal-card{background:#fff;width:100%;max-width:500px;border-radius:28px;padding:40px;box-shadow:0 25px 50px -12px #00000080;position:relative;margin-bottom:40px}.setup-modal-header h2{margin:0 0 12px;color:#000;font-size:1.75rem;font-weight:800}.setup-modal-header p{color:#4b5563;margin:0 0 32px;line-height:1.6;font-size:1rem}.setup-modal-form{display:flex;flex-direction:column;gap:24px}.setup-field{display:flex;flex-direction:column;gap:10px}.setup-field label{font-size:.95rem;font-weight:700;color:#111827}.setup-input{padding:14px 18px;border:2px solid #e5e7eb;border-radius:14px;font-size:1rem;transition:all .2s;background:#f9fafb}.setup-input:focus{outline:none;border-color:#2563eb;background:#fff;box-shadow:0 0 0 4px #2563eb1a}.setup-input.disabled{background:#f3f4f6;color:#6b7280;cursor:not-allowed;border-color:#f3f4f6}.field-hint{font-size:.8rem;color:#6b7280}.setup-logo-upload{margin-top:6px}.logo-dropzone{border:2px dashed #d1d5db;border-radius:16px;padding:30px;display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;color:#4b5563;background:#f9fafb;transition:all .2s}.logo-dropzone:hover{border-color:#2563eb;background:#eff6ff;color:#2563eb}.logo-preview-container{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px;border:2px solid #e5e7eb;border-radius:16px;background:#fff}.logo-preview{max-height:60px;width:auto;object-fit:contain}.remove-logo-btn{padding:8px 16px;font-size:.85rem;font-weight:600;color:#dc2626;background:#fee2e2;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.remove-logo-btn:hover{background:#fecaca}.setup-error{display:flex;align-items:center;gap:10px;padding:16px;background:#fef2f2;color:#b91c1c;border-radius:12px;font-size:.9rem;border:1px solid #fee2e2;line-height:1.4}.setup-submit-btn{background:#2563eb;color:#fff;border:none;padding:18px;border-radius:16px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s;margin-top:10px;box-shadow:0 4px 6px -1px #2563eb33}.setup-submit-btn:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 10px 15px -3px #2563eb4d}.setup-submit-btn:active:not(:disabled){transform:translateY(0)}.setup-submit-btn:disabled{opacity:.5;cursor:not-allowed;background:#9ca3af;box-shadow:none}
