:root{--color-river: #2D5A27;--color-river-light: #4a8a40;--color-suite: #3B6DB5;--color-suite-light: #5a8fd4;--color-primary: #2D5A27;--color-primary-dark: #1e4019;--color-primary-light: #4a8a40;--color-primary-bg: rgba(45, 90, 39, .08);--color-accent: #e8864a;--color-accent-light: #f4a574;--color-accent-bg: rgba(232, 134, 74, .1);--color-success: #10b981;--color-success-bg: rgba(16, 185, 129, .1);--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .1);--color-error: #ef4444;--color-error-bg: rgba(239, 68, 68, .08);--color-info: #3b82f6;--color-info-bg: rgba(59, 130, 246, .08);--color-text: #2d3436;--color-text-secondary: #636e72;--color-text-muted: #b2bec3;--color-border: #e9ecef;--color-border-light: #f1f3f5;--color-bg: #f8f6f3;--color-bg-white: #ffffff;--color-bg-card: #ffffff;--sidebar-bg: #ffffff;--sidebar-hover: #f4f2ef;--sidebar-active: rgba(45, 90, 39, .08);--sidebar-text: #636e72;--sidebar-text-active: #2D5A27;--sidebar-width: 210px;--sidebar-collapsed-width: 72px;--topbar-height: 64px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs: .75rem;--font-sm: .8125rem;--font-base: .875rem;--font-md: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .03);--shadow-md: 0 2px 8px rgba(0, 0, 0, .04);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .06);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .08);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-base);color:var(--color-text);background:var(--color-bg);line-height:1.6;overflow-x:hidden}a{color:var(--color-primary);text-decoration:none}ul,ol{list-style:none}img{max-width:100%;display:block}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.modal-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:20px}.form-group.full-width{grid-column:span 2}.badge-confirmado{background-color:var(--color-success-bg);color:var(--color-success)}.badge-blue{background-color:var(--color-info-bg);color:var(--color-info)}.badge-yellow{background-color:var(--color-warning-bg);color:var(--color-warning)}.badge-gray{background-color:var(--color-border);color:var(--color-text-secondary)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid var(--color-border);position:fixed;top:0;left:0;bottom:0;z-index:100;display:flex;flex-direction:column;transition:transform var(--transition-base);overflow-y:auto}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar-overlay.show{display:block}.sidebar-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-6) var(--space-5);border-bottom:1px solid var(--color-border-light)}.sidebar-logo{width:42px;height:42px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-river),var(--color-river-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:var(--font-xl);flex-shrink:0}.sidebar-brand-name{font-size:var(--font-lg);font-weight:800;color:var(--color-text)}.sidebar-brand-sub{font-size:var(--font-xs);color:var(--color-text-muted);font-weight:500}.sidebar-nav{flex:1;padding:var(--space-4) var(--space-3)}.sidebar-section-title{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:1.2px;color:var(--color-text-muted);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1);font-weight:600}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--sidebar-text);font-weight:500;font-size:var(--font-base);transition:all var(--transition-fast);text-decoration:none;margin-bottom:2px;position:relative}.sidebar-link:hover{background:var(--sidebar-hover);color:var(--color-text)}.sidebar-link.active{background:var(--sidebar-active);color:var(--sidebar-text-active);font-weight:700}.sidebar-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--color-primary);border-radius:0 4px 4px 0}.sidebar-link-icon{width:20px;height:20px;flex-shrink:0}.sidebar-link-badge{margin-left:auto;background:var(--color-accent);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);min-width:22px;text-align:center}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid var(--color-border-light)}.topbar{height:var(--topbar-height);background:var(--color-bg-white);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 var(--space-6);gap:var(--space-5);position:sticky;top:0;z-index:50}.topbar-hamburger{display:none;color:var(--color-text-secondary);padding:var(--space-2);border-radius:var(--radius-sm)}.topbar-hamburger:hover{background:var(--sidebar-hover)}.topbar-title{font-size:var(--font-xl);font-weight:800;color:var(--color-text);white-space:nowrap}.topbar-search{flex:1;max-width:400px;position:relative}.topbar-search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--color-text-muted)}.topbar-search-input{width:100%;padding:var(--space-2) var(--space-4) var(--space-2) 40px;border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-sm);background:var(--color-bg);color:var(--color-text);transition:all var(--transition-fast)}.topbar-search-input:focus{outline:none;border-color:var(--color-primary);background:var(--color-bg-white);box-shadow:0 0 0 3px var(--color-primary-bg)}.topbar-search-input::placeholder{color:var(--color-text-muted)}.topbar-right{display:flex;align-items:center;gap:var(--space-4);margin-left:auto}.property-selector{display:flex;background:var(--color-bg);border-radius:var(--radius-full);padding:3px;border:1px solid var(--color-border-light)}.property-btn{padding:var(--space-1) var(--space-4);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600;color:var(--color-text-secondary);transition:all var(--transition-fast)}.property-btn.active{background:var(--color-bg-white);color:var(--color-primary);box-shadow:var(--shadow-sm)}.property-btn:hover:not(.active){color:var(--color-text)}.topbar-notifications{position:relative;color:var(--color-text-secondary);padding:var(--space-2);border-radius:var(--radius-full);transition:all var(--transition-fast)}.topbar-notifications:hover{background:var(--color-bg);color:var(--color-text)}.notif-badge{position:absolute;top:0;right:0;width:18px;height:18px;background:var(--color-accent);color:#fff;font-size:10px;font-weight:700;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;border:2px solid var(--color-bg-white)}.topbar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.topbar-user:hover{background:var(--color-bg)}.topbar-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-river),var(--color-suite));display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-xs);font-weight:700}.topbar-user-info{display:flex;flex-direction:column}.topbar-user-name{font-size:var(--font-sm);font-weight:700;color:var(--color-text);line-height:1.2}.topbar-user-role{font-size:var(--font-xs);color:var(--color-text-muted)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column}.page-content{flex:1;padding:var(--space-6)}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-xl)}.main-content{margin-left:0}.topbar-hamburger{display:flex}.topbar-search,.topbar-user-info{display:none}}@media(max-width:640px){.page-content{padding:var(--space-4)}.property-selector{display:none}.topbar{padding:0 var(--space-4)}}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.card-header{padding:var(--space-5) var(--space-5) var(--space-3);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:var(--font-md);font-weight:700;color:var(--color-text)}.card-subtitle{font-size:var(--font-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.card-body{padding:0 var(--space-5) var(--space-5)}.card-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--color-border-light);display:flex;align-items:center;gap:var(--space-2)}.stat-card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);display:flex;align-items:flex-start;gap:var(--space-4);transition:all var(--transition-fast)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.blue{background:var(--color-info-bg);color:var(--color-info)}.stat-icon.green{background:var(--color-success-bg);color:var(--color-success)}.stat-icon.yellow{background:var(--color-warning-bg);color:var(--color-warning)}.stat-icon.red{background:var(--color-error-bg);color:var(--color-error)}.stat-icon.purple{background:var(--color-primary-bg);color:var(--color-primary)}.stat-info{flex:1}.stat-label{font-size:var(--font-sm);color:var(--color-text-secondary);font-weight:500}.stat-value{font-size:var(--font-2xl);font-weight:800;color:var(--color-text);line-height:1.2;margin-top:var(--space-1)}.stat-change{font-size:var(--font-xs);font-weight:600;margin-top:var(--space-1)}.stat-change.positive{color:var(--color-success)}.stat-change.negative{color:var(--color-error)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600;white-space:nowrap}.badge-nuevo,.badge-blue{background:var(--color-info-bg);color:var(--color-info)}.badge-espera,.badge-yellow{background:var(--color-warning-bg);color:var(--color-warning)}.badge-confirmado,.badge-green{background:var(--color-success-bg);color:var(--color-success)}.badge-rechazado,.badge-red,.badge-error{background:var(--color-error-bg);color:var(--color-error)}.badge-purple{background:var(--color-primary-bg);color:var(--color-primary)}.badge-gray{background:var(--color-border-light);color:var(--color-text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;transition:all var(--transition-fast);white-space:nowrap;cursor:pointer;border:none}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-xs);border-radius:var(--radius-sm)}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover{background:#0da370}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{background:#dc2626}.btn-warning{background:var(--color-warning);color:#fff}.btn-warning:hover{background:#d97706}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.btn-outline:hover{background:var(--color-bg);color:var(--color-text);border-color:var(--color-text-muted)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-bg);color:var(--color-text)}.filters-bar{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;padding:var(--space-4) var(--space-5);background:var(--color-bg-white);border-radius:var(--radius-lg);margin-bottom:var(--space-5);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.filter-group{display:flex;align-items:center;gap:var(--space-2)}.filter-label{font-size:var(--font-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.filter-select{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--color-text);background:var(--color-bg-white);outline:none;cursor:pointer;min-width:120px}.filter-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.filter-search{flex:1;min-width:200px;position:relative}.filter-search input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) 36px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--color-text);outline:none}.filter-search input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.filter-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--color-text-muted)}.section-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.section-title{font-size:var(--font-md);font-weight:700;color:var(--color-text)}.section-count{background:var(--color-bg);color:var(--color-text-secondary);font-size:var(--font-xs);font-weight:600;padding:2px 10px;border-radius:var(--radius-full)}.data-card{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);border:1px solid var(--color-border-light);transition:all var(--transition-fast);cursor:pointer;margin-bottom:var(--space-3)}.data-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary)}.data-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.data-card-ref{font-weight:700;font-size:var(--font-base);color:var(--color-text)}.data-card-amount{font-weight:800;font-size:var(--font-md);color:var(--color-text)}.data-card-body{display:flex;flex-direction:column;gap:var(--space-1)}.data-card-row{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);color:var(--color-text-secondary)}.data-card-row svg{width:14px;height:14px;flex-shrink:0;color:var(--color-text-muted)}.data-card-footer{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border-light)}.grid{display:grid;gap:var(--space-5)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.tabs{display:flex;gap:var(--space-1);background:var(--color-bg);padding:4px;border-radius:var(--radius-md);margin-bottom:var(--space-5);overflow-x:auto}.tab{padding:var(--space-2) var(--space-5);border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:600;color:var(--color-text-secondary);transition:all var(--transition-fast);white-space:nowrap;cursor:pointer}.tab.active{background:var(--color-bg-white);color:var(--color-primary);box-shadow:var(--shadow-sm)}.tab:hover:not(.active){color:var(--color-text)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .2s ease}.modal{background:var(--color-bg-white);border-radius:var(--radius-xl);width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .25s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-light);position:sticky;top:0;background:var(--color-bg-white);z-index:1;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.modal-title{font-size:var(--font-lg);font-weight:700}.modal-close{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:all var(--transition-fast)}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-body{padding:var(--space-6)}.modal-section{margin-bottom:var(--space-5)}.modal-section-title{font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary);margin-bottom:var(--space-3)}.modal-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.modal-info-item{display:flex;flex-direction:column;gap:2px}.modal-info-label{font-size:var(--font-xs);color:var(--color-text-muted);font-weight:500}.modal-info-value{font-size:var(--font-sm);color:var(--color-text);font-weight:600}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);position:sticky;bottom:0;background:var(--color-bg-white);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.notif-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer}.notif-item:hover{background:var(--color-bg)}.notif-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0;margin-top:6px}.notif-dot.blue{background:var(--color-info)}.notif-dot.green{background:var(--color-success)}.notif-dot.yellow{background:var(--color-warning)}.notif-dot.red{background:var(--color-error)}.notif-text{flex:1;font-size:var(--font-sm);color:var(--color-text)}.notif-time{font-size:var(--font-xs);color:var(--color-text-muted);white-space:nowrap}.progress-bar{width:100%;height:8px;background:var(--color-bg);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-fill.green{background:var(--color-success)}.progress-fill.blue{background:var(--color-info)}.progress-fill.yellow{background:var(--color-warning)}.progress-fill.purple{background:var(--color-primary)}.chart-bars{display:flex;align-items:flex-end;gap:var(--space-2);height:160px;padding-top:var(--space-4)}.chart-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.chart-bar-container{display:flex;gap:4px;align-items:flex-end;height:140px;width:100%;justify-content:center}.chart-bar{width:16px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:height var(--transition-slow);min-height:4px}.chart-bar.suite{background:var(--color-suite)}.chart-bar.river{background:var(--color-river)}.chart-bar-label{font-size:var(--font-xs);color:var(--color-text-muted);text-align:center}.table-container{overflow-x:auto}table{width:100%;border-collapse:separate;border-spacing:0}th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border-light);white-space:nowrap}td{padding:var(--space-3) var(--space-4);font-size:var(--font-sm);color:var(--color-text);border-bottom:1px solid var(--color-border-light)}tr:hover td{background:var(--color-bg)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:var(--font-sm);font-weight:600;color:var(--color-text);margin-bottom:var(--space-2)}.form-input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-base);color:var(--color-text);background:var(--color-bg-white);outline:none;transition:all var(--transition-fast)}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.form-textarea{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-base);color:var(--color-text);min-height:100px;resize:vertical;outline:none}.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.form-checkbox{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);color:var(--color-text);cursor:pointer}.form-checkbox input[type=checkbox]{width:18px;height:18px;border-radius:4px;accent-color:var(--color-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);color:var(--color-text-muted)}.empty-state svg{width:48px;height:48px;margin:0 auto var(--space-4);opacity:.4}.empty-state-text{font-size:var(--font-md);font-weight:500}.timeline{position:relative;padding-left:var(--space-6)}.timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:var(--color-border-light)}.timeline-item{position:relative;padding-bottom:var(--space-4)}.timeline-item:before{content:"";position:absolute;left:calc(-1 * var(--space-6) + 4px);top:4px;width:10px;height:10px;border-radius:var(--radius-full);background:var(--color-primary);border:2px solid var(--color-bg-white)}.timeline-text{font-size:var(--font-sm);color:var(--color-text)}.timeline-time{font-size:var(--font-xs);color:var(--color-text-muted)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8f6f3,#ede9e3,#f0ebe5);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(45,90,39,.08),transparent 70%);top:-200px;right:-200px}.login-page:after{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(232,134,74,.06),transparent 70%);bottom:-200px;left:-100px}.login-card{background:#fffffff7;border-radius:var(--radius-xl);padding:var(--space-10) var(--space-8);width:100%;max-width:420px;box-shadow:var(--shadow-xl);position:relative;z-index:1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.login-logo{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-8)}.login-logo-icon{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-river),var(--color-suite));display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-2xl);font-weight:800}.login-logo-text{display:flex;flex-direction:column}.login-logo-name{font-size:var(--font-xl);font-weight:800;color:var(--color-text);letter-spacing:.5px}.login-logo-sub{font-size:var(--font-xs);color:var(--color-text-secondary);font-weight:500}.login-title{text-align:center;font-size:var(--font-lg);font-weight:700;color:var(--color-text);margin-bottom:var(--space-6)}.login-form .form-group{margin-bottom:var(--space-4)}.login-form .form-input{padding:var(--space-3) var(--space-4);font-size:var(--font-base)}.login-btn{width:100%;padding:var(--space-3) var(--space-6);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;font-size:var(--font-md);font-weight:700;border-radius:var(--radius-md);margin-top:var(--space-4);transition:all var(--transition-fast);border:none;cursor:pointer}.login-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px #2d5a274d}.login-forgot{text-align:center;margin-top:var(--space-4);font-size:var(--font-sm);color:var(--color-primary);cursor:pointer}.page-header{margin-bottom:var(--space-6)}.page-title{font-size:var(--font-2xl);font-weight:800;color:var(--color-text)}.page-description{font-size:var(--font-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);margin-bottom:var(--space-6)}@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.stats-grid{grid-template-columns:1fr}}.home-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-5)}@media(max-width:1024px){.home-grid{grid-template-columns:1fr}}.chart-legend{display:flex;gap:var(--space-5);margin-top:var(--space-3);justify-content:center}.legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-xs);color:var(--color-text-secondary)}.legend-dot{width:10px;height:10px;border-radius:var(--radius-full)}.legend-dot.suite{background:var(--color-suite)}.legend-dot.river{background:var(--color-river)}.income-total{font-size:var(--font-3xl);font-weight:800;color:var(--color-text);margin-bottom:var(--space-4)}.income-breakdown{display:flex;gap:var(--space-5)}.income-item{display:flex;flex-direction:column;gap:2px}.income-item-label{font-size:var(--font-xs);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-2)}.income-item-value{font-size:var(--font-md);font-weight:700;color:var(--color-text)}.status-section{margin-bottom:var(--space-6)}.data-card.highlight{border-left:4px solid var(--color-info);animation:slideUp .3s ease}.pipeline-column{margin-bottom:var(--space-6)}.pipeline-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.pipeline-dot{width:12px;height:12px;border-radius:var(--radius-full)}.pipeline-title{font-weight:700;font-size:var(--font-md);color:var(--color-text)}.pipeline-count{background:var(--color-bg);color:var(--color-text-secondary);padding:2px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600}.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}@media(max-width:900px){.report-grid{grid-template-columns:1fr}}.metric-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border-light)}.metric-row:last-child{border-bottom:none}.metric-label{font-size:var(--font-sm);color:var(--color-text-secondary)}.metric-value{font-size:var(--font-sm);font-weight:700;color:var(--color-text)}.config-section{margin-bottom:var(--space-8)}.config-title{font-size:var(--font-lg);font-weight:700;color:var(--color-text);margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:2px solid var(--color-border-light)}.user-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-bg-card);border-radius:var(--radius-md);border:1px solid var(--color-border-light);margin-bottom:var(--space-3)}.user-card-avatar{width:44px;height:44px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:var(--font-md);flex-shrink:0}.user-card-info{flex:1}.user-card-name{font-weight:700;font-size:var(--font-base);color:var(--color-text)}.user-card-email{font-size:var(--font-sm);color:var(--color-text-secondary)}.user-card-meta{display:flex;gap:var(--space-3);margin-top:var(--space-1)}.user-card-actions{display:flex;gap:var(--space-2)}.registro-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5);align-items:start}.registro-historial-toggle{display:none}@media(max-width:1024px){.registro-layout{grid-template-columns:1fr}.registro-historial-toggle{display:flex;width:100%;justify-content:center;margin-bottom:var(--space-4)}.registro-historial-container{display:none}.registro-historial-container.show-mobile{display:block}}.registro-card .card-body{padding:var(--space-5) var(--space-6)}.registro-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:480px){.registro-row{grid-template-columns:1fr}.registro-card .card-body{padding:var(--space-4)}}.registro-submit{width:100%;padding:var(--space-4) var(--space-6)!important;font-size:var(--font-md)!important;font-weight:700!important;margin-top:var(--space-4);gap:var(--space-3)!important;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark))!important;transition:all var(--transition-fast)!important}.registro-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #2d5a274d}.registro-submit:disabled{opacity:.65;cursor:not-allowed;transform:none!important}.registro-alert{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--font-sm);font-weight:600;animation:slideUp .3s ease}.registro-alert.success{background:var(--color-success-bg);color:#155724;border:1px solid #c3e6cb}.registro-alert.error{background:var(--color-error-bg);color:#721c24;border:1px solid #f5c6cb}.registro-empty{padding:var(--space-10) var(--space-5);text-align:center;color:var(--color-text-muted)}.registro-empty p{margin-top:var(--space-3);font-size:var(--font-sm)}.registro-historial-list{max-height:600px;overflow-y:auto}.registro-historial-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.registro-historial-item:last-child{border-bottom:none}.registro-historial-item:hover{background:var(--color-bg)}.registro-historial-main{flex:1;min-width:0}.registro-historial-name{font-weight:700;font-size:var(--font-base);color:var(--color-text);margin-bottom:var(--space-1)}.registro-historial-details{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);margin-bottom:var(--space-2)}.registro-historial-details span{font-size:var(--font-xs);color:var(--color-text-secondary);display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.registro-historial-meta{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-1)}.registro-historial-date{font-size:var(--font-xs);color:var(--color-text-muted)}.registro-delete-btn{color:var(--color-error)!important;flex-shrink:0;margin-top:var(--space-1)}.registro-delete-btn:hover{background:var(--color-error-bg)!important}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.lobby-main-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--space-5);margin-bottom:var(--space-5)}@media(max-width:1200px){.lobby-main-grid{grid-template-columns:1fr}}.lobby-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5);margin-top:var(--space-5)}@media(max-width:900px){.lobby-bottom-grid{grid-template-columns:1fr}}.lobby-rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-3)}.lobby-room-cell{border:2px solid;border-radius:var(--radius-md);padding:var(--space-3);text-align:center;transition:all var(--transition-fast);cursor:default}.lobby-room-cell:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.lobby-room-name{font-weight:800;font-size:var(--font-base);color:var(--color-text);margin-bottom:2px}.lobby-room-status{font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.lobby-room-guest{font-size:10px;color:var(--color-text-muted);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lobby-property-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);font-weight:700;color:var(--color-text);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border-light)}.lobby-prop-dot{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0}.lobby-status-legend{display:flex;gap:var(--space-3);flex-wrap:wrap}.lobby-legend-item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--color-text-secondary);font-weight:500}.lobby-legend-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.lobby-occ-chart{display:flex;align-items:flex-end;gap:4px;height:190px;padding-top:var(--space-4)}.lobby-occ-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.lobby-occ-bar-container{display:flex;align-items:flex-end;height:150px;width:100%;justify-content:center}.lobby-occ-bar{width:100%;max-width:28px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:height var(--transition-slow);min-height:4px;position:relative;display:flex;align-items:flex-start;justify-content:center}.lobby-occ-pct{font-size:9px;font-weight:700;color:#fff;padding-top:4px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.lobby-occ-label{font-size:10px;color:var(--color-text-muted);text-align:center;margin-top:6px;line-height:1.2}.lobby-products-list{display:flex;flex-direction:column}.lobby-product-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.lobby-product-item:last-child{border-bottom:none}.lobby-product-item:hover{background:var(--color-bg)}.lobby-product-emoji{font-size:1.3rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-bg);border-radius:var(--radius-md);flex-shrink:0}.lobby-product-info{flex:1;min-width:0}.lobby-product-name{font-weight:600;font-size:var(--font-sm);color:var(--color-text)}.lobby-product-stock{font-size:var(--font-xs);color:var(--color-text-muted)}.lobby-product-price{font-weight:700;font-size:var(--font-sm);color:var(--color-primary);white-space:nowrap}.lobby-channels-list{display:flex;flex-direction:column;gap:var(--space-3)}.lobby-channel-item{display:flex;align-items:center;gap:var(--space-3)}.lobby-channel-info{display:flex;align-items:center;gap:var(--space-2);min-width:110px;flex-shrink:0}.lobby-channel-dot{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0}.lobby-channel-name{font-size:var(--font-sm);font-weight:600;color:var(--color-text);white-space:nowrap}.lobby-channel-bar-wrap{flex:1;height:8px;background:var(--color-bg);border-radius:var(--radius-full);overflow:hidden}.lobby-channel-bar{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow);min-width:4px}.lobby-channel-stats{display:flex;align-items:center;gap:var(--space-2);min-width:60px;justify-content:flex-end}.lobby-channel-count{font-weight:700;font-size:var(--font-sm);color:var(--color-text)}.lobby-channel-pct{font-size:var(--font-xs);color:var(--color-text-muted);font-weight:500}.cal-container{position:relative}.cal-toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--color-border);flex-wrap:wrap}.cal-legend{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);padding:var(--space-2) var(--space-5);border-bottom:1px solid var(--color-border-light);background:var(--color-bg)}.cal-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.cal-legend-swatch{width:16px;height:10px;border-radius:2px;flex-shrink:0}.cal-toolbar-left,.cal-toolbar-right{display:flex;align-items:center;gap:var(--space-3)}.cal-date-input{display:flex;align-items:center;gap:var(--space-2);padding:6px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-white);font-size:var(--font-sm);color:var(--color-text)}.cal-date-input input[type=date]{border:none;background:transparent;font-size:var(--font-sm);color:var(--color-text);cursor:pointer;outline:none;font-family:inherit}.cal-nav-group{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.cal-nav-btn{display:flex;align-items:center;justify-content:center;padding:6px 8px;background:var(--color-bg-white);border:none;border-right:1px solid var(--color-border);cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-fast)}.cal-nav-btn:last-child{border-right:none}.cal-nav-btn:hover{background:var(--color-bg);color:var(--color-text)}.cal-scroll{overflow-x:auto;overflow-y:visible}.cal-table{width:100%;border-collapse:collapse;table-layout:fixed;min-width:900px}.cal-table th,.cal-table td{border:1px solid var(--color-border-light)}.cal-header-room{position:sticky;left:0;z-index:3;background:var(--color-bg);min-width:260px;width:260px;padding:var(--space-2) var(--space-3);text-align:left;font-weight:700;font-size:var(--font-sm);color:var(--color-text);border-bottom:2px solid var(--color-border)}.cal-header-date{padding:var(--space-1) var(--space-1);text-align:center;background:var(--color-bg);border-bottom:2px solid var(--color-border);min-width:60px;width:60px}.cal-today-header{background:#2d5a2714;border-bottom-color:var(--color-primary)}.cal-date-num{font-size:var(--font-lg);font-weight:800;color:var(--color-text);line-height:1.2}.cal-date-month{font-size:10px;font-weight:600;color:var(--color-text-secondary);text-transform:capitalize}.cal-date-day{font-size:10px;color:var(--color-text-muted)}.cal-date-occ{font-size:10px;font-weight:700;margin-top:2px}.cal-room-name-cell{position:sticky;left:0;z-index:2;background:var(--color-bg-white);min-width:260px;width:260px;padding:0 var(--space-3);border-right:2px solid var(--color-border)}.cal-room-info{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);min-height:42px}.cal-room-label{font-weight:700;font-size:var(--font-sm);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-room-icons{display:flex;gap:2px;flex-shrink:0}.cal-rate-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.cal-rate-icon:hover{background:var(--color-bg);color:var(--color-text)}.cal-cell{padding:0;height:42px;position:relative;vertical-align:middle}.cal-today{background:#2d5a270a}.cal-booking-cell{padding:4px 2px}.cal-booking-bar{display:flex;align-items:center;padding:0 8px;height:32px;border-radius:4px;color:#fff;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all var(--transition-fast);box-shadow:0 1px 2px #0000001f}.cal-booking-bar:hover{filter:brightness(1.1);box-shadow:0 2px 6px #0003;transform:scaleY(1.05)}.cal-block-bar{display:flex;align-items:center;justify-content:center;padding:0 8px;height:32px;border-radius:4px;background:#374151;color:#9ca3af;font-size:11px;font-weight:600;white-space:nowrap;letter-spacing:.3px}.cal-popup{position:fixed;z-index:100;background:var(--color-bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);min-width:200px;animation:calPopupIn .15s ease-out}@keyframes calPopupIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.cal-popup-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);font-size:var(--font-sm)}.cal-popup-header strong{flex:1}.cal-popup-close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-muted)}.cal-popup-close:hover{background:var(--color-bg);color:var(--color-text)}.cal-popup-body{padding:var(--space-3) var(--space-4)}.cal-popup-guest-icon{font-size:1rem}.cal-rate-popup{min-width:200px;max-width:260px}.cal-rate-table{width:100%;border-collapse:collapse}.cal-rate-table td{padding:3px 0;font-size:var(--font-sm);color:var(--color-text);border:none}.cal-booking-popup{min-width:380px;max-width:440px}.cal-popup-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.cal-popup-col{display:flex;flex-direction:column;gap:var(--space-2)}.cal-popup-field{display:flex;flex-direction:column}.cal-popup-label{font-size:10px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px;display:flex;align-items:center;gap:4px}.cal-popup-value{font-size:var(--font-sm);color:var(--color-text);font-weight:500}.cal-popup-footer{margin-top:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border-light)}@media(max-width:768px){.cal-toolbar{flex-direction:column;align-items:stretch}.cal-toolbar-left,.cal-toolbar-right{justify-content:space-between}.cal-booking-popup{min-width:300px;max-width:340px}.cal-popup-grid{grid-template-columns:1fr}}
