/* ============================================================
   JustVeg — styles.css  ·  mobile-first, grid 8px
   Variables de marca inyectadas desde head.php (:root)
   ============================================================ */

/* Tipografia auto-alojada (sin Google Fonts: mas rapido y sin terceros/RGPD) */
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400 800;font-display:swap;src:url(/assets/fonts/pjs-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400 800;font-display:swap;src:url(/assets/fonts/pjs-latin-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}

:root{
  --green:#1f9d55; --green-600:#178a49; --green-700:#0f6d39;
  --green-50:#eafaf0; --green-100:#d2f3df;
  --ink:#0b1712; --ink-2:#16271f;
  --amber:#ffb03a; --amber-600:#f59e1b;
  --slate:#5b6b63; --slate-2:#8a9991;
  --line:#e6ebe8; --bg:#ffffff; --bg-soft:#f6faf7;
  --radius:16px; --radius-sm:11px; --radius-lg:24px;
  --shadow-sm:0 1px 2px rgba(11,23,18,.06),0 2px 8px rgba(11,23,18,.05);
  --shadow:0 6px 24px rgba(11,23,18,.10);
  --shadow-lg:0 24px 60px rgba(11,23,18,.16);
  --maxw:1180px;
  --ff: "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none!important}   /* fix: respeta el atributo hidden (banner cookies, etc.) */
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:var(--ff);color:var(--ink);background:var(--bg);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.15;margin:0 0 .5em;font-weight:800;letter-spacing:-.02em}
h2{font-size:clamp(1.55rem,4.5vw,2.3rem)}
h3{font-size:1.2rem;font-weight:700}
p{margin:0 0 1rem}
ul{margin:0;padding:0;list-style:none}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:16px}
@media(min-width:768px){.container{padding-inline:24px}}

.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--amber);outline-offset:2px;border-radius:6px}

/* ── Botones ──────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-weight:700;font-size:1rem;padding:13px 22px;border-radius:999px;border:0;
  cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  min-height:48px;line-height:1}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 8px 20px rgba(31,157,85,.28)}
.btn-primary:hover{background:var(--green-600);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#16261d;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--green);color:var(--green-700);background:var(--green-50)}
.btn-amber{background:var(--amber);color:#3a2a06}
.btn-amber:hover{background:var(--amber-600);transform:translateY(-2px)}
.btn-lg{padding:16px 30px;font-size:1.06rem;min-height:54px}
.btn-block{width:100%}

/* ── Header ───────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.88);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.nav-wrap{display:flex;align-items:center;gap:14px;min-height:66px}
.brand{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:1.28rem;color:var(--ink);letter-spacing:-.03em}
.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;
  background:linear-gradient(135deg,var(--green),var(--green-700));color:#fff;box-shadow:0 6px 14px rgba(31,157,85,.35)}
.brand-name strong{color:var(--green)}
.brand--footer{color:#fff;font-size:1.2rem}
.brand--footer .brand-name strong{color:var(--amber)}

.header-search{position:relative;flex:1;max-width:430px;margin-inline:auto;display:none}
@media(min-width:980px){.header-search{display:flex}}
.header-search .hs-icon{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--slate-2)}
.jv-ac-input{width:100%;border:1.5px solid var(--line);background:var(--bg-soft);
  border-radius:999px;padding:11px 16px 11px 42px;font:inherit;font-size:.95rem;color:var(--ink)}
.jv-ac-input::placeholder{color:var(--slate-2)}
.jv-ac-input:focus{outline:none;border-color:var(--green);background:#fff;box-shadow:0 0 0 4px var(--green-50)}

.main-nav ul{display:flex;align-items:center;gap:6px}
.main-nav a{display:inline-block;padding:9px 13px;border-radius:9px;font-weight:600;font-size:.96rem;color:var(--ink-2)}
.main-nav a:hover{background:var(--green-50);color:var(--green-700)}
.main-nav a[aria-current=page]{color:var(--green-700)}
.nav-cta{background:var(--ink);color:#fff!important}
.nav-cta:hover{background:var(--green)!important;color:#fff!important}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:10px;margin-left:auto}
.nav-toggle span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:.25s}

@media(max-width:979px){
  .nav-toggle{display:flex}
  .main-nav{position:fixed;inset:66px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .3s ease;box-shadow:var(--shadow);max-height:calc(100vh - 66px);overflow:auto}
  .main-nav.open{transform:translateY(0)}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:2px;padding:14px}
  .main-nav a{padding:14px 16px;border-radius:12px;font-size:1.05rem}
  .nav-cta{text-align:center;margin-top:6px}
}

/* ── Autocompletar (dropdown) ─────────────────────────── */
.jv-ac-list{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;
  border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);
  overflow:hidden;z-index:120;max-height:62vh;overflow-y:auto}
