/* ============================================================
   PETSHOP — DESIGN SYSTEM "CLEAN PRO"
   Paleta: white #ffffff · surface #f5f7fb · navy #1e293b · accent #3b82f6
   ============================================================ */

:root{
  --bg:#f5f7fb;
  --surface:#ffffff;
  --surface-2:#f8fafc;
  --border:#e5e9f2;
  --border-strong:#cbd5e1;
  --text:#0f172a;
  --text-2:#475569;
  --muted:#64748b;
  --primary:#3b82f6;
  --primary-600:#2563eb;
  --primary-700:#1d4ed8;
  --primary-50:#eff6ff;
  --primary-100:#dbeafe;
  --navy:#1e293b;
  --navy-2:#0f172a;
  --success:#10b981;
  --success-50:#ecfdf5;
  --warn:#f59e0b;
  --warn-50:#fffbeb;
  --danger:#ef4444;
  --danger-50:#fef2f2;
  --shadow-xs:0 1px 2px rgba(15,23,42,.04);
  --shadow-sm:0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
  --shadow-md:0 4px 12px rgba(15,23,42,.06), 0 2px 4px rgba(15,23,42,.04);
  --shadow-lg:0 12px 32px rgba(15,23,42,.08);
  --radius:10px;
  --radius-lg:14px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primary-600)}
a:hover{color:var(--primary-700)}

/* ============ LAYOUT ============ */
.layout{display:flex;min-height:100vh}

/* ============ SIDEBAR ============ */
.sidebar{
  width:248px;
  background:#ffffff;
  color:var(--text-2);
  display:flex;flex-direction:column;
  position:fixed;inset:0 auto 0 0;z-index:50;
  border-right:1px solid var(--border);
}
.sidebar .brand{
  padding:20px 18px;
  display:flex;align-items:center;gap:12px;
  border-bottom:1px solid var(--border);
}
.brand-logo{
  width:40px;height:40px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary),var(--primary-700));
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;color:#fff;
  box-shadow:0 4px 10px rgba(59,130,246,.3);
}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text strong{color:var(--navy);font-size:1rem;font-weight:700;letter-spacing:-.01em}
.brand-text small{color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:1.2px;margin-top:2px;font-weight:600}

.side-nav{flex:1;padding:14px 10px;display:flex;flex-direction:column;gap:1px;overflow-y:auto}
.side-nav::-webkit-scrollbar{width:6px}
.side-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

.nav-group{
  font-size:.66rem;text-transform:uppercase;letter-spacing:1.4px;
  color:var(--muted);padding:14px 12px 6px;font-weight:700;
}
.nav-group:first-child{padding-top:4px}

.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:9px 12px;color:var(--text-2);text-decoration:none;
  border-radius:8px;font-size:.88rem;font-weight:500;
  position:relative;transition:all .15s ease;
}
.nav-item .ico{
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  border-radius:9px;flex-shrink:0;
  color:#fff;
  background:linear-gradient(160deg,#60a5fa 0%,#3b82f6 50%,#1d4ed8 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    inset 0 -2px 4px rgba(15,23,42,.25),
    0 4px 8px rgba(59,130,246,.35),
    0 1px 2px rgba(15,23,42,.15);
  transition:transform .2s cubic-bezier(.34,1.56,.64,1), box-shadow .2s ease;
  position:relative;
  overflow:hidden;
}
.nav-item .ico::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(180deg,rgba(255,255,255,.35) 0%,rgba(255,255,255,0) 45%);
  pointer-events:none;
}
.nav-item .ico svg{
  position:relative;z-index:1;
  filter:drop-shadow(0 1px 1px rgba(15,23,42,.4));
  width:15px;height:15px;
  stroke-width:2.4;
}
.nav-item .label{flex:1}
.nav-item .chevron{opacity:0;transform:translateX(-4px);transition:.15s;color:var(--primary);font-weight:700}
.nav-item:hover{background:var(--surface-2);color:var(--navy)}
.nav-item:hover .ico{
  transform:translateY(-2px) scale(1.06);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.5),
    inset 0 -2px 4px rgba(15,23,42,.25),
    0 8px 16px rgba(59,130,246,.45),
    0 2px 4px rgba(15,23,42,.18);
}
.nav-item:hover .chevron{opacity:.7;transform:translateX(0)}

