:root{
    --orange:#f36b21;
    --dark:#2f2f2f;
    --muted:#f7f7f7;
}

/* RESET BÁSICO */
*{
    box-sizing:border-box;
}

body{
    margin:0;
    font-family:Inter,Arial,Helvetica,sans-serif;
    background:#fff;
    color:var(--dark);
    padding-top:88px; /* espacio para el navbar fijo */
}

/* WRAPPER GENÉRICO (si quieres usarlo) */
.wrap{
    max-width:1200px;
    margin:0 auto;
    padding:20px;
}

/* ===========================
   NAVBAR (partials_nav.php)
   =========================== */

#navbar{
    background:#fff;
    position:fixed;
    top:0;
    width:100%;
    z-index:9999;
}

#navbar .navbar-brand img{
    height:48px;
}

#menu .nav-link{
    margin-left:16px;
    text-decoration:none;
    color:var(--dark);
    font-weight:600;
}

#menu .nav-link:hover{
    color:var(--orange);
}

#menu .btn-primary{
    background:var(--orange);
    border:none;
    font-weight:700;
    padding:10px 18px;
    border-radius:8px;
}

/* ===========================
   HERO / SLIDER ADAPTADO
   (usa .hero-slider + .slide)
   =========================== */

.hero{
    margin:20px 0;
}

/* contenedor del slider */
.hero-slider{
    height:420px;
    border-radius:10px;
    background:#000;
    position:relative;
    overflow:hidden;
    margin:20px 0;
    color:#fff;
}

/* cada slide viene de la BD */
.hero-slider .slide{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    background-size:cover;
    background-position:center;
    display:none; /* IMPORTANTE: oculta todos */
}

/* solo mostramos el primero para que no se apilen */
.hero-slider .slide:first-child{
    display:block;
}

/* overlay tipo degradado */
.slide-overlay{
    position:absolute;
    left:0;
    top:0;
    width:100%;
    height:100%;
    background:linear-gradient(90deg,rgba(0,0,0,.55),rgba(0,0,0,.1));
}

/* contenido del slide (equivalente a .hero-inner) */
.slide-content{
    position:relative;
    padding:40px;
    max-width:620px;
    z-index:2;
}

.slide-content h1{
    margin:0 0 10px;
    font-size:34px;
    text-shadow:0 4px 16px rgba(0,0,0,.4);
}

.slide-content p{
    margin:0 0 18px;
    font-size:18px;
}

/* botón dentro del slide */
.slide-content .btn-primary{
    display:inline-block;
    padding:11px 18px;
    background:var(--orange);
    color:#000000;
    border-radius:8px;
    text-decoration:none;
    border:none;
    cursor:pointer;
    font-weight:700;
}


/* ===========================
   SECCIÓN CATEGORÍAS
   (usa .grid-categorias + .card-categoria)
   =========================== */

.grid-categorias{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:18px;
    margin:20px 0;
}

.card-categoria{
    background:#fff;
    border:1px solid #eee;
    border-radius:10px;
    padding:16px;
    box-shadow:0 4px 16px rgba(0,0,0,.04);
}

.card-categoria h3{
    margin-top:0;
    font-size:20px;
    font-weight:700;
}

.card-categoria p{
    font-size:15px;
    opacity:.9;
    margin-bottom:12px;
}

.card-categoria .btn-primary{
    padding:9px 14px;
    border-radius:6px;
}

/* ===========================
   CTA CITAS
   (usa .cta-citas existente)
   =========================== */

.cta-citas{
    margin:24px 0;
    padding:18px;
    border-radius:10px;
    background:#f36b21;
    text-align:center;
}

.cta-citas h2{
    margin-bottom:8px;
}

.cta-citas p{
    margin-top:0;
    margin-bottom:14px;
}

/* ===========================
   FORMULARIOS GENERALES
   (puede usarse en contacto / citas)
   =========================== */

.form-cita label{
    font-size:14px;
    display:block;
    margin-bottom:6px;
}

.form-cita input,
.form-cita textarea{
    width:100%;
    padding:10px;
    border-radius:6px;
    border:1px solid #ddd;
    font-family:inherit;
    font-size:14px;
}

.form-cita textarea{
    min-height:90px;
    resize:vertical;
}

/* ===========================
   FOOTER
   =========================== */

.footer{
    background:#f36b21;
    border-top:1px solid #eee;
    margin-top:30px;
    text-align:center;
}

.footer p{
    margin:10px 0;
    font-size:13px;
}

/* ===========================
   ADMIN BASICO (por si lo usas)
   =========================== */

.admin-body{
    background:#f3f3f8;
}

.admin-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:12px;
}

.admin-nav a{
    margin-right:12px;
    text-decoration:none;
    color:var(--dark);
    font-weight:700;
}

.admin-nav a.active{
    color:var(--orange);
}

.tabla-admin,
.admin-table{
    width:100%;
    border-collapse:collapse;
    margin-top:12px;
    background:#fff;
}

.tabla-admin th,
.admin-table th{
    background:var(--orange);
    color:#fff;
    padding:8px;
    font-size:13px;
}

