@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;600;700&family=DM+Sans:wght@300;400;500;600;700&display=swap');

:root{
  --bg:#080808;
  --bg-soft:#0f0f0f;
  --card:#141414;
  --muted:#7a6d67;
  --text:#f5ede8;
  --primary:#c4788a;
  --primary-dark:#a05a6c;
  --primary-light:#f0c0c8;
  --primary-2:#f0c0c8;
  --danger:#c0392b;
  --warning:#c4788a;
  --border:rgba(196,120,138,.18);
  --border-soft:rgba(196,120,138,.08);
  --shadow:0 20px 60px rgba(0,0,0,.5);
  --shadow-gold:0 8px 32px rgba(196,120,138,.2);
  --radius:22px;
  --glow:0 0 0 4px rgba(196,120,138,.18);
}

*{box-sizing:border-box}
html,body{
  margin:0;padding:0;
  font-family:'DM Sans',sans-serif;
  background:var(--bg);
  color:var(--text);
  background-image:
    radial-gradient(ellipse 800px 600px at 20% 10%, rgba(196,120,138,.04) 0%, transparent 70%),
    radial-gradient(ellipse 600px 500px at 80% 80%, rgba(196,120,138,.03) 0%, transparent 70%);
  background-attachment: fixed;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}

/* ─── LAYOUT ─── */
.site-shell{min-height:100vh}
.container{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:24px 0 64px}

/* ─── TOPBAR / NAV ─── */
.topbar{
  width:min(1180px,calc(100% - 32px));margin:16px auto 0;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 18px;
  background:rgba(20,12,6,.8);
  border:1px solid var(--border);
  border-radius:24px;
  backdrop-filter:blur(20px);
  position:sticky;top:16px;z-index:20;
  box-shadow:0 4px 32px rgba(0,0,0,.4), inset 0 1px 0 rgba(196,120,138,.1);
}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;overflow:hidden;
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  box-shadow:var(--shadow-gold);
  border:1px solid rgba(196,120,138,.3);
}
.brand-mark img{
  width:100%;height:100%;object-fit:cover;border-radius:14px;display:block;
}
.brand-mark span{font-weight:800;font-size:1.1rem;color:#fff}
.brand small{display:block;color:var(--muted);font-size:.82rem;margin-top:2px;font-family:'DM Sans',sans-serif;letter-spacing:.03em}
.nav{display:flex;align-items:center;gap:18px}
.nav a{color:var(--text);opacity:.8;transition:.2s ease;font-size:.9rem;font-weight:500;letter-spacing:.01em}
.nav a:hover{opacity:1;transform:translateY(-1px);color:var(--primary-light)}
.nav-link-logout{
  padding:.65rem 1rem;border:1px solid var(--border);border-radius:14px;
  background:rgba(196,120,138,.05);transition:.25s ease;
}
.nav-link-logout:hover{background:rgba(196,120,138,.12);border-color:rgba(196,120,138,.35)}
.user-pill{
  padding:.55rem .9rem;border-radius:999px;
  background:rgba(196,120,138,.12);border:1px solid rgba(196,120,138,.3);
  color:var(--primary-light);font-size:.88rem;font-weight:600;
}
.nav-toggle{display:none;background:none;border:0;color:var(--text);font-size:1.5rem;cursor:pointer}

/* ─── HERO ─── */
.hero{display:grid;grid-template-columns:1.2fr .9fr;gap:28px;align-items:center;padding:36px 0 20px}
.hero-copy h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.6rem,5vw,5.2rem);
  line-height:1.02;margin:0 0 16px;
  background:linear-gradient(135deg, #f5ede8 30%, var(--primary-light) 70%, var(--primary) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  font-weight:700;
}
.hero-copy p{font-size:1.05rem;color:var(--muted);line-height:1.7;max-width:62ch}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:.55rem .9rem;border-radius:999px;
  background:rgba(196,120,138,.1);border:1px solid rgba(196,120,138,.25);
  color:var(--primary-light);font-size:.88rem;margin-bottom:18px;font-weight:500;letter-spacing:.02em;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}

