
:root{
  --bg1:#0b1220;
  --bg2:#070b14;
  --glass: rgba(255,255,255,.08);
  --glass2: rgba(255,255,255,.12);
  --border: rgba(255,255,255,.14);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.62);
  --accent:#19a280;
  --danger:#ff5c77;
  --warn:#ffd166;
  --shadow: 0 18px 60px rgba(0,0,0,.45);
  --radius: 18px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--text);
  background: radial-gradient(1200px 800px at 20% 10%, rgba(25,162,128,.22), transparent 55%),
              radial-gradient(900px 700px at 80% 30%, rgba(99,102,241,.18), transparent 60%),
              linear-gradient(180deg, var(--bg1), var(--bg2));
  overflow:hidden;
}
a{color:inherit}
.app{display:flex;height:100vh;width:100vw}
.sidebar{
  width:280px; min-width:280px;
  padding:18px;
  border-right:1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  backdrop-filter: blur(16px);
  transition: width .22s ease, min-width .22s ease, transform .22s ease;
}
.sidebar.is-collapsed{width:86px;min-width:86px}
.sidebar__brand{position:relative;display:flex;gap:12px;align-items:center;padding:10px 8px;margin-bottom:10px}
.sidebar__toggle{position:absolute;right:8px;top:10px}
.logo{
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  background: rgba(25,162,128,.18);
  border: 1px solid rgba(25,162,128,.35);
  color: var(--text);
  font-weight:800;
}
.brand__text small{color:var(--muted)}
.sidebar.is-collapsed .brand__text{display:none}

.nav{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.nav__item{
  display:flex;align-items:center;gap:10px;
  padding:12px 12px;border-radius:14px;
  border:1px solid transparent;
  text-decoration:none;
  color:var(--text);
}
.nav__item i{width:18px;height:18px;opacity:.9}
.nav__item span{white-space:nowrap}
.sidebar.is-collapsed .nav__item span{display:none}
.nav__item:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.10);
}
.nav__item.active{
  background: rgba(25,162,128,.14);
  border-color: rgba(25,162,128,.35);
}
.sidebar__foot{margin-top:auto;padding:10px;color:var(--muted)}
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(16px);
}
.topbar__title{display:flex;align-items:baseline;gap:12px}
.topbar h1{font-size:18px;margin:0}
.badge{
  font-size:12px;color:var(--muted);
  border:1px solid rgba(255,255,255,.14);
  padding:6px 10px;border-radius:999px;
  background: rgba(255,255,255,.05);
}
.icon-btn{
  border:none;background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:var(--text);
  border-radius:14px;
  width:42px;height:42px;
  display:grid;place-items:center;
  cursor:pointer;
}
.icon-btn:hover{background: rgba(255,255,255,.10)}
.content{flex:1;min-height:0;overflow:hidden;padding:16px}
.card{
  height:100%;
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  display:flex;flex-direction:column;
  overflow:hidden;
}
.card__head{
  padding:14px 14px 12px;
  display:flex;gap:12px;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.card__head h2{font-size:15px;margin:0}
.card__sub{color:var(--muted);font-size:12px;margin-top:2px}
.card__body{flex:1;min-height:0;overflow:auto;padding:12px 14px}
.table-wrap{min-height:0;overflow:auto;border-radius:14px;border:1px solid rgba(255,255,255,.10)}
table{width:100%;border-collapse:collapse;min-width:720px}
th,td{padding:12px;border-bottom:1px solid rgba(255,255,255,.06);text-align:left;font-size:13px}
th{position:sticky;top:0;background: rgba(10,16,28,.85);backdrop-filter: blur(12px);z-index:2}
.muted{color:var(--muted)}
.row-actions{position:relative}
.kebab{
  width:36px;height:36px;border-radius:12px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  display:grid;place-items:center;cursor:pointer;
}
.menu{
  position:absolute;right:0;top:42px;
  min-width:170px;
  background: rgba(15,20,32,.92);
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  box-shadow: var(--shadow);
  overflow:hidden;
  display:none;
  z-index:5;
}
.menu a, .menu button{
  width:100%;
  display:flex;gap:10px;align-items:center;
  padding:10px 12px;
  background:none;border:none;color:var(--text);
  cursor:pointer;text-decoration:none;font-size:13px;
}
.menu a:hover, .menu button:hover{background: rgba(255,255,255,.08)}
.menu .danger{color: var(--danger)}
.actions{display:flex;gap:10px;align-items:center}
.btn{
  border:none;
  background: rgba(25,162,128,.18);
  border:1px solid rgba(25,162,128,.35);
  color: var(--text);
  padding:10px 12px;
  border-radius:14px;
  cursor:pointer;
  font-size:13px;
}
.btn:hover{background: rgba(25,162,128,.26)}
.btn.ghost{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
}
.input{
  width:100%;
  padding:11px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  outline:none;
}
.input::placeholder{color: rgba(255,255,255,.45)}
.grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}

