*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream-50:#FBF6EC;--cream-100:#F2E8D5;--cream-200:#E8DCC4;--cream-300:#D9C9A8;--cream-400:#C4B08C;
  --olive-900:#2A3220;--olive-800:#3F4A2E;--olive-700:#4F5C39;--olive-600:#5C6E45;--olive-500:#6F8252;--olive-300:#A8B68F;
  --walnut-800:#3D2918;--walnut-700:#5A3E26;--walnut-500:#7D5A3D;
  --amber-700:#B8843D;--amber-600:#D4A05A;--amber-500:#E8B66E;--amber-300:#F2D4A0;
  --s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:24px;--s-6:32px;--s-7:48px;--s-8:64px;--s-9:96px;--s-10:128px;
  --font-sans:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",system-ui,sans-serif;
  --font-display:"Iowan Old Style","Apple Garamond","Baskerville","Times New Roman",serif;
  --canvas-w:640px;
  --canvas-bg:#EFE7D2;
  --sheet-h:140px;
}
html,body{height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-sans);font-size:16px;line-height:1.5;color:var(--olive-900);background:#EFE7D2;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;overflow-x:hidden}

/* BG layer (desktop) */
.bg-layer{position:fixed;inset:0;z-index:0;background:#EFE7D2}
.bg-wordmark{position:fixed;left:50%;bottom:12vh;transform:translateX(-50%);font-family:var(--font-display);font-size:11px;letter-spacing:0.5em;text-transform:uppercase;color:rgba(242,232,213,0.12);z-index:1;pointer-events:none;display:none}
@media (min-width:1024px){.bg-wordmark{display:none}}

/* App canvas */
.app-canvas{position:relative;z-index:2;max-width:var(--canvas-w);margin:0 auto;min-height:100vh;background:var(--canvas-bg);padding-bottom:var(--sheet-h)}
@media (max-width:1023px){.app-canvas{max-width:720px;box-shadow:none}}
@media (max-width:767px){.app-canvas{max-width:100%}}

/* Hero */
.hero{padding:var(--s-9) var(--s-5) var(--s-7);text-align:center;position:relative;background:transparent}
.hero-logo{display:inline-flex;width:200px;height:200px;margin-bottom:var(--s-5)}
.logo-svg{width:100%;height:100%}
.hero-spa-name{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:0.30em;text-transform:uppercase;color:var(--olive-700);margin-bottom:var(--s-3)}
.hero-tagline{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:24px;line-height:1.25;color:var(--olive-900);max-width:22ch;margin:var(--s-2) auto var(--s-7);letter-spacing:-0.005em}
.hero-stat{display:inline-flex;flex-direction:column;align-items:center;padding:var(--s-4) var(--s-5);margin-top:var(--s-4);position:relative}
.hero-stat::before,.hero-stat::after{content:'';position:absolute;left:50%;transform:translateX(-50%);width:60px;height:1px;background:var(--cream-300)}
.hero-stat::before{top:0}
.hero-stat::after{bottom:0}
.hero-stat-number{font-family:var(--font-display);font-size:56px;line-height:1;font-weight:400;color:var(--olive-900);font-variant-numeric:oldstyle-nums}
.hero-stat-label{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--olive-700);margin-top:var(--s-2)}
.hero-location{margin-top:var(--s-4);font-size:12px;color:var(--walnut-500);letter-spacing:0.08em;font-style:italic;font-family:var(--font-display)}

/* Section head */
.section{padding:var(--s-7) 0 var(--s-5);scroll-margin-top:80px;background:transparent}
.section + .section{padding-top:var(--s-6)}
.section-head{padding:0 var(--s-5);margin-bottom:var(--s-5);text-align:center}
.section-ornament{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--olive-700);margin-bottom:var(--s-4)}
.section-ornament svg{width:100%;height:100%}
.section-eyebrow{font-size:10px;font-weight:600;letter-spacing:0.30em;text-transform:uppercase;color:var(--olive-700);margin-bottom:var(--s-4)}
.section-title{font-family:var(--font-display);font-size:30px;line-height:1.15;font-weight:400;color:var(--olive-900);letter-spacing:-0.01em;text-align:center;max-width:18ch;margin:0 auto var(--s-2)}
.section-subtitle{font-family:var(--font-display);font-style:italic;font-size:14px;color:var(--walnut-500);text-align:center;max-width:34ch;margin:0 auto;line-height:1.5}

