/* =========================================================
   ChopControl — Design System
   Paleta: zinc (fundo) + amber (primária)
   ========================================================= */
:root{
  --bg:#09090b;            /* zinc-950 */
  --panel:#18181b;         /* zinc-900 */
  --panel-2:#27272a;       /* zinc-800 */
  --border:#27272a;        /* zinc-800 */
  --hover:#27272a;

  --text:#f4f4f5;          /* zinc-100 */
  --text-soft:#a1a1aa;     /* zinc-400 */
  --muted:#71717a;         /* zinc-500 */
  --muted-2:#52525b;       /* zinc-600 */

  --primary:#f59e0b;       /* amber-500 */
  --primary-2:#d97706;     /* amber-600 */
  --primary-3:#b45309;     /* amber-700 */

  --green:#22c55e;
  --blue:#3b82f6;
  --purple:#a855f7;
  --orange:#f97316;
  --red:#ef4444;

  --radius:0.75rem;        /* rounded-xl */
  --radius-lg:1rem;        /* rounded-2xl */
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  font-size:14px;
  line-height:1.5;
}
button{font-family:inherit;cursor:pointer;color:inherit}
input,select,textarea{font-family:inherit}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#3f3f46;border-radius:4px}

/* ================= SIDEBAR DESKTOP ================= */
#sidebar{
  display:none;
  position:fixed;inset:0 auto 0 0;
  width:16rem;                      /* w-64 */
  background:var(--panel);
  border-right:1px solid var(--border);
  flex-direction:column;
  z-index:50;
}
@media(min-width:1024px){ #sidebar{display:flex} }

.brand{
  display:flex;align-items:center;gap:.75rem;
  padding:1.25rem 1.5rem;
  border-bottom:1px solid var(--border);
}
.brand-icon{
  width:2.5rem;height:2.5rem;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  display:flex;align-items:center;justify-content:center;
  color:#18181b;flex-shrink:0;
}
.brand-icon svg{width:1.5rem;height:1.5rem}
.brand-title{font-weight:700;font-size:1.125rem;color:var(--text)}
.brand-sub{font-size:.75rem;color:var(--muted)}

#menu{flex:1;padding:1rem .75rem;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}

.nav-item{
  display:flex;align-items:center;gap:.75rem;
  padding:.75rem 1rem;border-radius:var(--radius);
  color:var(--text-soft);font-weight:500;
  transition:all .15s;border:none;background:transparent;
  width:100%;text-align:left;font-size:.875rem;
}
.nav-item svg{width:1.25rem;height:1.25rem;flex-shrink:0}
.nav-item:hover{background:var(--panel-2);color:var(--text)}
.nav-item.active{background:rgba(245,158,11,.10);color:var(--primary)}

.nav-group-btn{
  display:flex;align-items:center;justify-content:space-between;gap:.75rem;
  padding:.75rem 1rem;border-radius:var(--radius);
  color:var(--text-soft);font-weight:500;width:100%;
  border:none;background:transparent;transition:all .15s;font-size:.875rem;
}
.nav-group-btn:hover,.nav-group-btn.open{background:var(--panel-2);color:var(--text)}
.nav-group-btn .left{display:flex;align-items:center;gap:.75rem}
.nav-group-btn svg{width:1.25rem;height:1.25rem}
.nav-group-btn .chev{width:1rem;height:1rem;transition:transform .2s}
.nav-group-btn.open .chev{transform:rotate(180deg)}
.nav-sub{margin:.25rem 0 0 1rem;display:none;flex-direction:column;gap:.25rem}
.nav-sub.open{display:flex}
.nav-sub .nav-item{padding:.625rem 1rem;font-size:.875rem;border-radius:.5rem;color:var(--muted)}
.nav-sub .nav-item:hover{background:var(--panel-2);color:var(--text)}
.nav-sub .nav-item.active{background:rgba(245,158,11,.10);color:var(--primary)}

.sidebar-footer{padding:1rem;border-top:1px solid var(--border)}
.user-row{display:flex;align-items:center;gap:.75rem;padding:0 .5rem;margin-bottom:.75rem}
.user-avatar{
  width:2.25rem;height:2.25rem;border-radius:9999px;background:#3f3f46;
  display:flex;align-items:center;justify-content:center;color:var(--text-soft);flex-shrink:0;
}
.user-avatar svg{width:1rem;height:1rem}
.user-name{font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:.75rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.btn-logout{
  width:100%;display:flex;align-items:center;gap:.75rem;
  padding:.625rem 1rem;border-radius:var(--radius);
  color:var(--text-soft);background:transparent;border:none;font-size:.875rem;transition:all .15s;
}
.btn-logout:hover{background:var(--panel-2);color:var(--text)}
.btn-logout svg{width:1rem;height:1rem}

/* ================= HEADER MOBILE ================= */
#mobileHeader{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(24,24,27,.95);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
}
@media(min-width:1024px){ #mobileHeader{display:none} }
#mobileHeader .inner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem}
#mobileHeader .left{display:flex;align-items:center;gap:.75rem}
#mobileHeader .brand-icon{width:2.25rem;height:2.25rem}
#mobileHeader .brand-icon svg{width:1.25rem;height:1.25rem}
#mobileHeader .title{font-weight:700;color:var(--text)}
#btnMenu{padding:.5rem;border-radius:.5rem;background:transparent;border:none;color:var(--text)}
#btnMenu:hover{background:var(--panel-2)}
#btnMenu svg{width:1.5rem;height:1.5rem;display:block}

/* drawer mobile */
#overlay{
  display:none;position:fixed;inset:0;z-index:40;
  background:rgba(0,0,0,.6);backdrop-filter:blur(4px);
}
#overlay.active{display:block}
@media(min-width:1024px){ #overlay{display:none!important} }
#drawer{
  position:absolute;right:0;top:0;bottom:0;width:18rem;  /* w-72 */
  background:var(--panel);box-shadow:0 25px 50px -12px rgba(0,0,0,.5);
  padding:4rem .75rem 1rem;overflow-y:auto;
  display:flex;flex-direction:column;gap:.25rem;
}
#drawer .sep{border-top:1px solid var(--border);margin-top:.75rem;padding-top:.75rem;display:flex;flex-direction:column;gap:.25rem}

/* bottom nav mobile */
#bottomNav{
  position:fixed;bottom:0;left:0;right:0;z-index:30;
  background:rgba(24,24,27,.95);backdrop-filter:blur(8px);
  border-top:1px solid var(--border);
}
@media(min-width:1024px){ #bottomNav{display:none} }
#bottomNav .inner{display:flex;align-items:center;justify-content:space-around;padding:.5rem 0}
.bottom-item{
  display:flex;flex-direction:column;align-items:center;gap:.25rem;
  padding:.5rem .75rem;border-radius:var(--radius);
  color:var(--muted);background:none;border:none;transition:all .15s;
}
.bottom-item svg{width:1.25rem;height:1.25rem}
.bottom-item span{font-size:10px;font-weight:500}
.bottom-item.active{color:var(--primary)}

/* ================= MAIN ================= */
#main{min-height:100vh;padding-top:3.5rem}
@media(min-width:1024px){ #main{padding-left:16rem;padding-top:0} }
#content{padding:1rem;padding-bottom:5.5rem}
@media(min-width:1024px){ #content{padding:1.5rem;padding-bottom:1.5rem} }

/* ================= LOADER ================= */
#globalLoader{
  display:none;position:fixed;inset:0;z-index:90;
  align-items:center;justify-content:center;
  background:rgba(9,9,11,.6);backdrop-filter:blur(2px);
}
#globalLoader.active{display:flex}
.spinner{
  width:2.5rem;height:2.5rem;border-radius:9999px;
  border:3px solid var(--panel-2);border-top-color:var(--primary);
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-block{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:5rem 0;color:var(--muted)}

/* ================= TIPOGRAFIA / PAGE HEADER ================= */
.page-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}
@media(min-width:640px){.page-header{flex-direction:row;align-items:center;justify-content:space-between}}
.page-title{font-size:1.5rem;font-weight:700;color:var(--text)}
@media(min-width:1024px){.page-title{font-size:1.875rem}}
.page-sub{color:var(--muted);margin-top:.25rem}

/* ================= CARDS ================= */
.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
}
.card-pad{padding:1.25rem}
.card-header{padding:1.25rem 1.25rem .75rem;font-weight:600;font-size:1rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.card-body{padding:0 1.25rem 1.25rem}

/* card turno ativo */
.turno-card{
  background:linear-gradient(90deg,rgba(245,158,11,.10),rgba(217,119,6,.05));
  border:1px solid rgba(245,158,11,.20);
  border-radius:var(--radius-lg);
  padding:1.25rem;
}
.pulse-dot{width:.75rem;height:.75rem;border-radius:9999px;background:var(--green);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* stat cards */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}
@media(min-width:1024px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}
.stat-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-weight:500}
.stat-value{font-size:1.5rem;font-weight:700;margin-top:.25rem}
.stat-extra{font-size:.75rem;margin-top:.25rem;color:var(--muted)}
.stat-icon{width:3rem;height:3rem;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-icon svg{width:1.5rem;height:1.5rem}
.tint-amber{background:rgba(245,158,11,.10);color:var(--primary)}
.tint-blue{background:rgba(59,130,246,.10);color:var(--blue)}
.tint-purple{background:rgba(168,85,247,.10);color:var(--purple)}
.tint-green{background:rgba(34,197,94,.10);color:var(--green)}
.tint-red{background:rgba(239,68,68,.10);color:var(--red)}
.tint-orange{background:rgba(249,115,22,.10);color:var(--orange)}

/* quick actions */
.quick-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}
@media(min-width:1024px){.quick-grid{grid-template-columns:repeat(4,1fr)}}
.quick-card{
  border-radius:var(--radius-lg);padding:1.25rem;cursor:pointer;border:1px solid var(--border);
  background:var(--panel);transition:all .15s;display:flex;flex-direction:column;gap:.5rem;height:100%;
  text-align:left;
}
.quick-card:hover{background:var(--panel-2)}
.quick-card svg{width:1.75rem;height:1.75rem}
.quick-card .label{font-weight:600}
.quick-card.primary{
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  border:none;color:#18181b;
}
.quick-card.primary:hover{background:linear-gradient(135deg,var(--primary-2),var(--primary-3))}

/* ================= BOTÕES ================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  border-radius:var(--radius);font-weight:500;font-size:.875rem;
  padding:.625rem 1rem;border:1px solid transparent;transition:all .15s;
  background:var(--panel-2);color:var(--text);
}
.btn svg{width:1.125rem;height:1.125rem}
.btn:hover{background:#3f3f46}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-lg{height:3rem;padding:0 1.5rem}
.btn-sm{padding:.375rem .625rem;font-size:.8125rem}
.btn-sm svg{width:.9375rem;height:.9375rem}
.btn-primary{
  background:linear-gradient(90deg,var(--primary),var(--primary-2));
  color:#18181b;font-weight:600;border:none;
}
.btn-primary:hover{background:linear-gradient(90deg,var(--primary-2),var(--primary-3))}
.btn-outline{background:transparent;border:1px solid var(--panel-2);color:var(--text)}
.btn-outline:hover{background:var(--panel-2)}
.btn-danger{background:var(--red);color:#fff;border:none}
.btn-danger:hover{background:#dc2626}
.btn-danger-outline{background:transparent;border:1px solid rgba(239,68,68,.5);color:var(--red)}
.btn-danger-outline:hover{background:rgba(239,68,68,.10)}
.btn-ghost{background:transparent;color:var(--text-soft)}
.btn-ghost:hover{background:var(--panel-2);color:var(--text)}
.btn-icon{padding:.5rem;border-radius:.5rem}
.btn-block{width:100%}

/* ================= FORMULÁRIOS ================= */
.field{margin-bottom:1rem}
.field label{display:block;font-size:.875rem;font-weight:500;color:var(--text-soft);margin-bottom:.375rem}
.field .hint{font-size:.75rem;color:var(--muted-2);margin-top:.25rem}
.input,select.input,textarea.input{
  width:100%;background:var(--panel-2);border:1px solid var(--panel-2);
  border-radius:var(--radius);color:var(--text);padding:.625rem .875rem;font-size:.875rem;
  outline:none;transition:border .15s, box-shadow .15s;
}
.input:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(245,158,11,.25)}
.input::placeholder{color:var(--muted-2)}
textarea.input{resize:vertical;min-height:5rem}
.input-icon{position:relative}
.input-icon svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1.25rem;height:1.25rem;color:var(--muted)}
.input-icon .input{padding-left:2.75rem}

