/* ================================
   DESIGN SYSTEM — GestInquilinos v2
   Arrendatarios + Propiedades + Ley 172-13
   ================================ */
:root {
  --bg-primary: #0F172A; --bg-secondary: #1E293B; --bg-card: rgba(30,41,59,0.7); --bg-input: rgba(15,23,42,0.6); --bg-sidebar: rgba(15,23,42,0.95);
  --border-color: rgba(148,163,184,0.12); --border-color-light: rgba(148,163,184,0.08); --border-focus: #F59E0B;
  --text-primary: #F1F5F9; --text-secondary: #94A3B8; --text-muted: #64748B; --text-inverse: #0F172A;
  --accent-amber: #F59E0B; --accent-amber-glow: rgba(245,158,11,0.25); --accent-green: #10B981; --accent-green-glow: rgba(16,185,129,0.25);
  --accent-blue: #3B82F6; --accent-blue-glow: rgba(59,130,246,0.25); --accent-purple: #8B5CF6; --accent-purple-glow: rgba(139,92,246,0.25);
  --accent-red: #EF4444; --accent-red-glow: rgba(239,68,68,0.25); --accent-cyan: #06B6D4;
  --space-xs: 4px; --space-sm: 8px; --space-md: 16px; --space-lg: 24px; --space-xl: 32px; --space-2xl: 48px;
  --radius-sm: 6px; --radius-md: 10px; --radius-lg: 16px; --radius-xl: 24px; --radius-full: 9999px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3); --shadow-md: 0 4px 16px rgba(0,0,0,0.3); --shadow-lg: 0 8px 32px rgba(0,0,0,0.4);
  --shadow-glow-amber: 0 0 20px rgba(245,158,11,0.15); --shadow-glow-green: 0 0 20px rgba(16,185,129,0.15);
  --transition-fast: 150ms ease; --transition-base: 250ms ease; --transition-slow: 400ms ease;
  --sidebar-width: 260px; --sidebar-collapsed: 72px; --topbar-height: 64px;
  --font-family: 'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:15px;scroll-behavior:smooth;}
body{font-family:var(--font-family);background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 50%,#162033 100%);background-attachment:fixed;color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;}
::-webkit-scrollbar{width:6px;height:6px;}::-webkit-scrollbar-track{background:transparent;}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full);}

/* ===========================
   AUTH SCREEN
   =========================== */
.auth-screen{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;}
.auth-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0F172A 0%,#1a1a3e 50%,#0F172A 100%);z-index:0;}
.auth-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(245,158,11,0.08) 0%,transparent 50%),radial-gradient(circle at 70% 30%,rgba(59,130,246,0.06) 0%,transparent 50%);}
.auth-container{position:relative;z-index:1;width:100%;max-width:480px;padding:var(--space-lg);}
.auth-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);backdrop-filter:blur(20px);padding:var(--space-2xl) var(--space-xl);animation:fadeIn .5s ease;}
.auth-logo{text-align:center;margin-bottom:var(--space-xl);}
.auth-logo-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--accent-amber),#D97706);border-radius:var(--radius-lg);display:inline-flex;align-items:center;justify-content:center;color:var(--text-inverse);margin-bottom:var(--space-md);}
.auth-logo-icon svg{width:28px;height:28px;}
.auth-logo-text{font-size:1.6rem;font-weight:800;background:linear-gradient(135deg,var(--accent-amber),#FBBF24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-xs);}
.auth-subtitle{color:var(--text-secondary);font-size:0.88rem;}
.auth-form-title{font-size:1.1rem;font-weight:700;margin-bottom:var(--space-lg);text-align:center;}
.auth-switch{text-align:center;margin-top:var(--space-lg);font-size:0.85rem;color:var(--text-secondary);}
.auth-switch a{color:var(--accent-amber);text-decoration:none;font-weight:600;}
.auth-switch a:hover{text-decoration:underline;}

/* ===========================
   APP LAYOUT
   =========================== */
.app-layout{display:flex;min-height:100vh;width:100%;}

/* Sidebar */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-sidebar);backdrop-filter:blur(20px);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-base),transform var(--transition-base);}
.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-md);border-bottom:1px solid var(--border-color-light);}
.logo{display:flex;align-items:center;gap:var(--space-sm);}
.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-amber),#D97706);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-inverse);flex-shrink:0;}
.logo-icon svg{width:20px;height:20px;}
.logo-text{font-weight:700;font-size:1.1rem;letter-spacing:-0.02em;background:linear-gradient(135deg,var(--accent-amber),#FBBF24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;}
.sidebar-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:color var(--transition-fast);}
.sidebar-toggle:hover{color:var(--text-primary);background:rgba(255,255,255,0.05);}
.sidebar-toggle svg{width:20px;height:20px;}
.sidebar-nav{flex:1;padding:var(--space-md) var(--space-sm);display:flex;flex-direction:column;gap:var(--space-xs);}
.nav-link{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.93rem;transition:all var(--transition-fast);position:relative;overflow:hidden;}
.nav-link svg{width:20px;height:20px;flex-shrink:0;}.nav-link span{white-space:nowrap;}
.nav-link:hover{color:var(--text-primary);background:rgba(255,255,255,0.05);}
.nav-link.active{color:var(--accent-amber);background:var(--accent-amber-glow);}
.nav-link.active::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--accent-amber);border-radius:0 var(--radius-full) var(--radius-full) 0;}