/* Divider entre cards */
.divider{display:flex;align-items:center;justify-content:center;height:var(--s-9);color:var(--olive-600)}
.divider svg{width:48px;height:auto;max-height:32px}

/* ===== Editorial cards (premium/deluxe) ===== */
.cards-editorial{display:flex;flex-direction:column;gap:var(--s-4);padding:0 var(--s-2)}
.card-premium,.card-deluxe{background:transparent;position:relative;text-align:center;padding:0 var(--s-3)}
.card-premium .card-visual{height:100px;background:transparent;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.card-deluxe .card-visual{height:84px;background:transparent;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.card-visual svg{width:60%;max-width:160px;height:80%}
.card-seal{position:absolute;top:var(--s-4);left:var(--s-4);font-size:8px;font-weight:600;letter-spacing:0.24em;text-transform:uppercase;padding:5px 10px;border-radius:999px;z-index:2}
.seal-premium{background:var(--olive-900);color:var(--cream-50)}
.seal-deluxe{background:rgba(63,74,46,0.94);color:var(--cream-50)}
.card-body{padding:0}
.card-eyebrow{font-size:9px;font-weight:600;letter-spacing:0.32em;text-transform:uppercase;color:var(--olive-700);margin-bottom:var(--s-2);font-variant-numeric:tabular-nums}
.card-kicker{font-family:var(--font-display);font-style:italic;font-size:11.5px;letter-spacing:0.04em;color:var(--amber-700);margin-bottom:var(--s-2)}
.card-title{font-family:var(--font-display);font-weight:400;line-height:1.1;color:var(--olive-900);letter-spacing:-0.015em;margin:0 auto var(--s-2);max-width:18ch}
.card-premium .card-title{font-size:26px}
.card-deluxe .card-title{font-size:22px}
.card-tagline{font-family:var(--font-display);font-style:italic;font-size:14px;color:var(--walnut-500);line-height:1.45;margin:0 auto var(--s-4);max-width:28ch}
.card-desc{font-size:14px;line-height:1.6;color:var(--walnut-700);margin:0 auto var(--s-5);max-width:32ch}
.card-glyph{display:inline-flex;width:28px;height:28px;color:var(--olive-600);margin:var(--s-2) auto var(--s-5)}
.card-glyph svg{width:100%;height:100%}
.card-highlights{list-style:none;display:flex;flex-direction:column;gap:var(--s-3);margin:0 auto var(--s-6);max-width:30ch;text-align:left}
.card-highlights li{display:flex;align-items:flex-start;gap:var(--s-3);font-size:13.5px;line-height:1.5;color:var(--olive-800)}
.hi-bullet{flex:0 0 auto;width:12px;height:12px;color:var(--amber-700);margin-top:5px}
.hi-bullet svg{width:100%;height:100%}
.card-meta{display:flex;flex-direction:row;align-items:baseline;justify-content:center;gap:var(--s-3);margin-top:var(--s-3)}
.card-dur{font-size:10px;letter-spacing:0.24em;text-transform:uppercase;color:var(--walnut-500);font-variant-numeric:tabular-nums}
.card-price{font-family:var(--font-display);font-size:22px;font-weight:400;color:var(--olive-900);letter-spacing:-0.01em;line-height:1;font-variant-numeric:oldstyle-nums}

/* ===== Menu cards (normales) ===== */
.cards-menu{display:flex;flex-direction:column;gap:var(--s-3);padding:0 var(--s-2)}
.card-normal{background:transparent;padding:0 var(--s-3)}
.menu-row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--s-5)}
.menu-main{flex:1;min-width:0}
.menu-title{font-family:var(--font-display);font-size:18px;font-weight:400;line-height:1.2;color:var(--olive-900);letter-spacing:-0.01em;margin-bottom:var(--s-1)}
.menu-tagline{font-family:var(--font-display);font-style:italic;font-size:14px;color:var(--walnut-700);line-height:1.4;margin-bottom:var(--s-2)}
.menu-desc{font-size:13px;line-height:1.5;color:var(--walnut-500);margin-bottom:var(--s-2)}
.menu-dur{display:inline-block;font-size:10px;letter-spacing:0.20em;text-transform:uppercase;color:var(--walnut-500);font-variant-numeric:tabular-nums;margin-top:var(--s-1)}
.menu-price{flex:0 0 auto;font-family:var(--font-display);font-size:19px;font-weight:400;color:var(--olive-800);letter-spacing:-0.01em;text-align:right;font-variant-numeric:oldstyle-nums;line-height:1.1;padding-top:2px}

