:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--primary-light: #dbeafe;--success-color: #059669;--success-light: #d1fae5;--warning-color: #d97706;--warning-light: #fef3c7;--error-color: #dc2626;--error-light: #fee2e2;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius: 8px;--radius-lg: 12px}*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--gray-50);color:var(--gray-800);line-height:1.5}.app-container{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,var(--primary-color) 0%,#1e40af 100%);color:#fff;padding:1rem 2rem;box-shadow:var(--shadow-md)}.app-header h1{margin:0;font-size:1.5rem;font-weight:700;display:flex;align-items:center;gap:.75rem}.app-header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.user-info{display:flex;align-items:center;gap:1rem;font-size:.9rem}.app-main{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.5rem;margin-bottom:1.5rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.card-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--gray-800)}.card-subtitle{margin:.25rem 0 0;font-size:.875rem;color:var(--gray-500)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius);border:none;cursor:pointer;transition:all .15s ease;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){background:#047857}.btn-warning{background:var(--warning-color);color:#fff}.btn-warning:hover:not(:disabled){background:#b45309}.btn-danger{background:var(--error-color);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--gray-700);margin-bottom:.375rem}.form-input,.form-select{width:100%;padding:.625rem .875rem;font-size:.875rem;border:1px solid var(--gray-300);border-radius:var(--radius);background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.form-input::placeholder{color:var(--gray-400)}select.form-input,.form-select,select.form-input:not([disabled]),.form-select:not([disabled]){appearance:auto!important;-webkit-appearance:menulist!important;-moz-appearance:menulist!important;cursor:pointer;color:#111827!important;background-color:#fff!important;font-size:16px!important;font-weight:700!important;text-align:left;padding:.625rem 2rem .625rem .875rem!important;height:44px;opacity:1!important;min-width:120px;line-height:1.5!important}select.form-input option,.form-select option{background:#fff!important;color:#111827!important;padding:.5rem;font-size:16px!important;font-weight:600!important;opacity:1!important}.form-row{display:flex;gap:1rem}.form-row>*{flex:1}.table-container{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--gray-200)}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table th{background:var(--gray-50);padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--gray-600);border-bottom:1px solid var(--gray-200);white-space:nowrap}.table td{padding:.75rem 1rem;border-bottom:1px solid var(--gray-100);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover{background:var(--gray-50)}.tabs{display:flex;gap:.25rem;background:var(--gray-100);padding:.25rem;border-radius:var(--radius);margin-bottom:1.5rem}.tab{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;color:var(--gray-600);background:transparent;border:none;border-radius:calc(var(--radius) - 2px);cursor:pointer;transition:all .15s ease}.tab:hover{color:var(--gray-800)}.tab.active{background:#fff;color:var(--primary-color);box-shadow:var(--shadow-sm)}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:500;border-radius:9999px}.badge-pending{background:var(--warning-light);color:var(--warning-color)}.badge-verified{background:var(--success-light);color:var(--success-color)}.badge-incorrect,.badge-error{background:var(--error-light);color:var(--error-color)}.alert{padding:1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.875rem}.alert-error{background:var(--error-light);color:var(--error-color);border:1px solid #fecaca}.alert-success{background:var(--success-light);color:var(--success-color);border:1px solid #a7f3d0}.alert-warning{background:var(--warning-light);color:var(--warning-color);border:1px solid #fde68a}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe)}.login-card{background:#fff;padding:3rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center;max-width:400px;width:90%}.login-card h1{margin:0 0 .5rem;font-size:1.75rem;color:var(--gray-800)}.login-card p{color:var(--gray-500);margin-bottom:2rem}.login-buttons{display:flex;flex-direction:column;gap:.75rem}.bulk-upload-zone{border:2px dashed var(--gray-300);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;background:var(--gray-50);cursor:pointer;transition:all .15s ease}.bulk-upload-zone:hover,.bulk-upload-zone.dragover{border-color:var(--primary-color);background:var(--primary-light)}.bulk-upload-icon{width:48px;height:48px;margin:0 auto 1rem;color:var(--gray-400)}.bulk-upload-text{color:var(--gray-600);margin:0}.bulk-upload-hint{color:var(--gray-400);font-size:.875rem;margin-top:.5rem}.bulk-item{display:grid;grid-template-columns:120px 1fr auto;gap:1rem;padding:1rem;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);margin-bottom:.75rem;align-items:center}.bulk-item-image{width:120px;height:80px;object-fit:cover;border-radius:calc(var(--radius) - 2px);background:var(--gray-100)}.bulk-item-details{display:flex;flex-direction:column;gap:.5rem}.bulk-item-flat{font-weight:600;color:var(--gray-800)}.bulk-item-reading{display:flex;align-items:center;gap:.75rem}.bulk-item-reading label{font-size:.875rem;color:var(--gray-600)}.bulk-item-reading input{width:120px;padding:.5rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.875rem}.bulk-item-confidence{font-size:.75rem;color:var(--gray-500)}.confidence-high{color:var(--success-color)}.confidence-low{color:var(--warning-color)}.bulk-item-actions{display:flex;gap:.5rem}.progress-bar{height:4px;background:var(--gray-200);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--primary-color);transition:width .3s ease}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-gray{color:var(--gray-500)}.text-center{text-align:center}.font-medium{font-weight:500}.font-semibold{font-weight:600}.user-content-grid{display:grid;grid-template-columns:minmax(320px,480px) 1fr;gap:1.5rem;align-items:start}.file-upload-zone{border:2px dashed var(--gray-300);border-radius:var(--radius);padding:1.5rem;text-align:center;background:#fff;cursor:pointer;transition:all .2s ease}.file-upload-zone:hover{border-color:var(--primary-color);background:var(--primary-light)}.file-upload-zone.has-file{border-color:var(--success-color);border-style:solid}@media (max-width: 768px){.app-main{padding:1rem}.bulk-item{grid-template-columns:1fr}.bulk-item-image{width:100%;height:150px}.form-row{flex-direction:column}.tabs{flex-wrap:wrap}.user-content-grid{grid-template-columns:1fr}.card{padding:1rem}.form-grid-2{grid-template-columns:1fr!important}}@media (max-width: 480px){.app-header{padding:.75rem 1rem}.app-header h1{font-size:1.25rem}.btn{padding:.5rem .75rem;font-size:.8rem}.btn-sm{padding:.25rem .5rem}.form-input,.form-select{font-size:16px;padding:.75rem}.btn-primary{width:100%;padding:.875rem}}@media (min-width: 768px){.user-content-grid{grid-template-columns:minmax(320px,480px) 1fr!important}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.auth-card{background:#fff;border-radius:20px;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:440px;overflow:hidden}.auth-header{background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;padding:2rem;text-align:center}.auth-logo{width:64px;height:64px;background:#fff3;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:2rem}.auth-header h1{margin:0 0 .5rem;font-size:1.5rem;font-weight:700}.auth-header p{margin:0;opacity:.9;font-size:.9rem}.auth-body{padding:2rem}.auth-section{margin-bottom:1.5rem}.auth-section-title{font-size:.85rem;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:var(--gray-400);font-size:.85rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--gray-200)}.registration-form{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:12px;padding:1.5rem;border:1px solid #86efac}.registration-step{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.25rem}.registration-step:last-child{margin-bottom:0}.step-number{width:28px;height:28px;background:#22c55e;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;flex-shrink:0}.step-content{flex:1}.step-label{font-weight:600;color:var(--gray-800);margin-bottom:.5rem;font-size:.9rem}.flat-chip{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;padding:.5rem .875rem;border-radius:50px;font-size:.85rem;font-weight:500;margin:.25rem;box-shadow:0 2px 4px #22c55e4d}.flat-chip-remove{width:18px;height:18px;background:#ffffff4d;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background .2s}.flat-chip-remove:hover{background:#ffffff80}.flat-selector{display:grid;grid-template-columns:2fr 2fr 2fr auto;gap:.75rem;align-items:end}.flat-selector select{min-width:150px;width:100%}@media (max-width: 480px){.flat-selector{grid-template-columns:1fr 1fr}.flat-selector>button{grid-column:span 2}}.upload-hero{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;padding:2rem;border-radius:16px;margin-bottom:1.5rem;position:relative;overflow:hidden}.upload-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:300px;height:300px;background:#ffffff1a;border-radius:50%}.upload-hero-content{position:relative;z-index:1}.upload-hero h2{margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.upload-hero p{margin:0;opacity:.9;font-size:1rem}.upload-period-badge{display:inline-flex;align-items:center;gap:.5rem;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.75rem 1rem;border-radius:50px;font-size:.9rem;margin-top:1rem}.upload-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden}.upload-card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;gap:.75rem}.upload-card-icon{width:40px;height:40px;background:var(--primary-light);color:var(--primary-color);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.upload-card-title{font-size:1.1rem;font-weight:600;color:var(--gray-800);margin:0}.upload-card-body{padding:1.5rem}.upload-zone{border:2px dashed var(--gray-300);border-radius:12px;padding:2rem;text-align:center;background:var(--gray-50);cursor:pointer;transition:all .3s ease}.upload-zone:hover{border-color:var(--primary-color);background:var(--primary-light);transform:translateY(-2px)}.upload-zone-icon{width:64px;height:64px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:2rem;box-shadow:0 4px 6px -1px #0000001a}.upload-zone h4{margin:0 0 .5rem;font-size:1rem;color:var(--gray-800)}.upload-zone p{margin:0;font-size:.85rem;color:var(--gray-500)}.upload-buttons{display:flex;gap:.75rem;justify-content:center;margin-top:1rem}.preview-card{border:2px solid var(--success-color);border-radius:12px;overflow:hidden;background:#fff}.preview-image{width:100%;max-height:280px;object-fit:contain;background:#1a1a1a;display:block}.preview-badge{position:absolute;top:.75rem;right:.75rem;background:var(--success-color);color:#fff;padding:.375rem .75rem;border-radius:50px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.375rem}.preview-actions{padding:1rem;display:flex;gap:.5rem;background:var(--gray-50)}.step-indicator{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--primary-light);border-radius:8px;margin-bottom:1rem}.step-indicator-number{width:24px;height:24px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.step-indicator-text{font-size:.9rem;font-weight:500;color:var(--primary-color)}.reading-result{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac;border-radius:12px;padding:1.25rem}.reading-result-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.reading-result-icon{width:40px;height:40px;background:#22c55e;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.reading-value{font-size:2rem;font-weight:700;color:#166534;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace}.reading-unit{font-size:1rem;font-weight:400;color:#15803d;margin-left:.25rem}.history-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--gray-100);transition:background .2s}.history-item:last-child{border-bottom:none}.history-item:hover{background:var(--gray-50)}.history-period{font-weight:600;color:var(--gray-800);margin-bottom:.25rem}.history-date{font-size:.8rem;color:var(--gray-500)}.history-reading{text-align:right}.history-value{font-size:1.25rem;font-weight:700;color:var(--gray-800);font-family:SF Mono,Monaco,monospace}.history-bill{font-size:.85rem;color:var(--success-color);font-weight:500}.user-info-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:12px;margin-bottom:1rem}.user-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid white;box-shadow:0 2px 4px #0000001a}.user-avatar-placeholder{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600}.user-details h4{margin:0 0 .25rem;font-size:1rem;color:var(--gray-800)}.user-details p{margin:0;font-size:.85rem;color:var(--gray-600)}.flat-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border-radius:8px;border:1px solid var(--gray-200);font-weight:500}.flat-badge-icon{font-size:1.25rem}.flat-type-badge{font-size:.7rem;padding:.2rem .5rem;border-radius:50px;font-weight:500}.flat-type-owner{background:#dcfce7;color:#166534}.flat-type-tenant{background:#fef3c7;color:#92400e}.flat-type-family{background:#ede9fe;color:#5b21b6}
