:root{
  --bg: #f6f7f9;
  --card: #ffffff;
  --text: #0f172a;
  --muted: #64748b;
  --brand: #16a3a6;
  --brand-2: #0ea5e9;
  --border: #e5e7eb;
}

html, body { height: 100%; }

body{
  background: var(--bg);
  color: var(--text);
}

/* Fundo com “vida” (bem discreto) */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(900px 450px at 15% 10%, rgba(14,165,233,.14), transparent 55%),
    radial-gradient(800px 420px at 85% 20%, rgba(22,163,166,.14), transparent 55%),
    radial-gradient(900px 550px at 50% 90%, rgba(99,102,241,.07), transparent 60%);
}

/* Brand */
.brand-logo{
  height:26px;
  width:auto;
  border-radius:6px;
  background:#000;
  padding:2px 6px;
}

/* Layout */
.min-vh-lg-100 { min-height: 100vh; }
@media (max-width: 991px){ .min-vh-lg-100 { min-height: auto; } }

/* Sidebar links */
.nav-item-link{
  display:flex;
  align-items:center;
  padding:.55rem .75rem;
  border:1px solid var(--border);
  border-radius:12px;
  color:var(--text);
  text-decoration:none;
  transition: background .18s ease, border-color .18s ease, transform .18s ease;
}
.nav-item-link:hover{
  background:#f1f5f9;
  border-color:#d1d5db;
  transform: translateY(-1px);
}
.nav-item-link.is-active{
  background:rgba(22,163,166,.10);
  border-color:rgba(22,163,166,.35);
}

/* Cards */
.card{
  border:1px solid var(--border);
  border-radius:16px;
}
.card.shadow-sm{
  box-shadow:0 10px 28px rgba(15,23,42,.07) !important;
}
.card.hover-lift{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card.hover-lift:hover{
  transform: translateY(-2px);
  border-color: rgba(22,163,166,.32);
  box-shadow:0 14px 34px rgba(15,23,42,.10) !important;
}

/* Buttons */
.btn-brand{
  background:var(--brand);
  border-color:var(--brand);
  color:#fff;
}
.btn-brand:hover{ filter:brightness(.95); }
.btn-soft{
  background: rgba(22,163,166,.10);
  border: 1px solid rgba(22,163,166,.25);
  color: #0b6b6e;
}
.btn-soft:hover{ background: rgba(22,163,166,.14); }

/* Typography helpers */
.price{
  font-variant-numeric: tabular-nums;
  font-size: 1.35rem;
  font-weight: 800;
}
.muted{ color: var(--muted); }

/* Badges */
.badge-soft{
  background:rgba(22,163,166,.12);
  color:#0b6b6e;
  border:1px solid rgba(22,163,166,.25);
}
.badge-soft-blue{
  background:rgba(14,165,233,.12);
  color:#075985;
  border:1px solid rgba(14,165,233,.25);
}

/* HERO “água” */
.hero{
  border:1px solid var(--border);
  border-radius:18px;
  position: relative;
  overflow: hidden;
}
.hero-water{
  background: linear-gradient(135deg,
    rgba(22,163,166,.14),
    rgba(14,165,233,.12),
    rgba(99,102,241,.06)
  );
}
.hero-water::after{
  content:"";
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.35), transparent 55%);
  opacity:.45;
  transform: rotate(12deg);
  animation: heroGlow 10s ease-in-out infinite;
}
@keyframes heroGlow{
  0%{ transform: translate3d(-2%, -2%, 0) rotate(12deg); opacity:.35; }
  50%{ transform: translate3d(2%, 2%, 0) rotate(12deg); opacity:.55; }
  100%{ transform: translate3d(-2%, -2%, 0) rotate(12deg); opacity:.35; }
}

.hero-wave{
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  width:100%;
  height:64px;
  opacity:.55;
}

/* Section titles */
.section-title{
  font-weight: 800;
  letter-spacing: -0.02em;
}
.card { border-radius: 16px; }
.btn-lg { border-radius: 14px; }
.form-control, .input-group-text { border-radius: 12px; }
.form-select { border-radius: 12px; }

.surface-panel{
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(14px);
  border:1px solid rgba(226,232,240,.9);
  border-radius:24px;
  padding:24px;
  box-shadow: 0 18px 44px rgba(15,23,42,.08);
}

.eyebrow{
  font-size:.75rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#0f766e;
  font-weight:800;
  margin-bottom:.45rem;
}

.page-title,
.section-heading{
  font-weight:800;
  letter-spacing:-.03em;
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:16px;
}

