/* ============================================================
   Celaya Recomienda — Mockup home
   Mobile-first. Placeholders para assets reales (logo, torre,
   bordes talavera, fotos de negocios).
   ============================================================ */

:root{
  /* Paleta basada en el logo oficial Celaya Recomienda */
  --cream:        #FEF4E3;
  --cream-soft:   #FFF9F0;
  --card:         #FFFCF7;
  --orange:       #FD6103;
  --orange-light: #FE8A3D;
  --red:          #FB4505;
  --magenta:      #D5054E;
  --teal:         #025467;
  --teal-deep:    #013B49;
  --teal-band:    #025467;
  --yellow:       #F4B62C;
  --purple:       #D5054E;
  --ink:          #2A2622;
  --ink-soft:     #6E6055;
  --line:         #F0DCBC;
  --line-dash:    #F39A4E;

  --radius:   16px;
  --radius-sm:10px;
  --shadow:   0 8px 24px rgba(120, 80, 30, .10);
  --shadow-sm:0 3px 12px rgba(120, 80, 30, .08);
  --maxw: 1180px;

  --font-display: "Bitter", Georgia, serif;
  --font-body: "Nunito Sans", system-ui, -apple-system, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
.ico{ width:1.1em; height:1.1em; flex:0 0 auto; }

.visually-hidden,.visually-hidden{
  position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0);
}

.container{
  width:100%;
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:18px;
}

/* ---------- Bordes laterales florales ---------- */
.edge{
  position:fixed;
  top:0; bottom:0;
  width:clamp(110px, 13vw, 200px);
  z-index:40;
  pointer-events:none;
  display:none;
  background-image:url(../assets/borde-floral.png);
  background-repeat:no-repeat;
  background-size:cover;
  background-position:left center;
}
.edge--left{ left:0; }
.edge--right{ right:0; transform:scaleX(-1); }

/* ============================================================
   BOTONES
   ============================================================ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.5em;
  font-family:var(--font-body);
  font-weight:800;
  font-size:.95rem;
  padding:.72em 1.25em;
  border-radius:999px;
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  line-height:1;
}
.btn:hover{ transform:translateY(-2px); }
.btn--publish{ background:var(--orange); color:#fff; box-shadow:0 4px 12px rgba(226,114,42,.35); }
.btn--publish:hover{ background:#d0641f; }
.btn--teal{ background:var(--teal); color:#fff; box-shadow:0 4px 12px rgba(28,138,134,.30); }
.btn--teal:hover{ background:var(--teal-deep); }
.btn--outline{ background:transparent; color:var(--red); border-color:var(--red); }
.btn--outline:hover{ background:var(--red); color:#fff; }
.btn--ghost-light{ background:#fff; color:var(--teal-deep); box-shadow:var(--shadow-sm); }
.btn--ghost-light:hover{ background:var(--cream-soft); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(251,243,224,.94);
  backdrop-filter:blur(8px);
  border-bottom:2px dashed var(--line-dash);
}
.header-inner{
  display:flex;
  align-items:center;
  gap:14px;
  padding-block:10px;
}

.logo{ display:flex; align-items:center; }
.logo__img{ height:56px; width:auto; }

.nav{
  display:none;
  align-items:center;
  gap:22px;
  margin-left:auto;
}
.nav__link{
  font-weight:700;
  font-size:.92rem;
  color:var(--ink);
  padding-bottom:3px;
  border-bottom:2px solid transparent;
  transition:color .15s, border-color .15s;
}
.nav__link:hover{ color:var(--orange); }
.nav__link.is-active{ color:var(--orange); border-color:var(--orange); }

.btn--publish{ margin-left:auto; }

.nav-toggle{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:42px; height:42px;
  background:transparent;
  border:0;
  cursor:pointer;
  margin-left:4px;
}
.nav-toggle span{
  display:block; height:3px; border-radius:3px; background:var(--ink);
  transition:transform .25s, opacity .2s;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  padding-block:32px 8px;
  background:
    radial-gradient(120% 90% at 80% 10%, rgba(242,180,49,.12), transparent 60%),
    var(--cream);
}
.hero-inner{ display:grid; gap:8px; }
.hero__copy{ order:2; }
.hero__art{ order:1; }

.flourish{ color:var(--orange); font-size:1.6rem; }

.hero__title{
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(1.7rem, 7.5vw, 3.1rem);
  line-height:1.06;
  letter-spacing:-.015em;
  display:flex;
  flex-direction:column;
  margin:.1em 0 .35em;
}
.c-orange{ color:var(--orange); }
.c-magenta{ color:var(--magenta); }
.c-teal{ color:var(--teal); }

.hero__sub{
  font-size:1.02rem;
  color:var(--ink-soft);
  max-width:34ch;
  margin-bottom:1.4em;
}

/* buscador */
.search{
  display:flex;
  flex-direction:column;
  gap:10px;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:10px;
  box-shadow:var(--shadow-sm);
  margin-bottom:1.1em;
}
.search__field{
  display:flex; align-items:center; gap:8px;
  flex:1;
  padding:10px 12px;
}
.search__ico{ width:20px; height:20px; color:var(--ink-soft); flex:0 0 auto; }
.search__field input{
  border:0; background:transparent; outline:none;
  font-family:var(--font-body); font-size:1rem; width:100%; color:var(--ink);
}
.search__select select{
  width:100%;
  font-family:var(--font-body); font-size:.95rem; font-weight:600;
  color:var(--ink);
  background:var(--cream-soft);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:11px 12px;
  cursor:pointer;
}