/* Sidebar footer / user */
.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border-color-light);display:flex;align-items:center;gap:var(--space-sm);}
.sidebar-user{display:flex;align-items:center;gap:var(--space-sm);flex:1;overflow:hidden;}
.sidebar-user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;color:white;flex-shrink:0;}
.sidebar-user-info{overflow:hidden;}
.sidebar-user-name{display:block;font-weight:600;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sidebar-user-email{display:block;font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sidebar-logout{flex-shrink:0;}

.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:99;}
.sidebar.collapsed{width:var(--sidebar-collapsed);}
.sidebar.collapsed .logo-text,.sidebar.collapsed .nav-link span,.sidebar.collapsed .sidebar-user-info,.sidebar.collapsed .sidebar-user-name,.sidebar.collapsed .sidebar-user-email{display:none;}
.sidebar.collapsed .sidebar-header{justify-content:center;}.sidebar.collapsed .sidebar-toggle{display:none;}

/* Main */
.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;transition:margin-left var(--transition-base);}
.sidebar.collapsed ~ .main-content{margin-left:var(--sidebar-collapsed);}

/* Top Bar */
.top-bar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:var(--space-md);padding:0 var(--space-xl);height:var(--topbar-height);background:rgba(15,23,42,0.8);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color-light);}
.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer;}.mobile-menu-btn svg{width:24px;height:24px;}
.page-title{font-size:1.25rem;font-weight:700;letter-spacing:-0.02em;flex:1;}
.top-bar-actions{display:flex;gap:var(--space-sm);}

/* ===========================
   BUTTONS
   =========================== */