.tabla-admin td,
.admin-table td{
    border:1px solid #eee;
    padding:8px;
    font-size:13px;
}

.alert-ok{
    background:#e6f7ec;
    border-left:4px solid #2ecc71;
    padding:10px 12px;
    border-radius:6px;
    margin-bottom:10px;
    font-size:14px;
}

.alert-error{
    background:#fdecea;
    border-left:4px solid #e74c3c;
    padding:10px 12px;
    border-radius:6px;
    margin-bottom:10px;
    font-size:14px;
}

/* ===========================
   MOBILE
   =========================== */

@media(max-width:768px){

  /* NAV responsive */
  #navbar .navbar-brand img{
      height:40px;
  }

  .hero-slider{
      height:320px;
      border-radius:0;
      margin:10px 0 20px;
  }

  .slide-content{
      padding:20px;
  }

  .slide-content h1{
      font-size:24px;
  }

  .slide-content p{
      font-size:16px;
  }

  .grid-categorias{
      grid-template-columns:1fr;
  }

  .card-categoria{
      padding:18px;
  }
}
/* ===================================================================
   ⬆⬆⬆  NO TOCAR EL CSS ANTERIOR  — AGREGAR ESTE AL FINAL  ⬆⬆⬆
   =================================================================== */


/* ============================================
   FORMULARIO DE CITAS — DISEÑO CORPORATIVO PRO
   ============================================ */

.form-wrapper {
    max-width: 600px;
    margin: 40px auto;
    padding: 30px;
    background: #ffffff;
    border-radius: 14px;
    box-shadow: 0 6px 22px rgba(0,0,0,0.08);
    border: 1px solid #eee;
}

.form-wrapper h1 {
    text-align: center;
    font-size: 28px;
    margin-bottom: 8px;
    color: var(--dark);
}

.form-wrapper .sub-title {
    text-align: center;
    color: #666;
    margin-bottom: 25px;
}


/* Inputs corporativos */
.form-cita input,
.form-cita textarea,
.form-cita select {
    width: 100%;
    padding: 12px;
    border-radius: 8px;
    background: #fafafa;
    border: 1px solid #ccc;
    font-size: 16px;
    transition: .2s;
}

.form-cita input:focus,
.form-cita textarea:focus,
.form-cita select:focus {
    border-color: var(--orange);
    box-shadow: 0 0 0 3px rgba(243,107,33,0.15);
    outline: none;
}


/* ===========================
   BOTONES CORPORATIVOS
   =========================== */

.btn-citas,
.btn-primary {
    background: var(--orange) !important;
    color: #fff !important;   /* TEXTO BLANCO */
    padding: 12px 20px;
    border-radius: 10px;
    display: inline-block;
    font-weight: 700;
    border: none;
    cursor: pointer;
    text-align: center;
    transition: 0.25s;
}

.btn-citas:hover,
.btn-primary:hover {
    background: #d95d16 !important; /* Naranja más oscuro */
    color: #fff !important;
    transform: translateY(-2px);
}

/* Cuando se hace click */
.btn-citas:active,
.btn-primary:active {
    background: #f36b21 !important; /* vuelve al original */
    color: #000 !important; /* TEXTO NEGRO AL SER PRESIONADO */
    transform: scale(.97);
}


/* ===========================
   MENSAJES
   =========================== */

.alert-error {
    background: #ffe2e2;
    border-left: 5px solid #b30000;
    padding: 12px;
    border-radius: 8px;
    color: #7a0000;
    text-align: center;
    font-weight: 600;
    margin-bottom: 20px;
}

.alert-ok {
    background: #e6ffe9;
    border-left: 5px solid #26c45a;
    padding: 12px;
    border-radius: 8px;
    
    text-align: center;
    font-weight: 600;
    margin-bottom: 20px;
}


/* ===========================
   MOBILE OPTIMIZADO
   =========================== */

@media(max-width: 768px) {
    .form-wrapper {
        margin: 20px;
        padding: 20px;
    }

    .form-wrapper h1 {
        font-size: 24px;
    }
}
/* =========================
   WIDGET SOCIAL CON IMÁGENES
   ========================= */

.social-floating {
    position: fixed;
    right: 18px;
    bottom: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    z-index: 999999 !important;
}

.sf-btn {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: #ffffff;
    box-shadow: 0 4px 14px rgba(0,0,0,0.25);
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 8px;
    cursor: pointer;
    transition: .25s ease;
    overflow: hidden;
}

.sf-btn img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* Hover */
.sf-btn:hover {
    transform: scale(1.12);
    box-shadow: 0 6px 18px rgba(0,0,0,0.35);
}

.contenedor{
    margin-top:15px;
    padding-top: 35px;
}
.contenedor h1{
    margin: auto;
    display: flex;         /* Activa Flexbox */
    justify-content: center; /* Centra horizontalmente */
    min-height: 0vh;     /* Asegura que ocupe al menos el alto de la pantalla */
    margin: 0;             /* Elimina márgenes por defecto del body */
}
