:root{
  --bg:#09090b;
  --bg-soft:#111114;
  --card:rgba(255,255,255,.05);
  --card-strong:#151519;
  --soft:#202026;
  --text:#f6f6f7;
  --muted:#a7a7b1;
  --red:#d91f26;
  --red-soft:rgba(217,31,38,.14);
  --white:#fff;
  --border:rgba(255,255,255,.09);
  --shadow:0 18px 50px rgba(0,0,0,.35);
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:#0b0b0f}
body{
  margin:0;
  font-family:Inter,Arial,sans-serif;
  background:#0b0b0f;
  color:var(--text);
  min-height:100vh;
  padding-top:env(safe-area-inset-top);
  padding-bottom:env(safe-area-inset-bottom);
}
a{text-decoration:none;color:inherit}
.login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top,rgba(255,255,255,.1),transparent 20%),linear-gradient(160deg,#040404,#151519 56%,#3a090b)}
.phone-login{width:min(430px,92vw);background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);backdrop-filter:blur(20px);border-radius:40px;padding:28px;box-shadow:0 30px 80px rgba(0,0,0,.46)}
.phone-notch{width:122px;height:28px;background:#000;border-radius:0 0 18px 18px;margin:-28px auto 20px}
.brand-center{text-align:center;margin:16px 0 28px}
.logo-round,.logo-mark{position:relative;overflow:hidden}
.logo-round{width:82px;height:82px;border-radius:24px;background:linear-gradient(145deg,#fff,#d6d6d6);color:#111;font-weight:900;display:grid;place-items:center;margin:0 auto 14px;font-size:26px;box-shadow:var(--shadow)}
.logo-round::after,.logo-mark::after{content:"";position:absolute;inset:auto -20% -40% auto;width:72px;height:72px;background:rgba(255,255,255,.22);border-radius:50%}
.input,select,textarea{width:100%;padding:13px 15px;border-radius:16px;border:1px solid var(--border);background:#0f0f12;color:#fff;outline:none;transition:.2s ease;box-shadow:inset 0 1px 0 rgba(255,255,255,.03)}
.input:focus,select:focus,textarea:focus{border-color:rgba(217,31,38,.55);box-shadow:0 0 0 4px rgba(217,31,38,.14)}
button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:14px;border:none;background:linear-gradient(180deg,#eb3239,#c3161d);color:#fff;font-weight:800;cursor:pointer;box-shadow:0 12px 28px rgba(217,31,38,.22);transition:transform .15s ease,opacity .2s ease}
button:hover,.btn:hover{transform:translateY(-1px)}
.btn.secondary{background:#232329;box-shadow:none;color:#fff}.btn.ghost{background:transparent;border:1px solid var(--border);box-shadow:none}.btn.small{padding:8px 12px;border-radius:11px;font-size:13px}
.form-group{margin-bottom:14px}.help{color:var(--muted);font-size:13px}
.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh;width:100%;max-width:100%}
.sidebar{background:rgba(10,10,12,.96);border-right:1px solid var(--border);padding:22px;position:sticky;top:0;height:100vh;backdrop-filter:blur(14px)}
.brand{display:flex;gap:12px;align-items:center;margin-bottom:24px}
.brand-text{min-width:0}
.logo-mark{width:54px;height:54px;border-radius:18px;background-color:#fff;display:grid;place-items:center;font-weight:900}
.brand h1{font-size:16px;margin:0}.brand small{color:var(--muted)}
.sidebar nav{display:flex;flex-direction:column;gap:8px}
.sidebar nav a{padding:12px 14px;border-radius:16px;color:#ddd;border:1px solid transparent;transition:.2s ease}
.sidebar nav a:hover,.sidebar nav a.active{background:rgba(255,255,255,.05);border-color:var(--border)}
.sidebar nav a.active{box-shadow:inset 3px 0 0 var(--red);color:#fff}
.content{padding:24px 24px 30px;min-width:0;max-width:100%;overflow-x:hidden}
.topbar{margin-bottom:22px;display:flex;justify-content:space-between;gap:12px;align-items:center}
.topbar h2{margin:0 0 4px;font-size:28px}.topbar p{margin:0;color:var(--muted)}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:18px;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px}.panel-header h3{margin:0}
.grid{display:grid;gap:18px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.stat{background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.03));padding:18px;border-radius:22px;border:1px solid var(--border);position:relative;overflow:hidden}.stat::after{content:"";position:absolute;right:-16px;top:-16px;width:88px;height:88px;background:var(--red-soft);border-radius:50%}.stat h3{margin:0 0 8px;font-size:14px;color:var(--muted)}.stat strong{font-size:28px;position:relative;z-index:1}
.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:18px;background:rgba(0,0,0,.12)}
table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:14px 12px;border-bottom:1px solid var(--border);text-align:left}th{color:#c4c4cd;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.05em;background:rgba(255,255,255,.02)}tbody tr:hover{background:rgba(255,255,255,.025)}
.actions{display:flex;gap:8px;flex-wrap:wrap}.alert{padding:12px 14px;border-radius:14px;margin-bottom:15px;border:1px solid transparent}.alert.success{background:#113119;color:#cbffd5;border-color:rgba(91,255,139,.2)}.alert.error{background:#3b1114;color:#ffd3d6;border-color:rgba(255,87,99,.22)}
.row{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-6{grid-column:span 6}.col-8{grid-column:span 8}.col-12{grid-column:span 12}
.badge{padding:6px 10px;border-radius:999px;background:#2a1214;color:#ffcad0;font-size:12px;border:1px solid rgba(217,31,38,.18)}
.page-actions{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px}.search-box{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.search-box input,.search-box select{min-width:180px}.muted{color:var(--muted)}
.table-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}.pagination{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:14px}.pagination button{padding:8px 12px;border-radius:10px}.pagination .page-status{color:var(--muted);font-size:13px}
.kpi-strip{display:flex;gap:10px;flex-wrap:wrap}.pill{padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid var(--border);color:#ddd}
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.58);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:18px;z-index:999}.modal-backdrop.open{display:flex}.modal{width:min(980px,100%);max-height:92vh;overflow:auto;background:linear-gradient(180deg,#17171b,#101014);border:1px solid var(--border);border-radius:28px;box-shadow:0 40px 90px rgba(0,0,0,.52)}
.modal-header{padding:18px 18px 0;display:flex;justify-content:space-between;align-items:center;gap:12px}.modal-body{padding:18px}.modal-close{width:42px;height:42px;border-radius:12px;background:#26262c;box-shadow:none}
.item-row{padding:14px;border:1px dashed rgba(255,255,255,.12);border-radius:18px;background:rgba(255,255,255,.02)}
.inline-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:10px;background:rgba(255,255,255,.05);font-size:14px}
.print-hidden{display:inline-flex}
.mobile-fab-menu,.mobile-overlay{display:none}

html,body{max-width:100%;overflow-x:hidden}
img,canvas,svg{max-width:100%;height:auto}
.content,.content > *, .card, .stat, .page-actions, .panel-header, .table-toolbar, .search-box, .actions, .row, .grid, .modal-body, form{min-width:0;max-width:100%}
.card,.stat,.modal,.item-row,.table-wrap,.purchase-view-table-wrap,.sale-view-table-wrap{overflow-wrap:anywhere}
label{display:block;margin-bottom:8px;color:var(--muted);font-size:14px}
.sidebar-nav{display:flex;flex-direction:column;gap:8px}
.responsive-table table{min-width:0}

@media (max-width: 980px){
  .app-shell{display:block}
  .sidebar{
    position:fixed;
    top:0;
    left:-290px;
    width:280px;
    max-width:84vw;
    height:100dvh;
    z-index:1000;
    transition:left .28s ease;
    overflow-y:auto;
  }
  .sidebar.mobile-open{left:0}
  .mobile-fab-menu{
    display:flex;
    position:fixed;
    top:calc(env(safe-area-inset-top) + 12px);
    left:12px;
    width:46px;
    height:46px;
    padding:0;
    border-radius:14px;
    z-index:1002;
    background:#232329;
    border:1px solid var(--border);
    box-shadow:none;
    font-size:22px;
    line-height:1;
  }
  .mobile-overlay{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.55);
    z-index:999;
  }
  .mobile-overlay.active{display:block}
  body.menu-open{overflow:hidden}
  .content{padding:74px 14px 18px}
  .topbar{align-items:flex-start;flex-direction:column;margin-bottom:16px}
  .topbar .kpi-strip{width:100%}
  .topbar .pill{width:100%;justify-content:center;text-align:center}
  .page-actions,.panel-header,.table-toolbar,.search-box,.actions{flex-direction:column;align-items:stretch}
  .page-actions > *, .panel-header > *, .table-toolbar > *, .search-box > *, .actions > *{width:100%}
  .search-box input,.search-box select,.search-box .input,.actions .btn,.page-actions .btn,.table-toolbar .btn{width:100%;min-width:0}
  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table{min-width:680px}
  .modal{width:100%;border-radius:20px}
  .modal-header{padding:16px 16px 0;align-items:flex-start}
  .modal-body{padding:16px}
}

@media (max-width: 768px){
  .logo-mark{width:46px;height:46px;border-radius:14px}
  .logo-mark img{height:30px !important}
  .topbar h2{font-size:22px;line-height:1.2}
  .card{padding:14px;border-radius:18px}
  .stat strong{font-size:24px}
  .input,select,textarea,button,.btn{min-height:46px}
  .btn.small{min-height:40px}
}

@media print {
  .sidebar,.topbar,.print-hidden,form,.btn,.page-actions,.table-toolbar,.pagination,.modal-backdrop,.mobile-fab-menu,.mobile-overlay{display:none!important}
  .content{padding:0}
  .card{border:none;box-shadow:none;background:#fff;color:#000}
}
/* PATCH MOBILE HEADER FIXO - adicionar no FINAL do seu style.css original */

@media (max-width: 980px){
  /* mantém a sidebar fora da tela até abrir */
  .sidebar{
    position: fixed !important;
    top: 0 !important;
    left: -290px !important;
    width: 280px !important;
    max-width: 84vw !important;
    height: 100dvh !important;
    z-index: 1000 !important;
    transition: left .28s ease !important;
    overflow-y: auto !important;
    background: rgba(10,10,12,.96) !important;
    border-right: 1px solid var(--border) !important;
  }

  .sidebar.mobile-open{
    left: 0 !important;
  }

  /* botão do menu sempre visível */
  .mobile-fab-menu{
    display: flex !important;
    position: fixed !important;
    top: calc(env(safe-area-inset-top) + 10px) !important;
    left: 12px !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    border-radius: 14px !important;
    z-index: 1002 !important;
    background: #232329 !important;
    border: 1px solid var(--border) !important;
    box-shadow: none !important;
    font-size: 22px !important;
    line-height: 1 !important;
    align-items: center !important;
    justify-content: center !important;
  }

  /* fundo escuro ao abrir menu */
  .mobile-overlay{
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0,0,0,.55) !important;
    z-index: 999 !important;
    display: none !important;
  }

  .mobile-overlay.active{
    display: block !important;
  }

  body.menu-open{
    overflow: hidden !important;
  }

  /* header fixo estilo app sem quebrar o restante do CSS */
  .topbar{
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1001 !important;
    min-height: 72px !important;
    margin: 0 !important;
    padding:
      calc(env(safe-area-inset-top) + 10px)
      14px
      12px
      68px !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    background: rgba(11,11,15,.96) !important;
    border-bottom: 1px solid var(--border) !important;
    backdrop-filter: blur(14px) !important;
    -webkit-backdrop-filter: blur(14px) !important;
  }

  .topbar > div:first-child{
    min-width: 0 !important;
    flex: 1 !important;
  }

  .topbar h2{
    margin: 0 0 2px !important;
    font-size: 20px !important;
    line-height: 1.15 !important;
  }

  .topbar p{
    margin: 0 !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    color: var(--muted) !important;
  }

  .topbar .kpi-strip{
    display: none !important;
  }

  /* espaço para o header fixo */
  .content{
    padding-top: calc(env(safe-area-inset-top) + 88px) !important;
    overflow-x: hidden !important;
  }
}

@media (max-width: 420px){
  .topbar p{
    display: none !important;
  }

  .topbar h2{
    margin: 0 !important;
    font-size: 19px !important;
  }
}
/* PATCH MOBILE HEADER FIXO - adicionar no FINAL do seu style.css original */

@media (max-width: 980px){
  /* mantém a sidebar fora da tela até abrir */
  .sidebar{
    position: fixed !important;
    top: 0 !important;
    left: -290px !important;
    width: 280px !important;
    max-width: 84vw !important;
    height: 100dvh !important;
    z-index: 1000 !important;
    transition: left .28s ease !important;
    overflow-y: auto !important;
    background: rgba(10,10,12,.96) !important;
    border-right: 1px solid var(--border) !important;
  }

  .sidebar.mobile-open{
    left: 0 !important;
  }

  /* botão do menu sempre visível */
  .mobile-fab-menu{
    display: flex !important;
    position: fixed !important;
    top: calc(env(safe-area-inset-top) + 10px) !important;
    left: 12px !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    border-radius: 14px !important;
    z-index: 1002 !important;
    background: #232329 !important;
    border: 1px solid var(--border) !important;
    box-shadow: none !important;
    font-size: 22px !important;
    line-height: 1 !important;
    align-items: center !important;
    justify-content: center !important;
  }

  /* fundo escuro ao abrir menu */
  .mobile-overlay{
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0,0,0,.55) !important;
    z-index: 999 !important;
    display: none !important;
  }

  .mobile-overlay.active{
    display: block !important;
  }

  body.menu-open{
    overflow: hidden !important;
  }

  /* header fixo estilo app sem quebrar o restante do CSS */
  .topbar{
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1001 !important;
    min-height: 72px !important;
    margin: 0 !important;
    padding:
      calc(env(safe-area-inset-top) + 10px)
      14px
      12px
      68px !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    background: rgba(11,11,15,.96) !important;
    border-bottom: 1px solid var(--border) !important;
    backdrop-filter: blur(14px) !important;
    -webkit-backdrop-filter: blur(14px) !important;
  }

  .topbar > div:first-child{
    min-width: 0 !important;
    flex: 1 !important;
  }

  .topbar h2{
    margin: 0 0 2px !important;
    font-size: 20px !important;
    line-height: 1.15 !important;
  }

  .topbar p{
    margin: 0 !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    color: var(--muted) !important;
  }

  .topbar .kpi-strip{
    display: none !important;
  }

  /* espaço para o header fixo */
  .content{
    padding-top: calc(env(safe-area-inset-top) + 88px) !important;
    overflow-x: hidden !important;
  }
}

@media (max-width: 420px){
  .topbar p{
    display: none !important;
  }

  .topbar h2{
    margin: 0 !important;
    font-size: 19px !important;
  }
}
@media (max-width: 980px){

  .kpi-strip{
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px;
  }

  .kpi{
    padding: 12px !important;
    border-radius: 14px !important;
  }

  .kpi span{
    font-size: 12px !important;
  }

  .kpi strong{
    font-size: 16px !important;
  }

}