.metric-card{
  background:#fff;
  border:1px solid rgba(226,232,240,.95);
  border-radius:22px;
  padding:20px;
  box-shadow:0 16px 36px rgba(15,23,42,.06);
}

.metric-card-brand{
  background:linear-gradient(135deg, rgba(22,163,166,.14), rgba(14,165,233,.18), rgba(255,255,255,.96));
  border-color:rgba(22,163,166,.25);
}

.metric-label{
  color:#64748b;
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
}

.metric-value{
  font-size:1.95rem;
  font-weight:800;
  letter-spacing:-.04em;
  color:#0f172a;
  margin-top:.45rem;
}

.metric-meta{
  font-size:.85rem;
  color:#64748b;
  margin-top:.55rem;
}

.stack-list{
  display:grid;
  gap:12px;
}

.stack-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding:14px 16px;
  border:1px solid rgba(226,232,240,.95);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,252,.96));
  text-decoration:none;
  color:inherit;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.stack-item:hover{
  transform:translateY(-1px);
  border-color:rgba(22,163,166,.3);
  box-shadow:0 12px 28px rgba(15,23,42,.08);
}

.table-modern thead th{
  border-bottom:1px solid rgba(226,232,240,.95);
  color:#64748b;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.table-modern tbody td{
  border-color:rgba(226,232,240,.72);
  vertical-align:middle;
}

.status-pill{
  display:inline-flex;
  align-items:center;
  padding:.38rem .7rem;
  border-radius:999px;
  font-size:.76rem;
  font-weight:700;
}

.status-pill-success{
  background:rgba(22,163,74,.12);
  color:#166534;
}

.status-pill-warning{
  background:rgba(245,158,11,.16);
  color:#92400e;
}

.status-pill-danger{
  background:rgba(239,68,68,.12);
  color:#991b1b;
}

.status-pill-muted{
  background:rgba(100,116,139,.12);
  color:#334155;
}

.store-card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:20px;
}

.store-selector-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:14px;
}

.store-selector-card{
  width:100%;
  text-align:left;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
  border:1px solid rgba(226,232,240,.95);
  border-radius:20px;
  padding:16px 18px;
  box-shadow:0 10px 24px rgba(15,23,42,.05);
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.store-selector-card:hover{
  transform:translateY(-1px);
  border-color:rgba(22,163,166,.28);
  box-shadow:0 14px 28px rgba(15,23,42,.08);
}

.store-selector-card.is-active{
  border-color:rgba(14,165,233,.34);
  box-shadow:0 16px 34px rgba(14,165,233,.12);
  background:linear-gradient(180deg, rgba(240,249,255,.96), rgba(255,255,255,.98));
}

.store-selector-title{
  font-size:1rem;
  font-weight:800;
  letter-spacing:-.02em;
}

.store-selector-subtitle{
  color:#64748b;
  font-size:.86rem;
  margin-top:2px;
}

.store-selector-metrics{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
  color:#475569;
  font-size:.82rem;
}

.store-selector-caret{
  color:#94a3b8;
  transition:transform .18s ease, color .18s ease;
}

.store-selector-card.is-active .store-selector-caret{
  color:#0284c7;
  transform:rotate(180deg);
}

.store-panel-stack{
  display:grid;
  gap:18px;
}

.store-detail-panel{
  display:none;
}

.store-detail-panel.is-active{
  display:block;
}

.store-detail-summary{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));
  gap:12px;
}

.store-card-panel{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
  border:1px solid rgba(226,232,240,.95);
  border-radius:24px;
  padding:24px;
  box-shadow:0 18px 42px rgba(15,23,42,.08);
}

.store-card-accent{
  position:absolute;
  inset:0 auto 0 0;
  width:5px;
}