/* ===== Compact rows ===== */
.rows{display:flex;flex-direction:column;background:#FFFFFF;border-radius:6px;margin:0 var(--s-5);padding:var(--s-3) 0;box-shadow:0 1px 2px rgba(63,74,46,0.04)}
.row{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--s-4) var(--s-5);gap:var(--s-4)}
.row + .row{margin-top:var(--s-3)}
.row-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.row-name{font-size:15px;font-weight:500;color:var(--olive-900);letter-spacing:-0.005em}
.row-tagline{font-family:var(--font-display);font-style:italic;font-size:13px;color:var(--walnut-500)}
.row-dur{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--walnut-500);font-variant-numeric:tabular-nums;margin-top:4px}
.row-meta{flex:0 0 auto;text-align:right}
.row-price{font-family:var(--font-display);font-size:17px;font-weight:400;color:var(--olive-800);font-variant-numeric:oldstyle-nums;line-height:1.2}

/* ===== Footer ===== */
.foot{padding:var(--s-9) var(--s-5) var(--s-9);text-align:center;background:transparent}
.foot-glyph{width:36px;height:36px;margin:0 auto var(--s-5);color:var(--olive-700)}
.foot-glyph svg{width:100%;height:100%}
.foot-seal{display:inline-block;font-size:10px;letter-spacing:0.30em;text-transform:uppercase;color:var(--olive-700);padding:var(--s-3) 0;margin-bottom:var(--s-5);position:relative}
.foot-seal::before,.foot-seal::after{content:'';position:absolute;left:50%;transform:translateX(-50%);width:80px;height:1px;background:var(--cream-300)}
.foot-seal::before{top:0}
.foot-seal::after{bottom:0}
.foot-name{font-family:var(--font-display);font-size:24px;font-weight:400;color:var(--olive-900);font-style:italic;margin-bottom:var(--s-3)}
.foot-promise{font-family:var(--font-display);font-style:italic;font-size:14px;color:var(--walnut-700);margin-bottom:var(--s-6);max-width:30ch;margin-left:auto;margin-right:auto;line-height:1.5}
.foot-contact{display:flex;flex-direction:column;gap:var(--s-2);margin-bottom:var(--s-6);font-size:14px;color:var(--olive-800)}
.foot-contact a{color:inherit;text-decoration:none}
.foot-hours{font-size:12px;color:var(--walnut-500);line-height:1.8;letter-spacing:0.04em}
.foot-hours strong{color:var(--olive-800);font-weight:500}
.foot-mark{margin-top:var(--s-7);font-size:9px;letter-spacing:0.35em;text-transform:uppercase;color:var(--cream-400)}