.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:10px 20px;border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-weight:600;font-size:.88rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;}
.btn svg{width:16px;height:16px;}
.btn-sm{padding:7px 14px;font-size:.82rem;}.btn-block{width:100%;justify-content:center;}
.btn-primary{background:linear-gradient(135deg,var(--accent-amber),#D97706);color:var(--text-inverse);box-shadow:var(--shadow-glow-amber);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 30px rgba(245,158,11,0.3);}
.btn-primary:disabled{opacity:0.5;cursor:not-allowed;transform:none;}
.btn-success{background:linear-gradient(135deg,var(--accent-green),#059669);color:white;box-shadow:var(--shadow-glow-green);}
.btn-success:hover{transform:translateY(-1px);}
.btn-danger{background:linear-gradient(135deg,var(--accent-red),#DC2626);color:white;}
.btn-danger:hover{transform:translateY(-1px);}
.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);}
.btn-ghost:hover{color:var(--text-primary);background:rgba(255,255,255,0.05);}
.btn-icon{padding:8px;background:transparent;color:var(--text-secondary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;}
.btn-icon:hover{color:var(--text-primary);background:rgba(255,255,255,0.08);}.btn-icon svg{width:18px;height:18px;}
.btn-back{margin-bottom:var(--space-lg);}

/* ===========================
   VIEWS
   =========================== */
.view{display:none;padding:var(--space-xl);animation:fadeIn .3s ease;}.view.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

/* ===========================
   CARDS
   =========================== */
.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);backdrop-filter:blur(12px);transition:all var(--transition-base);}
.card:hover{border-color:rgba(148,163,184,0.2);}
.card-header{padding:var(--space-lg) var(--space-lg) 0;}
.card-title{font-size:1rem;font-weight:600;display:flex;align-items:center;gap:var(--space-sm);color:var(--text-primary);}
.card-title svg{width:18px;height:18px;color:var(--accent-amber);}
.card-body{padding:var(--space-lg);}

/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl);}
.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);backdrop-filter:blur(12px);padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-lg);transition:all var(--transition-base);}
.stat-card:hover{transform:translateY(-2px);border-color:rgba(148,163,184,0.2);box-shadow:var(--shadow-md);}
.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.stat-icon svg{width:24px;height:24px;}
.stat-icon.blue{background:var(--accent-blue-glow);color:var(--accent-blue);}
.stat-icon.amber{background:var(--accent-amber-glow);color:var(--accent-amber);}
.stat-icon.green{background:var(--accent-green-glow);color:var(--accent-green);}
.stat-icon.purple{background:var(--accent-purple-glow);color:var(--accent-purple);}
.stat-info{display:flex;flex-direction:column;}
.stat-value{font-size:1.75rem;font-weight:800;letter-spacing:-0.03em;}
.stat-label{font-size:.82rem;color:var(--text-secondary);margin-top:2px;}

/* Dashboard */
.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);}
.dashboard-grid .card:last-child{grid-column:1/-1;}
#chartDistribucion{max-width:260px;max-height:260px;margin:0 auto var(--space-md);}
.chart-legend{display:flex;flex-wrap:wrap;gap:var(--space-sm) var(--space-lg);justify-content:center;}
.chart-legend-item{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-secondary);}
.chart-legend-dot{width:10px;height:10px;border-radius:var(--radius-full);}

/* Top tenants */
.top-tenant-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid var(--border-color-light);cursor:pointer;}
.top-tenant-item:last-child{border-bottom:none;}
.top-tenant-rank{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;background:var(--accent-amber-glow);color:var(--accent-amber);flex-shrink:0;}
.top-tenant-rank.rank-1{background:linear-gradient(135deg,var(--accent-amber),#D97706);color:var(--text-inverse);}
.top-tenant-info{flex:1;}.top-tenant-name{font-weight:600;font-size:.9rem;}.top-tenant-address{font-size:.78rem;color:var(--text-secondary);margin-top:2px;}
.top-tenant-score{font-weight:700;font-size:.95rem;color:var(--accent-green);}
.empty-state-small{text-align:center;color:var(--text-muted);padding:var(--space-xl) 0;font-size:.9rem;}

/* Mini map */
.mini-map{height:250px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color);}

/* ===========================
   PROPERTIES
   =========================== */
.properties-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg);}
.property-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base);cursor:pointer;}
.property-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:rgba(148,163,184,0.25);}
.property-card-map{height:140px;background:var(--bg-input);}
.property-card-body{padding:var(--space-lg);}
.property-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm);}
.property-card-name{font-weight:700;font-size:1.05rem;}
.property-card-type{font-size:.75rem;padding:3px 10px;border-radius:var(--radius-full);font-weight:600;}
.type-Apartamento{background:var(--accent-blue-glow);color:var(--accent-blue);}
.type-Casa{background:var(--accent-green-glow);color:var(--accent-green);}
.type-Local\ Comercial,.type-LocalComercial{background:var(--accent-purple-glow);color:var(--accent-purple);}
.type-Oficina{background:var(--accent-amber-glow);color:var(--accent-amber);}
.type-Habitación,.type-Habitacion{background:var(--accent-red-glow);color:var(--accent-red);}
.type-Otro{background:rgba(148,163,184,0.15);color:var(--text-secondary);}
.property-card-address{font-size:.82rem;color:var(--text-secondary);margin-bottom:var(--space-md);line-height:1.5;}
.property-card-stats{display:flex;gap:var(--space-lg);font-size:.82rem;color:var(--text-muted);}
.property-card-stat{display:flex;align-items:center;gap:4px;}
.property-card-stat svg{width:14px;height:14px;}
.property-card-actions{display:flex;gap:var(--space-xs);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-color-light);}

