:root{
  --r-xl: 18px; --r-lg: 16px; --r-md: 12px; --r-sm: 10px;
  --t: 180ms cubic-bezier(.2,.9,.2,1);
  --shadow: 0 10px 28px rgba(0,0,0,.12);
  --shadow2: 0 18px 60px rgba(0,0,0,.18);

  --bg:#0B1220; --panel:#0F172A; --card:#111C33;
  --text:#EAF0FF; --muted:rgba(234,240,255,.70);
  --border:rgba(234,240,255,.10);

  --primary:#3B82F6; --water:#22D3EE; --gas:#F59E0B;
  --ok:#22C55E; --warn:#F59E0B; --bad:#FB7185;

  --focus:0 0 0 4px rgba(59,130,246,.25);
  --sidebar-w: 280px;
  --topbar-h: 70px;
  --bottom-h: 72px;
}

html[data-theme="light"]{
  --bg:#F6F8FF; --panel:#FFFFFF; --card:#FFFFFF;
  --text:#0B1220; --muted:rgba(11,18,32,.62);
  --border:rgba(11,18,32,.12);
  --shadow: 0 10px 26px rgba(11,18,32,.10);
  --shadow2: 0 18px 60px rgba(11,18,32,.14);
}

/* dark: texto dos atalhos mais claro */
html:not([data-theme="light"]) .shortcut__txt strong{
  color: var(--text) !important;
}

html:not([data-theme="light"]) .shortcut__txt .muted,
html:not([data-theme="light"]) .shortcut__txt span{
  color: color-mix(in oklab, var(--text) 78%, transparent) !important;
}


@media (prefers-color-scheme: light){
  html[data-theme="system"]{
    --bg:#F6F8FF; --panel:#FFFFFF; --card:#FFFFFF;
    --text:#0B1220; --muted:rgba(11,18,32,.62);
    --border:rgba(11,18,32,.12);
    --shadow: 0 10px 26px rgba(11,18,32,.10);
    --shadow2: 0 18px 60px rgba(11,18,32,.14);
  }
}

*{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(900px 520px at 10% 0%, rgba(34,211,238,.11), transparent 55%),
    radial-gradient(900px 520px at 90% 20%, rgba(245,158,11,.10), transparent 60%),
    var(--bg);
}

.hidden{display:none !important}
.muted{color:var(--muted)}
.tiny{font-size:12px}

.app{
  min-height:100%;
  display:grid;
  grid-template-columns: var(--sidebar-w) 1fr;
}

.sidebar{
  position:sticky; top:0;
  height:100vh;
  padding:16px;
  border-right:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 90%, transparent);
  backdrop-filter: blur(10px);
  display:grid;
  grid-template-rows:auto auto 1fr auto;
  gap:16px;
}

.sidebar__brand{display:flex; align-items:center; gap:12px}
.logo{
  width:40px;height:40px;border-radius:14px;
  display:grid;place-items:center;
  background: linear-gradient(135deg, color-mix(in oklab, var(--primary) 78%, var(--water)),
                             color-mix(in oklab, var(--primary) 55%, var(--gas)));
  color:white;font-weight:900;
  box-shadow: var(--shadow);
}
.brandtxt{display:grid; line-height:1.05}

.sidebar__label{font-size:12px;color:var(--muted); margin-bottom:8px}

.seg{
  display:flex; gap:6px; padding:6px;
  border-radius:999px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
}
.seg__btn{
  flex:1;
  border:none; cursor:pointer;
  padding:10px 10px;
  border-radius:999px;
  background:transparent;
  color:var(--muted);
  transition: background var(--t), transform var(--t);
}
.seg__btn:hover{transform: translateY(-1px)}
.seg__btn.is-active{
  color: color-mix(in oklab, var(--primary) 85%, var(--text));
  background: color-mix(in oklab, var(--primary) 16%, var(--panel));
}

.sidebar__nav{display:grid; gap:10px}
.navgroup{display:grid; gap:6px}

