/* ======================================================
   VARIÁVEIS
====================================================== */
:root{
  --bg:#0b1220;
  --card:#0f172a;
  --line:#1e293b;
  --text:#e5e7eb;
  --muted:#94a3b8;

  --ok:#22c55e;
  --ok-bg:#dcfce7;

  --warn:#f59e0b;
  --warn-bg:#fef3c7;

  --danger:#ef4444;
  --danger-bg:#fee2e2;

  --info:#38bdf8;
}

/* ======================================================
   BASE
====================================================== */
*{box-sizing:border-box}

body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu;
  background:radial-gradient(1200px 600px at 10% -10%,#111827,#020617);
  color:var(--text);
}

.container{
  max-width:720px;
  margin:auto;
  padding:16px;
}

/* ======================================================
   LINKS / BADGES
====================================================== */
.link{
  color:#a78bfa;
  text-decoration:none;
  font-weight:700;
}


/* ======================================================
   HEADER DA AGENDA (DATA + TÍTULO)
====================================================== */
.header-agenda{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;

  background:#0f172a;
  border:1px solid var(--line);
  border-radius:16px;

  padding:12px 14px;
  margin-bottom:14px;
}

.header-agenda .date-nav{
  display:flex;
  align-items:center;
  gap:10px;
}

.header-agenda .date-nav button{
  width:40px;
  height:40px;
  border-radius:12px;
  border:none;
  background:#1e293b;
  color:#e5e7eb;
  font-size:22px;
  font-weight:900;
  cursor:pointer;
}

.header-agenda .date-nav button:active{
  transform:scale(.95);
}

.header-agenda .date-label{
  font-size:14px;
  font-weight:800;
  color:var(--info);
  white-space:nowrap;
}

.header-agenda .title{
  font-size:20px;
  font-weight:900;
  color:var(--text);
  white-space:nowrap;
}

