@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.sidebar__hamburger{z-index:300;background:var(--nav-bg);cursor:pointer;border:none;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:38px;height:38px;padding:0;display:none;position:fixed;top:14px;left:14px}.sidebar__hamburger span{background:#fffc;border-radius:2px;width:18px;height:2px;display:block}.sidebar__overlay{z-index:199;background:#00000080;display:none;position:fixed;inset:0}.sidebar{width:var(--sidebar-w);background:var(--nav-bg);z-index:200;flex-direction:column;height:100vh;transition:transform .25s;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:2px}.sidebar__brand{border-bottom:1px solid #ffffff12;padding:20px 18px 16px}.sidebar__brand a{text-decoration:none;display:block}.sidebar__brand img{width:auto;height:32px;display:block}.sidebar__nav{flex:1;padding:12px 0;list-style:none}.sidebar__group-label{letter-spacing:.8px;text-transform:uppercase;color:#ffffff4d;-webkit-user-select:none;user-select:none;padding:14px 18px 4px;font-size:10px;font-weight:700}.sidebar__nav li a,.sidebar__nav li .nav-link-btn{color:#ffffffa6;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:0;align-items:center;gap:9px;width:100%;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:400;text-decoration:none;transition:background .12s,color .12s;display:flex}.sidebar__nav li a:hover,.sidebar__nav li .nav-link-btn:hover{color:#fff;background:#ffffff12;text-decoration:none}.sidebar__nav li a.is-active{color:#fff;background:#16a34a40;font-weight:600}.sidebar__nav li{position:relative}.sidebar__nav li a.is-active:before{content:"";background:var(--primary);border-radius:0 2px 2px 0;width:3px;position:absolute;top:4px;bottom:4px;left:0}.sidebar__nav .nav-icon{opacity:.7;flex-shrink:0;width:15px;height:15px}.sidebar__nav li a.is-active .nav-icon{opacity:1}.sidebar__footer{border-top:1px solid #ffffff12;justify-content:space-between;align-items:center;gap:8px;padding:14px 18px;display:flex}.sidebar__username{color:#fff9;text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.sidebar__logout{color:#ffffff80;cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:4px;flex-shrink:0;padding:3px 9px;font-family:inherit;font-size:11px;transition:background .15s,color .15s}.sidebar__logout:hover{color:#fff;background:#ffffff1a;border-color:#ffffff4d}@media (width<=768px){.sidebar__hamburger{display:flex}.sidebar__overlay{display:block}.sidebar{transform:translate(-100%)}.sidebar--open{transform:translate(0)}}:root{--primary:#16a34a;--primary-dark:#15803d;--primary-light:#dcfce7;--primary-xlight:#f0fdf4;--nav-bg:#0f2b1e;--nav-h:58px;--sidebar-w:220px;--bg:#f7f9f7;--card-bg:#fff;--text:#111827;--text-muted:#6b7280;--border:#e5e7eb;--border-light:#f0fdf4;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--info:#0284c7;--radius:10px;--radius-sm:6px;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow:0 4px 12px #00000014;--shadow-lg:0 10px 30px #0000001f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.6}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-dark);text-decoration:underline}.main-content{margin-left:var(--sidebar-w);max-width:1320px;width:calc(100% - var(--sidebar-w));min-height:100vh;padding:28px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h1{color:var(--text);letter-spacing:-.3px;font-size:22px;font-weight:700}.card{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:22px}.card--interactive{cursor:pointer;transition:box-shadow .2s,transform .15s}.card--interactive:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.card--table{padding:0}.card h2{color:var(--text);border-bottom:1px solid var(--border);letter-spacing:.1px;margin-bottom:16px;padding-bottom:10px;font-size:14px;font-weight:600}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin-bottom:20px;display:grid}.kpi-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px;position:relative;overflow:hidden}.kpi-card:after{content:"";background:var(--primary-light);border-radius:var(--radius) var(--radius) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.kpi-card.kpi-highlight:after{background:var(--primary)}.kpi-card.kpi-warning:after{background:var(--warning)}.kpi-card.kpi-danger:after{background:var(--danger)}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;font-size:11px;font-weight:600}.kpi-value{color:var(--text);letter-spacing:-.5px;font-size:24px;font-weight:700}.kpi-sub{color:var(--text-muted);margin-top:2px;font-size:11px}.dashboard-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}@media (width<=900px){.dashboard-row{grid-template-columns:1fr}}@media (width<=768px){.main-content{width:100%;margin-left:0;padding:64px 16px 24px}.page-header{flex-direction:column;align-items:flex-start}.page-header h1{font-size:18px}.card{padding:16px}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:500;line-height:1.4;transition:all .15s;display:inline-flex;text-decoration:none!important}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 1px 3px #16a34a4d}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff;box-shadow:0 2px 6px #16a34a59}.btn-secondary{color:#374151;border-color:var(--border);background:#fff}.btn-secondary:hover{background:var(--bg);color:var(--text)}.btn-ghost{color:var(--primary);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--primary-light)}.btn-danger{color:var(--danger);background:#fff;border-color:#fca5a5}.btn-danger:hover{background:#fef2f2}.btn-sm{border-radius:5px;padding:4px 11px;font-size:12px}.btn-lg{padding:11px 24px;font-size:14px}.form-group{flex-direction:column;gap:5px;min-width:140px;display:flex}.form-group label{color:#374151;letter-spacing:.1px;font-size:12px;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:#fff;width:100%;padding:8px 11px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #16a34a1f}.form-group textarea{resize:vertical;min-height:70px}.form-row{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:14px;display:flex}.form-group-wide{flex:1;min-width:280px}.table-full{border-collapse:collapse;width:100%;font-size:13px}.table-full thead th{background:var(--primary-xlight);text-align:left;color:#15803d;border-bottom:1px solid var(--primary-light);letter-spacing:.4px;text-transform:uppercase;padding:9px 12px;font-size:11px;font-weight:600}.table-full tbody td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px 12px}.table-full tbody tr:hover{background:var(--primary-xlight)}.table-full tbody tr:last-child td{border-bottom:none}.badge{color:#6b7280;white-space:nowrap;background:#f3f4f6;border-radius:20px;align-items:center;padding:2px 9px;font-size:11px;font-weight:600;display:inline-flex}.badge-activo{color:#15803d;background:#dcfce7}.badge-cotizado{color:#1d4ed8;background:#dbeafe}.badge-terminado{color:#6d28d9;background:#ede9fe}.badge-cobrado{color:#15803d;background:#dcfce7}.badge-pausado{color:#b45309;background:#fef3c7}.alert{border-radius:var(--radius-sm);align-items:center;gap:8px;margin-bottom:16px;padding:11px 16px;font-size:13px;font-weight:500;display:flex}.alert-success{color:#15803d;background:#dcfce7;border:1px solid #bbf7d0}.alert-warning{color:#b45309;background:#fef3c7;border:1px solid #fde68a}.alert-error{color:#b91c1c;background:#fee2e2;border:1px solid #fca5a5}.alert-info{color:#1d4ed8;background:#dbeafe;border:1px solid #bfdbfe}.empty-state{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:13px}.empty-state svg{opacity:.3;width:40px;height:40px;margin-bottom:10px}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.login-page{background:linear-gradient(135deg,#0f2b1e 0%,#15803d 60%,#16a34a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-box{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px 40px 44px;box-shadow:0 20px 60px #00000040}.login-subtitle{text-align:center;color:var(--text-muted);margin-bottom:28px;font-size:13px}.login-box .form-group{margin-bottom:14px}.modal-backdrop{z-index:500;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-box{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;padding:24px;animation:.15s ease-out modal-in;overflow-y:auto}.modal-box-lg{max-width:720px}@keyframes modal-in{0%{opacity:0;transform:scale(.97)translateY(-8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.modal-header h3{font-size:16px;font-weight:700}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:4px 6px;font-size:16px;line-height:1}.modal-close:hover{background:var(--border);color:var(--text)}.tab-bar{border-bottom:1px solid var(--border);gap:2px;margin-bottom:20px;display:flex}.tab-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:color .15s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.progress-bar{background:var(--border);border-radius:3px;height:6px;margin-top:6px;overflow:hidden}.progress-bar__fill{background:var(--primary);border-radius:3px;height:100%;transition:width .3s}.progress-bar__fill.over{background:var(--warning)}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:16px;display:grid}.stat-box{background:var(--primary-xlight);border-radius:var(--radius-sm);padding:12px 14px}.stat-box .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.stat-box .value{color:var(--text);margin-top:2px;font-size:18px;font-weight:700}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}.breadcrumb{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:18px;font-size:13px;display:flex}.breadcrumb a{color:var(--text-muted);text-decoration:none;transition:color .12s}.breadcrumb a:hover{color:var(--primary);text-decoration:none}.breadcrumb__sep{color:var(--border);font-size:16px;line-height:1}.breadcrumb__current{color:var(--text);font-weight:500}.row-menu{display:inline-block;position:relative}.row-menu__trigger{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;padding:3px 8px;font-size:16px;line-height:1;transition:background .12s,border-color .12s}.row-menu__trigger:hover{background:var(--bg);border-color:var(--border);color:var(--text)}.row-menu__dropdown{border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);z-index:300;background:#fff;min-width:140px;animation:.1s ease-out dd-open;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden}@keyframes dd-open{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.row-menu__item{text-align:left;cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;padding:9px 14px;font-family:inherit;font-size:13px;text-decoration:none;transition:background .1s;display:block}.row-menu__item:hover{background:var(--bg);text-decoration:none}.row-menu__item--danger{color:var(--danger)}.row-menu__item--danger:hover{background:#fef2f2}.row-menu__divider{background:var(--border);height:1px;margin:2px 0}.empty-cta{color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:48px 24px;display:flex}.empty-cta svg{opacity:.25;width:40px;height:40px}.empty-cta p{margin:0;font-size:13px}