.navitem{
  width:100%;
  text-align:left;
  border:1px solid transparent;
  background: transparent;
  padding:12px 12px;
  border-radius:14px;
  cursor:pointer;
  color:var(--muted);
  display:flex; align-items:center; gap:10px;
  transition: background var(--t), border-color var(--t), transform var(--t);
  text-decoration: none;
}
.navitem:hover{transform: translateY(-1px); background: color-mix(in oklab, var(--panel) 86%, transparent); text-decoration: none;}
.navitem.is-active{
  color: var(--text);
  border-color: color-mix(in oklab, var(--primary) 22%, var(--border));
  background: color-mix(in oklab, var(--primary) 12%, var(--panel));
  text-decoration: none;
}

.sidebar__foot{
  display:grid; gap:10px;
  padding-top:10px;
  border-top:1px solid var(--border);
}

.themebtn{
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  padding:12px;
  border-radius:14px;
  cursor:pointer;
  display:flex; align-items:center; gap:10px;
}
.themebtn__icon{width:22px;text-align:center}

.usermini{display:flex; align-items:center; gap:10px}
.avatar{
  width:38px;height:38px;border-radius:999px;
  display:grid;place-items:center;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 88%, transparent);
  font-weight:800;
}

.main{
  min-height:100vh;
  display:grid;
  grid-template-rows: var(--topbar-h) 1fr;
}

.topbar{
  position:sticky; top:0; z-index:10;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 18px;
  border-bottom:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 88%, transparent);
  backdrop-filter: blur(10px);
}
.topbar__left{display:flex; align-items:center; gap:12px}
.title{font-weight:900; letter-spacing:-.02em}
.crumb{font-size:12px}

.topbar__right{display:flex; align-items:center; gap:10px}

.iconbtn{
  width:42px;height:42px;
  border-radius:14px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  cursor:pointer;
  transition: transform var(--t);
}
.iconbtn:hover{transform: translateY(-1px)}
.iconbtn:focus-visible{outline:none; box-shadow: var(--focus)}

.search{position:relative; width:min(420px, 42vw)}
.search__icon{position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--muted)}
.search__input{
  width:100%;
  padding:12px 12px 12px 38px;
  border-radius:999px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  color:var(--text);
  outline:none;
}
.search__input:focus{box-shadow: var(--focus); border-color: rgba(59,130,246,.35)}

.pill{
  border:1px solid color-mix(in oklab, var(--primary) 35%, var(--border));
  background: color-mix(in oklab, var(--primary) 14%, var(--panel));
  color: var(--text);
  padding:10px 12px;
  border-radius:999px;
  cursor:pointer;
  display:flex; align-items:center; gap:10px;
  transition: transform var(--t);
}
.pill:hover{transform: translateY(-1px)}
.pill__dot{
  width:10px;height:10px;border-radius:999px;
  background: linear-gradient(135deg, var(--water), var(--primary));
  box-shadow: 0 0 0 4px rgba(59,130,246,.18);
}

.content{padding:18px; max-width:1200px; width:100%; margin:0 auto}
.screen{display:none}
.screen.is-active{display:block}

.pagehead{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:12px; flex-wrap:wrap;
  margin-bottom:14px;
}
.pagehead h1{margin:0; font-size:22px; letter-spacing:-.02em}
.pagehead p{margin:6px 0 0 0}
.pagehead__actions{display:flex; gap:10px; flex-wrap:wrap}

.grid{display:grid; gap:14px}
.grid--2{grid-template-columns: 1fr}
.grid--kpis{grid-template-columns: repeat(2, minmax(0,1fr))}
@media (min-width: 980px){
  .grid--2{grid-template-columns: 1.1fr .9fr}
  .grid--kpis{grid-template-columns: repeat(4, minmax(0,1fr))}
}

.card{
  background: color-mix(in oklab, var(--card) 92%, transparent);
  border:1px solid var(--border);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.card__head{
  padding:16px 16px 0 16px;
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:12px;
}
.card__head h2{margin:0; font-size:16px}
.card__header {
  padding: 16px;
  border-bottom: 1px solid var(--border);
}
.card__header h3 {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
}
.card__body {
  padding: 16px;
}
.card__title {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
}
.pad{padding:16px}
.formpad{padding:14px 16px 16px 16px}

.kpi{padding:14px}
.kpi__label{font-size:12px;color:var(--muted)}
.kpi__value{font-size:20px;font-weight:900;margin-top:8px;letter-spacing:-.02em}
.kpi__hint{font-size:12px;margin-top:6px}

.kpi{
  padding: 16px;
  background: color-mix(in oklab, var(--panel) 86%, var(--card));
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow2);
}