/* ─── BUTTONS ─── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:.95rem 1.35rem;border-radius:16px;border:1px solid transparent;
  cursor:pointer;transition:.25s ease;font-weight:600;font-size:.95rem;letter-spacing:.01em;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 35px rgba(0,0,0,.3)}
.btn-primary{
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:#fff;border-color:rgba(196,120,138,.4);
  box-shadow:0 4px 20px rgba(196,120,138,.25);
}
.btn-primary:hover{box-shadow:0 8px 32px rgba(196,120,138,.4)}
.btn-secondary{
  background:rgba(196,120,138,.06);
  border-color:var(--border);color:var(--text);
}
.btn-secondary:hover{background:rgba(196,120,138,.12);border-color:rgba(196,120,138,.35)}
.btn-success{background:linear-gradient(135deg,#2d6a4f,#40916c);color:white}
.btn-danger{background:linear-gradient(135deg,#7f1d1d,#c0392b);color:white}
.btn-sm{padding:.65rem .9rem;border-radius:12px;font-size:.88rem}

/* ─── HERO CARD ─── */
.hero-card{
  background:rgba(20,12,6,.6);
  border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow), inset 0 1px 0 rgba(196,120,138,.08);
}
.hero-card .cover{
  height:360px;
  background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.5)),
    url('../img/ubicacion.png') center/cover no-repeat;
}
.hero-card .card-body{padding:20px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.stat{padding:16px;border-radius:18px;background:rgba(196,120,138,.05);border:1px solid var(--border)}
.stat strong{display:block;font-size:1.4rem;color:var(--primary-light)}
.stat span{color:var(--muted);font-size:.86rem}

/* ─── SECTIONS ─── */
.section{margin-top:42px}
.section h2{
  font-family:'Cormorant Garamond',serif;
  font-size:2.2rem;margin:0 0 10px;font-weight:700;
  color:var(--primary-light);
}
.section p.lead{color:var(--muted);margin-top:0}
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:rgba(20,12,6,.6);border:1px solid var(--border);
  border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;
}
.card .card-body{padding:22px}
.card h3{margin:0 0 10px;font-family:'Cormorant Garamond',serif;color:var(--primary-light)}
.card p{color:var(--muted);line-height:1.65}

/* ─── GALLERY ─── */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery img{
  height:220px;width:100%;object-fit:cover;
  border-radius:20px;border:1px solid var(--border);
  box-shadow:var(--shadow);
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  cursor:pointer;
}
.gallery img:hover{
  transform:scale(1.08) translateY(-6px);
  box-shadow:0 28px 64px rgba(0,0,0,.55), 0 0 0 1px rgba(196,120,138,.45);
  border-color:rgba(196,120,138,.5);
}

/* ─── FORM ─── */
.form-wrap{max-width:720px;margin:0 auto}
.form-card{
  background:rgba(20,12,6,.7);border:1px solid var(--border);
  border-radius:var(--radius);padding:32px;
  box-shadow:var(--shadow), inset 0 1px 0 rgba(196,120,138,.08);
}
.form-card h1{
  font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:700;
  margin:0 0 6px;color:var(--primary-light);
}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
label{font-weight:600;font-size:.9rem;letter-spacing:.02em;color:var(--primary-light);text-transform:uppercase}
input,select,textarea{
  width:100%;padding:14px 16px;border-radius:14px;
  border:1px solid rgba(196,120,138,.18);
  background:#0d0906;color:var(--text);outline:none;transition:.2s ease;
  font-size:.95rem;
}
input:focus,select:focus,textarea:focus{
  border-color:rgba(196,120,138,.65);
  box-shadow:var(--glow);
  background:#100c08;
}
textarea{min-height:120px;resize:vertical}