/* Cores 3D distintas por grupo (via nth-of-type adjacente ao nav-group) */
.nav-group + .nav-item .ico,
.nav-group + .nav-item ~ .nav-item .ico{}

/* Variantes de cor 3D — aplicadas conforme o grupo (1º grupo: azul padrão) */
.side-nav .nav-group:nth-of-type(2) ~ .nav-item .ico{
  background:linear-gradient(160deg,#a78bfa 0%,#8b5cf6 50%,#6d28d9 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45),inset 0 -2px 4px rgba(15,23,42,.25),0 4px 8px rgba(139,92,246,.35),0 1px 2px rgba(15,23,42,.15);
}
.side-nav .nav-group:nth-of-type(3) ~ .nav-item .ico{
  background:linear-gradient(160deg,#fb923c 0%,#f97316 50%,#c2410c 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45),inset 0 -2px 4px rgba(15,23,42,.25),0 4px 8px rgba(249,115,22,.35),0 1px 2px rgba(15,23,42,.15);
}
.side-nav .nav-group:nth-of-type(4) ~ .nav-item .ico{
  background:linear-gradient(160deg,#34d399 0%,#10b981 50%,#047857 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45),inset 0 -2px 4px rgba(15,23,42,.25),0 4px 8px rgba(16,185,129,.35),0 1px 2px rgba(15,23,42,.15);
}
.side-nav .nav-group:nth-of-type(5) ~ .nav-item .ico{
  background:linear-gradient(160deg,#94a3b8 0%,#64748b 50%,#334155 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4),inset 0 -2px 4px rgba(15,23,42,.3),0 4px 8px rgba(71,85,105,.4),0 1px 2px rgba(15,23,42,.18);
}

.nav-item.active{background:var(--primary-50);color:var(--primary-700);font-weight:600}
.nav-item.active::before{
  content:'';position:absolute;left:-10px;top:8px;bottom:8px;width:3px;
  background:var(--primary);border-radius:0 3px 3px 0;
}
.nav-item.active .ico{transform:scale(1.05)}
.nav-item.active .chevron{opacity:1;transform:translateX(0)}

.side-foot{padding:12px;border-top:1px solid var(--border);background:var(--surface-2)}
.user-card{
  display:flex;align-items:center;gap:10px;padding:8px;
  background:#fff;border-radius:10px;border:1px solid var(--border);
}
.user-card .avatar{
  width:36px;height:36px;border-radius:8px;
  background:linear-gradient(135deg,var(--primary),var(--primary-700));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.82rem;flex-shrink:0;
}
.user-card .user-mini{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.2}
.user-card .user-mini strong{color:var(--navy);font-size:.83rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.user-card .user-mini small{color:var(--muted);font-size:.7rem;text-transform:capitalize;margin-top:2px}
.user-card .logout{
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  border-radius:7px;color:var(--danger);background:var(--danger-50);
  text-decoration:none;font-size:.95rem;transition:.15s;border:1px solid transparent;
}
.user-card .logout:hover{background:var(--danger);color:#fff}

.scrim{position:fixed;inset:0;background:rgba(15,23,42,.4);backdrop-filter:blur(2px);z-index:40;opacity:0;pointer-events:none;transition:opacity .25s}
body.sb-open .scrim{opacity:1;pointer-events:auto}

/* ============ MAIN AREA ============ */
.main-area{flex:1;margin-left:248px;display:flex;flex-direction:column;min-width:0}
.topbar{
  background:#fff;padding:12px 24px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:14px;min-height:56px;
  position:sticky;top:0;z-index:20;
}
.menu-toggle{
  display:none;background:var(--primary-50);border:1px solid var(--primary-100);
  font-size:1.1rem;cursor:pointer;color:var(--primary-700);
  width:38px;height:38px;border-radius:8px;
  align-items:center;justify-content:center;
}
.container{flex:1;max-width:1240px;width:100%;margin:0 auto;padding:24px}

/* ============ TYPOGRAPHY ============ */
h1{font-size:1.5rem;margin-bottom:14px;color:var(--navy);font-weight:700;letter-spacing:-.015em}
h2{font-size:1.05rem;margin-bottom:12px;color:var(--navy);font-weight:600;letter-spacing:-.01em}
h3{font-size:.95rem;color:var(--navy);font-weight:600}
.muted{color:var(--muted);font-size:.85rem}
.muted.block{display:block;margin-top:2px}

/* ============ CARD ============ */
.card{
  background:#fff;border-radius:var(--radius-lg);padding:20px;
  box-shadow:var(--shadow-xs);margin-bottom:18px;
  border:1px solid var(--border);
}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px}
.card-head h2{margin:0}

/* ============ TABLE ============ */
table{width:100%;border-collapse:collapse}
th,td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--border);font-size:.88rem;vertical-align:middle}
th{
  background:var(--surface-2);color:var(--text-2);font-weight:600;
  font-size:.74rem;text-transform:uppercase;letter-spacing:.5px;
}
tr:hover td{background:var(--surface-2)}
tr:last-child td{border-bottom:0}
.table-wrap{overflow-x:auto;border-radius:8px}
.tbl-clean{font-size:.88rem}
.tbl-clean th{background:transparent;border-bottom:2px solid var(--border)}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 14px;border-radius:8px;border:1px solid var(--border-strong);
  cursor:pointer;font-size:.86rem;text-decoration:none;
  transition:all .15s;font-weight:500;color:var(--text);background:#fff;
  white-space:nowrap;
}
.btn:hover{background:var(--surface-2);border-color:var(--text-2);color:var(--navy)}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-600);border-color:var(--primary-600);color:#fff}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-danger:hover{background:#dc2626;border-color:#dc2626;color:#fff}
.btn-ghost{background:transparent;color:var(--text);border-color:transparent}
.btn-ghost:hover{background:var(--surface-2)}
.btn-sm{padding:5px 10px;font-size:.78rem;border-radius:6px}
.actions{display:flex;gap:6px;flex-wrap:wrap}
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px;flex-wrap:wrap}