/* ======================================================
   CARDS / FORMULÁRIOS
====================================================== */
.card{
  background:linear-gradient(180deg,#0b1220,#020617);
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px;
}

.field label{
  display:block;
  font-size:13px;
  color:var(--muted);
  margin-bottom:6px;
}

.field textarea,
.field input{
  width:100%;
  background:#020617;
  border:1px solid var(--line);
  color:var(--text);
  border-radius:10px;
  padding:10px;
}

/* ======================================================
   BOTÕES
====================================================== */
.row{
  display:flex;
  gap:10px;
  margin-top:10px;
}

button{
  border:none;
  border-radius:12px;
  padding:12px;
  font-weight:800;
  cursor:pointer;
}

button.secondary{
  background:#020617;
  border:1px solid var(--line);
  color:var(--text);
}

button.danger{
  background:var(--danger);
  color:#fff;
}

/* ======================================================
   AGENDA – SLOTS
====================================================== */
.slots{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:10px;
}

/* SLOT BASE */
.slot{
  position:relative;
  border-radius:14px;
  padding:10px;
  font-size:13px;
  cursor:pointer;
}

.slot .hora{
  font-weight:900;
  margin-bottom:4px;
}

.slot .info{
  font-size:12px;
  opacity:.9;
}

/* LIVRE */
.slot.livre{
  border:2px solid var(--ok);
  background:color-mix(in srgb, var(--ok) 20%, white);
  color:#14532d;
}

/* AGENDADO */
.slot.agendado{
  border:2px solid var(--warn);
  background:color-mix(in srgb, var(--warn) 25%, white);
  color:#78350f;
  cursor:default;
}

/* BLOQUEADO */
.slot.bloqueado{
  border:2px solid var(--danger);
  background:color-mix(in srgb, var(--danger) 25%, white);
  color:#7f1d1d;
  cursor:default;
}

/* ======================================================
   LAÇO VISUAL – MESMO SERVIÇO
====================================================== */
.slot.mesmo-servico::before{
  content:'';
  position:absolute;
  left:-6px;
  top:4px;
  bottom:4px;
  width:4px;
  border-radius:4px;
  background:rgba(0,0,0,.35);
}





.badge.agendado{
  background:#22c55e;
  color:#000;
}

.badge.concluido{
  background:#3b82f6;
  color:#fff;
}

.badge.cancelado{
  background:#ef4444;
  color:#fff;
}

/* =========================
   SERVIÇO
========================= */

.card-servico-linha{
  display:flex;
  align-items:center;
  gap:10px;
}

/* ===== CARD BASE ===== */

.agenda-top{
  display:flex;
  flex-direction:column;   /* 👈 coloca embaixo */
  align-items:flex-start;
  gap:6px;
  margin-bottom:12px;
}

.agenda-hora{
  font-size:18px;
  font-weight:800;
  color:#000;
}

.agenda-servico-row{
  display:flex;
  align-items:center;
  gap:8px;
}

/* 👇 PERMITE ENCOLHER */
.agenda-servico{
  font-size:16px;
  font-weight:700;
  flex:1;
  min-width:0;           /* ⭐ ESSENCIAL */
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* 👇 NUNCA ESTOURA */
.agenda-qtd{
  background:#000;
  color:#fff;
  padding:4px 10px;
  border-radius:20px;
  font-size:12px;
  font-weight:700;
  flex-shrink:0;         /* ⭐ FIXA NO LUGAR */
}

/* ===== EMPRESA ===== */

.agenda-empresa{
  margin-top:6px;
  font-size:15px;
  font-weight:600;
}

/* ===== LOCAL ===== */

.agenda-local{
  margin-top:10px;
  font-size:14px;
  font-weight:600;
}

.endereco{
  font-size:13px;
  color:#475569;
}

/* ======================================================
   DETALHE
====================================================== */
body[data-page="detalhe"] .row{
  flex-wrap:wrap;
}

body[data-page="detalhe"] .row button{
  flex:1;
}

/* BLOQUEIO - visual vermelho claro */
.slot.bloqueado{
  border: 1px solid #ef4444;
  background: #fee2e2;
}

.badge.bloqueado{
  background: #ef4444;
  color: #fff;
}

.card-servico.concluido {
  background: #ecfdf5;
  border: 2px solid #16a34a;
  box-shadow: 0 0 0 3px rgba(22,163,74,0.15);
}

.badge.concluido {
  background: #16a34a;
  color: #fff;
  font-weight: 900;
}

.card-servico.concluido .hora {
  color: #166534;
  font-weight: 900;
}


/* =========================
   PATCH LOGOUT MOBILE
========================= */

/* garante que o header vira referência e abre espaço pro botão */
.header-agenda{
  position: relative !important;
  padding-right: 52px !important;   /* RESERVA espaço do botão */
}

/* garante que a área da data não invade o espaço do botão */
.header-agenda .date-nav{
  max-width: calc(100% - 52px) !important;
}

/* botão power sempre visível por cima */
.logout-icon{
  position: absolute !important;
  right: 10px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;

  z-index: 9999 !important;         /* FICA POR CIMA */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  width: 36px !important;
  height: 36px !important;
  border-radius: 999px !important;

  background: #dc2626 !important;
  color: #fff !important;
  text-decoration: none !important;
  font-weight: 900 !important;
  font-size: 18px !important;
}

/* se o header tiver overflow escondendo, isso ajuda */
.header-agenda{
  overflow: visible !important;
}



.card-servico:hover{
  transform:scale(1.01);
}

.slot-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
}

.hora{
  font-weight:700;
  font-size:16px;
}


.endereco{
  font-size:13px;
  margin-top:4px;
  color:#555;
}




.badge.bloqueado{
  background:#dc3545;
  color:#fff;
}

.qtd-servico{
  background:#000;
  color:#fff;
  padding:2px 8px;
  border-radius:20px;
  font-size:12px;
  margin-left:6px;
}


/* ===========================
   CARD BASE (NEUTRO)
=========================== */
.agenda-card {
  border-radius: 14px;
  padding: 16px;
  margin-bottom: 14px;
  border: 1px solid var(--line);
  background: #f8fafc; /* neutro */
  color: #000;
  cursor: pointer;
  transition: 0.2s;
}

/* ===========================
   STATUS CORES
=========================== */

.status-agendado {
  background: #d1fae5;
  border: 2px solid #22c55e;
}

.status-concluido {
  background: #bfdbfe;
  border: 2px solid #1d4ed8;
}

.status-bloqueado {
  background: #fee2e2;
  border: 2px solid #ef4444;
}

.status-em_andamento {
  background: #fef3c7;
  border: 2px solid #f59e0b;
}

/* ===========================
   SLOT LIVRE (CINZA)
=========================== */

.slot.livre {
  background: #f3f4f6;         /* cinza claro */
  border: 1px solid #d1d5db;
  border-radius: 12px;
  padding: 12px;
  cursor: pointer;
  transition: 0.2s;
}

.slot.livre:hover {
  background: #e5e7eb;
}