:root{--bg:#f4f7f6;--surface:#fff;--border:#dce3e1;--text-strong:#111827;--text:#374151;--text-muted:#6b7280;--green:#0f9f6e;--amber:#f59e0b;--red:#dc2626;--blue:#2563eb;--sans:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;color:var(--text);background:var(--bg);font:15px/1.45 var(--sans);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{background:var(--bg)}body{min-width:320px;min-height:100vh;margin:0}#root{min-height:100vh}.app-shell{background:var(--bg);grid-template-columns:248px minmax(0,1fr);min-height:100vh;display:grid}.login-shell{background:radial-gradient(circle at 15% 20%, #0f9f6e1f, transparent 28%), radial-gradient(circle at 85% 80%, #f59e0b1f, transparent 26%), var(--bg);place-items:center;min-height:100vh;padding:20px;display:grid}.login-card{border:1px solid var(--border);background:var(--surface);border-radius:8px;width:min(420px,100%);padding:22px;box-shadow:0 24px 70px #1118271f}.login-brand{border-bottom-color:var(--border);padding-bottom:16px}.login-brand strong{color:var(--text-strong)}.login-copy{margin:20px 0}.login-copy h1{color:var(--text-strong);margin:0;font-size:26px;line-height:1.1}.login-copy p{color:var(--text-muted);margin:8px 0 0;font-size:14px}.login-form{gap:13px;display:grid}.login-form label{color:var(--text-strong);gap:7px;font-size:12px;font-weight:900;display:grid}.login-form input{border:1px solid var(--border);width:100%;min-height:44px;color:var(--text-strong);background:#fff;border-radius:8px;padding:0 12px;font-size:14px;font-weight:700}.login-error{color:#b91c1c;background:#fff1f2;border:1px solid #fecaca;border-radius:8px;margin:0;padding:10px 12px;font-size:13px;font-weight:800}.sidebar{color:#d1d5db;background:#111827;flex-direction:column;gap:20px;height:100vh;padding:22px 16px;display:flex;position:sticky;top:0}.brand{border-bottom:1px solid #ffffff1a;align-items:center;gap:12px;padding-bottom:16px;display:flex}.brand-mark,.metric-icon,.avatar,.insight-icon{place-items:center;display:grid}.brand-mark{color:#fff;background:var(--green);border-radius:8px;width:40px;height:40px}.brand strong,.brand span,.sidebar-summary span,.sidebar-summary small,.metric-card span,.metric-card small,.appointment-main strong,.appointment-main span,.client-block strong,.client-block span,.plan-card strong,.plan-card span,.plan-card small,.insight strong,.insight span{display:block}.brand strong{color:#fff;font-size:17px;line-height:1.1}.brand span,.sidebar-summary span,.sidebar-summary small{color:#9ca3af;font-size:12px}.sidebar nav{gap:5px;display:grid}.nav-item{color:#cbd5e1;width:100%;min-height:42px;font:700 13px/1 var(--sans);text-align:left;cursor:pointer;background:0 0;border:0;border-radius:8px;align-items:center;gap:11px;padding:0 11px;display:flex}.nav-item:hover,.nav-item.active{color:#fff;background:#ffffff1a}.sidebar-summary{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;margin-top:auto;padding:14px}.sidebar-summary strong{color:#fff;margin:6px 0;font-size:24px;line-height:1;display:block}.workspace{min-width:0;padding:22px}.topbar{justify-content:space-between;align-items:center;gap:20px;margin-bottom:16px;display:flex}.topbar h1{color:var(--text-strong);margin:0;font-size:26px;line-height:1.1}.topbar p{color:var(--text-muted);margin:5px 0 0;font-size:13px}.topbar-actions{align-items:center;gap:10px;display:flex}.search-box{border:1px solid var(--border);background:var(--surface);width:min(330px,30vw);min-height:40px;color:var(--text-muted);border-radius:8px;align-items:center;gap:8px;padding:0 11px;display:flex}.search-box input{width:100%;min-width:0;color:var(--text-strong);font:600 13px/1 var(--sans);background:0 0;border:0;outline:0}button,input,select{font-family:var(--sans)}button{transition:transform .14s,border-color .14s,background .14s,color .14s}button:active{transform:translateY(1px)}button:focus-visible,input:focus-visible,select:focus-visible{outline-offset:2px;outline:2px solid #0f9f6e6b}.primary-button,.secondary-button,.ghost-button,.danger-button,.icon-button,.mobile-menu{cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:40px;font-size:13px;font-weight:800;display:inline-flex}.primary-button{color:#fff;background:var(--green);border:1px solid #0f8f64;padding:0 14px;box-shadow:0 10px 22px #0f9f6e29}.secondary-button{color:#7c4a03;background:#fff6df;border:1px solid #f3c15b;padding:0 14px}.ghost-button,.icon-button,.mobile-menu{border:1px solid var(--border);color:var(--text-strong);background:var(--surface);padding:0 12px}.danger-button{color:#b91c1c;background:#fff1f2;border:1px solid #fecaca;padding:0 12px}.icon-button,.mobile-menu,.icon-only{width:40px;padding:0}.mobile-menu,.mobile-view-tabs,.bottom-nav{display:none}.desktop-only{display:inline-flex}.full{width:100%}.slim{min-height:34px}.command-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px;display:grid}.metric-card{border:1px solid var(--border);background:var(--surface);border-radius:8px;min-height:112px;padding:15px;position:relative;overflow:hidden}.metric-card:after{content:"";opacity:.12;border-radius:50%;width:88px;height:88px;position:absolute;bottom:-26px;right:-22px}.metric-card.green:after{background:var(--green)}.metric-card.amber:after{background:var(--amber)}.metric-card.red:after{background:var(--red)}.metric-card.blue:after{background:var(--blue)}.metric-icon{color:#111827;background:#f3f4f6;border-radius:8px;width:34px;height:34px;margin-bottom:12px}.metric-card span,.metric-card small{color:var(--text-muted);font-size:12px}.metric-card strong{color:var(--text-strong);margin:4px 0;font-size:25px;line-height:1;display:block}.view{display:none}.view.active{display:block}.two-column,.dashboard-grid{grid-template-columns:minmax(0,1.45fr) minmax(330px,.7fr);align-items:start;gap:16px;display:grid}.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.wide{grid-column:1/-1}.panel{border:1px solid var(--border);background:var(--surface);border-radius:8px;min-width:0;padding:16px}.panel-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.panel-header h2{color:var(--text-strong);margin:0;font-size:17px;line-height:1.2}.panel-header p{color:var(--text-muted);margin:3px 0 0;font-size:12px}.filters{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.filters select,.appointment-form select,.appointment-form input,.settings-grid select{border:1px solid var(--border);background:var(--surface);min-height:40px;color:var(--text-strong);border-radius:8px;padding:0 10px;font-size:13px;font-weight:700}.segmented-control{border:1px solid var(--border);background:#f8fafc;border-radius:8px;grid-auto-flow:column;gap:3px;padding:3px;display:inline-grid}.segmented-control button{min-height:31px;color:var(--text-muted);cursor:pointer;background:0 0;border:0;border-radius:6px;padding:0 11px;font-size:12px;font-weight:900}.segmented-control button.selected{color:#fff;background:#111827}.appointment-list,.compact-list,.plans-list,.payment-bars,.insight-list,.phase-list{gap:8px;display:grid}.appointment-row{border:1px solid var(--border);width:100%;min-height:74px;color:var(--text-strong);text-align:left;cursor:pointer;background:#fff;border-radius:8px;grid-template-columns:58px minmax(0,1fr) auto 90px;align-items:center;gap:12px;padding:10px 12px;display:grid}.appointment-row:hover,.appointment-row.selected{background:#f6fffb;border-color:#0f9f6e7a}.appointment-row time{color:#111827;font-size:13px;font-weight:900}.appointment-main{min-width:0}.appointment-main strong,.appointment-main span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.appointment-main strong{font-size:14px}.appointment-main span{color:var(--text-muted);margin-top:4px;font-size:12px}.row-status{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.row-money{text-align:right}.row-money strong,.row-money span{display:block}.row-money strong{color:var(--text-strong);font-size:13px}.row-money span{color:var(--text-muted);font-size:11px}.status-chip{color:#3730a3;white-space:nowrap;background:#eef2ff;border-radius:999px;justify-content:center;align-items:center;min-height:26px;padding:0 9px;font-size:11px;font-weight:900;display:inline-flex}.status-chip.compact{min-width:72px}.status-chip.en-silla,.status-chip.confirmado{color:#047857;background:#ecfdf5}.status-chip.pagado{color:#166534;background:#dcfce7}.status-chip.pendiente,.status-chip.parcial{color:#c2410c;background:#fff7ed}.status-chip.cancelado{color:#b91c1c;background:#fee2e2}.selected-detail{gap:14px;display:grid}.client-block,.risk-card{background:#f8fafc;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:14px;display:flex}.avatar{color:#fff;background:#111827;border-radius:8px;flex:none;width:44px;height:44px;font-weight:900}.avatar.small{border-radius:8px;width:34px;height:34px;font-size:12px}.client-block>div:last-child{flex:1;min-width:0}.client-block strong,.risk-card strong{color:var(--text-strong);font-size:15px}.client-block span,.risk-card span{color:var(--text-muted);font-size:12px}.detail-list{gap:10px;margin:0;display:grid}.detail-list>div{border-bottom:1px solid var(--border);padding-bottom:10px}.detail-list>div:last-child{border-bottom:0}.detail-list dt{color:var(--text-muted);text-transform:uppercase;margin-bottom:5px;font-size:11px;font-weight:900}.detail-list dd{color:var(--text-strong);margin:0;font-size:13px;line-height:1.45}.payment-detail{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.action-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.money-row,.client-row,.staff-row,.inventory-row,.phase-row{border:1px solid var(--border);background:#fff;border-radius:8px;align-items:center;gap:10px;min-height:58px;padding:10px;display:grid}.money-row{grid-template-columns:minmax(0,1fr) auto}.client-row,.staff-row{grid-template-columns:34px minmax(0,1fr) auto}.inventory-row{grid-template-columns:18px minmax(0,1fr) auto}.inventory-row svg{color:var(--green)}.money-row strong,.client-row strong,.staff-row strong,.inventory-row strong,.phase-row strong{color:var(--text-strong);font-size:13px}.money-row span,.client-row span,.staff-row span,.inventory-row span{color:var(--text-muted);margin-top:3px;font-size:12px;display:block}.cash-close{background:#f8fafc;border-radius:8px;gap:8px;padding:14px;display:grid}.cash-close strong{color:var(--text-strong);font-size:32px;line-height:1}.cash-close span{color:var(--text-muted);font-size:13px}.payment-line{grid-template-columns:92px minmax(0,1fr) 72px;align-items:center;gap:10px;min-height:36px;display:grid}.payment-line span,.payment-line strong{color:var(--text-strong);font-size:12px;font-weight:800}.payment-line strong{text-align:right}.bar-track{background:#edf2f7;border-radius:999px;height:9px;overflow:hidden}.bar-track div{border-radius:inherit;background:linear-gradient(90deg, var(--green), var(--amber));height:100%}.plans-list.cards{grid-template-columns:repeat(3,minmax(0,1fr))}.plan-card{border:1px solid var(--border);text-align:left;cursor:pointer;background:#fff;border-radius:8px;align-content:space-between;gap:10px;min-height:150px;padding:14px;display:grid}.plan-card.active{background:#f6fffb;border-color:#0f9f6e80}.plan-card>strong{color:var(--text-strong);font-size:26px}.plan-card span,.plan-card small{color:var(--text-muted);font-size:12px}.insight-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.insight{border:1px solid var(--border);background:#fff;border-radius:8px;align-items:flex-start;gap:10px;min-height:72px;padding:12px;display:flex}.insight-icon{color:#047857;background:#ecfdf5;border-radius:8px;flex:none;width:34px;height:34px}.insight strong{color:var(--text-strong);font-size:13px}.insight span{color:var(--text-muted);margin-top:4px;font-size:12px;line-height:1.35}.row-actions{gap:6px;display:flex}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px;display:grid}.settings-grid label{color:var(--text-strong);gap:7px;font-size:12px;font-weight:900;display:grid}.phase-row{grid-template-columns:28px minmax(0,1fr)}.phase-row span{color:#fff;background:#111827;border-radius:8px;place-items:center;width:28px;height:28px;font-size:12px;font-weight:900;display:grid}.drawer-backdrop{z-index:30;background:#11182761;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer{background:var(--surface);width:min(420px,100%);height:100%;padding:20px;overflow-y:auto;box-shadow:-24px 0 60px #11182733}.drawer-header{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px;display:flex}.drawer-header h2{color:var(--text-strong);margin:0;font-size:20px}.drawer-header p{color:var(--text-muted);margin:5px 0 0;font-size:13px}.appointment-form{gap:13px;display:grid}.appointment-form label{color:var(--text-strong);gap:7px;font-size:12px;font-weight:900;display:grid}.appointment-form input,.appointment-form select{width:100%}@media (width<=1180px){.app-shell{grid-template-columns:82px minmax(0,1fr)}.sidebar{padding-inline:12px}.brand{justify-content:center}.brand>div:last-child,.nav-item{font-size:0}.nav-item{justify-content:center;padding:0}.sidebar-summary{display:none}.command-strip,.insight-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.two-column{grid-template-columns:1fr}}@media (width<=820px){.app-shell{display:block}.sidebar{display:none}.workspace{padding:14px 14px 88px}.mobile-menu,.mobile-view-tabs{display:inline-flex}.topbar{flex-wrap:wrap;align-items:flex-start;gap:12px;margin-bottom:12px}.topbar h1{font-size:22px}.topbar-actions{grid-template-columns:1fr 40px;width:100%;display:grid}.desktop-only{display:none}.topbar-actions .primary-button{grid-column:1/-1;min-height:44px}.search-box{width:100%}.command-strip{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.metric-card{min-height:104px;padding:12px}.metric-icon{width:30px;height:30px;margin-bottom:10px}.metric-card strong{font-size:22px}.mobile-view-tabs{border:1px solid var(--border);background:#fff;border-radius:8px;gap:6px;width:100%;margin-bottom:12px;padding:4px;overflow-x:auto}.mobile-view-tabs button{min-height:34px;color:var(--text-muted);background:0 0;border:0;border-radius:6px;flex:1 0 auto;padding:0 10px;font-size:12px;font-weight:900;transition:none}.mobile-view-tabs button.selected{color:#fff;background:#111827}.two-column,.dashboard-grid,.plans-list.cards,.insight-grid{grid-template-columns:1fr}.panel{padding:14px}.filters{flex-direction:column;align-items:stretch}.segmented-control{grid-auto-flow:initial;grid-template-columns:repeat(4,minmax(0,1fr))}.appointment-row{grid-template-columns:50px minmax(0,1fr);align-items:start;min-height:96px}.row-status,.row-money{text-align:left;grid-column:2;justify-content:flex-start}.row-money{gap:8px;display:flex}.client-block,.risk-card{align-items:flex-start}.risk-card{flex-direction:column}.action-grid{grid-template-columns:1fr}.action-grid button,.money-row button{min-height:44px}.payment-line{grid-template-columns:82px minmax(0,1fr) 64px}.settings-grid{grid-template-columns:1fr}.bottom-nav{z-index:25;padding:8px 8px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff5;grid-template-columns:repeat(5,minmax(0,1fr));display:grid;position:fixed;bottom:0;left:0;right:0}.bottom-nav button{min-height:50px;color:var(--text-muted);background:0 0;border:0;border-radius:8px;place-items:center;gap:4px;font-size:11px;font-weight:900;transition:none;display:grid}.bottom-nav button.active{color:#047857;background:#ecfdf5}}