/* Full map */
.map-full-container{height:calc(100vh - var(--topbar-height) - var(--space-xl) * 2);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-color);}
.full-map{height:100%;width:100%;}

/* Modal map */
.modal-map{height:260px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color);margin-bottom:var(--space-md);}

/* ===========================
   TABLES & FORMS
   =========================== */
.list-toolbar{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;align-items:center;}
.search-box{display:flex;align-items:center;gap:var(--space-sm);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:0 var(--space-md);flex:1;min-width:200px;transition:border-color var(--transition-fast);}
.search-box:focus-within{border-color:var(--accent-amber);}.search-box svg{width:18px;height:18px;color:var(--text-muted);}
.search-box input{background:transparent;border:none;color:var(--text-primary);font-family:var(--font-family);font-size:.9rem;padding:10px 0;width:100%;outline:none;}
.search-box input::placeholder{color:var(--text-muted);}
.filter-group{display:flex;gap:var(--space-sm);flex-wrap:wrap;}
.select-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:.88rem;padding:10px var(--space-md);cursor:pointer;outline:none;transition:border-color var(--transition-fast);appearance:auto;}
.select-input:focus{border-color:var(--accent-amber);}.select-full{width:100%;}
.table-container{overflow-x:auto;}
.data-table{width:100%;border-collapse:collapse;}
.data-table thead th{text-align:left;padding:var(--space-md);font-size:.78rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);white-space:nowrap;}
.data-table tbody tr{border-bottom:1px solid var(--border-color-light);transition:background var(--transition-fast);}
.data-table tbody tr:hover{background:rgba(255,255,255,0.03);}
.data-table tbody td{padding:var(--space-md);font-size:.9rem;vertical-align:middle;}
.tenant-name-cell{font-weight:600;cursor:pointer;color:var(--accent-cyan);transition:color var(--transition-fast);}
.tenant-name-cell:hover{color:var(--accent-amber);}
.actions-cell{display:flex;gap:var(--space-xs);}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;white-space:nowrap;}
.badge-excelente{background:rgba(16,185,129,0.15);color:#34D399;}.badge-bueno{background:rgba(59,130,246,0.15);color:#60A5FA;}
.badge-regular{background:rgba(245,158,11,0.15);color:#FBBF24;}.badge-deficiente{background:rgba(239,68,68,0.15);color:#F87171;}
.badge-malo{background:rgba(239,68,68,0.25);color:#EF4444;}.badge-sin-evaluar{background:rgba(148,163,184,0.15);color:var(--text-secondary);}
.badge-activo{background:rgba(16,185,129,0.15);color:#34D399;}.badge-inactivo{background:rgba(148,163,184,0.15);color:var(--text-secondary);}
.badge-consent-si{background:rgba(16,185,129,0.15);color:#34D399;}.badge-consent-no{background:rgba(239,68,68,0.15);color:#F87171;}

/* Forms */
.form-group{margin-bottom:var(--space-md);flex:1;}
.form-group label{display:block;font-size:.82rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px;}
.form-input{width:100%;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:.9rem;padding:10px var(--space-md);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);}
.form-input:focus{border-color:var(--accent-amber);box-shadow:0 0 0 3px rgba(245,158,11,0.1);}
textarea.form-input{resize:vertical;min-height:60px;}
.form-row{display:flex;gap:var(--space-md);}
.checkbox-label{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;font-size:.9rem;color:var(--text-primary);}
.checkbox-label input[type="checkbox"]{width:18px;height:18px;accent-color:var(--accent-amber);cursor:pointer;}.checkbox-mt{margin-top:28px;}
.form-divider{border:none;border-top:1px solid var(--border-color-light);margin:var(--space-lg) 0;}
.form-section-title{font-size:.95rem;font-weight:600;margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm);color:var(--accent-amber);}
.form-section-title svg{width:18px;height:18px;}
.form-hint{font-size:.75rem;font-weight:400;color:var(--text-muted);margin-left:var(--space-sm);}

/* Consent warning */
.consent-warning{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);background:var(--accent-red-glow);border:1px solid rgba(239,68,68,0.3);border-radius:var(--radius-md);margin-top:var(--space-md);}
.consent-warning svg{width:24px;height:24px;color:var(--accent-red);flex-shrink:0;margin-top:2px;}
.consent-warning strong{color:var(--accent-red);}
.consent-warning p{font-size:.82rem;color:var(--text-secondary);margin-top:4px;}

/* Consent box in modal */
.consent-box{padding:var(--space-md);background:rgba(59,130,246,0.05);border:1px solid rgba(59,130,246,0.15);border-radius:var(--radius-md);}
.consent-text{font-size:.82rem;color:var(--text-secondary);margin-bottom:var(--space-md);}

/* ===========================
   EVALUATIONS
   =========================== */
.eval-layout{display:flex;flex-direction:column;gap:var(--space-lg);}
.eval-section{border:1px solid var(--border-color-light);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-md);}
.eval-section legend{display:flex;align-items:center;gap:var(--space-sm);font-weight:600;font-size:.95rem;color:var(--accent-amber);padding:0 var(--space-sm);}
.eval-section legend svg{width:18px;height:18px;}
.rating-group{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) 0;gap:var(--space-md);}
.rating-group label{font-size:.88rem;color:var(--text-secondary);margin-bottom:0;}
.star-rating{display:flex;gap:4px;direction:rtl;}
.star-rating .star{cursor:pointer;font-size:1.5rem;color:var(--text-muted);transition:color var(--transition-fast),transform var(--transition-fast);user-select:none;}
.star-rating .star:hover,.star-rating .star.hovered{color:var(--accent-amber);transform:scale(1.15);}
.star-rating .star.active{color:var(--accent-amber);}
#chartTendencia{width:100%;max-height:200px;margin-bottom:var(--space-lg);}
.eval-history-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--border-color-light);transition:background var(--transition-fast);}
.eval-history-item:last-child{border-bottom:none;}.eval-history-item:hover{background:rgba(255,255,255,0.03);}
.eval-history-month{font-weight:600;font-size:.9rem;min-width:120px;}
.eval-history-scores{display:flex;gap:var(--space-md);flex:1;flex-wrap:wrap;}
.eval-history-metric{font-size:.78rem;color:var(--text-secondary);}.eval-history-metric strong{color:var(--text-primary);}
.eval-history-total{font-weight:700;font-size:1rem;min-width:50px;text-align:right;}
.eval-history-actions{display:flex;gap:var(--space-xs);}

