:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: rgba(255, 255, 255, .85);--bg-glass: rgba(0, 0, 0, .02);--bg-glass-hover: rgba(0, 0, 0, .04);--bg-input: rgba(0, 0, 0, .03);--border-glass: rgba(0, 0, 0, .08);--border-focus: rgba(99, 102, 241, .5);--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--text-dim: #cbd5e1;--accent-primary: #6366f1;--accent-primary-glow: rgba(99, 102, 241, .15);--accent-success: #10b981;--accent-success-glow: rgba(16, 185, 129, .12);--accent-warning: #f59e0b;--accent-warning-glow: rgba(245, 158, 11, .12);--accent-danger: #ef4444;--accent-danger-glow: rgba(239, 68, 68, .12);--accent-info: #3b82f6;--accent-cyan: #06b6d4;--gradient-hero: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #06b6d4 100%);--gradient-card: linear-gradient(135deg, rgba(99, 102, 241, .06) 0%, rgba(6, 182, 212, .03) 100%);--gradient-danger: linear-gradient(135deg, rgba(239, 68, 68, .08) 0%, rgba(245, 158, 11, .03) 100%);--gradient-success: linear-gradient(135deg, rgba(16, 185, 129, .08) 0%, rgba(6, 182, 212, .03) 100%);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .08), 0 4px 8px rgba(0, 0, 0, .04);--shadow-glow: 0 0 16px var(--accent-primary-glow);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(99,102,241,.04) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(6,182,212,.03) 0%,transparent 50%);pointer-events:none;z-index:0}#app{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:0 var(--space-lg);min-height:100vh;display:flex;flex-direction:column}#top-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) 0;border-bottom:1px solid var(--border-glass)}.logo{display:flex;align-items:center;gap:var(--space-sm)}.logo-icon{font-size:var(--font-size-2xl);filter:drop-shadow(0 0 8px var(--accent-primary-glow))}.logo-text{font-size:var(--font-size-xl);font-weight:700;background:var(--gradient-hero);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-sub{font-weight:400;opacity:.8}.header-actions{display:flex;gap:var(--space-sm)}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid var(--border-glass);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.btn-ghost{background:var(--bg-glass);color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-glass-hover);color:var(--text-primary);border-color:#ffffff26;transform:translateY(-1px)}.btn-primary{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:0 2px 12px var(--accent-primary-glow)}.btn-primary:hover{background:#5558e6;transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-primary-glow)}.btn-success{background:var(--accent-success);color:#fff;border-color:var(--accent-success);box-shadow:0 2px 12px var(--accent-success-glow)}.btn-success:hover{background:#0ea572;transform:translateY(-1px)}.btn-danger{background:transparent;color:var(--accent-danger);border-color:#ef44444d}.btn-danger:hover{background:var(--accent-danger-glow)}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-base)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.btn-icon{font-size:1.1em}#step-nav{display:flex;align-items:center;justify-content:center;gap:0;padding:var(--space-lg) 0;overflow-x:auto}.step-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:transparent;border:none;cursor:pointer;transition:all var(--transition-base);position:relative;min-width:90px}.step-num{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-sm);border:2px solid var(--border-glass);color:var(--text-muted);background:var(--bg-glass);transition:all var(--transition-base)}.step-label{font-size:var(--font-size-xs);font-weight:500;color:var(--text-muted);transition:color var(--transition-base)}.step-btn.active .step-num{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:var(--shadow-glow)}.step-btn.active .step-label{color:var(--text-primary)}.step-btn.completed .step-num{background:var(--accent-success);border-color:var(--accent-success);color:#fff}.step-btn.completed .step-label{color:var(--accent-success)}.step-btn:hover:not(.active) .step-num{border-color:#fff3;background:var(--bg-glass-hover)}.step-btn:hover:not(.active) .step-label{color:var(--text-secondary)}.step-connector{width:40px;height:2px;background:var(--border-glass);flex-shrink:0}.step-connector.active{background:var(--accent-primary);box-shadow:0 0 8px var(--accent-primary-glow)}#content-area{flex:1;padding:var(--space-md) 0 var(--space-2xl);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.card{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--space-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-base)}.card:hover{border-color:#ffffff1f}.card-gradient{background:var(--gradient-card)}.card-danger{background:var(--gradient-danger);border-color:#ef444433}.card-success{background:var(--gradient-success);border-color:#10b98133}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.card-title{font-size:var(--font-size-lg);font-weight:600;display:flex;align-items:center;gap:var(--space-sm)}.section-header{margin-bottom:var(--space-lg)}.section-title{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-xs);background:var(--gradient-hero);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary)}.upload-zone{border:2px dashed var(--border-glass);border-radius:var(--radius-xl);padding:var(--space-3xl) var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.upload-zone:before{content:"";position:absolute;inset:0;background:var(--gradient-card);opacity:0;transition:opacity var(--transition-base)}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent-primary);background:#6366f10d}.upload-zone:hover:before,.upload-zone.drag-over:before{opacity:1}.upload-zone-content{position:relative;z-index:1}.upload-icon{font-size:3rem;margin-bottom:var(--space-md);display:block;filter:drop-shadow(0 0 12px var(--accent-primary-glow))}.upload-title{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--space-sm)}.upload-desc{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-md)}.upload-formats{display:flex;gap:var(--space-sm);justify-content:center;flex-wrap:wrap}.format-tag{padding:var(--space-xs) var(--space-sm);background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:500}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-input);border:1px solid var(--border-glass);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-primary-glow)}.form-input::placeholder{color:var(--text-dim)}.form-select option,.form-select optgroup{background:var(--bg-card);color:var(--text-primary)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md)}.table-container{overflow-x:auto;border:1px solid var(--border-glass);border-radius:var(--radius-lg);background:var(--bg-card)}.data-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.data-table thead{position:sticky;top:0;z-index:2}.data-table th{background:#6366f11a;padding:var(--space-sm) var(--space-md);text-align:left;font-weight:600;color:var(--text-secondary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-glass);white-space:nowrap}.data-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid rgba(255,255,255,.03);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.data-table th.col-main,.data-table td.col-main{width:100%;white-space:normal;min-width:200px}.data-table th:not(.col-main),.data-table td:not(.col-main){white-space:nowrap;width:1%}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-glass-hover)}.data-table td.missing{color:var(--accent-warning);font-style:italic}.data-table td.editable{cursor:pointer;position:relative}.data-table td.editable:hover{background:#6366f11a}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.02em}.badge-success{background:var(--accent-success-glow);color:var(--accent-success)}.badge-warning{background:var(--accent-warning-glow);color:var(--accent-warning)}.badge-danger{background:var(--accent-danger-glow);color:var(--accent-danger)}.badge-info{background:#3b82f633;color:var(--accent-info)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.stat-card{background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--space-md);text-align:center;transition:all var(--transition-base)}.stat-card:hover{transform:translateY(-2px);border-color:#ffffff1f}.stat-value{font-size:var(--font-size-3xl);font-weight:800;background:var(--gradient-hero);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.stat-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--space-xs)}.quality-bar{width:100%;height:8px;background:#ffffff0d;border-radius:var(--radius-full);overflow:hidden;margin-top:var(--space-sm)}.quality-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}.quality-fill.high{background:linear-gradient(90deg,var(--accent-success),var(--accent-cyan))}.quality-fill.medium{background:linear-gradient(90deg,var(--accent-warning),#fbbf24)}.quality-fill.low{background:linear-gradient(90deg,var(--accent-danger),var(--accent-warning))}.action-card{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);transition:all var(--transition-base);animation:slideUp .4s ease backwards}.action-card:hover{border-color:#6366f14d;box-shadow:0 4px 20px #0000004d}.action-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;font-size:var(--font-size-xs);font-weight:700;margin-right:var(--space-sm);flex-shrink:0}.action-title{font-size:var(--font-size-lg);font-weight:600;display:flex;align-items:center;margin-bottom:var(--space-sm)}.action-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-sm);margin-top:var(--space-md)}.action-meta-item{padding:var(--space-sm) var(--space-md);background:var(--bg-glass);border-radius:var(--radius-md);border:1px solid var(--border-glass)}.action-meta-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.action-meta-value{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary)}.pattern-card{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);animation:slideUp .4s ease backwards}.pattern-icon{font-size:1.5rem;margin-right:var(--space-sm)}.pattern-type{font-size:var(--font-size-xs);color:var(--accent-primary);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:var(--space-xs)}.pattern-finding{font-size:var(--font-size-base);color:var(--text-primary);margin-bottom:var(--space-sm)}.pattern-action-hint{font-size:var(--font-size-sm);color:var(--accent-success);padding:var(--space-sm) var(--space-md);background:var(--accent-success-glow);border-radius:var(--radius-md);display:inline-block}.feedback-card{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md)}.feedback-action-title{font-weight:600;margin-bottom:var(--space-sm)}.feedback-options{display:flex;gap:var(--space-sm);flex-wrap:wrap}.feedback-btn{padding:var(--space-sm) var(--space-md);border:1px solid var(--border-glass);border-radius:var(--radius-md);background:var(--bg-glass);color:var(--text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base)}.feedback-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.feedback-btn.selected{border-color:var(--accent-primary);background:#6366f126;color:var(--accent-primary)}.feedback-btn.selected-success{border-color:var(--accent-success);background:var(--accent-success-glow);color:var(--accent-success)}.feedback-btn.selected-danger{border-color:var(--accent-danger);background:var(--accent-danger-glow);color:var(--accent-danger)}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl);color:var(--text-muted)}.empty-state-icon{font-size:4rem;margin-bottom:var(--space-md);opacity:.4}.empty-state-title{font-size:var(--font-size-xl);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm)}.empty-state-desc{font-size:var(--font-size-sm);max-width:400px;margin:0 auto}.manual-entry-section{margin-top:var(--space-xl)}.manual-entry-toggle{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:var(--font-size-sm);cursor:pointer;margin-bottom:var(--space-md);transition:color var(--transition-fast)}.manual-entry-toggle:hover{color:var(--text-primary)}.data-gaps{margin-top:var(--space-md)}.gap-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;font-size:var(--font-size-sm);color:var(--text-secondary);border-bottom:1px solid rgba(255,255,255,.03)}.gap-icon{color:var(--accent-warning)}.output-section{margin-bottom:var(--space-xl)}.output-section-title{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-glass);display:flex;align-items:center;gap:var(--space-sm)}.stop-card{background:var(--gradient-danger);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md)}.stop-card .action-title{color:var(--accent-danger)}#app-footer{padding:var(--space-lg) 0;border-top:1px solid var(--border-glass);text-align:center;font-size:var(--font-size-xs);color:var(--text-dim);margin-top:auto}@media(max-width:768px){#app{padding:0 var(--space-md)}#step-nav{gap:0;padding:var(--space-md) 0}.step-btn{min-width:60px;padding:var(--space-xs)}.step-label{display:none}.step-connector{width:20px}.header-actions .btn span:not(.btn-icon){display:none}.stats-row{grid-template-columns:repeat(2,1fr)}.action-meta,.form-row{grid-template-columns:1fr}}@media(max-width:480px){.stats-row{grid-template-columns:1fr}.upload-zone{padding:var(--space-xl) var(--space-md)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.hidden{display:none!important}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-success{color:var(--accent-success)}.text-warning{color:var(--accent-warning)}.text-danger{color:var(--accent-danger)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.gap-md{gap:var(--space-md)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.w-full{width:100%}.step-content-enter{animation:fadeIn .3s ease}.table-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);font-size:var(--font-size-sm);color:var(--text-muted)}.table-footer-actions{display:flex;gap:var(--space-sm)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.chart-card{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--space-md);height:300px;display:flex;flex-direction:column}.chart-card h3{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em;text-align:center}.chart-card canvas{flex:1;width:100%!important;height:100%!important}@media print{*,*:before,*:after{background:transparent!important;color:#000!important;text-shadow:none!important;box-shadow:none!important;-webkit-text-fill-color:#000!important}body{background:#fff!important;color:#000!important;font-size:12pt!important;line-height:1.5!important;margin:0!important;padding:20px!important}#top-bar,.no-print,.btn,.btn-icon,.btn-copy,.btn-ghost,.btn-primary,.btn-secondary,#step-nav,.badge,nav,.step-nav{display:none!important}.card,.card-gradient,.action-card,.stop-card,.pattern-card{background:#fff!important;border:1px solid #ccc!important;border-radius:4px!important;padding:12px 16px!important;margin-bottom:12px!important;page-break-inside:avoid!important;break-inside:avoid!important}.section-title,.output-section-title,.card-title{background:none!important;background-clip:unset!important;-webkit-background-clip:unset!important;color:#000!important;-webkit-text-fill-color:#000!important;font-size:16pt!important;margin-bottom:8px!important}.section-subtitle{color:#444!important;-webkit-text-fill-color:#444!important;font-size:10pt!important}.output-section-title{font-size:13pt!important;border-bottom:1px solid #ddd!important;padding-bottom:4px!important;margin-bottom:8px!important}.stats-row{display:flex!important;gap:16px!important}.stat-card{background:#f9f9f9!important;border:1px solid #ddd!important;border-radius:4px!important;padding:8px 12px!important;text-align:center!important}.stat-value{background:none!important;-webkit-background-clip:unset!important;background-clip:unset!important;-webkit-text-fill-color:#000!important;color:#000!important;font-size:14pt!important;font-weight:700!important}.stat-label{color:#666!important;-webkit-text-fill-color:#666!important;font-size:9pt!important}.action-title{font-size:11pt!important;font-weight:600!important;margin-bottom:8px!important}.action-number{background:#333!important;color:#fff!important;-webkit-text-fill-color:#fff!important;width:22px!important;height:22px!important;font-size:9pt!important;border-radius:50%!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;margin-right:8px!important;flex-shrink:0!important}.action-meta{display:block!important}.action-meta-item{background:#f5f5f5!important;border:1px solid #ddd!important;border-radius:3px!important;padding:6px 10px!important;margin-bottom:6px!important;page-break-inside:avoid!important}.action-meta-label{color:#666!important;-webkit-text-fill-color:#666!important;font-size:8pt!important;text-transform:uppercase!important;font-weight:600!important}.action-meta-value{color:#000!important;font-size:10pt!important}.output-section{margin-bottom:20px!important;page-break-inside:avoid!important}.pattern-card,.card.mb-md{border-left:3px solid #333!important}.stop-card{border-left:3px solid #cc0000!important}.card ul li{border-color:#ddd!important}.section-header{display:block!important;margin-bottom:16px!important}.section-header .flex.gap-sm{display:none!important}@page{margin:1.5cm;size:A4}h1,h2,h3,.output-section-title{page-break-after:avoid!important}}.location-setup-card{margin-bottom:var(--space-lg, 24px)}.location-badge{display:flex;align-items:center;gap:var(--space-sm, 8px);padding:10px 16px;background:var(--bg-secondary, #fff);border:1px solid var(--border-primary, #e2e8f0);border-radius:10px}.location-icon{font-size:1.1em}.location-text{font-weight:600;color:var(--text-primary, #1e293b)}.location-change-btn{background:none;border:none;cursor:pointer;font-size:.9em;opacity:.6;transition:opacity .2s}.location-change-btn:hover{opacity:1}.location-form{padding:16px 20px;background:var(--bg-secondary, #fff);border:1px dashed var(--border-primary, #e2e8f0);border-radius:10px}.location-prompt{font-size:var(--font-size-sm, .875rem);color:var(--text-secondary, #64748b);margin-bottom:var(--space-sm, 8px)}.location-inputs{display:flex;gap:var(--space-sm, 8px);align-items:center;flex-wrap:wrap}.loc-input{padding:8px 12px;border:1px solid var(--border-primary, #e2e8f0);border-radius:6px;background:var(--bg-primary, #f8fafc);color:var(--text-primary, #1e293b);font-size:var(--font-size-sm, .875rem)}.loc-input:focus{outline:none;border-color:var(--accent, #6366f1)}.loc-input-sm{max-width:100px}.loc-save-btn{padding:8px 16px;background:var(--accent, #6366f1);color:#fff;border:none;border-radius:6px;font-weight:600;font-size:var(--font-size-sm, .875rem);cursor:pointer;transition:opacity .2s}.loc-save-btn:hover{opacity:.9}.loc-save-btn:disabled{opacity:.5;cursor:not-allowed}.location-error{font-size:var(--font-size-xs, .75rem);color:var(--danger, #ef4444);margin-top:var(--space-xs, 4px)}.location-badge-inline{font-size:var(--font-size-xs, .75rem);color:var(--text-secondary, #64748b)}.location-not-set{opacity:.7;font-style:italic}