/* ============ FORMS ============ */
form .field{margin-bottom:14px}
form label{display:block;font-size:.82rem;font-weight:600;margin-bottom:5px;color:var(--text-2)}
form input,form select,form textarea{
  width:100%;padding:9px 12px;border:1px solid var(--border-strong);border-radius:8px;
  font-size:.9rem;font-family:inherit;color:var(--text);background:#fff;
  transition:border-color .15s,box-shadow .15s;
}
form input:focus,form select:focus,form textarea:focus{
  outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(59,130,246,.15);
}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ============ ALERTS ============ */
.flash,.alert{padding:11px 14px;border-radius:8px;margin-bottom:14px;font-size:.88rem;border:1px solid}
.flash{background:var(--success-50);color:#065f46;border-color:#a7f3d0}
.error,.alert-danger{background:var(--danger-50);color:#991b1b;border-color:#fecaca}
.alert-warn{background:var(--warn-50);color:#92400e;border-color:#fde68a}
.alert a{font-weight:600;margin-left:6px}

/* ============ FOOTER ============ */
.footer{text-align:center;padding:18px;color:var(--muted);font-size:.82rem}

/* ============ LOGIN ============ */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff 0%,#f5f7fb 100%);padding:20px}
.login-card{background:#fff;padding:36px;border-radius:16px;width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.login-card h1{text-align:center;margin-bottom:24px}

/* ============ STATS ============ */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:20px}
.stat{
  background:#fff;padding:18px;border-radius:var(--radius-lg);
  border:1px solid var(--border);box-shadow:var(--shadow-xs);
  position:relative;overflow:hidden;
}
.stat .label{color:var(--muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.stat .value{font-size:1.7rem;font-weight:700;color:var(--navy);margin-top:6px;letter-spacing:-.02em;line-height:1.1}

/* ============ KPI GRID (Painel) ============ */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:20px}
.kpi{
  background:#fff;border-radius:var(--radius-lg);padding:18px;
  border:1px solid var(--border);box-shadow:var(--shadow-xs);
  display:flex;align-items:flex-start;gap:14px;
  transition:transform .15s,box-shadow .15s;
}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.kpi-ico{
  width:44px;height:44px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;flex-shrink:0;
  background:var(--primary-50);color:var(--primary-700);
}
.kpi-blue .kpi-ico{background:#eff6ff;color:#1d4ed8}
.kpi-teal .kpi-ico{background:#ecfeff;color:#0e7490}
.kpi-violet .kpi-ico{background:#f5f3ff;color:#6d28d9}
.kpi-green .kpi-ico{background:#ecfdf5;color:#047857}
.kpi-orange .kpi-ico{background:#fff7ed;color:#c2410c}
.kpi-pink .kpi-ico{background:#fdf2f8;color:#be185d}
.kpi-body{flex:1;min-width:0}
.kpi-label{color:var(--muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.kpi-value{font-size:1.55rem;font-weight:700;color:var(--navy);margin-top:4px;line-height:1.1;letter-spacing:-.02em}
.kpi-foot{color:var(--muted);font-size:.78rem;margin-top:6px}
.trend{display:inline-flex;align-items:center;font-size:.74rem;font-weight:600;padding:2px 6px;border-radius:5px;margin-right:4px}
.trend.up{background:var(--success-50);color:#047857}
.trend.down{background:var(--danger-50);color:#b91c1c}
.trend.flat{background:var(--surface-2);color:var(--muted)}

/* ============ BADGES ============ */
.badge{display:inline-block;padding:3px 9px;border-radius:6px;font-size:.74rem;font-weight:600;text-transform:capitalize;border:1px solid}
.badge-agendado{background:var(--primary-50);color:#1e40af;border-color:#bfdbfe}
.badge-em_andamento{background:var(--warn-50);color:#92400e;border-color:#fde68a}
.badge-concluido{background:var(--success-50);color:#065f46;border-color:#a7f3d0}
.badge-cancelado{background:var(--danger-50);color:#991b1b;border-color:#fecaca}

/* ============ PAINEL ============ */
.painel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.painel-head h1{margin:0}
.quick-actions{display:flex;gap:8px;flex-wrap:wrap}
.painel-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;margin-bottom:18px}
@media(max-width:1000px){.painel-grid{grid-template-columns:1fr}}

.spark{display:flex;align-items:flex-end;gap:8px;height:160px;padding:8px 0}
.spark-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.spark-bar{width:100%;max-width:36px;background:linear-gradient(180deg,var(--primary),var(--primary-700));border-radius:6px 6px 0 0;min-height:4px;transition:opacity .15s}
.spark-col:hover .spark-bar{opacity:.8}
.spark-lbl{font-size:.7rem;color:var(--muted);font-weight:500}

.rank{list-style:none;display:flex;flex-direction:column;gap:12px}
.rank li{display:flex;flex-direction:column;gap:6px}
.rank-row{display:flex;align-items:center;gap:10px;font-size:.86rem}
.rank-pos{font-weight:700;color:var(--primary);font-size:.78rem;width:24px}
.rank-name{flex:1;color:var(--navy);font-weight:500}
.rank-val{color:var(--muted);font-size:.78rem}
.rank-bar{height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden}
.rank-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-700));border-radius:3px}

.bday{list-style:none;display:flex;flex-direction:column;gap:8px}
.bday li{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:8px;background:var(--surface-2)}
.bday-day{font-weight:700;color:var(--primary);font-size:.82rem;min-width:48px}
.bday-info{display:flex;flex-direction:column}
.bday-info strong{color:var(--navy);font-size:.88rem}
.bday-info small{color:var(--muted);font-size:.76rem}

/* ============ AGENDA DO DIA ============ */
.agenda-grid{display:grid;grid-template-columns:70px 1fr;gap:0;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff}
.agenda-hours,.agenda-slots{display:flex;flex-direction:column}
.agenda-hour{height:64px;padding:8px;border-bottom:1px solid var(--border);font-size:.76rem;color:var(--muted);text-align:right;font-weight:600;background:var(--surface-2)}
.agenda-row{height:64px;border-bottom:1px solid var(--border);position:relative;padding:5px;display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.agenda-row:hover{background:var(--surface-2)}
.agenda-event{
  background:var(--primary);color:#fff;padding:7px 11px;border-radius:8px;
  font-size:.78rem;line-height:1.3;min-width:170px;text-decoration:none;
  display:flex;flex-direction:column;gap:2px;
  box-shadow:0 2px 6px rgba(59,130,246,.25);
  transition:transform .15s,box-shadow .15s;
}
.agenda-event:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(59,130,246,.35);color:#fff}
.agenda-event strong{font-weight:600;font-size:.8rem}
.agenda-event small{opacity:.85;font-size:.72rem}
.agenda-event.s-concluido{background:var(--success)}
.agenda-event.s-em_andamento{background:var(--warn)}
.agenda-event.s-cancelado{background:var(--muted);opacity:.7;text-decoration:line-through}

.date-nav{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.date-nav input[type=date]{padding:6px 10px;font-size:.85rem;width:auto}

/* ============ MOBILE ============ */
@media (max-width:900px){
  .sidebar{transform:translateX(-100%);transition:transform .25s ease}
  body.sb-open .sidebar{transform:translateX(0)}
  .main-area{margin-left:0}
  .menu-toggle{display:flex}
  .container{padding:16px}
  .row,.row-3{grid-template-columns:1fr}
  h1{font-size:1.3rem}
  .kpi-value{font-size:1.4rem}
}

/* ============ LOGO IMAGEM ============ */
.brand-logo-img{background:#fff;border:1px solid var(--border);padding:4px;box-shadow:none;overflow:hidden}
.brand-logo-img img{width:100%;height:100%;object-fit:contain}
.login-logo{width:72px;height:72px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--primary-700));color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;margin:0 auto 16px;box-shadow:0 8px 20px rgba(59,130,246,.35);overflow:hidden}
.login-logo.has-img{background:#fff;padding:6px;border:1px solid var(--border)}
.login-logo img{max-width:100%;max-height:100%;object-fit:contain}

/* ===== Melhorias visuais v3 ===== */
.kpi{transition:transform .18s ease, box-shadow .18s ease}
.kpi:hover{transform:translateY(-2px);box-shadow:0 12px 24px -12px rgba(15,23,42,.18)}
.btn{transition:all .15s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px -6px rgba(15,23,42,.25)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-700));border-color:transparent;color:#fff}
.alert{border-radius:10px;padding:12px 16px;margin:0 0 14px;border:1px solid;font-size:.92rem}
.alert-warn{background:#fff7ed;border-color:#fdba74;color:#9a3412}
.alert-danger{background:#fef2f2;border-color:#fca5a5;color:#991b1b}
.alert a{font-weight:600;text-decoration:none;color:inherit;margin-left:6px}
.card{transition:box-shadow .2s ease}
.card:hover{box-shadow:0 8px 24px -16px rgba(15,23,42,.18)}
.agenda-event{transition:all .15s ease}
.agenda-event:hover{transform:translateY(-1px);box-shadow:0 4px 10px -4px rgba(15,23,42,.25)}
.sidebar .nav-item.active{background:linear-gradient(90deg,rgba(59,130,246,.12),transparent);border-left:3px solid var(--primary)}