/* ===========================
   CERTIFICATE
   =========================== */
.cert-controls{margin-bottom:var(--space-xl);}
.cert-preview-wrapper{display:flex;justify-content:center;padding:var(--space-lg);}
.certificate{width:900px;max-width:100%;background:#FFFBF0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);}
.cert-border{margin:12px;border:3px solid #B8860B;border-radius:var(--radius-md);padding:8px;}
.cert-inner{border:1px solid #DAA520;border-radius:var(--radius-sm);padding:var(--space-2xl) var(--space-xl);text-align:center;color:#2C1810;}
.cert-header-section{margin-bottom:var(--space-xl);}
.cert-shield-icon{width:56px;height:56px;color:#B8860B;}
.cert-title{font-size:1.8rem;font-weight:800;color:#8B6914;letter-spacing:.05em;text-transform:uppercase;margin-bottom:var(--space-md);}
.cert-divider{width:200px;height:2px;background:linear-gradient(90deg,transparent,#DAA520,transparent);margin:0 auto;}
.cert-body-section{margin-bottom:var(--space-xl);}
.cert-intro{font-size:1rem;color:#5C4A32;margin-bottom:var(--space-sm);font-style:italic;}
.cert-tenant-name{font-size:1.6rem;font-weight:800;color:#1a1a1a;margin-bottom:var(--space-sm);border-bottom:2px solid #DAA520;display:inline-block;padding-bottom:4px;}
.cert-cedula{font-size:.9rem;color:#5C4A32;margin-bottom:var(--space-md);}
.cert-text{font-size:.95rem;color:#3B2F20;line-height:1.6;margin-bottom:var(--space-sm);max-width:600px;margin-inline:auto;}
.cert-address{font-weight:700;font-size:1rem;color:#2C1810;margin-bottom:var(--space-sm);}
.cert-score-badge{display:inline-flex;align-items:baseline;gap:6px;background:linear-gradient(135deg,#B8860B,#DAA520);color:white;padding:10px 28px;border-radius:var(--radius-full);margin:var(--space-md) 0;}
.cert-score-value{font-size:2rem;font-weight:800;}.cert-score-max{font-size:1rem;opacity:.8;}
.cert-metrics-row{display:flex;justify-content:center;gap:var(--space-2xl);margin-top:var(--space-lg);}
.cert-metric{display:flex;flex-direction:column;align-items:center;gap:4px;}
.cert-metric-label{font-size:.75rem;color:#5C4A32;text-transform:uppercase;letter-spacing:.05em;}
.cert-metric-value{font-size:1.2rem;font-weight:700;color:#2C1810;}
.cert-footer-section{display:flex;justify-content:space-between;align-items:flex-end;padding-top:var(--space-xl);border-top:1px solid rgba(218,165,32,0.3);}
.cert-signature-area{text-align:center;}.cert-signature-line{width:200px;height:1px;background:#2C1810;margin:0 auto var(--space-sm);}
.cert-signer-name{font-weight:700;font-size:.9rem;color:#2C1810;}.cert-signer-role{font-size:.78rem;color:#5C4A32;}
.cert-date-area{text-align:right;}.cert-date{font-size:.85rem;color:#5C4A32;}.cert-id{font-size:.72rem;color:#8B7D6B;margin-top:4px;}

/* ===========================
   PROFILE
   =========================== */
.perfil-header{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-xl);backdrop-filter:blur(12px);}
.perfil-avatar{width:80px;height:80px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--accent-amber),#D97706);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:2rem;font-weight:800;color:var(--text-inverse);}
.perfil-info{flex:1;}.perfil-name{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-xs);}
.perfil-details{display:flex;flex-wrap:wrap;gap:var(--space-md) var(--space-xl);color:var(--text-secondary);font-size:.88rem;}
.perfil-detail{display:flex;align-items:center;gap:6px;}.perfil-detail svg{width:16px;height:16px;}
.perfil-score-area{text-align:center;}
.perfil-score-value{font-size:2.5rem;font-weight:800;line-height:1;}
.perfil-score-label{font-size:.78rem;color:var(--text-secondary);margin-top:4px;}
.perfil-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);}
.perfil-grid .perfil-eval-history{grid-column:1/-1;}
.metric-bar-group{margin-bottom:var(--space-md);}
.metric-bar-label{display:flex;justify-content:space-between;font-size:.82rem;margin-bottom:6px;}
.metric-bar-name{color:var(--text-secondary);}.metric-bar-value{font-weight:600;}
.metric-bar-track{height:8px;background:rgba(255,255,255,0.05);border-radius:var(--radius-full);overflow:hidden;}
.metric-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .6s ease;}
.metric-bar-fill.amber{background:linear-gradient(90deg,#D97706,var(--accent-amber));}
.metric-bar-fill.green{background:linear-gradient(90deg,#059669,var(--accent-green));}
.metric-bar-fill.blue{background:linear-gradient(90deg,#2563EB,var(--accent-blue));}

/* ===========================
   CONSENT DOCUMENT (for PDF)
   =========================== */
.consent-doc{width:800px;max-width:100%;background:white;padding:0;font-family:'Inter',sans-serif;}
.consent-doc-inner{padding:48px 56px;color:#1a1a1a;line-height:1.7;}
.consent-doc-title{font-size:1.3rem;font-weight:800;text-align:center;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;color:#1a1a1a;}
.consent-doc-ref{text-align:center;font-size:.82rem;color:#555;margin-bottom:16px;font-style:italic;}
.consent-doc-divider{width:100%;height:2px;background:linear-gradient(90deg,transparent,#B8860B,transparent);margin:16px 0 24px;}
.consent-doc-subtitle{font-size:1rem;font-weight:700;margin:24px 0 12px;text-transform:uppercase;color:#333;}
.consent-doc-text{font-size:.9rem;margin-bottom:12px;color:#333;}
.consent-doc-address{font-weight:700;font-size:.95rem;text-align:center;margin:8px 0 16px;color:#1a1a1a;padding:8px;border:1px dashed #ccc;border-radius:4px;}
.consent-doc-list{margin:0 0 16px 24px;font-size:.88rem;color:#333;}
.consent-doc-list li{margin-bottom:10px;}
.consent-doc-signatures{display:flex;justify-content:space-between;margin-top:48px;gap:32px;}
.consent-doc-sig{flex:1;text-align:center;}
.consent-doc-sig-line{width:100%;height:1px;background:#1a1a1a;margin-bottom:8px;margin-top:60px;}
.consent-doc-sig p{font-size:.82rem;color:#333;margin:4px 0;}
.consent-doc-date{margin-top:32px;font-size:.88rem;color:#333;}.consent-doc-location{font-size:.88rem;color:#333;margin-bottom:24px;}
.consent-doc-footer{text-align:center;font-size:.72rem;color:#999;border-top:1px solid #eee;padding-top:12px;margin-top:24px;}

/* ===========================
   MODALS
   =========================== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(4px);z-index:200;justify-content:center;align-items:center;padding:var(--space-lg);animation:fadeIn .2s ease;}
.modal-overlay.open{display:flex;}
.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s ease;}
.modal-sm{max-width:400px;}.modal-lg{max-width:700px;}
@keyframes slideUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-color-light);}
.modal-header h2{font-size:1.1rem;font-weight:700;}
.modal-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast);}
.modal-close:hover{color:var(--text-primary);background:rgba(255,255,255,0.05);}.modal-close svg{width:20px;height:20px;}
.modal-body{padding:var(--space-lg);}
.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg) var(--space-lg);}

/* ===========================
   TOAST
   =========================== */
.toast-container{position:fixed;bottom:var(--space-lg);right:var(--space-lg);z-index:300;display:flex;flex-direction:column;gap:var(--space-sm);}
.toast{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);display:flex;align-items:center;gap:var(--space-sm);font-size:.88rem;box-shadow:var(--shadow-lg);animation:toastIn .3s ease;min-width:280px;}
.toast.toast-success{border-left:3px solid var(--accent-green);}.toast.toast-error{border-left:3px solid var(--accent-red);}.toast.toast-info{border-left:3px solid var(--accent-blue);}
.toast svg{width:18px;height:18px;flex-shrink:0;}
.toast.toast-success svg{color:var(--accent-green);}.toast.toast-error svg{color:var(--accent-red);}.toast.toast-info svg{color:var(--accent-blue);}
@keyframes toastIn{from{opacity:0;transform:translateX(40px);}to{opacity:1;transform:translateX(0);}}
.toast-exit{animation:toastOut .3s ease forwards;}
@keyframes toastOut{to{opacity:0;transform:translateX(40px);}}

/* Empty state */
.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--text-muted);}
.empty-state svg{width:48px;height:48px;margin-bottom:var(--space-md);opacity:.5;}
.empty-state h3{font-size:1.1rem;color:var(--text-secondary);margin-bottom:var(--space-sm);}.empty-state p{margin-bottom:var(--space-lg);}

/* Score colors */
.score-excelente{color:#34D399;}.score-bueno{color:#60A5FA;}.score-regular{color:#FBBF24;}.score-deficiente{color:#F87171;}.score-malo{color:#EF4444;}

/* ===========================
   RESPONSIVE
   =========================== */
@media(max-width:1024px){.dashboard-grid,.perfil-grid{grid-template-columns:1fr;}.properties-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));}}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);width:var(--sidebar-width);}.sidebar.mobile-open{transform:translateX(0);}.sidebar-overlay.show{display:block;}
  .main-content,.sidebar.collapsed ~ .main-content{margin-left:0;}.mobile-menu-btn{display:block;}
  .top-bar{padding:0 var(--space-md);}.view{padding:var(--space-md);}
  .stats-grid{grid-template-columns:1fr 1fr;}.form-row{flex-direction:column;}
  .list-toolbar{flex-direction:column;}.filter-group{flex-wrap:wrap;}
  .perfil-header{flex-direction:column;text-align:center;}.perfil-details{justify-content:center;}
  .cert-footer-section{flex-direction:column;gap:var(--space-lg);align-items:center;}.cert-date-area{text-align:center;}
  .top-bar-actions span{display:none;}.map-full-container{height:60vh;}
}
@media(max-width:480px){.stats-grid{grid-template-columns:1fr;}.cert-metrics-row{flex-direction:column;}.properties-grid{grid-template-columns:1fr;}}

/* Leaflet popup override */
.leaflet-popup-content-wrapper{border-radius:var(--radius-md) !important;}.leaflet-popup-content{font-family:var(--font-family) !important;font-size:.88rem !important;}

/* ===========================
   ADMIN PANEL
   =========================== */
.nav-divider{height:1px;background:var(--border-color-light);margin:var(--space-sm) var(--space-md);}
.sidebar-user-role{display:inline-block;font-size:.65rem;font-weight:700;padding:1px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;}
.sidebar-user-role.role-admin{background:linear-gradient(135deg,var(--accent-amber),#D97706);color:var(--text-inverse);}
.sidebar-user-role.role-arrendatario{background:var(--accent-blue-glow);color:var(--accent-blue);}
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-md);}
.admin-stat{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;}
.admin-stat-value{font-size:1.5rem;font-weight:800;color:var(--accent-amber);}
.admin-stat-label{font-size:.78rem;color:var(--text-secondary);margin-top:4px;}
.badge-admin{background:linear-gradient(135deg,var(--accent-amber),#D97706);color:var(--text-inverse);}
.badge-arrendatario{background:var(--accent-blue-glow);color:var(--accent-blue);}

/* ===========================
   RETROACTIVE EVALUATION
   =========================== */
.retro-intro{font-size:.88rem;color:var(--text-secondary);margin-bottom:var(--space-lg);line-height:1.6;}
.retro-scores-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm) var(--space-xl);margin-bottom:var(--space-lg);}
.retro-score-group{margin-bottom:var(--space-sm);}
.retro-score-group label{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:4px;}
.retro-score-group label svg{width:16px;height:16px;color:var(--accent-amber);}
.retro-score-control{display:flex;align-items:center;gap:var(--space-md);}
.retro-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:rgba(255,255,255,0.08);border-radius:var(--radius-full);outline:none;cursor:pointer;}
.retro-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--accent-amber),#D97706);cursor:pointer;box-shadow:0 0 8px rgba(245,158,11,0.3);}
.retro-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--accent-amber),#D97706);cursor:pointer;border:none;}
.retro-score-val{min-width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--accent-amber-glow);color:var(--accent-amber);font-weight:700;font-size:.9rem;border-radius:var(--radius-sm);}
.retro-preview{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);margin:var(--space-md) 0;max-height:160px;overflow-y:auto;}
.retro-preview-title{font-size:.82rem;font-weight:600;color:var(--accent-amber);margin-bottom:var(--space-sm);}
.retro-preview-months{display:flex;flex-wrap:wrap;gap:var(--space-xs);}
.retro-preview-month{font-size:.72rem;padding:2px 8px;background:rgba(255,255,255,0.05);border:1px solid var(--border-color-light);border-radius:var(--radius-full);color:var(--text-secondary);}
.retro-preview-month.exists{background:var(--accent-red-glow);border-color:rgba(239,68,68,0.3);color:var(--accent-red);text-decoration:line-through;}
.retro-preview-summary{margin-top:var(--space-sm);font-size:.78rem;color:var(--text-muted);}
.card-header{display:flex;align-items:center;gap:var(--space-sm);}
@media(max-width:768px){.retro-scores-grid{grid-template-columns:1fr;}}
