/* Panel admin — KikiBrows and BeaSkin. Paleta de marca (oliva / crema / rosa). */
:root{
  --oliva:#8F8457; --oliva-deep:#6b6340; --oliva-12:rgba(143,132,87,.12);
  --rosa:#D9B5AF; --rosa-deep:#b9766c; --rosa-12:rgba(217,181,175,.18);
  --ink:#2c2a24; --soft:#8a8576; --line:#e7e1d4;
  --paper:#fff; --bg:#f6f3ea; --card2:#fcfaf4;
  --ok:#3f6b34; --okbg:#e9f3e1; --warn:#9a6a00; --warnbg:#fdf3df;
  --err:#b1493d; --errbg:#f8ece9; --demo:#6a5aa0; --demobg:#efeafb; --gris:#8a857a;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5}
.admin{max-width:1100px;margin:0 auto;padding:24px 18px 64px}
a{color:var(--oliva-deep);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--soft)}
.sm{font-size:.85em}

/* Botones */
.btn{display:inline-block;background:var(--oliva);color:#fff;border:1px solid var(--oliva);border-radius:9px;
  padding:9px 16px;font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:none;transition:.15s}
.btn:hover{background:var(--oliva-deep);border-color:var(--oliva-deep);text-decoration:none}
.btn.sm{padding:5px 11px;font-size:.8rem}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn.ghost:hover{background:var(--oliva-12);border-color:var(--oliva);color:var(--oliva-deep)}

/* Login */
.login-wrap{min-height:80vh;display:flex;align-items:center;justify-content:center}
.login-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:34px 30px;width:340px;box-shadow:0 12px 40px -20px rgba(107,99,64,.4)}
.login-card h1{font-size:1.3rem;margin:0 0 2px;color:var(--oliva-deep)}
.login-card .sub{color:var(--soft);margin:0 0 20px;font-size:.9rem}
.login-card label{display:block;font-size:.78rem;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px}
.login-card input{width:100%;margin-top:6px;padding:11px 13px;border:1px solid var(--line);border-radius:9px;font-size:1rem}
.login-card .btn{width:100%;margin-top:6px}

/* Topbar */
.admin-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.admin-topbar strong{color:var(--oliva-deep)}

/* Navegación del panel */
.admin-nav{display:flex;flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:22px;border-bottom:1px solid var(--line);padding-bottom:10px}
.admin-nav a{padding:7px 14px;border-radius:9px;color:var(--ink);font-weight:600;font-size:.88rem}
.admin-nav a:hover{background:var(--oliva-12);text-decoration:none}
.admin-nav a.on{background:var(--oliva);color:#fff}
.admin-nav .admin-user{margin-left:auto;color:var(--oliva-deep);font-weight:700;font-size:.82rem;background:var(--rosa-12);padding:5px 12px;border-radius:20px}
.admin-nav .logout{margin-left:auto;color:var(--soft);font-weight:500}
.admin-nav .admin-user ~ .logout{margin-left:10px}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}
.stat{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:0 4px 18px -14px rgba(107,99,64,.5)}
.stat .n{display:block;font-size:1.8rem;font-weight:800;color:var(--oliva-deep);line-height:1.1}
.stat .l{color:var(--soft);font-size:.82rem;margin-top:2px}
.stat .l a{color:var(--rosa-deep);font-weight:600}