.jv-ac-list li{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--bg-soft)}
.jv-ac-list li:last-child{border-bottom:0}
.jv-ac-list li:hover,.jv-ac-list li.active{background:var(--green-50)}
.jv-ac-thumb{width:44px;height:44px;border-radius:10px;object-fit:cover;flex:none;background:var(--bg-soft)}
.jv-ac-txt{min-width:0}
.jv-ac-name{font-weight:700;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jv-ac-meta{font-size:.8rem;color:var(--slate)}
.jv-ac-empty{padding:16px;text-align:center;color:var(--slate);font-size:.9rem}

/* ── Hero ─────────────────────────────────────────────── */
.hero{position:relative;background:radial-gradient(110% 120% at 80% -10%,#103b27 0%,var(--ink) 55%);color:#fff;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(40% 50% at 12% 20%,rgba(31,157,85,.32),transparent 60%),
  radial-gradient(38% 42% at 92% 90%,rgba(255,176,58,.20),transparent 60%);pointer-events:none}
.hero-inner{position:relative;z-index:1;padding:54px 0 64px;text-align:center;max-width:780px;margin-inline:auto}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);color:#dffae9;padding:7px 14px;border-radius:999px;font-size:.82rem;font-weight:600;margin-bottom:18px}
.hero h1{font-size:clamp(2.05rem,7vw,3.6rem);margin-bottom:.4em;letter-spacing:-.03em}
.hero h1 .hl{color:var(--amber)}
.hero .lead{font-size:clamp(1.02rem,2.6vw,1.22rem);color:#cfe6da;max-width:600px;margin:0 auto 26px}

.hero-search{position:relative;max-width:560px;margin:0 auto}
.hero-search form{display:flex;gap:8px;background:#fff;padding:8px;border-radius:18px;box-shadow:var(--shadow-lg)}
.hero-search .field{position:relative;flex:1}
.hero-search .hs-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--slate-2)}
.hero-search input{width:100%;border:0;background:transparent;padding:14px 14px 14px 44px;font:inherit;font-size:1rem;color:var(--ink)}
.hero-search input:focus{outline:none}
.hero-search .btn{flex:none}
.hero-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:18px}
.hero-chips a{font-size:.85rem;color:#dffae9;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:7px 13px;border-radius:999px;font-weight:600}
.hero-chips a:hover{background:rgba(255,255,255,.18)}
.hero-stats{display:flex;gap:26px;justify-content:center;flex-wrap:wrap;margin-top:34px}
.hero-stats .n{font-size:1.6rem;font-weight:800;color:#fff}
.hero-stats .l{font-size:.8rem;color:#9fc4b3;text-transform:uppercase;letter-spacing:.06em}

@media(max-width:560px){
  .hero-search form{flex-direction:column;border-radius:18px}
  .hero-search .btn{width:100%}
}

/* ── Secciones genericas ──────────────────────────────── */
.section{padding:56px 0}
.section--soft{background:var(--bg-soft)}
.section-head{max-width:680px;margin:0 auto 34px;text-align:center}
.section-head .kicker{color:var(--green-700);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;display:block;margin-bottom:8px}
.section-head p{color:var(--slate);font-size:1.05rem;margin:0}
.section-head.left{text-align:left;margin-inline:0}

/* ── Grid de tarjetas (sitios) ────────────────────────── */
.cards{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:560px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.cards{grid-template-columns:repeat(3,1fr)}}

.card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card-media{position:relative;aspect-ratio:16/10;background:var(--bg-soft)}
.card-media img{width:100%;height:100%;object-fit:cover}
.card-badges{position:absolute;top:10px;left:10px;display:flex;gap:6px;flex-wrap:wrap}
.badge{font-size:.72rem;font-weight:700;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.94);color:var(--ink);box-shadow:var(--shadow-sm)}
.badge--vegan{background:var(--green);color:#fff}
.badge--top{background:var(--amber);color:#3a2a06}
.card-fav{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;border:0;
  background:rgba(255,255,255,.92);display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow-sm);color:var(--ink-2);transition:.15s}
.card-fav:hover{color:#e23;transform:scale(1.08)}
.card-fav.is-fav{color:#e23;background:#fff}
.card-body{padding:15px 16px 17px;display:flex;flex-direction:column;flex:1}
.card-cat{font-size:.76rem;font-weight:700;color:var(--green-700);text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:5px}
.card-cat svg{flex:none}
.h1-cat-ic{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:12px;margin-right:10px;vertical-align:-10px}
.card-title{font-size:1.12rem;font-weight:800;margin:3px 0 4px}
.card-loc{font-size:.86rem;color:var(--slate);display:flex;align-items:center;gap:5px;margin-bottom:8px}
.card-desc{font-size:.9rem;color:#3d4d45;margin:0 0 14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between}
.card-price{font-weight:700;color:var(--ink);font-size:.9rem}
.card-link{font-weight:700;color:var(--green-700);font-size:.9rem;display:inline-flex;align-items:center;gap:4px}
.card-link::after{content:"→";transition:transform .15s}
.card:hover .card-link::after{transform:translateX(3px)}
.stretched{position:absolute;inset:0;z-index:1}

/* ── Categorias (tiles) ───────────────────────────────── */
.cats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:680px){.cats{grid-template-columns:repeat(4,1fr)}}
.cat{display:flex;flex-direction:column;gap:8px;padding:18px 16px;border-radius:var(--radius);
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:.18s;text-align:left}
.cat:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--green-100)}
.cat-ic{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;background:var(--green-50);color:var(--green-700);transition:transform .2s cubic-bezier(.22,.68,0,1)}
.cat:hover .cat-ic{transform:scale(1.1) rotate(-3deg)}
.cat-name{font-weight:800;font-size:1rem}
.cat-count{font-size:.82rem;color:var(--slate)}
/* Identidad de color por categoria */
.cat-ic--restaurante{background:var(--green-50);color:var(--green-700)}
.cat-ic--brunch{background:#fff2da;color:#bd7a10}
.cat-ic--asiatico{background:#ffe7e3;color:#cf3a2e}
.cat-ic--burger{background:#ffeed8;color:#dc7510}
.cat-ic--tapas{background:#ece6ff;color:#6244e6}
.cat-ic--dulce{background:#ffe6f1;color:#cf3f86}
.cat-ic--tienda{background:#e0f5ef;color:#0e9277}

/* ── Como funciona ────────────────────────────────────── */
.steps{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:780px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow-sm)}
.step-n{width:42px;height:42px;border-radius:12px;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:800;margin-bottom:14px}
.step h3{margin-bottom:6px}
.step p{color:var(--slate);margin:0;font-size:.95rem}

/* ── Franja ciudad / feature ──────────────────────────── */
.feature{display:grid;grid-template-columns:1fr;gap:26px;align-items:center}
@media(min-width:880px){.feature{grid-template-columns:1.05fr .95fr;gap:48px}}
.feature-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3}
.feature-media img{width:100%;height:100%;object-fit:cover}
.feature ul.ticks{margin:18px 0 24px;display:grid;gap:12px}
.feature ul.ticks li{display:flex;gap:11px;align-items:flex-start;font-size:1rem}
.tick{flex:none;width:24px;height:24px;border-radius:50%;background:var(--green-50);color:var(--green-700);display:grid;place-items:center;margin-top:1px}

/* ── CTA comunidad / monetizacion ─────────────────────── */
.band{background:linear-gradient(135deg,var(--green-700),#0c5e34);color:#fff;border-radius:var(--radius-lg);padding:40px 28px;text-align:center;position:relative;overflow:hidden}
.band::after{content:"";position:absolute;inset:0;background:radial-gradient(50% 60% at 90% 10%,rgba(255,176,58,.25),transparent 60%)}
.band > *{position:relative;z-index:1}
.band h2{color:#fff}
.band p{color:#d6f0e2;max-width:560px;margin:0 auto 22px}
.band .btn-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

.newsletter{max-width:480px;margin:18px auto 0;display:flex;gap:8px;background:#fff;padding:7px;border-radius:14px}
.newsletter input{flex:1;border:0;padding:12px 14px;font:inherit;font-size:.95rem;border-radius:9px;color:var(--ink)}
.newsletter input:focus{outline:2px solid var(--amber)}
@media(max-width:520px){.newsletter{flex-direction:column}}

/* ── Tiras de logos/afiliados (micromonetizacion) ─────── */
.perks{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:780px){.perks{grid-template-columns:repeat(3,1fr)}}
.perk{display:flex;gap:14px;align-items:flex-start;padding:20px;border:1px dashed var(--line);border-radius:var(--radius);background:var(--bg-soft)}
.perk .ic{flex:none;width:44px;height:44px;border-radius:12px;background:#fff;color:var(--green-700);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.perk h3{font-size:1rem;margin-bottom:3px}
.perk p{font-size:.88rem;color:var(--slate);margin:0}

/* ── Pagina guia (listado + filtros) ──────────────────── */
.guide-head{background:var(--bg-soft);border-bottom:1px solid var(--line);padding:30px 0}
.guide-head h1{font-size:clamp(1.7rem,5vw,2.5rem);margin-bottom:6px}
.guide-head p{color:var(--slate);margin:0}
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:22px 0 6px}
.filters .search-mini{position:relative;flex:1;min-width:220px}
.filters .search-mini .hs-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--slate-2)}
.filters .search-mini input{width:100%;border:1.5px solid var(--line);border-radius:999px;padding:11px 14px 11px 40px;font:inherit;background:#fff}
.filters .search-mini input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px var(--green-50)}
.chip-row{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:.86rem;font-weight:600;padding:9px 15px;border-radius:999px;border:1.5px solid var(--line);background:#fff;color:var(--ink-2);cursor:pointer}
.chip:hover{border-color:var(--green);color:var(--green-700)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.result-count{color:var(--slate);font-size:.92rem;margin:18px 0 14px}
.empty-state{text-align:center;padding:50px 20px;color:var(--slate)}
.empty-state svg{color:var(--slate-2);margin-bottom:10px}
.empty-h{font-size:1.3rem;margin:6px 0}
.section-head h1{font-size:clamp(1.55rem,4.5vw,2.3rem)}

/* ── Ficha (sitio) ────────────────────────────────────── */
.fichahero{position:relative;aspect-ratio:21/9;min-height:240px;background:var(--bg-soft);overflow:hidden}
.fichahero img{width:100%;height:100%;object-fit:cover}
.fichahero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(11,23,18,.78))}
.ficha-overcard{position:relative;margin-top:-90px;z-index:2}
.ficha-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:26px}
@media(min-width:880px){.ficha-card{padding:34px}}
.ficha-top{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-start;justify-content:space-between}
.ficha-card h1{font-size:clamp(1.7rem,5vw,2.4rem);margin-bottom:6px}
.ficha-sub{display:flex;flex-wrap:wrap;gap:10px;align-items:center;color:var(--slate);font-size:.95rem}
.ficha-dot{width:4px;height:4px;border-radius:50%;background:var(--slate-2)}
.ficha-actions{display:flex;gap:10px;flex-wrap:wrap}
.ficha-grid{display:grid;grid-template-columns:1fr;gap:28px;margin-top:28px}
@media(min-width:880px){.ficha-grid{grid-template-columns:1.6fr .9fr}}
.ficha-body h2{font-size:1.3rem;margin-top:10px}
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}
.tag{font-size:.82rem;background:var(--green-50);color:var(--green-700);padding:6px 12px;border-radius:999px;font-weight:600}
.infobox{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.infobox h3{font-size:1rem;margin-bottom:12px}
.info-row{display:flex;gap:11px;padding:9px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.info-row:last-child{border-bottom:0}
.info-row .ic{color:var(--green-700);flex:none}
.review-note{display:flex;gap:11px;background:var(--green-50);border:1px solid var(--green-100);border-radius:var(--radius);padding:16px;margin-top:16px;font-size:.9rem;color:var(--ink-2)}

/* ── Breadcrumbs ──────────────────────────────────────── */
.breadcrumbs{background:#fff;border-bottom:1px solid var(--line)}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:8px;padding-block:12px;font-size:.85rem;color:var(--slate)}
.breadcrumbs li::after{content:"/";margin-left:8px;color:var(--slate-2)}
.breadcrumbs li:last-child::after{content:""}
.breadcrumbs a:hover{color:var(--green-700)}

/* ── Footer ───────────────────────────────────────────── */
.site-footer{background:var(--ink);color:#bcd0c6;padding-top:50px;margin-top:10px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:30px;padding-bottom:34px}
@media(min-width:560px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1fr 1fr}}
.footer-about p{color:#9fc4b3;font-size:.92rem;margin-top:12px}
.footer-h{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.site-footer a:hover{color:#fff}
.site-footer li{margin-bottom:9px;font-size:.93rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:space-between;font-size:.84rem;color:#7e9a8c}
.footer-note{color:#5f7a6d}

/* ── Volver arriba / cookies ──────────────────────────── */
.back-to-top{position:fixed;right:18px;bottom:18px;width:46px;height:46px;border-radius:50%;border:0;
  background:var(--ink);color:#fff;display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow);
  opacity:0;transform:translateY(12px);transition:.25s;z-index:90}
.back-to-top.show{opacity:1;transform:translateY(0)}
.cookie-banner{position:fixed;left:14px;right:14px;bottom:14px;background:#fff;border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow-lg);padding:16px;z-index:130;display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between}
.cookie-banner p{margin:0;font-size:.9rem}
.cookie-actions{display:flex;gap:8px;margin-left:auto}
.cookie-actions .btn{padding:10px 18px;min-height:42px;font-size:.9rem}

/* ── FAQ ──────────────────────────────────────────────── */
.faq-item{border:1px solid var(--line);border-radius:var(--radius);padding:4px 18px;margin-bottom:12px;background:#fff;transition:box-shadow .2s}
.faq-item[open]{box-shadow:var(--shadow-sm)}
.faq-item summary{cursor:pointer;padding:16px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;font-size:1.04rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.5rem;color:var(--green-700);font-weight:400;transition:transform .2s;flex:none}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{padding:0 0 16px;margin:0;color:#3d4d45}
.faq-item a{color:var(--green-700);font-weight:600;text-decoration:underline}

/* ── Formularios (contacto) ───────────────────────────── */
.narrow{max-width:720px;margin-inline:auto}
.form{margin-top:22px;display:grid;gap:16px;max-width:560px}
.form .field{display:grid;gap:6px}
.form label{font-weight:600;font-size:.92rem}
.form input,.form textarea{border:1.5px solid var(--line);border-radius:12px;padding:13px 14px;font:inherit;font-size:1rem;background:#fff}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px var(--green-50)}
.form .err{color:#c0392b;font-size:.85rem}
.hp{position:absolute;left:-9999px}
.alert{padding:14px 18px;border-radius:12px;margin:18px 0;font-size:.95rem}
.alert-ok{background:var(--green-50);border:1px solid var(--green-100);color:var(--green-700)}

/* Casilla de consentimiento (RGPD) en formularios */
.form-consent{display:flex;gap:10px;align-items:flex-start;font-size:.88rem;color:var(--slate);line-height:1.5;text-align:left;cursor:pointer}
.form-consent input{margin-top:3px;flex:none;width:18px;height:18px;accent-color:var(--green)}
.form-consent a{color:var(--green-700);text-decoration:underline}

/* ── Pulido responsive (desktop equilibrado + movil perfecto) ── */
img,svg,video,iframe{max-width:100%}
.cards{align-items:stretch}
@media(min-width:1280px){.container{padding-inline:32px}}
@media(max-width:760px){
  .ficha-actions{width:100%}
  .ficha-actions .btn{flex:1;justify-content:center}
  .ficha-top{gap:12px}
  .breadcrumbs ol{font-size:.8rem}
  .hero-tools{gap:8px}
  .tool-btn{font-size:.85rem;padding:10px 14px}
}
@media(max-width:400px){
  .hero-stats{gap:12px}
  .chip,.city-pill{font-size:.82rem}
  .btn{font-size:.95rem}
}

/* ── Utilidades ───────────────────────────────────────── */
.center{text-align:center}
.mt-32{margin-top:32px}
.prose{max-width:720px;margin:0 auto}
.prose p{color:#33433b}
.lead-p{font-size:1.1rem;color:var(--slate)}
.muted-s{color:var(--slate-2);font-size:.85rem}

/* Paginas legales / texto largo con listas */
.legal h2{font-size:1.25rem;margin:1.7em 0 .5em}
.legal p,.legal li{color:#33433b;line-height:1.7}
.prose ul,.prose ol{margin:0 0 1.1rem;padding-left:22px}
.prose li{margin-bottom:.45rem}
.prose code{background:var(--bg-soft);border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-size:.88em}
.legal a{color:var(--green-700);text-decoration:underline;text-underline-offset:2px}
.btn-sm{padding:9px 16px;min-height:40px;font-size:.9rem;margin-top:12px}

/* ============================================================
   v2 — Espectacularidad + ciudades + compactado movil
   ============================================================ */

/* Hero: orbes animados + mas dramatismo */
.hero-orbs{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.hero-orbs span{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;animation:float 14s ease-in-out infinite}
.hero-orbs span:nth-child(1){width:420px;height:420px;background:#1f9d55;top:-120px;left:-80px}
.hero-orbs span:nth-child(2){width:360px;height:360px;background:#ffb03a;bottom:-140px;right:-60px;animation-delay:-5s;opacity:.4}
.hero-orbs span:nth-child(3){width:300px;height:300px;background:#27c2b3;top:40%;left:55%;animation-delay:-9s;opacity:.35}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(24px,-30px) scale(1.08)}}
@media (prefers-reduced-motion:reduce){.hero-orbs span{animation:none}}
.hero-inner{padding-block:64px 72px}
.hero h1 br{display:block}

/* Cards: ciudad sobre la foto + diet en pie */
.card-city{position:absolute;bottom:10px;left:10px;font-size:.74rem;font-weight:700;color:#fff;
  background:rgba(11,23,18,.55);backdrop-filter:blur(4px);padding:5px 11px;border-radius:999px;letter-spacing:.02em}
.card-diet{font-weight:700;color:var(--green-700);font-size:.84rem}
.card-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(11,23,18,.35));opacity:0;transition:opacity .25s}
.card:hover .card-media::after{opacity:1}

/* Cards grid: hasta 4 columnas en pantallas anchas (equilibrado desktop) */
@media(min-width:1200px){.cards{grid-template-columns:repeat(4,1fr)}}

/* Rejilla de ciudades (tiles con foto) */
.city-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(min-width:680px){.city-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1000px){.city-grid{grid-template-columns:repeat(4,1fr)}}
.city-tile{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;aspect-ratio:5/4;display:block}
.city-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.city-tile-media{position:absolute;inset:0}
.city-tile-media img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.city-tile:hover .city-tile-media img{transform:scale(1.06)}
.city-tile-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,23,18,.05) 30%,rgba(11,23,18,.82))}
.city-tile-body{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;color:#fff;z-index:1}
.city-tile-name{display:block;font-weight:800;font-size:1.18rem;letter-spacing:-.02em}
.city-tile-count{font-size:.82rem;color:#cfe6da}
.comunidad-h{font-size:1.15rem;color:var(--slate);font-weight:700;margin:30px 0 14px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.comunidad-h:first-child{margin-top:0}

/* Tira de ciudades (scroll horizontal en guia nacional) */
.city-strip{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:66px;z-index:50}
.city-scroll{display:flex;gap:8px;overflow-x:auto;padding:14px 0;scrollbar-width:thin;-webkit-overflow-scrolling:touch}
.city-scroll::-webkit-scrollbar{height:6px}
.city-scroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.city-pill{flex:none;font-size:.88rem;font-weight:600;padding:9px 15px;border-radius:999px;border:1.5px solid var(--line);background:#fff;color:var(--ink-2);white-space:nowrap}
.city-pill:hover{border-color:var(--green);color:var(--green-700)}
.city-pill.active{background:var(--green);color:#fff;border-color:var(--green)}

.chip-n{display:inline-block;font-size:.72rem;opacity:.65;font-weight:700;margin-left:2px}
.guide-eyebrow{display:inline-block;color:var(--green-700);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}

/* Ficha: bloque "que dice la gente" + mini ciudad */
.verdict-card{display:flex;gap:14px;background:var(--green-50);border:1px solid var(--green-100);border-radius:var(--radius);padding:18px;margin-top:8px}
.verdict-ic{flex:none;width:44px;height:44px;border-radius:12px;background:#fff;color:var(--green-700);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.verdict-text{font-weight:600;color:var(--ink);margin:0 0 8px}
.verdict-note{font-size:.85rem;color:var(--slate);margin:0 0 8px}
.city-mini{display:flex;flex-direction:column;gap:2px;margin-top:14px;padding:16px 18px;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--ink),#16261d);color:#fff}
.city-mini span{font-size:.8rem;color:#9fc4b3}
.city-mini strong{font-size:1.1rem}
.city-mini:hover strong{color:var(--amber)}

/* ── COMPACTADO MOVIL (<=600px) ─────────────────────── */
@media(max-width:600px){
  .section{padding:38px 0}
  .hero-inner{padding-block:40px 46px}
  .section-head{margin-bottom:24px}
  .cards{gap:12px}
  .card-media{aspect-ratio:16/9}
  .card-body{padding:13px 13px 15px}
  .card-title{font-size:1.05rem}
  .card-desc{-webkit-line-clamp:2;font-size:.86rem}
  .city-grid{gap:10px}
  .city-tile{aspect-ratio:4/3}
  .city-tile-name{font-size:1rem}
  .band{padding:30px 20px}
  .steps,.perks{gap:12px}
  .step{padding:20px 18px}
  .hero-stats{gap:16px;margin-top:26px}
  .hero-stats .n{font-size:1.3rem}
  .ficha-card{padding:20px}
  .ficha-overcard{margin-top:-60px}
  .verdict-card{flex-direction:column;gap:10px}
  .filters{gap:8px}
  .filters .btn{width:100%}
}
@media(max-width:380px){
  .cats{grid-template-columns:1fr}
  .city-grid{grid-template-columns:1fr 1fr}
}

/* Enlazado interno (SEO/UX) */
.interlink{display:grid;grid-template-columns:1fr;gap:26px}
@media(min-width:760px){.interlink{grid-template-columns:1fr 1fr;gap:40px}}
.interlink-h{font-size:1.1rem;margin-bottom:14px}
.link-cloud{display:flex;flex-wrap:wrap;gap:8px}
.link-cloud a{font-size:.88rem;font-weight:600;color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--line);
  padding:8px 14px;border-radius:999px;transition:.15s}
.link-cloud a:hover{border-color:var(--green);color:var(--green-700);background:var(--green-50)}
.link-cloud .link-more{background:var(--ink);color:#fff;border-color:var(--ink)}
.link-cloud .link-more:hover{background:var(--green);color:#fff;border-color:var(--green)}

/* Valoracion Google (cuando hay dato real via Places API) */
.g-rating{display:inline-flex;align-items:center;gap:4px;font-weight:800;color:#1a7f4b;font-size:.9rem}
.g-rating svg{color:var(--amber)}
.g-rating .g-rev{font-weight:600;color:var(--slate);font-size:.82rem}
.verdict-rating{margin:0 0 6px;font-size:1.05rem}
.verdict-rating .g-rating{font-size:1.1rem}
.verdict-rating-src{font-size:.8rem;color:var(--slate);font-weight:600}

/* Tarjeta patrocinada (anunciantes) */
.card--sponsor{border:1.5px dashed var(--green);background:linear-gradient(160deg,var(--green-50),#fff);justify-content:center}
.card--sponsor .card-cat{color:var(--amber-600)}
.card--sponsor .card-title{font-size:1.12rem}
.card--sponsor .card-link{color:var(--green-700)}

/* Planes de publicidad (/anunciate) */
.plan-card{cursor:default}
.plan-card .stretched{display:none}
.plan-card--feat{border:2px solid var(--green);box-shadow:var(--shadow)}
.plan-list{margin:12px 0 0;display:grid;gap:8px}
.plan-list li{position:relative;padding-left:24px;font-size:.92rem;color:#33433b}
.plan-list li::before{content:"";position:absolute;left:0;top:6px;width:14px;height:14px;border-radius:50%;
  background:var(--green-50);box-shadow:inset 0 0 0 2px var(--green)}

/* Contenido SEO (texto largo) */
.seo-copy{max-width:760px}
.seo-copy h2{font-size:clamp(1.4rem,3.5vw,1.9rem);margin-bottom:.5em}
.seo-copy p{color:#33433b;font-size:1.02rem;line-height:1.75;margin-bottom:1.1rem}
.seo-copy a{color:var(--green-700);font-weight:600;text-decoration:underline;text-underline-offset:2px}

/* ── Blog / articulo ──────────────────────────────────── */
.post-card .card-title{font-size:1.12rem}
.post-wrap{max-width:820px;margin-inline:auto}
.post-header{padding:26px 0 8px}
.post-header h1{font-size:clamp(1.8rem,5.5vw,2.7rem);margin:6px 0}
.post-meta{color:var(--slate);font-size:.9rem}
.post-body{max-width:none}
.post-body>.lead-p{font-size:1.12rem;color:#33433b;line-height:1.7}
.post-body h2{font-size:clamp(1.3rem,4vw,1.7rem);margin:1.4em 0 .5em}
.post-list{list-style:none;counter-reset:none;margin:24px 0;padding:0;display:grid;gap:22px}
.post-item{display:grid;grid-template-columns:1fr;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
@media(min-width:640px){.post-item{grid-template-columns:260px 1fr}}
.post-item-media{aspect-ratio:4/3;background:var(--bg-soft)}
.post-item-media img{width:100%;height:100%;object-fit:cover}
.post-item-body{padding:16px 18px 18px}
@media(min-width:640px){.post-item-body{padding:18px 20px}}
.post-item-head{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.post-num{flex:none;width:34px;height:34px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-weight:800}
.post-item-head h2{margin:0;font-size:1.25rem}
.post-item-head h2 a{color:var(--ink)}
.post-item-head h2 a:hover{color:var(--green-700)}
.post-item-meta{font-size:.86rem;color:var(--slate);margin:0 0 8px}
.post-veg{color:var(--green-700);font-weight:700}
.post-item-body p{color:#3d4d45}
.post-item-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.post-item-links .btn-sm{margin-top:0}
.post-related{margin:30px 0 10px;padding:22px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius)}
.post-related h2{margin:0 0 12px;font-size:1.2rem}
.post-related ul{display:grid;gap:8px}
.post-related a{color:var(--green-700);font-weight:600}

.ficha-claim{margin-top:14px;font-size:.86rem;color:var(--slate);text-align:center}
.ficha-claim a{color:var(--green-700);font-weight:600;text-decoration:underline}

/* Quicklinks en ficha */
.quicklinks{display:grid;gap:8px;margin-top:14px}
.quicklinks a{font-size:.9rem;font-weight:600;color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--line);
  padding:11px 14px;border-radius:11px;transition:.15s}
.quicklinks a:hover{border-color:var(--green);color:var(--green-700);background:var(--green-50)}

/* ============================================================
   v3 — UX/UI disruptiva: motion, hero XL, herramientas
   ============================================================ */

/* Motion: scroll-reveal (estilo Framer Motion, sin libreria) */
.js-anim .reveal{opacity:0;transform:translateY(20px);will-change:opacity,transform}
.js-anim .reveal.in{opacity:1;transform:none;
  transition:opacity .6s ease var(--rd,0ms), transform .65s cubic-bezier(.22,.68,0,1) var(--rd,0ms)}

/* Barra de progreso de scroll */
.scroll-progress{position:absolute;left:0;right:0;bottom:-1px;height:3px;transform:scaleX(0);transform-origin:0 50%;
  background:linear-gradient(90deg,var(--green),var(--amber));z-index:101}

/* Header con sombra al hacer scroll */
.site-header.scrolled{box-shadow:0 6px 24px rgba(11,23,18,.08)}

/* Favoritos en nav */
.nav-fav{position:relative;display:inline-flex!important;align-items:center;gap:6px}
.nav-fav:hover{color:#e23!important}
.fav-count{position:absolute;top:2px;right:-2px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;
  background:#e23;color:#fff;font-size:.66rem;font-weight:800;display:grid;place-items:center;line-height:1}
@media(max-width:979px){.nav-fav-label{display:inline}.fav-count{position:static}}
@media(min-width:980px){.nav-fav-label{display:none}}

/* ── HERO XL ──────────────────────────────────────────── */
.hero--xl .hero-inner{padding-block:72px 40px;max-width:880px}
.hero-grain{position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:4px 4px}
.eyebrow-dot{width:8px;height:8px;border-radius:50%;background:#6ee7a8;box-shadow:0 0 0 0 rgba(110,231,168,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(110,231,168,.5)}70%{box-shadow:0 0 0 8px rgba(110,231,168,0)}100%{box-shadow:0 0 0 0 rgba(110,231,168,0)}}
.hero h1{text-wrap:balance}

/* Herramientas del hero */
.hero-tools{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:20px}
.tool-btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.92rem;color:#eafaf0;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);padding:11px 18px;border-radius:999px;
  cursor:pointer;transition:.2s;backdrop-filter:blur(6px)}
.tool-btn:hover{background:rgba(255,255,255,.16);transform:translateY(-2px)}
.tool-btn--glow{background:rgba(31,157,85,.28);border-color:rgba(110,231,168,.45)}
.tool-btn--glow:hover{background:rgba(31,157,85,.42)}
.tool-spin{display:none;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
.tool-btn.loading .tool-spin{display:inline-block}
.tool-btn.loading .tool-label{opacity:.6}
@keyframes spin{to{transform:rotate(360deg)}}

/* Marquee de imagenes (motion graphics) */
.hero-marquee{position:relative;z-index:1;margin-top:30px;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:14px;width:max-content;padding-bottom:6px;animation:marquee 55s linear infinite}
.hero-marquee:hover .marquee-track{animation-play-state:paused}
.marquee-card{flex:none;width:170px;height:120px;border-radius:14px;overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.3)}
.marquee-card img{width:100%;height:100%;object-fit:cover}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:560px){.marquee-card{width:130px;height:94px}}

/* Tools row en guias */
.tools-row{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-top:14px}
.tools-row .tool-btn{color:var(--ink-2);background:var(--bg-soft);border-color:var(--line)}
.tools-row .tool-btn:hover{border-color:var(--green);color:var(--green-700);background:var(--green-50);transform:none}
.switch{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.92rem;color:var(--ink-2);cursor:pointer;user-select:none}
.switch input{position:absolute;opacity:0;width:0;height:0}
.switch-track{width:42px;height:24px;border-radius:999px;background:var(--line);position:relative;transition:.2s;flex:none}
.switch-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:.2s}
.switch input:checked + .switch-track{background:var(--green)}
.switch input:checked + .switch-track .switch-thumb{transform:translateX(18px)}
.switch input:focus-visible + .switch-track{outline:3px solid var(--amber);outline-offset:2px}

/* Texto largo justificado y legible */
.seo-copy p,.post-item-body p,.post-body>p{text-align:justify;hyphens:auto}
@media(max-width:560px){.seo-copy p,.post-item-body p,.post-body>p{text-align:left}}
h1,h2,h3{text-wrap:balance}

@media (prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
  .eyebrow-dot{animation:none}
  .hero-orbs span{animation:none}
  .js-anim .reveal{opacity:1;transform:none}
}

/* Mapa interactivo (pagina /mapa) */
.map-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.map-filters .chip{cursor:pointer}
.chip--geo{background:var(--green-50);border-color:var(--green-100);color:var(--green-700);font-weight:700}
.chip--geo.loading{opacity:.55;pointer-events:none}
#jv-map{height:540px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);z-index:0}
@media(max-width:600px){#jv-map{height:420px}}
.leaflet-popup-content{font-family:var(--ff)}
.leaflet-popup-content a{color:var(--green-700);font-weight:700}

/* Mapa embebido en ficha */
.ficha-map{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);margin:6px 0 8px}
.ficha-map iframe{width:100%;height:320px;border:0;display:block}

/* Paginador */
.pager{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:34px;flex-wrap:wrap}
.pager-btn{font-weight:700;padding:11px 20px;border-radius:999px;border:1.5px solid var(--line);background:#fff;color:var(--ink-2)}
.pager-btn:hover{border-color:var(--green);color:var(--green-700);background:var(--green-50)}
.pager-info{color:var(--slate);font-weight:600;font-size:.92rem}

/* Toast */
.jv-toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,16px);opacity:0;z-index:200;
  background:var(--ink);color:#fff;padding:12px 20px;border-radius:999px;font-weight:600;font-size:.92rem;box-shadow:var(--shadow-lg);transition:.3s}
.jv-toast.in{opacity:1;transform:translate(-50%,0)}

/* Ficha: datos rapidos */
.ficha-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:18px 0 4px;padding:0;list-style:none}
@media(min-width:680px){.ficha-facts{grid-template-columns:repeat(4,1fr)}}
.ficha-facts li{display:flex;align-items:center;gap:10px;background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:11px 13px;min-width:0}
.ff-ic{flex:none;width:32px;height:32px;border-radius:9px;background:#fff;color:var(--green-700);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.ficha-facts strong{display:block;font-size:.9rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}
.ficha-facts small{color:var(--slate);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}
.ficha-facts .g-rating{font-size:.9rem}

/* Favorito activo en botones de ficha */
.js-fav.is-fav{color:#e23;border-color:#e23}

/* Barra de accion fija en movil (ficha) */
.ficha-stickybar{display:none}
@media(max-width:760px){
  .ficha-stickybar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:95;gap:8px;padding:10px 12px;
    background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(11,23,18,.1)}
  .ficha-stickybar .btn{min-height:50px}
  .ficha-stickybar .js-fav,.ficha-stickybar .js-share{flex:none;width:54px;padding:0}
  .ficha-stickybar .btn-block{flex:1}
  .back-to-top{bottom:80px}
  .site-footer{padding-bottom:84px}
}

/* Rendimiento de render: no pintar lo que esta fuera de pantalla */
.card,.city-tile,.post-item,.cat,.perk,.step{content-visibility:auto;contain-intrinsic-size:auto 360px}

/* Card hover un punto mas vivo */
.card{transition:transform .22s cubic-bezier(.22,.68,0,1),box-shadow .22s ease}
.card:hover{transform:translateY(-6px)}
.card-media img{transition:transform .5s cubic-bezier(.22,.68,0,1)}
.card:hover .card-media img{transform:scale(1.05)}