/* ─── ALERTS ─── */
.alert{padding:16px 18px;border-radius:18px;margin:0 0 18px;border:1px solid transparent;font-size:.93rem}
.alert ul{margin:.4rem 0 0 1.2rem}
.alert-danger{background:rgba(192,57,43,.1);border-color:rgba(192,57,43,.2);color:#f5c6c0}
.alert-success{background:rgba(40,167,69,.1);border-color:rgba(40,167,69,.2);color:#b8dfc2}
.alert-info{background:rgba(196,120,138,.1);border-color:rgba(196,120,138,.2);color:var(--primary-light)}

/* ─── TABLE ─── */
.table-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}
table{width:100%;border-collapse:collapse;background:rgba(20,12,6,.6)}
th,td{padding:14px 16px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
th{
  color:var(--primary);font-size:.82rem;text-transform:uppercase;
  letter-spacing:.06em;background:rgba(196,120,138,.06);font-weight:700;
}
tr:hover td{background:rgba(196,120,138,.04)}
.status{display:inline-flex;align-items:center;padding:.38rem .7rem;border-radius:999px;font-size:.82rem;font-weight:700;letter-spacing:.02em}
.status-pendiente{background:rgba(196,120,138,.12);color:var(--primary-light);border:1px solid rgba(196,120,138,.25)}
.status-aprobado{background:rgba(40,167,69,.1);color:#b8dfc2;border:1px solid rgba(40,167,69,.2)}
.status-rechazado{background:rgba(192,57,43,.1);color:#f5c6c0;border:1px solid rgba(192,57,43,.2)}

/* ─── DASHBOARD ─── */
.dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpi{
  padding:22px;border-radius:22px;border:1px solid var(--border);
  background:rgba(20,12,6,.6);box-shadow:var(--shadow);
  position:relative;overflow:hidden;
}
.kpi::before{
  content:'';position:absolute;top:-20px;right:-20px;
  width:80px;height:80px;border-radius:50%;
  background:radial-gradient(circle, rgba(196,120,138,.15), transparent 70%);
}
.kpi strong{display:block;font-size:2rem;margin-bottom:6px;color:var(--primary-light);font-family:'Cormorant Garamond',serif}
.kpi span{color:var(--muted);font-size:.88rem}

/* ─── TOOLBAR ─── */
.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:end;margin-bottom:18px}
.toolbar .field{min-width:180px}
.toolbar .field.search{flex:1}
.actions{display:flex;flex-wrap:wrap;gap:8px}
.badge-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:currentColor;margin-right:6px}
.text-muted{color:var(--muted)}
.lead{color:var(--muted);line-height:1.7}
.footer{padding:26px 0 44px;color:var(--muted);text-align:center;font-size:.9rem;letter-spacing:.03em}

/* ─── DATE/TIME PICKER CONTAINERS (unified) ─── */
#horarios-container, #fechas-container {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
  padding: 18px;
  background: rgba(20,12,6,.9);
  border: 1px solid var(--border);
  border-radius: 18px;
  max-height: 300px;
  overflow-y: auto;
  box-shadow: var(--shadow), inset 0 1px 0 rgba(196,120,138,.06);
}

/* ─── UNIFIED SLOT BUTTON BASE ─── */
.hora-btn, .fecha-btn {
  padding: 12px 16px;
  border: 1px solid rgba(196,120,138,.2);
  background: rgba(196,120,138,.05);
  color: var(--text);
  border-radius: 12px;
  cursor: pointer;
  transition: all .2s ease;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-family: 'DM Sans', sans-serif;
}

.hora-btn {
  min-width: 80px;
  font-size: .95rem;
  font-weight: 600;
  letter-spacing: .03em;
}

.fecha-btn {
  min-width: 90px;
}

.hora-btn:hover, .fecha-btn:hover {
  background: rgba(196,120,138,.12);
  border-color: rgba(196,120,138,.45);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0,0,0,.3), 0 0 0 1px rgba(196,120,138,.2);
}

.hora-btn.active, .fecha-btn.active {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  color: white;
  border-color: transparent;
  box-shadow: 0 4px 20px rgba(196,120,138,.4);
}

/* Disabled / ocupado */
.hora-btn.ocupado, .hora-btn:disabled {
  background: rgba(0,0,0,.3);
  color: var(--muted);
  cursor: not-allowed;
  opacity: 0.4;
  border-color: rgba(255,255,255,.05);
  pointer-events: none;
}

/* Date button inner text */
.fecha-btn strong {
  font-size: .82rem;
  font-weight: 700;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.fecha-btn span {
  font-size: .88rem;
  color: var(--text);
}
.fecha-btn.active strong {
  color: rgba(255,255,255,.85);
}
.fecha-btn.active span {
  color: rgba(255,255,255,.95);
}

/* ─── RESPONSIVE ─── */
@media (max-width: 960px){
  .hero,.grid-3,.grid-2,.gallery,.dashboard-grid,.stats{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .topbar{position:relative}
}
@media (max-width: 760px){
  .nav-toggle{display:block}
  .nav{display:none;flex-direction:column;align-items:stretch;width:100%;padding-top:14px}
  .nav.is-open{display:flex}
  .topbar{flex-wrap:wrap}
}