/* ===== Bottom sheet ===== */
.sheet{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:var(--canvas-w);z-index:50;padding:var(--s-4) var(--s-3) var(--s-4);background:rgba(239,231,210,0.85);backdrop-filter:blur(20px) saturate(120%);-webkit-backdrop-filter:blur(20px) saturate(120%)}
@media (max-width:1023px){.sheet{max-width:720px}}
@media (max-width:767px){.sheet{max-width:100%}}
.sheet-handle{display:block;width:36px;height:4px;background:var(--cream-400);opacity:0.5;border-radius:999px;margin:0 auto 8px}
.chips{display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x proximity;padding:4px 12px 12px;margin:0 -12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:#FFFFFF;border:none;border-radius:999px;font-size:13px;font-weight:500;color:var(--olive-800);cursor:pointer;white-space:nowrap;transition:background 0.2s ease,color 0.2s ease;scroll-snap-align:start;font-family:inherit;box-shadow:0 1px 2px rgba(63,74,46,0.06)}
.chip:active{transform:scale(0.97)}
.chip.is-active{background:var(--olive-800);color:var(--cream-50);border-color:var(--olive-800)}
.chip-count{font-size:11px;opacity:0.75;font-variant-numeric:tabular-nums}
.search-wrap{position:relative;padding:0 4px}
.search-input{width:100%;padding:14px 16px 14px 44px;background:#FFFFFF;border:none;border-radius:999px;font-family:inherit;font-size:15px;color:var(--olive-900);outline:none;transition:box-shadow 0.2s ease;box-shadow:0 1px 2px rgba(63,74,46,0.06)}
.search-input::placeholder{color:var(--walnut-500)}
.search-input:focus{box-shadow:0 0 0 3px rgba(63,74,46,0.10),0 1px 2px rgba(63,74,46,0.06)}
.search-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--olive-700);pointer-events:none}

.is-hidden{display:none !important}