/* opções selecionáveis (meio de pagamento etc.) */
.opt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}
.opt-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.opt-btn{
  display:flex;flex-direction:column;align-items:center;gap:.375rem;
  padding:.75rem .5rem;border-radius:var(--radius);
  background:var(--panel-2);border:1px solid var(--panel-2);
  color:var(--text-soft);font-size:.8125rem;font-weight:500;transition:all .15s;
}
.opt-btn svg{width:1.25rem;height:1.25rem}
.opt-btn:hover{border-color:#3f3f46}
.opt-btn.selected{background:rgba(245,158,11,.10);border-color:var(--primary);color:var(--primary)}

/* ================= LISTAS / ITENS ================= */
.list{display:flex;flex-direction:column;gap:.75rem}
.list-item{
  display:flex;align-items:center;justify-content:space-between;gap:.75rem;
  background:var(--panel-2);border-radius:var(--radius);padding:.75rem 1rem;
}
.list-item > svg{width:1.25rem;height:1.25rem;flex-shrink:0;color:var(--muted)}
.item-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.item-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1280px){.item-grid{grid-template-columns:repeat(3,1fr)}}

/* badges */
.badge{display:inline-flex;align-items:center;gap:.25rem;border-radius:9999px;padding:.125rem .625rem;font-size:.75rem;font-weight:600}
.badge-amber{background:rgba(245,158,11,.15);color:var(--primary)}
.badge-green{background:rgba(34,197,94,.15);color:var(--green)}
.badge-blue{background:rgba(59,130,246,.15);color:var(--blue)}
.badge-red{background:rgba(239,68,68,.15);color:var(--red)}
.badge-zinc{background:#3f3f46;color:var(--text-soft)}

/* barra de progresso (volume do barril) */
.progress{height:.5rem;border-radius:9999px;background:var(--panel-2);overflow:hidden}
.progress > div{height:100%;border-radius:9999px;transition:width .3s}
.pg-green{background:var(--green)}
.pg-amber{background:var(--primary)}
.pg-red{background:var(--red)}

/* empty state */
.empty{
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  padding:3rem 1rem;color:var(--muted);text-align:center;
}
.empty svg{width:3rem;height:3rem;color:#3f3f46}
.empty .t{font-weight:600;color:var(--text-soft)}
.empty .s{font-size:.875rem;color:var(--muted-2)}

/* ================= MODAL ================= */
.modal-overlay{
  position:fixed;inset:0;z-index:80;background:rgba(0,0,0,.8);
  display:flex;align-items:center;justify-content:center;padding:1rem;
  animation:fadeIn .15s ease;
}
.modal{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius-lg);width:100%;max-width:32rem;
  max-height:90vh;overflow-y:auto;
  padding:1.5rem;box-shadow:0 25px 50px -12px rgba(0,0,0,.6);
  animation:zoomIn .15s ease;
}
.modal-sm{max-width:26rem}
.modal-lg{max-width:48rem}
.modal-title{font-size:1.125rem;font-weight:600;margin-bottom:.25rem}
.modal-desc{font-size:.875rem;color:var(--muted);margin-bottom:1.25rem}
.modal-footer{display:flex;flex-direction:column-reverse;gap:.5rem;margin-top:1.5rem}
@media(min-width:640px){.modal-footer{flex-direction:row;justify-content:flex-end}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes zoomIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}

/* ================= TOAST ================= */
#toasts{position:fixed;bottom:1.25rem;right:1.25rem;z-index:100;display:flex;flex-direction:column;gap:.5rem}
.toast{
  background:var(--panel);border:1px solid var(--border);color:var(--text);
  border-radius:var(--radius);padding:.75rem 1rem;min-width:16rem;max-width:22rem;
  display:flex;align-items:center;gap:.625rem;font-size:.875rem;
  box-shadow:0 10px 25px rgba(0,0,0,.4);animation:slideUp .2s ease;
}
.toast svg{width:1.125rem;height:1.125rem;flex-shrink:0}
.toast.success svg{color:var(--green)}
.toast.error svg{color:var(--red)}
@keyframes slideUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* utilitários */
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}
.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}
.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}
.text-muted{color:var(--muted)}.text-soft{color:var(--text-soft)}
.text-amber{color:var(--primary)}.text-green{color:var(--green)}
.text-blue{color:var(--blue)}.text-red{color:var(--red)}
.font-bold{font-weight:700}.font-semibold{font-weight:600}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cor-dot{width:.75rem;height:.75rem;border-radius:9999px;display:inline-block;flex-shrink:0}

/* ===== complementos (cadastros / relatórios / compras) ===== */
.stats-grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media(min-width:1024px){.stats-grid.cols-2{grid-template-columns:repeat(2,1fr)}}
.badge-purple{background:rgba(168,85,247,.15);color:var(--purple)}
.cor-dot-lg{width:1.25rem;height:1.25rem}
.cor-grid{display:flex;flex-wrap:wrap;gap:.5rem}
.cor-swatch{
  width:2rem;height:2rem;border-radius:9999px;border:2px solid transparent;
  cursor:pointer;transition:transform .1s,border-color .15s;
}
.cor-swatch:hover{transform:scale(1.1)}
.cor-swatch.ativo{border-color:var(--text);box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--primary)}
.op-avatar{
  width:2.5rem;height:2.5rem;border-radius:9999px;flex-shrink:0;
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#18181b;font-weight:700;display:flex;align-items:center;justify-content:center;
}
.filtro-datas{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.filtro-datas{grid-template-columns:repeat(2,1fr);max-width:28rem}}