.btn{
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  color:var(--text);
  padding:12px 14px;
  border-radius:14px;
  cursor:pointer;
  transition: transform var(--t);
}
.btn:hover{transform: translateY(-1px)}
.btn:focus-visible{outline:none; box-shadow: var(--focus)}
.btn--primary{
  border-color: color-mix(in oklab, var(--primary) 40%, var(--border));
  background: linear-gradient(135deg, color-mix(in oklab, var(--primary) 86%, #fff 0%),
                             color-mix(in oklab, var(--primary) 55%, var(--water)));
  color:white;
}
.btn--ghost{background:transparent}
.btn--sm{padding:8px 10px; border-radius:12px; font-size:12px}

.list{padding:12px 16px 16px 16px; display:grid; gap:10px}
.item{
  padding:12px;
  border-radius:14px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  display:grid; gap:8px;
}
.item__top{display:flex; justify-content:space-between; gap:10px}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  font-size:12px;
  background: color-mix(in oklab, var(--panel) 86%, transparent);
}
.badge--primary{border-color: color-mix(in oklab, var(--primary) 35%, var(--border))}
.badge--ok{border-color: rgba(34,197,94,.35)}
.badge--warn{border-color: rgba(245,158,11,.35)}
.badge--bad{border-color: rgba(251,113,133,.35)}
.right{text-align:right}

.shortcuts{
  padding:12px 16px 16px 16px;
  display:grid; gap:10px;
  grid-template-columns: 1fr;
}
@media (min-width: 980px){
  .shortcuts{grid-template-columns: 1fr 1fr;}
}
.shortcut{
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  border-radius:16px;
  padding:14px;
  cursor:pointer;
  display:flex; gap:12px; align-items:center;
  transition: transform var(--t);
}
.shortcut:hover{transform: translateY(-1px)}
.shortcut__icon{
  width:42px;height:42px;border-radius:16px;
  display:grid;place-items:center;
  background: color-mix(in oklab, var(--primary) 14%, var(--panel));
  border:1px solid color-mix(in oklab, var(--primary) 22%, var(--border));
}
.shortcut__txt{display:grid; line-height:1.1; gap:4px}

.quick{padding:12px 16px 16px 16px; display:grid; gap:10px}
.qitem{
  width:100%;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  border-radius:16px;
  padding:12px;
  cursor:pointer;
  display:grid;
  grid-template-columns: auto 1fr auto;
  gap:12px;
  align-items:center;
  transition: transform var(--t);
}
.qitem:hover{transform: translateY(-1px)}
.tag{
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
}
.tag--gas{border-color: rgba(245,158,11,.35)}
.tag--water{border-color: rgba(34,211,238,.35)}
.qitem__main{display:grid; gap:2px}
.qitem__price{font-weight:900}

.row2{display:grid; gap:12px; grid-template-columns: 1fr}
@media (min-width: 820px){ .row2{grid-template-columns: 1fr 1fr} }

.field{display:grid; gap:6px; margin-top:10px}
.field__label{font-size:12px; color:var(--muted)}
.field__input{
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  color:var(--text);
  border-radius:14px;
  padding:12px;
  outline:none;
}
.field__input:focus{box-shadow: var(--focus); border-color: rgba(59,130,246,.35)}
.field__input--textarea{min-height:92px; resize:vertical}

.cart{padding:12px 16px 0 16px; display:grid; gap:10px}
.cartrow{
  display:grid;
  grid-template-columns: 1fr auto;
  gap:10px;
  align-items:center;
  padding:12px;
  border-radius:16px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
}
.qty{
  display:inline-flex;
  border:1px solid var(--border);
  border-radius:999px;
  overflow:hidden;
}
.qty button{
  width:34px;height:34px;
  border:none;background:transparent;
  cursor:pointer;color:var(--text);
}
.qty span{width:34px;display:grid;place-items:center;color:var(--muted)}
.xbtn{
  width:34px;height:34px;
  border-radius:12px;
  border:1px solid var(--border);
  background:transparent;
  cursor:pointer;
  margin-left:8px;
}

.totals{
  padding:12px 16px 16px 16px;
  display:grid; gap:8px;
}
.totals__row{display:flex; justify-content:space-between}
.totals__row--big{
  padding-top:10px; margin-top:6px;
  border-top:1px solid var(--border);
  font-size:16px;
}