.hero__actions{ display:flex; flex-wrap:wrap; gap:12px; }

/* ilustración torre */
.hero__art{ display:flex; justify-content:center; }
.watertower{ width:min(78%, 340px); height:auto; filter:drop-shadow(0 12px 22px rgba(120,80,30,.18)); }

/* ============================================================
   CATEGORÍAS
   ============================================================ */
.categories{ padding-block:26px; }
.cat-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}
.cat{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px 8px 14px;
  box-shadow:var(--shadow-sm);
  text-align:center;
  transition:transform .15s, box-shadow .15s;
  position:relative;
}
.cat::after{
  content:"❧";
  color:var(--line-dash);
  font-size:.85rem;
  line-height:1;
}
.cat:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.cat__ico{
  width:54px; height:54px;
  border-radius:50%;
  background:var(--c, var(--orange));
  display:grid; place-items:center;
}
.cat__ico svg{ width:28px; height:28px; }
.cat__name{ font-weight:800; font-size:.92rem; line-height:1.2; overflow-wrap:break-word; max-width:100%; }

/* Categoría destacada (Dulces / cajetas) */
.cat--star{
  border-color:var(--c);
  box-shadow:0 0 0 2px color-mix(in srgb, var(--c) 30%, transparent), var(--shadow-sm);
}
.cat__tag{
  position:absolute;
  top:-9px; left:50%; transform:translateX(-50%);
  background:var(--c); color:#fff;
  font-size:.62rem; font-weight:800; letter-spacing:.02em;
  padding:3px 9px; border-radius:999px;
  box-shadow:0 2px 6px rgba(213,5,78,.35);
  white-space:nowrap;
}

/* ============================================================
   TÍTULOS DE SECCIÓN
   ============================================================ */
.section-title{
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(1.5rem, 5vw, 2rem);
  color:var(--magenta);
  text-align:center;
  letter-spacing:-.01em;
  position:relative;
}
.section-title::before,.section-title::after{
  content:"❀"; color:var(--orange); font-size:.7em; vertical-align:middle; margin:0 .4em;
}
.section-sub{ text-align:center; color:var(--ink-soft); margin-top:.25em; margin-bottom:1.6em; }

/* ============================================================
   NEGOCIOS DESTACADOS
   ============================================================ */
.featured{ padding-block:30px; }
.biz-rail{ position:relative; }
.biz-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
}
.biz-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .15s, box-shadow .15s;
}
.biz-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }

.biz-card__media{
  position:relative;
  aspect-ratio:16/10;
  display:grid; place-items:center;
  background:linear-gradient(135deg,#EAD9B6,#F3E6C9);
}
.biz-card__media--dulces{ background:linear-gradient(135deg,#E0922F,#F6D38A); }
.biz-card__media--coffee{ background:linear-gradient(135deg,#C9A678,#E4C79B); }
.biz-card__media--clinic{ background:linear-gradient(135deg,#A9D6D2,#CDE8E5); }
.biz-card__media--auto{ background:linear-gradient(135deg,#B7C2CC,#D5DDE4); }
.biz-card__media--shop{ background:linear-gradient(135deg,#D7B79C,#ECD6C2); }
.ph-ico{ font-size:2.6rem; filter:drop-shadow(0 2px 3px rgba(0,0,0,.15)); }

.badge{
  position:absolute; top:10px; left:10px;
  display:inline-flex; align-items:center; gap:5px;
  background:var(--orange); color:#fff;
  font-size:.72rem; font-weight:800;
  padding:5px 10px; border-radius:999px;
  box-shadow:0 3px 8px rgba(226,114,42,.4);
}
.badge .ico{ width:.85em; height:.85em; }

.biz-card__body{ padding:14px 16px 16px; }
.biz-card__body h3{ font-family:var(--font-display); font-size:1.18rem; font-weight:700; }
.biz-card__cat{ color:var(--ink-soft); font-size:.9rem; margin-bottom:.5em; }

.rating{ display:flex; align-items:center; gap:6px; font-size:.92rem; margin-bottom:.5em; }
.stars{ color:var(--yellow); letter-spacing:1px; }
.rating b{ color:var(--ink); }
.rating__n{ color:var(--ink-soft); }

.biz-card__phone{
  display:flex; align-items:center; gap:7px;
  font-weight:700; font-size:.95rem; color:var(--ink); margin-bottom:.7em;
}
.biz-card__phone .ico{ color:var(--teal); }

.biz-card__social{ display:flex; gap:10px; margin-bottom:.8em; }
.soc{
  width:34px; height:34px; border-radius:50%;
  display:grid; place-items:center;
  transition:transform .15s, filter .15s;
}
.soc svg{ width:18px; height:18px; }
.soc:hover{ transform:scale(1.08); }
.soc--wa{ background:#25D366; }
.soc--fb{ background:#1877F2; }
.soc--ig{ background:linear-gradient(45deg,#FEDA77,#F58529,#DD2A7B,#8134AF); }
.soc--yt{ background:#FF0000; }

.biz-card__loc{ display:flex; align-items:center; gap:6px; font-size:.9rem; color:var(--ink-soft); }
.biz-card__loc .ico{ width:1em; height:1em; }

.rail-next{
  display:none;
  position:absolute; top:38%; right:-18px;
  width:44px; height:44px; border-radius:50%;
  background:#fff; border:1px solid var(--line);
  box-shadow:var(--shadow); cursor:pointer;
  place-items:center;
}
.rail-next svg{ width:22px; height:22px; }

/* ============================================================
   ¿POR QUÉ?
   ============================================================ */
.why{ padding-block:30px; }
.why-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.why-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px 18px;
  box-shadow:var(--shadow-sm);
  display:flex; gap:14px; align-items:flex-start;
}
.why-card__ico{
  width:46px; height:46px; flex:0 0 auto;
  border-radius:14px;
  display:grid; place-items:center;
  background:color-mix(in srgb, var(--c) 14%, #fff);
}
.why-card__ico--solid{ background:var(--c); }
.why-card__ico svg{ width:24px; height:24px; }
.why-card h3{ font-family:var(--font-display); font-size:1.05rem; font-weight:700; margin-bottom:.2em; }
.why-card p{ font-size:.92rem; color:var(--ink-soft); }

/* ============================================================
   BANNER CTA
   ============================================================ */
.cta-band{ padding-block:30px; }
.cta-band__inner{
  background:var(--teal-band);
  border-radius:var(--radius);
  padding:26px 22px;
  display:flex; flex-direction:column; align-items:center; gap:16px;
  text-align:center;
  box-shadow:var(--shadow);
  position:relative; overflow:hidden;
}
.cta-band__inner::before,.cta-band__inner::after{
  content:""; position:absolute; width:120px; height:120px;
  background:repeating-linear-gradient(45deg, rgba(255,255,255,.08) 0 6px, transparent 6px 12px);
  border-radius:50%;
}
.cta-band__inner::before{ left:-40px; top:-40px; }
.cta-band__inner::after{ right:-40px; bottom:-40px; }
.cta-band__icon{
  width:64px; height:64px; border-radius:50%;
  background:#fff; display:grid; place-items:center;
  font-size:1.9rem; flex:0 0 auto; z-index:1;
}
.cta-band__copy{ z-index:1; }
.cta-band__copy h2{ font-family:var(--font-display); color:#fff; font-size:1.4rem; }
.cta-band__copy p{ color:var(--yellow); font-weight:700; }
.cta-band .btn{ z-index:1; }

/* ============================================================
   TESTIMONIOS
   ============================================================ */
.testimonials{ padding-block:30px 40px; }
.tst-grid{
  display:grid; grid-template-columns:1fr; gap:16px;
}
.tst-card{
  background:var(--card);
  border:1px solid var(--line);
  border-left:4px solid var(--orange);
  border-radius:var(--radius);
  padding:20px 18px;
  box-shadow:var(--shadow-sm);
  position:relative;
}
.tst-card__quote{
  font-family:var(--font-display);
  color:var(--red);
  font-size:2.6rem; line-height:0;
  position:absolute; top:24px; left:14px;
}
.tst-card p{ font-style:italic; color:var(--ink); margin:.4em 0 1.1em; padding-left:26px; }
.tst-card__person{ display:flex; align-items:center; gap:12px; }
.avatar{
  width:44px; height:44px; border-radius:50%;
  display:grid; place-items:center;
  color:#fff; font-weight:800; font-size:.95rem; flex:0 0 auto;
}
.avatar--a{ background:var(--magenta); }
.avatar--b{ background:var(--teal); }
.avatar--c{ background:var(--orange); }
.tst-card__person b{ display:block; font-size:.95rem; }
.tst-card__person span{ font-size:.82rem; color:var(--ink-soft); }
.tst-card__person > div{ margin-right:auto; }
.stars--sm{ font-size:.85rem; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:var(--cream-soft);
  border-top:2px dashed var(--line-dash);
  padding-top:34px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:26px;
}
.logo--footer .logo__img{ height:72px; }
.footer-brand p{ color:var(--ink-soft); font-size:.9rem; margin:.8em 0 1em; max-width:42ch; }
.footer-social{ display:flex; gap:10px; }

.footer-col h3{ font-family:var(--font-display); font-size:1.02rem; color:var(--magenta); margin-bottom:.7em; }
.footer-col a{ display:block; color:var(--ink-soft); font-size:.92rem; padding:4px 0; transition:color .15s; }
.footer-col a:hover{ color:var(--orange); }
.footer-contact{ display:flex; align-items:center; gap:8px; color:var(--ink-soft); font-size:.9rem; padding:4px 0; }
.footer-contact .ico{ color:var(--teal); width:1.05em; height:1.05em; }

.footer-bottom{
  margin-top:30px;
  border-top:1px solid var(--line);
  padding-block:16px;
  text-align:center;
  font-size:.84rem;
  color:var(--ink-soft);
}
.footer-bottom p{ margin:0; }
.footer-bottom .footer-credit{ margin-top:5px; }
.footer-credit a{ color:var(--orange); font-weight:700; transition:color .15s; }
.footer-credit a:hover{ color:var(--magenta); }

/* ============================================================
   BREAKPOINTS
   ============================================================ */
@media (min-width:600px){
  .biz-grid{ grid-template-columns:repeat(2, 1fr); }
  .why-grid{ grid-template-columns:repeat(2, 1fr); }
  .tst-grid{ grid-template-columns:repeat(2, 1fr); }
  .hero__sub{ max-width:none; }
}

@media (min-width:768px){
  .container{ padding-inline:28px; }
  .cat-grid{ grid-template-columns:repeat(5, 1fr); }
  .search{ flex-direction:row; align-items:center; }
  .search__field{ border-right:1px solid var(--line); }
  .search__select{ flex:0 0 auto; }
  .search__select select{ min-width:200px; background:#fff; }
  .cta-band__inner{ flex-direction:row; text-align:left; justify-content:space-between; padding:30px 34px; }
  .cta-band__copy{ flex:1; }
  .footer-grid{ grid-template-columns:1.6fr 1fr 1fr 1.2fr; }
  .tst-grid{ grid-template-columns:repeat(3, 1fr); }
}

@media (min-width:1024px){
  .nav{ display:flex; }
  .btn--publish{ margin-left:18px; }
  .nav-toggle{ display:none; }

  .edge{ display:block; }

  .hero{ padding-block:48px 24px; }
  .hero-inner{ grid-template-columns:1fr 1fr; align-items:center; gap:30px; }
  .hero__copy{ order:1; }
  .hero__art{ order:2; }
  .watertower{ width:min(100%, 420px); }

  .cat-grid{ grid-template-columns:repeat(5, 1fr); gap:16px; }
  .cat{ padding:22px 8px 16px; }

  .biz-grid{ grid-template-columns:repeat(4, 1fr); }
  .why-grid{ grid-template-columns:repeat(4, 1fr); }
  .rail-next{ display:grid; }

  .section-title{ font-size:2rem; }
}

@media (min-width:1024px){
  .header-inner{ padding-block:16px; }
  .logo__img{ height:88px; }
}

/* ---------- Menú móvil desplegado ---------- */
@media (max-width:1023px){
  .nav{
    position:fixed;
    top:0; right:0;
    width:min(78vw, 300px);
    height:100vh;
    background:var(--cream-soft);
    flex-direction:column;
    align-items:flex-start;
    gap:6px;
    padding:84px 26px 26px;
    box-shadow:-10px 0 30px rgba(0,0,0,.12);
    transform:translateX(100%);
    transition:transform .28s ease;
    z-index:45;
  }
  .nav.is-open{ display:flex; transform:translateX(0); }
  .nav__link{ font-size:1.05rem; padding:8px 0; width:100%; }
  .site-header .btn--publish{ display:none; }
  .nav-toggle{ margin-left:auto; }
}

@media (prefers-reduced-motion:reduce){
  *{ transition:none !important; scroll-behavior:auto; }
}
