/* ERP base + launcher estilo Treinta */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;height:100%}
body.treinta-ui{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}
.layout-treinta{display:flex;min-height:100vh}
.layout-treinta .main{flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}
.layout-treinta .main > .content{flex:1}
.appfooter{margin-top:auto;flex-shrink:0}
.sidebar{position:fixed;inset:0 auto 0 0;height:100vh;display:flex;flex-direction:column;z-index:45}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:44}
.sidebar-overlay.open{display:block}
.alert{padding:12px 16px;border-radius:10px;margin-bottom:12px;font-size:14px}
.alert-success{background:#ecfdf5;border:1px solid #6ee7b7;color:#065f46}
.alert-danger{background:#fef2f2;border:1px solid #fca5a5;color:#991b1b}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:var(--surface);font:inherit;font-weight:600;cursor:pointer}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dark);border-color:var(--accent-dark);color:#fff}
.btn-accent{background:var(--primary);border-color:var(--primary-dark);color:#fff}
.btn-sm{padding:6px 12px;font-size:13px}
.btn-icon{border:none;background:transparent;font-size:20px;cursor:pointer;padding:6px;border-radius:8px}

/* Home / launcher */
.content-home{padding:16px 20px 24px!important}

/* Dashboard — panel de datos */
.dash-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.dash-title{margin:0;font-size:24px;font-weight:800;color:var(--treinta-text)}
.dash-sub{margin:4px 0 0;font-size:13px;color:var(--text-soft)}
.dash-quick{display:flex;gap:8px;flex-wrap:wrap}
.dash-section{margin-bottom:22px}
.dash-section-title{margin:0 0 10px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft)}
.dash-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.dash-kpi-grid--4{grid-template-columns:repeat(4,1fr)}
.kpi-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 16px 14px;box-shadow:var(--shadow);min-height:100px}
.kpi-card small{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft);font-weight:700;margin-top:4px}
.kpi-card strong{display:block;font-size:22px;font-weight:800;margin-top:6px;color:var(--treinta-text);line-height:1.2}
.kpi-card strong.kpi-dual{font-size:18px;margin-top:4px;color:var(--text-soft)}
.kpi-card .kpi-meta{display:block;font-size:12px;color:var(--text-soft);margin-top:6px;font-weight:600}
.kpi-card .kpi-icon{position:absolute;top:14px;right:14px;font-size:22px;opacity:.85}
.kpi-card--primary{border-color:color-mix(in srgb,var(--primary) 45%,var(--border));background:linear-gradient(135deg,var(--surface),var(--primary-soft))}
.kpi-card--in{border-left:4px solid #22c55e}
.kpi-card--out{border-left:4px solid #f59e0b}
.kpi-card--warn{border-left:4px solid #eab308}
.kpi-card--danger{border-left:4px solid #ef4444}
.dash-alert{margin-top:12px;padding:12px 16px;border-radius:10px;background:#fffbeb;border:1px solid #fde68a;font-size:14px;color:#92400e}
.dash-alert a{margin-left:8px;font-weight:700;color:var(--accent)}
.dash-panels{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
.dash-panel{padding:0;overflow:hidden}
.dash-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}
.dash-panel-head h3{margin:0;font-size:15px;font-weight:800}
.dash-panel-head a{font-size:13px;font-weight:700;color:var(--accent)}
.dash-empty{padding:28px 16px;text-align:center;color:var(--text-soft);font-size:14px;margin:0}
.dash-empty a{font-weight:700;color:var(--accent)}

.home-quickstats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px}
.home-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.home-stat small{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft);font-weight:600}
.home-stat strong{display:block;font-size:22px;font-weight:800;margin-top:4px}
.modules-grid-6{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;width:100%}
.module-tile{aspect-ratio:1;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:10px 8px;background:var(--surface);border:1px solid var(--border);text-align:center;box-shadow:var(--shadow);transition:transform .15s,border-color .15s,box-shadow .15s}
.module-tile:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--primary) 40%,var(--border));box-shadow:0 8px 24px rgba(0,0,0,.08)}
.module-tile-icon{font-size:28px;line-height:1}
.module-tile-name{font-size:12px;font-weight:700;line-height:1.2;color:var(--text)}
.launcher-col-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);margin:0 0 8px;padding:0 4px}
.launcher-board{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.launcher-col{display:flex;flex-direction:column;gap:8px;min-width:0}

/* Platform hub — selector de empresas */
body.platform-hub{background:linear-gradient(165deg,#eef2f9 0%,#e8edf8 45%,#fff7ed 100%);min-height:100vh}
[data-theme="dark"].platform-hub,[data-theme="dark"] body.platform-hub{background:linear-gradient(165deg,#0b1220,#151f32 55%,#1a2538)}
.platform-shell{min-height:100vh;display:flex;flex-direction:column}
.platform-top{padding:20px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.platform-logo{display:flex;align-items:center;gap:12px}
.platform-logo-img{height:44px;width:auto;max-width:180px;object-fit:contain;display:block}
.platform-logo-mark{width:44px;height:44px;border-radius:12px;background:var(--brand-gradient);color:#fff;display:grid;place-items:center;font-weight:900;font-size:22px}
.platform-logo h1{margin:0;font-size:22px;font-weight:800;color:var(--accent-dark)}
[data-theme="dark"] .platform-logo h1{color:var(--text)}
.platform-logo p{margin:2px 0 0;font-size:13px;color:var(--text-soft)}
.platform-user{display:flex;align-items:center;gap:12px}
.platform-main{flex:1;padding:20px 28px 40px;max-width:1100px;margin:0 auto;width:100%}
.platform-hub .platform-top{position:relative;justify-content:center}
.platform-hub .platform-logo{flex-direction:column;align-items:center;text-align:center}
.platform-hub .platform-user{position:absolute;right:28px;top:50%;transform:translateY(-50%)}
.platform-head{margin-bottom:28px}
.platform-hub .platform-head{text-align:center}
.platform-head h2{margin:0 0 6px;font-size:28px;font-weight:800}
.platform-head p{margin:0;color:var(--text-soft);font-size:15px}
.company-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.company-card{display:flex;flex-direction:column;gap:14px;padding:24px;border-radius:16px;background:var(--surface);border:2px solid var(--border);box-shadow:var(--shadow);transition:transform .2s,border-color .2s,box-shadow .2s;color:var(--text)}
.platform-hub .company-card{align-items:center;text-align:center}
.company-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.1)}
.company-card-icon{width:64px;height:64px;border-radius:16px;display:grid;place-items:center;font-size:32px;flex-shrink:0}
.company-card h3{margin:0;font-size:20px;font-weight:800}
.company-card p{margin:0;font-size:14px;color:var(--text-soft);line-height:1.45;flex:1}
.company-card-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;color:var(--accent)}
.company-card--multicell{border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}
.company-card--multicell .company-card-icon{background:var(--accent-soft)}
.company-card--rotulaciones{border-color:color-mix(in srgb,var(--primary) 40%,var(--border))}
.company-card--rotulaciones .company-card-icon{background:var(--primary-soft)}
.company-card--generic{border-color:color-mix(in srgb,#64748b 30%,var(--border));background:linear-gradient(180deg,var(--surface) 0%,color-mix(in srgb,#f8fafc 80%,var(--surface)) 100%)}
.company-card--generic .company-card-icon{background:rgba(100,116,139,.12);font-size:28px}
.company-card--locked{opacity:.72;cursor:not-allowed;pointer-events:none;filter:grayscale(.25)}
.company-card-cta--locked{background:#e5e7eb;color:#6b7280}
.company-card-logo{width:48px;height:48px;object-fit:contain;border-radius:12px}

.settings-branding-preview{display:flex;align-items:center;gap:14px;padding:14px;border:1px dashed var(--border);border-radius:12px;margin-bottom:16px;background:var(--surface)}
.settings-branding-logo{width:56px;height:56px;object-fit:contain;border-radius:10px;background:#fff}
.settings-branding-mark{width:56px;height:56px;border-radius:10px;background:var(--tenant-accent,#1d4ed8);color:#fff;display:grid;place-items:center;font-weight:800;font-size:20px}
.company-card--generic p{font-size:15px;color:var(--text)}
.platform-admin{margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}
.platform-hub .platform-admin{text-align:center}
.platform-admin h3{font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);margin:0 0 12px}
.platform-admin-links{display:flex;flex-wrap:wrap;gap:10px}
.platform-hub .platform-admin-links{justify-content:center}
.platform-admin-links a{padding:8px 14px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);font-size:13px;font-weight:600}

.data-table-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}
.data-table{width:100%;border-collapse:collapse;font-size:14px}
.data-table th,.data-table td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left}
.data-table th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft);background:var(--surface-2)}
.coming-soon{text-align:center;padding:48px 20px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius)}
.page-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.page-toolbar h2{margin:0;font-size:20px;font-weight:800}
.badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;background:var(--primary-soft);color:var(--primary-dark)}
.settings-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px;box-shadow:var(--shadow)}
.settings-panel h3{margin:0 0 8px;font-size:18px;font-weight:800}
.settings-lead{margin:0 0 20px;color:var(--text-soft);font-size:14px;line-height:1.5}
.settings-currency-badges{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0}
.settings-tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;max-width:920px}
.settings-tool-card{border:1px solid var(--border);border-radius:14px;padding:20px;background:var(--surface)}
.settings-tool-card h4{margin:8px 0;font-size:16px;font-weight:800}
.settings-tool-card p{margin:0 0 16px;font-size:13px;color:var(--text-soft);line-height:1.5}
.settings-tool-icon{font-size:28px;line-height:1}
.settings-tool-card--danger{border-color:#fecaca;background:linear-gradient(180deg,#fff,#fff5f5)}
.settings-confirm-label{display:block;font-size:12px;font-weight:700;margin-bottom:6px;color:#991b1b}
.settings-confirm-input{max-width:220px;margin-bottom:12px}
.settings-tools-result{margin-top:16px;padding:12px 14px;border-radius:10px;font-size:14px;font-weight:600;max-width:720px}
.settings-tools-result.is-ok{background:#ecfdf5;color:#166534;border:1px solid #bbf7d0}
.settings-tools-result.is-err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
.btn-danger{background:#dc2626;color:#fff;border:none;padding:10px 16px;border-radius:10px;font:inherit;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center}
.btn-danger:hover{background:#b91c1c;color:#fff}
.cash-panel{margin-bottom:20px}
.cash-panel--open{border-color:color-mix(in srgb,var(--primary) 35%,var(--border));background:linear-gradient(180deg,var(--surface),var(--primary-soft))}
.cash-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:0 0 18px}
.cash-stat{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px}
.cash-stat span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft);font-weight:700}
.cash-stat strong{display:block;font-size:20px;font-weight:800;margin-top:6px}
.cash-stat--highlight{border-color:color-mix(in srgb,var(--accent) 40%,var(--border));background:var(--accent-soft)}
.cash-close-form{max-width:640px}
@media(max-width:700px){.cash-summary-grid{grid-template-columns:1fr}}
.btn-danger:disabled{opacity:.45;cursor:not-allowed}
.status{display:inline-block;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px}
.status-ok{background:#ecfdf5;color:#065f46}
.status-off{background:#f3f4f6;color:#6b7280}
.status-warn{background:#fffbeb;color:#92400e}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.stat-card span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft);font-weight:600}
.stat-card strong{display:block;font-size:22px;font-weight:800;margin-top:4px}

@media(max-width:1100px){
  .modules-grid-6,.launcher-board{grid-template-columns:repeat(3,1fr)}
  .dash-kpi-grid,.dash-kpi-grid--4{grid-template-columns:repeat(2,1fr)}
  .dash-panels{grid-template-columns:1fr}
}
.dash-section-first{margin-top:0}
.libre-wrap{max-width:640px;margin:0 auto;padding:8px 0 24px}
.libre-card{padding:24px!important}
.libre-title{margin:0 0 8px;font-size:22px;font-weight:800}
.libre-desc{margin:0 0 20px;color:var(--text-soft);font-size:14px;line-height:1.5}
.appfooter{padding:10px 20px;text-align:center;color:var(--text-soft);font-size:12px;border-top:1px solid var(--border);background:var(--surface)}

/* Botones Treinta */
.btn-treinta{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:10px;font:inherit;font-size:14px;font-weight:700;text-decoration:none;border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:background .15s,transform .1s}
.btn-treinta--dark{background:var(--accent);color:#fff;border-color:var(--accent);padding:11px 20px;font-size:14px;border-radius:10px}
.btn-treinta--dark:hover{background:var(--accent-dark);color:#fff;border-color:var(--accent-dark)}
.btn-treinta--green{background:var(--primary);color:#fff;border-color:var(--primary-dark)}
.btn-treinta--green:hover{background:var(--primary-dark);color:#fff}
.btn-treinta--red{background:#dc2626;color:#fff;border-color:#dc2626}
.btn-treinta--red:hover{background:#b91c1c;color:#fff}
.btn-treinta--outline{background:var(--surface);color:var(--treinta-text);border-color:var(--border)}
.btn-treinta--outline:hover{background:var(--surface-2)}
.btn-treinta--danger{background:#ef4444;color:#fff;border-color:#dc2626}

.page-toolbar .toolbar-actions{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.erp-form{max-width:720px}
.erp-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.erp-form .form-field{display:flex;flex-direction:column;gap:6px}
.erp-form .form-field.full{grid-column:1/-1}
.erp-form label{font-size:12px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em}
.erp-form input,.erp-form select,.erp-form textarea{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);font:inherit}
.erp-form textarea{min-height:80px;resize:vertical}
.erp-form .form-actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.erp-form .form-check{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600}
.erp-form .form-check input{width:auto}
.data-table .row-actions{display:flex;gap:6px}

@media(max-width:700px){
  .platform-hub .platform-top{flex-direction:column;align-items:center;padding-top:56px}
  .platform-hub .platform-user{position:static;transform:none;margin-top:8px}
  .erp-form .form-grid{grid-template-columns:1fr}
  .modules-grid-6,.launcher-board{grid-template-columns:repeat(2,1fr)}
  .dash-kpi-grid,.dash-kpi-grid--4{grid-template-columns:1fr}
  .home-quickstats{grid-template-columns:1fr}
  .platform-top,.platform-main{padding-left:16px;padding-right:16px}
}

/* PWA — banner instalar en celular */
.pwa-install-banner{position:fixed;left:12px;right:12px;bottom:max(12px,env(safe-area-inset-bottom));z-index:9999;display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;background:#1a1a1a;color:#fff;box-shadow:0 12px 40px rgba(0,0,0,.28);animation:pwaSlideUp .35s ease}
.pwa-install-banner img{border-radius:10px;flex-shrink:0}
.pwa-install-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.pwa-install-text strong{font-size:14px;font-weight:700}
.pwa-install-text span{font-size:12px;opacity:.85}
.pwa-install-btn{flex-shrink:0;border:none;border-radius:10px;padding:10px 14px;background:var(--primary);color:#fff;font:inherit;font-size:13px;font-weight:800;cursor:pointer}
.pwa-install-close{flex-shrink:0;border:none;background:transparent;color:#fff;opacity:.7;font-size:18px;cursor:pointer;padding:4px}
@keyframes pwaSlideUp{from{transform:translateY(120%);opacity:0}to{transform:translateY(0);opacity:1}}