.chips{display:flex; gap:8px; flex-wrap:wrap}
.chipbtn{
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  color:var(--muted);
  padding:10px 12px;
  border-radius:999px;
  cursor:pointer;
}
.chipbtn.is-active{
  color: var(--text);
  border-color: color-mix(in oklab, var(--primary) 22%, var(--border));
  background: color-mix(in oklab, var(--primary) 12%, var(--panel));
}

.tablewrap{overflow:auto}
.table{
  width:100%;
  border-collapse: separate;
  border-spacing: 0;
  min-width: 760px;
}
.table th, .table td{
  padding:12px 14px;
  border-bottom:1px solid var(--border);
  text-align:left;
}
.table thead th{
  position:sticky; top:0;
  background: color-mix(in oklab, var(--panel) 92%, transparent);
  backdrop-filter: blur(10px);
  z-index: 1;
  font-size:12px;
  color:var(--muted);
}

.callout{
  border:1px dashed var(--border);
  background: color-mix(in oklab, var(--panel) 84%, transparent);
  padding:14px;
  border-radius:16px;
  margin-bottom:12px;
}

/* MOBILE */
/* por padrão: escondido (desktop) */
/* Desktop padrão: sidebar ON, bottom OFF */
.show-mobile{ display:none !important; }
.bottom{ display:none !important; }

/* Mobile: sidebar OFF, bottom ON, botão ☰ OFF */
@media (max-width: 980px){
  .sidebar{ display:none !important; }
  .app{ grid-template-columns: 1fr !important; }

  .show-mobile{ display:grid !important; }

  [data-action="openMobileMenu"]{ display:none !important; }
  .mnav{ display:none !important; } /* se existir, nunca aparece no mobile */

  .content{
    max-width: 100% !important;
    width: 100% !important;
    padding-bottom: calc(var(--bottom-h) + 16px) !important;
  }
}


.bottom{
  position:fixed; left:0; right:0; bottom:0;
  height: var(--bottom-h);
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  border-top:1px solid var(--border);
  background: color-mix(in oklab, var(--panel) 92%, transparent);
  backdrop-filter: blur(10px);
  z-index: 30;
}
.bbtn{
  border:none; background:transparent;
  color: var(--muted);
  display:grid; place-items:center;
  gap:6px;
  cursor:pointer;
}
.bbtn span{font-size:12px}
.bbtn.is-active{color: var(--text)}

.mnav{position:fixed; inset:0; z-index:40}
.mnav__overlay{position:absolute; inset:0; background: rgba(0,0,0,.38)}
.mnav__panel{
  position:absolute; inset:0 auto 0 0;
  width: min(340px, 86vw);
  height:100%;
  background: var(--panel);
  border-right:1px solid var(--border);
  box-shadow: var(--shadow2);
  display:grid;
  grid-template-rows:auto 1fr;
}
.mnav__head{
  padding:14px;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--border);
}
.mnav__body{padding:12px; display:grid; gap:10px}

.toast{
  position:fixed;
  left:50%;
  bottom: calc(var(--bottom-h) + 16px);
  transform: translateX(-50%);
  z-index: 60;
  background: color-mix(in oklab, var(--panel) 92%, transparent);
  border:1px solid var(--border);
  box-shadow: var(--shadow2);
  padding:10px 12px;
  border-radius:999px;
}

.modal{position:fixed; inset:0; z-index:80}
.modal__overlay{position:absolute; inset:0; background: rgba(0,0,0,.38)}
.modal__panel{
  position:absolute;
  left:50%; top:50%;
  transform: translate(-50%,-50%);
  width: min(560px, 92vw);
  background: var(--panel);
  border:1px solid var(--border);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow2);
  overflow:hidden;
}
.modal__head{
  padding:14px;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--border);
}
/* Modal: botão X mais visível */
.modal__head .iconbtn{
  color: var(--text) !important;
}

.modal__head .iconbtn:hover{
  background: color-mix(in oklab, var(--panel) 70%, var(--text) 6%) !important;
  border-color: color-mix(in oklab, var(--text) 18%, var(--border)) !important;
}

.modal__body{padding:14px}
.modal__foot{padding:14px; border-top:1px solid var(--border); display:flex; justify-content:flex-end; gap:10px}