/* Select nativo: asegurar legibilidad de opciones */
select.input option{color:#111;background:#fff}

/* Overlay para sidebar en mobile */
.sidebar-overlay{display:none}
@media (max-width: 900px){
  .sidebar{position:fixed;left:0;top:0;bottom:0;z-index:20;transform: translateX(-100%);width:280px;min-width:280px}
  .sidebar.is-open{transform: translateX(0)}
  .main{margin-left:0}
  /* En mobile ignoramos el modo colapsado (se usa is-open) */
  .sidebar.is-collapsed{width:280px;min-width:280px}

  .sidebar-overlay{display:block;position:fixed;inset:0;z-index:19;background: rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .18s ease}
  body.sidebar-open .sidebar-overlay{opacity:1;pointer-events:auto}
  .grid{grid-template-columns: 1fr}
  table{min-width: 860px}
}
.modal.hidden{display:none}
.modal{position:fixed;inset:0;z-index:50}
.modal__backdrop{position:absolute;inset:0;background: rgba(0,0,0,.55)}
.modal__panel{
  position:absolute;inset:12px;
  max-width: 980px;
  margin:auto;
  height: calc(100% - 24px);
  border-radius: 22px;
  background: rgba(15,20,32,.55);
  border:1px solid rgba(255,255,255,.14);
  box-shadow: var(--shadow);
  backdrop-filter: blur(22px);
  overflow:hidden;
  display:flex;
}
.modal__body{flex:1;min-height:0;overflow:auto;padding:14px}
.modal-inner{
  height:100%;
  display:flex;
  flex-direction:column;
  min-height:0;
}
.modal-inner__head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:12px;
  padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08);
}
.modal-inner__content{flex:1;min-height:0;overflow:auto;padding:12px 0}
.modal-inner__foot{
  position:sticky;bottom:0;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, transparent, rgba(15,20,32,.85));
  backdrop-filter: blur(10px);
  display:flex;gap:10px;justify-content:flex-end;
}

/* Floating actions menu (superpuesto, no se recorta por el contenedor con scroll) */
.floating-menu{
  position: fixed;
  z-index: 9999;
  min-width: 190px;
}
.floating-menu.hidden{ display:none; }
.floating-menu .menu{
  background: rgba(20, 26, 36, .92);
  border: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
  display: block;
}
.floating-menu .menu a{
  display:flex; gap:10px; align-items:center;
  padding: 10px 12px;
  color: rgba(255,255,255,.92);
  text-decoration:none;
}
.floating-menu .menu a:hover{ background: rgba(255,255,255,.06); }
.floating-menu .menu a.danger{ color: #ff6b6b; }


/* ===== Scrollbars (app style) ===== */
*{
  scrollbar-width: thin;
  scrollbar-color: rgba(25,162,128,.55) rgba(255,255,255,.06);
}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{
  background: rgba(255,255,255,.06);
  border-radius: 999px;
}
::-webkit-scrollbar-thumb{
  background: rgba(25,162,128,.55);
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,.06);
}
::-webkit-scrollbar-thumb:hover{ background: rgba(25,162,128,.75); }



/* ===== Print (cotización) ===== */
.print-header{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.ph-logo{width:72px;height:72px;border-radius:18px;border:1px solid var(--border);background: rgba(255,255,255,.06);object-fit:cover}
.ph-logo--placeholder{display:grid;place-items:center;color:var(--muted);font-size:12px}
.ph-title{font-weight:800;font-size:16px}
.ph-meta{color:var(--muted);font-size:12px;margin-top:3px}

@media print{
  body{background:#fff !important;color:#111 !important}
  .sidebar,.topbar,.modal-backdrop{display:none !important}
  .app{display:block !important}
  .main{margin:0 !important;padding:0 !important}
  #modal{position:static !important;inset:auto !important;background:transparent !important}
  #modal .modal{box-shadow:none !important;border:none !important;background:transparent !important;max-height:none !important}
  .modal-inner__foot,.icon-btn{display:none !important}
  table{color:#111 !important}
  .muted{color:#444 !important}
  .pill{border-color:#ddd !important;background:#f7f7f7 !important;color:#111 !important}
}


/* Sidebar collapsed: hide brand (logo + text) */
.sidebar.is-collapsed .sidebar__brand .logo,
.sidebar.is-collapsed .sidebar__brand .brand__text{
  display:none !important;
}
.sidebar.is-collapsed .sidebar__brand{
  justify-content:center;
  padding: 14px 10px;
}
.sidebar.is-collapsed .sidebar__toggle{
  position: static;
}

/* Topbar mobile menu button */
.topbar{display:flex;align-items:center;gap:12px}
.topbar__menu{display:none;align-items:center;justify-content:center;width:42px;height:42px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);backdrop-filter:blur(10px);cursor:pointer}
.topbar__menu i{width:20px;height:20px}
@media (max-width: 900px){
  .topbar__menu{display:flex}
  .topbar__title h1{font-size:18px}
}

@media (max-width: 900px){
  .sidebar__toggle{left:8px;right:auto}
  .sidebar__brand{padding-left:52px}
}

/* Mobile sidebar: overlay + always show labels/text */
@media (max-width: 900px){
  .sidebar{transform:translateX(-110%); position:fixed; left:0; top:0; height:100vh; z-index:80; width:280px; max-width:86vw}
  .sidebar.is-open{transform:translateX(0)}
  /* Never use collapsed in mobile */
  .sidebar.is-collapsed{width:280px !important}
  .sidebar .brand__text{display:block !important}
  .sidebar.is-collapsed .brand__text{display:block !important}
  .sidebar .nav__label{display:inline !important; opacity:1 !important; width:auto !important}
  .sidebar.is-collapsed .nav__label{display:inline !important; opacity:1 !important}

  /* Toggle aligned left */
  .sidebar__brand{justify-content:flex-start !important}
  #sidebarToggle{order:-1; margin-left:0 !important; margin-right:12px !important}
}


/* Force desktop collapsed width */
@media (min-width: 901px){
  .sidebar.is-collapsed{width:86px !important; min-width:86px !important;}
}