/* ===== Ritual sheet (modal con ficha completa) ===== */
.ritual-sheet{position:fixed;inset:0;z-index:100;display:flex;align-items:flex-end;justify-content:center;pointer-events:none;opacity:0;transition:opacity 0.3s ease;visibility:hidden}
.ritual-sheet[aria-hidden="false"]{pointer-events:auto;opacity:1;visibility:visible}
.ritual-backdrop{position:absolute;inset:0;background:rgba(20,19,14,0.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.ritual-panel{position:relative;width:100%;max-width:var(--canvas-w);max-height:92vh;background:#FFFFFF;border-radius:20px 20px 0 0;display:flex;flex-direction:column;overflow:hidden;transform:translateY(100%);transition:transform 0.36s cubic-bezier(0.32,0.72,0,1);box-shadow:0 -10px 40px rgba(0,0,0,0.18)}
.ritual-sheet[aria-hidden="false"] .ritual-panel{transform:translateY(0)}
@media (min-width:1024px){
  .ritual-sheet{align-items:center}
  .ritual-panel{border-radius:16px;max-height:88vh}
}
@media (max-width:1023px){.ritual-panel{max-width:720px}}
@media (max-width:767px){.ritual-panel{max-width:100%}}

.ritual-panel-head{position:sticky;top:0;z-index:5;display:flex;flex-direction:column;align-items:center;padding:var(--s-3) var(--s-3) 0;background:rgba(255,255,255,0.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.ritual-handle{display:block;width:40px;height:4px;background:var(--cream-300);border-radius:999px}
.ritual-close{position:absolute;top:var(--s-3);right:var(--s-3);width:36px;height:36px;border:none;background:rgba(232,220,196,0.6);border-radius:999px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--olive-800);transition:background 0.2s ease}
.ritual-close:hover{background:var(--cream-300)}
.ritual-close svg{width:18px;height:18px}

.ritual-photo{width:100%;height:0;overflow:hidden;background:var(--cream-100);transition:height 0.3s ease}
.ritual-photo.has-img{height:280px}
.ritual-photo img{width:100%;height:100%;object-fit:cover;display:block}
@media (min-width:1024px){.ritual-photo.has-img{height:380px}.card-visual.has-photo{height:300px}}

.ritual-body{overflow-y:auto;padding:var(--s-6) var(--s-6) var(--s-9);flex:1;-webkit-overflow-scrolling:touch}
.ritual-eyebrow{font-size:10px;font-weight:600;letter-spacing:0.30em;text-transform:uppercase;color:var(--olive-700);margin-bottom:var(--s-3)}
.ritual-title{font-family:var(--font-display);font-size:32px;font-weight:400;line-height:1.12;color:var(--olive-900);letter-spacing:-0.015em;margin-bottom:var(--s-3);max-width:20ch}
.ritual-tagline{font-family:var(--font-display);font-style:italic;font-size:17px;color:var(--walnut-700);line-height:1.5;margin-bottom:var(--s-5);max-width:32ch}
.ritual-desc{font-size:15px;line-height:1.65;color:var(--olive-900);margin-bottom:var(--s-6);max-width:42ch}
.ritual-section{margin-bottom:var(--s-6)}
.ritual-section-eyebrow{font-size:9px;font-weight:600;letter-spacing:0.30em;text-transform:uppercase;color:var(--olive-700);margin-bottom:var(--s-3)}
.ritual-list{list-style:none;display:flex;flex-direction:column;gap:var(--s-2)}
.ritual-list li{display:flex;align-items:flex-start;gap:var(--s-3);font-size:14px;line-height:1.5;color:var(--olive-800)}
.ritual-list li::before{content:"";flex:0 0 auto;width:6px;height:6px;border-radius:999px;background:var(--amber-700);margin-top:7px;opacity:0.7}
.ritual-programs{display:flex;flex-direction:column;gap:var(--s-3)}
.ritual-program{display:flex;justify-content:space-between;align-items:baseline;padding:var(--s-3) 0;border-bottom:1px solid var(--cream-200)}
.ritual-program:last-child{border-bottom:none}
.ritual-program-label{font-size:14px;color:var(--olive-900);flex:1}
.ritual-program-meta{font-family:var(--font-display);font-variant-numeric:oldstyle-nums;font-size:14px;color:var(--olive-800);text-align:right;display:flex;flex-direction:column;gap:2px}
.ritual-program-each{font-size:12px;color:var(--walnut-500);font-style:italic}
.ritual-extras{display:flex;flex-direction:column;gap:var(--s-2)}
.ritual-extra{display:flex;justify-content:space-between;font-size:14px;color:var(--olive-800);padding:var(--s-2) 0;border-bottom:1px solid var(--cream-200)}
.ritual-extra:last-child{border-bottom:none}
.ritual-extra-price{font-family:var(--font-display);font-variant-numeric:oldstyle-nums}
.ritual-meta{display:flex;gap:var(--s-6);align-items:flex-start;padding-top:var(--s-5);margin-top:var(--s-2);border-top:1px solid var(--cream-200)}
.ritual-meta-block{display:flex;flex-direction:column;gap:var(--s-1)}
.ritual-meta-label{font-size:9px;font-weight:600;letter-spacing:0.30em;text-transform:uppercase;color:var(--olive-700)}
.ritual-meta-value{font-family:var(--font-display);font-variant-numeric:oldstyle-nums;font-size:22px;color:var(--olive-900)}
.ritual-meta-price{font-size:28px;color:var(--olive-800)}
.ritual-meta-alt{font-size:12px;font-style:italic;color:var(--walnut-500);margin-top:2px}


/* ===== Botón Filtros ===== */
.filter-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;margin:0 4px;padding:13px 20px;background:#FFFFFF;border:none;border-radius:999px;font-family:inherit;font-size:14px;font-weight:500;color:var(--olive-800);cursor:pointer;box-shadow:0 1px 2px rgba(63,74,46,0.06);transition:box-shadow 0.2s ease,transform 0.15s ease}
.filter-btn:active{transform:scale(0.98)}
.filter-btn:hover{box-shadow:0 2px 6px rgba(63,74,46,0.10)}
.filter-icon{width:18px;height:18px;flex:0 0 auto}
.filter-btn-label{letter-spacing:0.02em}
.filter-btn-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;background:var(--olive-800);color:#FFF;border-radius:999px;font-size:11px;font-weight:600;font-variant-numeric:tabular-nums}

/* ===== Panel de filtros ===== */
.filter-panel{position:fixed;inset:0;z-index:90;display:flex;align-items:flex-end;justify-content:center;pointer-events:none;opacity:0;transition:opacity 0.3s ease;visibility:hidden}
.filter-panel[aria-hidden="false"]{pointer-events:auto;opacity:1;visibility:visible}
.filter-backdrop{position:absolute;inset:0;background:rgba(20,19,14,0.50);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.filter-panel-inner{position:relative;width:100%;max-width:var(--canvas-w);max-height:80vh;background:#FFFFFF;border-radius:20px 20px 0 0;display:flex;flex-direction:column;transform:translateY(100%);transition:transform 0.36s cubic-bezier(0.32,0.72,0,1);box-shadow:0 -10px 40px rgba(0,0,0,0.18)}
.filter-panel[aria-hidden="false"] .filter-panel-inner{transform:translateY(0)}
@media (min-width:1024px){
  .filter-panel{align-items:center}
  .filter-panel-inner{border-radius:16px;max-height:78vh}
}
@media (max-width:1023px){.filter-panel-inner{max-width:720px}}
@media (max-width:767px){.filter-panel-inner{max-width:100%}}

.filter-head{padding:var(--s-3) var(--s-5) var(--s-5);display:flex;flex-direction:column;align-items:center;gap:var(--s-3);border-bottom:none}
.filter-head-row{display:flex;justify-content:space-between;align-items:center;width:100%}
.filter-title{font-family:var(--font-display);font-size:22px;font-weight:400;color:var(--olive-900)}
.filter-clear{background:transparent;border:none;font-family:inherit;font-size:13px;color:var(--walnut-500);cursor:pointer;letter-spacing:0.02em;padding:6px 0}
.filter-clear:hover{color:var(--olive-800)}

.filter-body{flex:1;overflow-y:auto;padding:0 var(--s-5) var(--s-5);-webkit-overflow-scrolling:touch}
.filter-group{margin-bottom:var(--s-6)}
.filter-group-title{font-size:10px;font-weight:600;letter-spacing:0.28em;text-transform:uppercase;color:var(--olive-700);margin-bottom:var(--s-3)}
.filter-chips{display:flex;flex-wrap:wrap;gap:8px}
.fchip{display:inline-flex;align-items:center;padding:10px 16px;background:var(--cream-50);border:1px solid var(--cream-300);border-radius:999px;font-family:inherit;font-size:13px;color:var(--olive-800);cursor:pointer;transition:background 0.2s ease,color 0.2s ease,border-color 0.2s ease;letter-spacing:0.01em}
.fchip:hover{background:var(--cream-100)}
.fchip.is-active{background:var(--olive-800);color:#FFF;border-color:var(--olive-800)}

.filter-foot{padding:var(--s-4) var(--s-5) var(--s-5);background:#FFFFFF;border-top:1px solid var(--cream-200)}
.filter-apply{width:100%;padding:16px;background:var(--olive-900);color:var(--cream-50);border:none;border-radius:999px;font-family:inherit;font-size:15px;font-weight:500;cursor:pointer;letter-spacing:0.02em;transition:background 0.2s ease}
.filter-apply:hover{background:var(--olive-800)}
.filter-apply:active{transform:scale(0.98)}

/* clicable feedback */
.is-clickable{cursor:pointer;transition:transform 0.18s ease,box-shadow 0.18s ease}
.is-clickable:active{transform:scale(0.98)}
.card.is-clickable:hover .card-inner{box-shadow:0 2px 6px rgba(63,74,46,0.10),0 14px 32px -10px rgba(63,74,46,0.12)}
@media (min-width:1024px){
  .card-premium .card-inner{padding:32px 32px}
  .card-deluxe .card-inner{padding:28px 32px}
  .card-standard .card-inner{padding:28px 32px}
  .card-premium .card-title{font-size:32px}
  .card-deluxe .card-title{font-size:26px}
  .card-standard .card-title{font-size:22px}
  .card-tagline{font-size:15px}
  .card-bignum{font-size:60px}
  .card-premium .card-bignum{font-size:72px}
  .card-deluxe .card-bignum{font-size:54px}
  .card-standard .card-bignum{font-size:44px}
  .hero{padding:128px 48px 64px}
  .hero-tagline{font-size:28px}
  .section{padding:96px 0 48px}
  .section-title{font-size:34px}
  .cards-editorial{gap:24px;padding:0 12px}
  .cards-menu{gap:16px;padding:0 12px}
}


/* ===== v3: cards como bloques aislados ===== */
.card-inner{background:#FFFFFF;border-radius:10px;padding:var(--s-5) var(--s-5) var(--s-5);box-shadow:0 1px 3px rgba(63,74,46,0.06),0 8px 24px -12px rgba(63,74,46,0.08);position:relative;overflow:hidden}
.card-inner-menu{padding:var(--s-4) var(--s-5)}
.card-premium .card-inner{padding:var(--s-6) var(--s-5) var(--s-6)}
.card-deluxe .card-inner{padding:var(--s-5) var(--s-5) var(--s-5)}
.card-bignum{position:absolute;top:var(--s-3);right:var(--s-4);font-family:var(--font-display);font-size:48px;font-weight:400;line-height:1;color:var(--cream-300);font-variant-numeric:oldstyle-nums;letter-spacing:-0.04em;pointer-events:none;z-index:0}
.card-premium .card-bignum{font-size:56px;color:var(--amber-300)}
.card-standard .card-bignum{font-size:38px;color:var(--cream-300);opacity:0.85}
.card-deluxe .card-bignum{font-size:48px;color:var(--cream-400)}

.card-body{position:relative;z-index:1}
.card-premium .card-visual,.card-deluxe .card-visual{padding-top:var(--s-3)}

.card-sep{font-size:14px;color:var(--cream-400);opacity:0.8;line-height:1}

/* ===== Fotos reales en cards ===== */
.card-visual.has-photo{height:260px !important;background:transparent;padding:0;overflow:hidden;position:relative;border-radius:8px 8px 0 0;margin:calc(-1 * var(--s-5)) calc(-1 * var(--s-5)) var(--s-5)}
.card-premium .card-inner:has(.has-photo){padding-top:0}
.card-deluxe .card-inner:has(.has-photo){padding-top:0}
.card-photo{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05) contrast(1.02)}
.card-visual.has-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 50%,rgba(0,0,0,0.18) 100%);pointer-events:none}
.card-visual.has-photo .card-seal{top:auto;bottom:var(--s-3);left:var(--s-4);color:#FFF;background:rgba(0,0,0,0.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:5}


/* ===== Tier standard (todas las cards no premium/deluxe) ===== */
.card-standard{background:transparent;position:relative;text-align:center;padding:0 var(--s-3)}
.card-standard .card-inner{padding:var(--s-5) var(--s-5) var(--s-5)}
.card-standard .card-visual{height:72px;background:transparent;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.card-standard .card-title{font-size:20px}

/* dividers ya no se usan entre cards */
.divider{display:none}


/* ===== v2.2 (10-jun-2026) · Sheet compacta + auto-hide al hacer scroll ===== */
:root{--sheet-h:92px}
.sheet{transition:transform .32s cubic-bezier(.32,.72,0,1);will-change:transform}
.sheet.sheet--away{transform:translateX(-50%) translateY(115%)}
.sheet--compact{padding:10px 12px 12px}
.sheet--compact .sheet-handle{margin-bottom:4px}
.sheet-row{display:flex;align-items:center;gap:8px}
.sheet-row .chips{flex:1;margin:0;padding:4px 2px 6px}
.sheet--compact .filter-btn{flex:0 0 auto;width:auto;margin:0;padding:11px 14px;gap:6px}
.sheet--compact .filter-btn-label{display:none}
@media (prefers-reduced-motion:reduce){.sheet{transition:none}}