@media (prefers-reduced-motion: reduce){
  *{transition:none !important}
}

/* ===== MOBILE LAYOUT FIX: header + conteúdo responsivo ===== */
@media (max-width: 980px){

  /* some com o botão Ação rápida no mobile */
  .topbar__right .pill{
    display: none !important;
  }

  /* topbar right fica simples */
  .topbar__right{
    width: 100% !important;
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 10px !important;
  }

  /* botão tema alinhado (nunca fica solto) */
  .topbar__right .iconbtn{
    width: 44px !important;
    height: 44px !important;
    display: inline-grid !important;
    place-items: center !important;
    padding: 0 !important;
    line-height: 1 !important;
  }

  /* topbar vira 2 linhas */
  .topbar{
    height: auto !important;
    padding: 10px 12px !important;
    align-items: flex-start !important;
  }

  .topbar__left{
    width: 100% !important;
  }


  /* busca ocupa a linha e não quebra layout */
  .search{
    display: block !important;
    width: 100% !important;
  }
  .search__input{
    width: 100% !important;
  }

  /* conteúdo mais compacto e 1 coluna */
  .content{
    padding: 12px !important;
    max-width: 100% !important;
    width: 100% !important;
    padding-bottom: calc(var(--bottom-h) + 16px) !important;
  }

  /* KPIs: 1 coluna (fica bonito e não aperta) */
  .grid--kpis{
     gap: 16px !important;          /* espaço entre os KPIs */
    margin-bottom: 16px !important; /* espaço entre KPIs e a próxima seção */
  }

  .grid--2{
    gap: 16px !important;          /* espaço entre cards abaixo */
  }

  /* atalhos (cards) também em 1 coluna */
  .shortcuts{
    grid-template-columns: 1fr !important;
  }

  /* garante sem scroll horizontal */
  html, body, .app, .main{
    overflow-x: hidden !important;
    max-width: 100vw !important;
  }
  /* garante que botão tema da sidebar não “vaze” */
  .themebtn{ display:none !important; }

  /* botão tema da topbar (iconbtn) alinhado e sem "bolinha" perdida */
  .topbar__right .iconbtn{
    width: 44px !important;
    height: 44px !important;
    display: inline-grid !important;
    place-items: center !important;
    border-radius: 14px !important;
    line-height: 1 !important;
    padding: 0 !important;
  }

  /* se algum span do themebtn estiver aparecendo solto */
  .themebtn__icon{
    display:none !important;
  }
}


/* desktop: mais espaço entre kpis (topo) e o restante */
@media (min-width: 981px){
  .grid--kpis{
    margin-bottom: 18px !important; /* ajusta: 14~28 */
  }
}

/* RESPONSIVIDADE: Mobile 480px e menor */
@media (max-width: 480px){
  :root{
    --topbar-h: 60px;
    --bottom-h: 70px;
  }

  .sidebar{ display:none !important; }

  .pagehead h1{
    font-size: 18px !important;
  }

  .content{
    padding: 12px !important;
  }

  .card{
    border-radius: var(--r-lg) !important;
  }

  .grid--kpis{
    gap: 10px !important;
    margin-bottom: 12px !important;
  }

  .kpi{
    padding: 12px !important;
  }

  .kpi__value{
    font-size: 18px !important;
  }

  .shortcuts{
    padding: 8px 12px 12px 12px !important;
  }

  .shortcut{
    padding: 12px !important;
    gap: 10px !important;
  }

  .shortcut__icon{
    width: 36px !important;
    height: 36px !important;
  }
}


/* Remove sublinhado de TODOS os links do sistema */
a,
a:hover,
a:focus,
a:active,
a:visited {
  text-decoration: none !important;
}

/* Details Layout */
.details {
  display: grid;
  gap: 0;
}

.details__row {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 16px;
  align-items: flex-start;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
}

.details__row:last-child {
  border-bottom: none;
}

.details__label {
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  letter-spacing: 0.4px;
}

.details__value {
  font-size: 14px;
  color: var(--text);
  line-height: 1.5;
  word-break: break-word;
}

@media (max-width: 680px) {
  .details__row {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .details__label {
    font-size: 11px;
  }

  .details__value {
    font-size: 13px;
  }
}