.store-card-accent-active{
  background:linear-gradient(180deg, #0ea5e9, #16a34a);
}

.store-card-accent-inactive{
  background:linear-gradient(180deg, #f97316, #ef4444);
}

.store-card-icon{
  width:62px;
  height:62px;
  border-radius:20px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(14,165,233,.14), rgba(59,130,246,.08));
  color:#0f66d6;
  font-size:1.55rem;
  box-shadow:inset 0 0 0 1px rgba(14,165,233,.12);
}

.store-card-title{
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:-.03em;
  margin:0;
}

.store-card-subtitle{
  color:#64748b;
  font-size:.92rem;
}

.store-card-add{
  width:42px;
  height:42px;
  border-radius:999px;
  display:grid;
  place-items:center;
  text-decoration:none;
  background:linear-gradient(135deg, #10b981, #14b8a6);
  color:#fff;
  box-shadow:0 10px 22px rgba(20,184,166,.28);
}

.store-card-add:hover{
  color:#fff;
  filter:brightness(.97);
}

.store-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:.28rem .72rem;
  border-radius:999px;
  font-size:.74rem;
  font-weight:800;
  letter-spacing:.02em;
  border:1px solid transparent;
}

.store-chip-brand{
  background:rgba(37,99,235,.1);
  color:#1d4ed8;
  border-color:rgba(37,99,235,.22);
}

.store-chip-success{
  background:rgba(22,163,74,.1);
  color:#166534;
  border-color:rgba(22,163,74,.18);
}

.store-chip-danger{
  background:rgba(239,68,68,.1);
  color:#991b1b;
  border-color:rgba(239,68,68,.18);
}

.store-chip-warning{
  background:rgba(245,158,11,.14);
  color:#92400e;
  border-color:rgba(245,158,11,.18);
}

.store-chip-muted{
  background:rgba(100,116,139,.12);
  color:#334155;
  border-color:rgba(100,116,139,.16);
}

.store-detail-list{
  display:grid;
  gap:10px;
}

.store-detail-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:#475569;
  font-size:.92rem;
}

.store-detail-item i{
  color:#0ea5e9;
  margin-top:2px;
}

.store-metrics-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}

.store-metric{
  background:#fff;
  border:1px solid rgba(226,232,240,.95);
  border-radius:18px;
  padding:14px 16px;
}

.store-metric-label{
  color:#64748b;
  font-size:.74rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.store-metric-value{
  color:#0f172a;
  font-size:1.1rem;
  font-weight:800;
  margin-top:.35rem;
}

.store-footer-pill{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:.7rem 1rem;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,252,.96));
  border:1px solid rgba(226,232,240,.95);
  color:#475569;
  font-size:.9rem;
}

.machine-webhook-box{
  width:min(100%, 520px);
  padding:16px 18px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
  border:1px solid rgba(226,232,240,.95);
  box-shadow:0 12px 26px rgba(15,23,42,.05);
}

.machine-webhook-box code{
  display:block;
  color:#0f172a;
  font-size:.96rem;
  word-break:break-all;
}

.machine-card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(290px, 1fr));
  gap:20px;
}

.machine-card-grid-compact{
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:16px;
}

.machine-card-panel{
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
  border:1px solid rgba(226,232,240,.95);
  border-radius:24px;
  padding:22px;
  box-shadow:0 18px 40px rgba(15,23,42,.07);
}

.machine-card-icon{
  width:56px;
  height:56px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(59,130,246,.14), rgba(14,165,233,.08));
  color:#2563eb;
  font-size:1.4rem;
}

.machine-card-title{
  font-size:1.08rem;
  font-weight:800;
  letter-spacing:-.02em;
  margin:0;
}

.machine-card-subtitle{
  color:#64748b;
  font-size:.92rem;
}

.machine-detail-list{
  display:grid;
  gap:10px;
}

.machine-detail-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:#475569;
  font-size:.92rem;
}

.machine-detail-item i{
  color:#0ea5e9;
  margin-top:2px;
}

.machine-metrics-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}

.machine-card-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.machine-mini-card{
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
  border:1px solid rgba(226,232,240,.95);
  border-radius:22px;
  padding:18px;
  box-shadow:0 12px 28px rgba(15,23,42,.06);
}

.machine-mini-title{
  font-size:1rem;
  font-weight:800;
  letter-spacing:-.02em;
  margin:0;
}

.machine-mini-subtitle{
  color:#64748b;
  font-size:.84rem;
}

.machine-mini-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  color:#475569;
  font-size:.84rem;
}

.machine-mini-meta a{
  text-decoration:none;
}

.machine-mini-stats{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}

.empty-panel{
  border:1px dashed rgba(203,213,225,.95);
  border-radius:22px;
  padding:42px 20px;
  text-align:center;
  color:#64748b;
  background:rgba(248,250,252,.7);
}

.customer-card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:20px;
}

.customer-card-panel{
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
  border:1px solid rgba(226,232,240,.95);
  border-radius:24px;
  padding:24px;
  box-shadow:0 18px 42px rgba(15,23,42,.07);
}

.customer-avatar{
  width:58px;
  height:58px;
  border-radius:20px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(22,163,166,.14), rgba(14,165,233,.10));
  color:#0f766e;
  font-size:1.3rem;
  font-weight:800;
}

.customer-balance{
  font-size:1.2rem;
  font-weight:800;
  color:#0f172a;
}

.customer-contact-list{
  display:grid;
  gap:10px;
}

.customer-contact-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:#475569;
  font-size:.92rem;
}

.customer-contact-item i{
  color:#0ea5e9;
  margin-top:2px;
}

.customer-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