/* Filtros / chips */
.filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}
.filters span{color:var(--soft);font-size:.85rem}
.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--line);border-radius:20px;font-size:.82rem;color:var(--ink);background:var(--paper)}
.chip.on{background:var(--oliva);color:#fff;border-color:var(--oliva)}
.chip:hover{text-decoration:none;border-color:var(--rosa-deep)}
.chip.on:hover{border-color:var(--oliva)}

/* Búsqueda */
.search-bar{display:flex;gap:8px;margin:14px 0;flex-wrap:wrap}
.search-bar input{flex:1;min-width:200px;padding:9px 12px;border:1px solid var(--line);border-radius:9px;font:inherit;background:var(--paper)}

/* Cards / tablas */
.card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:6px 0;margin-bottom:22px;overflow:hidden;box-shadow:0 4px 18px -16px rgba(107,99,64,.5)}
.card form{padding:14px 18px}
.sec-title{font-size:1rem;margin:22px 4px 10px;color:var(--oliva-deep)}
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--soft);padding:11px 14px;border-bottom:1px solid var(--line);background:var(--card2)}
.tbl td{padding:12px 14px;border-bottom:1px solid #f1ede4;vertical-align:top}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover{background:var(--oliva-12)}
.tbl .empty{text-align:center;color:var(--soft);padding:26px}
.tbl .msg{max-width:340px;color:var(--soft)}

/* Analítica (dashboard) — tarjetas con padding propio para no pegarse al borde */
.analytics{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:16px 0}
.an-card{padding:16px 20px}
.an-card h3{font-size:.95rem;margin:0 0 10px;color:var(--oliva-deep)}
.an-list{list-style:none;margin:0;padding:0}
.an-list li{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid #f1ede4;font-size:.92rem}
.an-list li:last-child{border-bottom:none}
.an-list li span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.an-list li b{color:var(--oliva-deep);font-variant-numeric:tabular-nums;flex:none}

/* Badges */
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:.72rem;font-weight:700;background:#efece4;color:#6a6457}
.badge.ok,.badge.confirmado,.badge.atendido{background:var(--okbg);color:var(--ok)}
.badge.warn,.badge.pending{background:var(--warnbg);color:var(--warn)}
.badge.err,.badge.no_show,.badge.cancelado{background:var(--errbg);color:var(--err)}
.badge.demo,.badge.reservado_demo{background:var(--demobg);color:var(--demo)}
.badge.gris{background:#eeece4;color:var(--gris)}

/* Detalle */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ficha{display:grid;grid-template-columns:130px 1fr;gap:6px 10px;margin:0 18px 10px}
.ficha dt{color:var(--soft);font-size:.85rem}
.ficha dd{margin:0;font-weight:600}
.mono{font-family:ui-monospace,Menlo,monospace;font-size:.82rem;font-weight:400}
.caso{padding:0 18px 16px;color:var(--ink)}
textarea,select{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:.95rem;font-family:inherit;margin-bottom:10px;background:var(--paper)}

/* Inputs CRUD */
.tbl input[type=text],.tbl input[type=number],.tbl input[type=time],.tbl input[type=email],.tbl input[type=password]{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:.9rem;font-family:inherit}
input[type=date],input[type=time]{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:.9rem;font-family:inherit}
input[type=text],input[type=number],input[type=email],input[type=password]{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:.9rem;font-family:inherit}
input[type=checkbox]{width:18px;height:18px;accent-color:var(--oliva)}
input[type=color]{cursor:pointer}

/* Alertas */
.alert{padding:11px 15px;border-radius:9px;margin-bottom:16px;font-size:.9rem}
.alert.ok{background:var(--okbg);color:var(--ok);border:1px solid #c6e0b8}
.alert.err{background:var(--errbg);color:var(--err);border:1px solid #efc9c2}

/* Selector de profesional (Disponibilidad) */
.picker{display:flex;flex-wrap:wrap;gap:10px;padding:4px 0 14px}
.picker-it{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:12px;padding:12px 16px;background:var(--card2);color:var(--ink);font-size:.95rem}
.picker-it:hover{border-color:var(--oliva);background:var(--oliva-12);text-decoration:none}
.picker-it b{color:var(--oliva-deep)}

@media(max-width:760px){.grid2{grid-template-columns:1fr}.stats{grid-template-columns:1fr 1fr}.ficha{grid-template-columns:110px 1fr}}
@media(max-width:640px){.analytics{grid-template-columns:1fr}}

/* ===== Responsive móvil del panel ===== */
@media(max-width:760px){
  .admin{padding:16px 12px 56px}
  /* Las tablas anchas (CRUD profesionales/servicios/horarios, reservas) se
     deslizan en horizontal en vez de quedar cortadas dentro de la card. */
  .card{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tbl{min-width:600px}
  .tbl th,.tbl td{padding:9px 10px}
  .card form{padding:12px 14px}
  .ficha{margin:0 14px 10px}
  .caso{padding:0 14px 16px}
}
@media(max-width:560px){
  body{font-size:13px}
  .admin-topbar{margin-bottom:14px}
  .admin-nav{gap:2px;padding-bottom:8px;margin-bottom:16px}
  .admin-nav a{padding:6px 10px;font-size:.82rem}
  .admin-nav .admin-user{margin-left:auto;font-size:.76rem;padding:4px 9px}
  .admin-nav .logout{margin-left:8px}
  .stats{grid-template-columns:1fr 1fr;gap:10px}
  .stat{padding:14px 14px}
  .stat .n{font-size:1.5rem}
  .login-card{width:100%;max-width:340px;padding:28px 22px}
  /* Pista visual de que la tabla se puede deslizar */
  .card{position:relative}
}

/* ===== Vista de agenda ===== */
.agenda-nav{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--paper)}
.seg .segbtn{padding:7px 16px;font-size:.85rem;font-weight:600;color:var(--ink)}
.seg .segbtn:hover{background:var(--oliva-12);text-decoration:none}
.seg .segbtn.on{background:var(--oliva);color:#fff}
.prof-legend{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}
.dot{width:12px;height:12px;border-radius:50%;display:inline-block;flex:none;box-shadow:0 0 0 1px rgba(0,0,0,.08)}
.empty-day{padding:30px;text-align:center;color:var(--soft)}

.agenda-wrap{overflow-x:auto;background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:0 4px 18px -16px rgba(107,99,64,.5)}
.agenda-grid{display:flex;min-width:620px}
.ag-col{flex:1;min-width:140px;border-left:1px solid var(--line);position:relative}
.ag-col.ag-times{flex:0 0 56px;min-width:56px;border-left:none}
.ag-col.ag-off{background:repeating-linear-gradient(45deg,#faf7ef,#faf7ef 8px,#f3efe4 8px,#f3efe4 16px)}
.ag-head{min-height:46px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;font-weight:700;font-size:.85rem;
  border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--card2);z-index:2;padding:5px 4px;text-align:center}
.ag-head .cal-dw{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--soft);font-weight:700}
.ag-head .cal-dd{font-size:.85rem}
.ag-head .cal-dd.is-hoy{color:#fff;background:var(--rosa-deep);border-radius:20px;padding:1px 9px}
.ag-body{position:relative}
.ag-hour{position:absolute;right:7px;font-size:.72rem;color:var(--soft);transform:translateY(-7px)}
.ag-line{position:absolute;left:0;right:0;border-top:1px solid #f1ede4}
.ag-offband{position:absolute;inset:0;display:flex;align-items:flex-start;justify-content:center;padding-top:14px;color:var(--soft);font-size:.78rem;letter-spacing:.05em}
.ag-block{position:absolute;left:4px;right:4px;border-radius:8px;color:#fff;padding:4px 8px;font-size:.74rem;
  overflow:hidden;box-shadow:0 2px 8px rgba(107,99,64,.28);text-decoration:none;line-height:1.25;z-index:1}
.ag-block:hover{filter:brightness(1.06);text-decoration:none}
.ag-block b{font-weight:800}
.ag-block span{display:block;opacity:.95;font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ag-block.done{opacity:.62}
.ag-block.done::after{content:'✓';position:absolute;top:3px;right:6px;font-weight:800}
.prof-cell{display:flex;align-items:center;gap:8px}
