/*
 * COMPAR CBD — Estilos globales
 * comprarcbd.net — Único archivo CSS
 * Cargado via functions.php en todas las páginas
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Sora:wght@400;600;700;800&display=swap');

/* ══════════════════════════════════════════
   VARIABLES GLOBALES
══════════════════════════════════════════ */
:root{
  --bg:#EDE8E0; --bg2:#E4DED4; --card:#F5F1EB; --card2:#EEEAE3;
  --ink:#1C1B18; --ink2:#3D3B35; --ink3:#6B6860; --ink4:#9A9890;
  --green:#3A5C3A; --green-lt:#5A8C5A; --green-pale:#D4DDD3;
  --amber:#8C5E2A; --amber-lt:#B07A3A; --amber-pale:#E8D5B7;
  --border:rgba(28,27,24,0.10); --border2:rgba(28,27,24,0.18);
  --r:18px; --r-sm:10px; --r-xs:6px;
  --nav-h:60px; --max:1280px;
  --ease:cubic-bezier(0.25,0.46,0.45,0.94); --t:0.28s;
  --font-h:'Sora',sans-serif; --font-b:'Inter',sans-serif;
}

/* ══════════════════════════════════════════
   RESET
══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{background:var(--bg);color:var(--ink);font-family:var(--font-b);font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}

/* ══════════════════════════════════════════
   BLANKSLATE RESETS
══════════════════════════════════════════ */
body{margin:0!important;padding:0!important;}
#page{display:block!important;padding:0!important;margin:0!important;max-width:100%!important;}
#header,.site-header,#masthead,#footer,.site-footer,#colophon,
h1.site-title,h2.site-description,#access,.main-navigation,.entry-title{display:none!important;}
#content,#main,.site-content{padding:0!important;margin:0!important;max-width:100%!important;width:100%!important;float:none!important;}
article.page,article.product,.hentry{max-width:100%!important;margin:0!important;padding:0!important;}
#secondary,.widget-area,.sidebar,#sidebar,aside.widget-area{display:none!important;}
#primary,.content-area,main#main{width:100%!important;float:none!important;margin:0!important;}

/* ══════════════════════════════════════════
   WRAP
══════════════════════════════════════════ */
.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(1rem,4vw,3rem);}

/* ══════════════════════════════════════════
   TOPBAR
══════════════════════════════════════════ */
.topbar{background:var(--ink);color:rgba(255,255,255,0.6);font-size:0.7rem;letter-spacing:0.04em;display:flex;align-items:center;justify-content:space-between;padding:0.5rem clamp(1rem,4vw,3rem);gap:1rem;flex-wrap:wrap;}
.topbar-pill{display:inline-flex;align-items:center;gap:0.4rem;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.1);border-radius:100px;padding:0.2rem 0.75rem;font-size:0.66rem;white-space:nowrap;}

/* ══════════════════════════════════════════
   NAV (desde nav-include.php)
══════════════════════════════════════════ */
.main-nav{position:sticky;top:0;z-index:90;height:var(--nav-h);background:rgba(237,232,224,0.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;}
.nav-inner{max-width:1320px;margin:0 auto;width:100%;padding:0 clamp(1rem,4vw,3rem);display:flex;align-items:center;justify-content:space-between;gap:2rem;}
.nav-logo{display:flex;align-items:center;gap:0.6rem;text-decoration:none;}
.nav-mark{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-size:0.65rem;font-weight:700;color:var(--ink);flex-shrink:0;}
.nav-name{font-family:var(--font-h);font-size:0.85rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--ink);}
.nav-center{display:flex;align-items:center;}
ul.nav-menu{display:flex;align-items:center;list-style:none;padding:0;margin:0;}
ul.nav-menu>li{position:relative;}
ul.nav-menu>li>a{display:block;padding:0 1rem;font-size:0.82rem;font-weight:500;color:var(--ink2);text-decoration:none;height:var(--nav-h);line-height:var(--nav-h);white-space:nowrap;transition:color 0.25s;}
ul.nav-menu>li>a:hover{color:var(--ink);}
ul.nav-menu>li.current-menu-item>a,
ul.nav-menu>li.current-page-ancestor>a,
ul.nav-menu>li.current_page_parent>a{color:var(--ink);font-weight:700;border-bottom:2px solid var(--green);}
ul.nav-menu>li>ul.sub-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--card);border:1px solid var(--border2);border-radius:12px;padding:0.5rem;min-width:190px;list-style:none;box-shadow:0 8px 32px rgba(28,27,24,0.12);opacity:0;visibility:hidden;transform:translateY(6px);transition:all 0.2s ease;pointer-events:none;z-index:100;}
ul.nav-menu>li:hover>ul.sub-menu{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;}
ul.nav-menu>li>ul.sub-menu>li>a{display:block;padding:0.55rem 0.85rem;font-size:0.8rem;color:var(--ink2);text-decoration:none;border-radius:8px;transition:all 0.15s;height:auto;line-height:1.5;}
ul.nav-menu>li>ul.sub-menu>li>a:hover{background:var(--bg2);color:var(--ink);}
.nav-actions{display:flex;gap:0.75rem;align-items:center;}
.nav-cart-btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.5rem 1.1rem;border:1.5px solid var(--border2);border-radius:100px;background:transparent;color:var(--ink2);font-family:var(--font-b);font-size:0.78rem;font-weight:500;text-decoration:none;transition:all var(--t);}
.nav-cart-btn:hover{border-color:var(--ink);color:var(--ink);}
.cart-count-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background:var(--green);color:#fff;border-radius:50%;font-size:0.6rem;font-weight:700;line-height:1;}
.hamburger-btn{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none;}
.hamburger-btn span{display:block;width:22px;height:1.5px;background:var(--ink);transition:all 0.25s;}
.mob-overlay{position:fixed;inset:0;z-index:95;background:var(--bg);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2rem;opacity:0;visibility:hidden;pointer-events:none;transition:opacity 0.3s,visibility 0.3s;}
.mob-overlay.open{opacity:1;visibility:visible;pointer-events:auto;}
.mob-close-btn{position:absolute;top:1.5rem;right:1.5rem;width:38px;height:38px;border-radius:50%;border:1.5px solid var(--border2);background:transparent;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;color:var(--ink);}
ul.mob-nav-list{list-style:none;padding:0;margin:0;text-align:center;display:flex;flex-direction:column;gap:1.5rem;}
ul.mob-nav-list>li>a{font-family:var(--font-h);font-size:2rem;font-weight:700;color:var(--ink);text-decoration:none;transition:color 0.25s;}
ul.mob-nav-list>li>a:hover{color:var(--green);}
ul.mob-nav-list ul{display:none;}
@media(max-width:780px){.nav-center{display:none;}.hamburger-btn{display:flex;}}

/* ══════════════════════════════════════════
   FOOTER COMPARTIDO
══════════════════════════════════════════ */
.site-footer{background:var(--ink);border-top:1px solid rgba(255,255,255,0.06);padding:clamp(3rem,6vw,5rem) 0 2rem;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem;}
.footer-brand-name{font-family:var(--font-h);font-size:1rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;color:#fff;margin-bottom:0.75rem;}
.footer-brand p{font-size:0.78rem;color:rgba(255,255,255,0.4);line-height:1.7;max-width:260px;}
.footer-col h4{font-family:var(--font-h);font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:1rem;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:0.5rem;}
.footer-col ul li a{font-size:0.82rem;color:rgba(255,255,255,0.55);text-decoration:none;transition:color 0.2s;}
.footer-col ul li a:hover{color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.06);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;}
.footer-copy{font-size:0.7rem;color:rgba(255,255,255,0.22);}
.footer-pay{display:flex;gap:0.5rem;flex-wrap:wrap;}
.pay-tag{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:6px;padding:0.3rem 0.7rem;font-size:0.62rem;color:rgba(255,255,255,0.4);}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem;}.footer-brand{grid-column:1/-1;}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr;}}

/* ══════════════════════════════════════════
   HOME — SECCIONES
══════════════════════════════════════════ */
.section{padding:clamp(3rem,5vw,4.5rem) 0;}
.section-sm{padding:clamp(2rem,4vw,3.5rem) 0;}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.75rem;gap:1rem;flex-wrap:wrap;}
.section-eyebrow{font-family:var(--font-h);font-size:0.72rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);margin-bottom:0.3rem;}
.section-subtitle{font-size:0.82rem;color:var(--ink3);max-width:480px;}
.link-ver-todo{font-size:0.8rem;font-weight:600;color:var(--ink2);text-decoration:none;display:inline-flex;align-items:center;gap:0.4rem;border:1.5px solid var(--border2);border-radius:100px;padding:0.5rem 1.1rem;transition:all var(--t);white-space:nowrap;}
.link-ver-todo:hover{border-color:var(--ink);color:var(--ink);}

/* HOME HERO */
.hero{padding:clamp(3rem,6vw,5rem) 0;border-bottom:1px solid var(--border);}
.hero-grid{display:grid;grid-template-columns:1fr 420px;gap:4rem;align-items:center;}
.hero-tag{display:inline-flex;align-items:center;gap:0.6rem;font-size:0.72rem;font-weight:500;color:var(--ink3);border:1px solid var(--border2);border-radius:100px;padding:0.35rem 0.9rem;margin-bottom:1.5rem;}
.hero-tag-dot{width:7px;height:7px;border-radius:50%;background:var(--green);}
.hero-h1{font-family:var(--font-h);font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;line-height:1.1;letter-spacing:-0.02em;color:var(--ink);margin-bottom:1rem;}
.hero-desc{font-size:0.95rem;color:var(--ink3);line-height:1.75;max-width:520px;margin-bottom:1.75rem;}
.hero-ctas{display:flex;flex-wrap:wrap;gap:0.75rem;margin-bottom:1.5rem;}
.btn-cta-solid{display:inline-flex;align-items:center;gap:0.4rem;padding:0.75rem 1.75rem;background:var(--ink);color:#fff;border:none;border-radius:100px;font-family:var(--font-b);font-size:0.85rem;font-weight:600;text-decoration:none;cursor:pointer;transition:background var(--t);}
.btn-cta-solid:hover{background:var(--green);}
.btn-cta-ghost{display:inline-flex;align-items:center;gap:0.4rem;padding:0.75rem 1.5rem;background:transparent;color:var(--ink2);border:1.5px solid var(--border2);border-radius:100px;font-family:var(--font-b);font-size:0.85rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all var(--t);}
.btn-cta-ghost:hover{border-color:var(--ink);color:var(--ink);}
.hero-pills{display:flex;flex-wrap:wrap;gap:0.5rem;}
.hero-pill{display:inline-flex;align-items:center;gap:0.35rem;padding:0.3rem 0.8rem;background:var(--card2);border:1px solid var(--border);border-radius:100px;font-size:0.7rem;color:var(--ink3);}
.hero-right{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;}
.hero-right-header{display:flex;justify-content:space-between;align-items:center;}
.hero-drop-label{font-family:var(--font-h);font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;}
.hero-drop-sub{font-size:0.65rem;color:var(--ink4);}
.hero-right-img{background:var(--bg2);border-radius:12px;height:170px;display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:4rem;color:rgba(28,27,24,0.1);}
.hero-cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:0.6rem;}
.hero-cat{background:var(--card2);border:1px solid var(--border);border-radius:12px;padding:0.9rem;text-decoration:none;color:inherit;transition:all var(--t);}
.hero-cat:hover{border-color:var(--border2);background:var(--bg2);}
.hero-cat-name{font-family:var(--font-h);font-size:0.85rem;font-weight:700;margin-bottom:0.2rem;}
.hero-cat-desc{font-size:0.7rem;color:var(--ink4);}
.hero-right-note{font-size:0.65rem;color:var(--ink4);line-height:1.55;border-top:1px solid var(--border);padding-top:0.75rem;}
.hero-right-cta{display:block;width:100%;padding:0.8rem;background:var(--bg2);border:1.5px solid var(--border2);border-radius:100px;text-align:center;font-size:0.82rem;font-weight:500;color:var(--ink2);text-decoration:none;transition:all var(--t);}
.hero-right-cta:hover{border-color:var(--ink);color:var(--ink);}

/* HOME CATEGORÍAS */
.cats-label{font-family:var(--font-h);font-size:0.72rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);margin-bottom:0.4rem;}
.cats-sublabel{font-size:0.82rem;color:var(--ink3);margin-bottom:1.75rem;max-width:480px;}
.cats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
.cat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;text-decoration:none;color:inherit;transition:all var(--t);display:flex;flex-direction:column;gap:0.75rem;}
.cat-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 8px 32px rgba(28,27,24,0.08);}
.cat-card-eyebrow{font-size:0.65rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink4);}
.cat-card-title{font-family:var(--font-h);font-size:1.25rem;font-weight:700;line-height:1.2;}
.cat-card-desc{font-size:0.8rem;color:var(--ink3);line-height:1.65;}
.cat-tags{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:auto;}
.tag{display:inline-block;padding:0.25rem 0.65rem;border:1px solid var(--border2);border-radius:100px;font-size:0.65rem;color:var(--ink3);}

/* HOME PRODUCTOS (shortcode) */
.filters{display:flex;gap:0.5rem;flex-wrap:wrap;margin-bottom:1.5rem;}
.filter-btn{padding:0.4rem 1rem;border-radius:100px;border:1.5px solid var(--border);background:transparent;color:var(--ink3);font-family:var(--font-b);font-size:0.72rem;font-weight:500;cursor:pointer;transition:all var(--t);}
.filter-btn:hover,.filter-btn.active{background:var(--ink);color:#fff;border-color:var(--ink);}
#home-prod-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.25rem;width:100%;}
.h-prod-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;text-decoration:none;color:inherit;display:flex;flex-direction:column;min-width:0;transition:all var(--t);}
.h-prod-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:0 16px 48px rgba(28,27,24,0.12);}
.h-prod-img{aspect-ratio:1;background:var(--bg2);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.h-prod-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;}
.h-prod-card:hover .h-prod-img img{transform:scale(1.05);}
.h-prod-badge{position:absolute;top:0.65rem;left:0.65rem;font-size:0.58rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;padding:0.22rem 0.65rem;border-radius:100px;}
.h-badge-green{background:var(--green);color:#fff;}
.h-badge-dark{background:var(--ink);color:#fff;}
.h-badge-star{background:rgba(255,255,255,0.93);color:var(--ink);}
.h-prod-body{padding:1.1rem;flex:1;display:flex;flex-direction:column;gap:0.2rem;min-width:0;}
.h-prod-cat{font-size:0.6rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--green);}
.h-prod-name{font-family:var(--font-h);font-size:1rem;font-weight:700;color:var(--ink);line-height:1.25;overflow-wrap:break-word;hyphens:none;white-space:normal;}
.h-prod-strain{font-size:0.72rem;color:var(--ink4);margin-bottom:0.4rem;}
.h-prod-price{font-family:var(--font-h);font-size:0.95rem;font-weight:700;color:var(--ink);margin-top:auto;}
.h-prod-from{font-size:0.6rem;font-weight:400;color:var(--ink4);margin-right:0.1rem;}
.h-prod-divider{height:1px;background:var(--border);margin:0.7rem 0 0.6rem;}
.h-prod-footer{display:flex;align-items:center;gap:0.6rem;min-width:0;}
.h-prod-cta{flex:1;display:block;padding:0.58rem 0.5rem;background:var(--ink);color:#fff;border-radius:100px;font-size:0.7rem;font-weight:600;text-align:center;transition:background var(--t);white-space:nowrap;}
.h-prod-card:hover .h-prod-cta{background:var(--green);}
.h-prod-lab{font-size:0.58rem;color:var(--ink4);white-space:nowrap;flex-shrink:0;}

/* HOME BLOG */
.blog-grid{display:grid;grid-template-columns:1.65fr 1fr 1fr;gap:1rem;}
.blog-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;text-decoration:none;color:inherit;transition:all var(--t);}
.blog-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 8px 32px rgba(28,27,24,0.08);}
.blog-img{background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:3rem;overflow:hidden;}
.blog-img-main{aspect-ratio:16/9;}
.blog-img-sm{aspect-ratio:4/3;}
.blog-body{padding:1.25rem;}
.blog-body-sm{padding:1rem;}
.blog-cat{font-size:0.65rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--green);margin-bottom:0.5rem;}
.blog-title{font-family:var(--font-h);font-size:1.05rem;font-weight:700;line-height:1.3;margin-bottom:0.5rem;}
.blog-title-sm{font-size:0.9rem;}
.blog-excerpt{font-size:0.8rem;color:var(--ink3);line-height:1.65;margin-bottom:0.85rem;}
.blog-meta{font-size:0.65rem;color:var(--ink4);display:flex;gap:1rem;}

/* HOME INFO STRIP */
.info-strip{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.info-inner{display:grid;grid-template-columns:repeat(4,1fr);}
.info-item{padding:1.75rem 2rem;border-right:1px solid var(--border);display:flex;align-items:flex-start;gap:0.85rem;}
.info-item:last-child{border-right:none;}
.info-icon{font-size:1.2rem;flex-shrink:0;margin-top:0.1rem;}
.info-text h4{font-family:var(--font-h);font-size:0.85rem;font-weight:700;margin-bottom:0.2rem;}
.info-text p{font-size:0.75rem;color:var(--ink3);line-height:1.55;}

/* HOME NEWSLETTER */
.newsletter{background:var(--ink);padding:clamp(3rem,6vw,5rem) 0;}
.nl-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.nl-title{font-family:var(--font-h);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;line-height:1.15;color:#fff;margin-bottom:0.6rem;}
.nl-desc{font-size:0.85rem;color:rgba(255,255,255,0.5);line-height:1.7;}
.nl-form{display:flex;gap:0.6rem;}
.nl-input{flex:1;padding:0.85rem 1.25rem;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.14);border-radius:100px;color:#fff;font-family:var(--font-b);font-size:0.85rem;outline:none;transition:border-color 0.2s;}
.nl-input::placeholder{color:rgba(255,255,255,0.3);}
.nl-input:focus{border-color:rgba(255,255,255,0.3);}
.btn-nl{padding:0.85rem 1.75rem;background:#fff;color:var(--ink);border:none;border-radius:100px;font-family:var(--font-b);font-size:0.82rem;font-weight:700;cursor:pointer;transition:background var(--t);white-space:nowrap;}
.btn-nl:hover{background:var(--bg);}
.nl-fine{font-size:0.65rem;color:rgba(255,255,255,0.25);margin-top:0.6rem;}

/* ══════════════════════════════════════════
   FLORES CBD
══════════════════════════════════════════ */
.f-wrap{max-width:1280px;margin:0 auto;padding:0 clamp(1rem,4vw,3rem);}
.f-hero{background:linear-gradient(135deg,#2E3A2D 0%,#1A2419 60%,#0F160E 100%);padding:clamp(3rem,6vw,5rem) 0;position:relative;overflow:hidden;}
.f-hero-noise{position:absolute;inset:0;opacity:0.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px;}
.f-hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr auto;align-items:center;gap:3rem;}
.f-hero-eyebrow{font-family:var(--font-b);font-size:0.7rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--green-pale);margin-bottom:1rem;display:flex;align-items:center;gap:0.6rem;}
.f-hero-eyebrow::before{content:'';display:block;width:20px;height:1px;background:var(--green-pale);}
.f-hero-title{font-family:var(--font-h);font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;line-height:1.05;letter-spacing:-0.02em;color:#F5F1EB;margin-bottom:1rem;}
.f-hero-title span{color:var(--green-pale);}
.f-hero-desc{font-size:0.95rem;color:rgba(245,241,235,0.6);line-height:1.75;max-width:520px;margin-bottom:2rem;}
.f-hero-badges{display:flex;flex-wrap:wrap;gap:0.5rem;}
.f-hero-badge{display:inline-flex;align-items:center;gap:0.35rem;padding:0.35rem 0.9rem;border:1px solid rgba(245,241,235,0.15);border-radius:100px;font-size:0.7rem;color:rgba(245,241,235,0.7);background:rgba(245,241,235,0.05);}
.f-hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(245,241,235,0.08);border-radius:16px;overflow:hidden;min-width:220px;}
.f-hero-stat{padding:1.5rem 1.25rem;background:rgba(15,22,14,0.5);text-align:center;}
.f-hero-stat-num{font-family:var(--font-h);font-size:2rem;font-weight:800;color:#F5F1EB;line-height:1;}
.f-hero-stat-label{font-size:0.65rem;letter-spacing:0.08em;text-transform:uppercase;color:rgba(245,241,235,0.4);margin-top:0.3rem;}
.f-breadcrumb{padding:1.25rem 0 0;font-size:0.75rem;color:var(--ink4);}
.f-breadcrumb a{color:var(--ink3);text-decoration:none;}
.f-breadcrumb a:hover{color:var(--ink);}
.f-filters-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:2rem 0 1.5rem;flex-wrap:wrap;}
.f-filters{display:flex;gap:0.5rem;flex-wrap:wrap;}
.f-filter-btn{padding:0.4rem 1rem;border-radius:100px;border:1.5px solid var(--border);background:transparent;color:var(--ink3);font-family:var(--font-b);font-size:0.72rem;font-weight:500;cursor:pointer;transition:all var(--t);}
.f-filter-btn:hover,.f-filter-btn.active{background:var(--ink);color:#fff;border-color:var(--ink);}
.f-results-count{font-size:0.78rem;color:var(--ink4);}
.f-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding-bottom:4rem;}
.f-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;text-decoration:none;color:inherit;transition:all var(--t);display:flex;flex-direction:column;}
.f-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:0 12px 48px rgba(28,27,24,0.10);}
.f-card-img{aspect-ratio:1;background:var(--bg2);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.f-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s var(--t);}
.f-card:hover .f-card-img img{transform:scale(1.04);}
.f-card-badge{position:absolute;top:0.65rem;left:0.65rem;background:var(--green);color:#fff;font-size:0.6rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;padding:0.22rem 0.65rem;border-radius:100px;}
.f-card-badge.new{background:var(--ink);}
.f-card-body{padding:1.1rem;flex:1;display:flex;flex-direction:column;}
.f-card-type{font-size:0.62rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--green);margin-bottom:0.3rem;}
.f-card-name{font-family:var(--font-h);font-size:1rem;font-weight:700;line-height:1.25;margin-bottom:0.2rem;color:var(--ink);}
.f-card-strain{font-size:0.72rem;color:var(--ink4);margin-bottom:0.9rem;}
.f-card-aroma{display:flex;flex-wrap:wrap;gap:0.3rem;margin-bottom:0.9rem;}
.f-card-aroma-tag{font-size:0.6rem;padding:0.15rem 0.55rem;border:1px solid var(--border2);border-radius:100px;color:var(--ink3);}
.f-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;}
.f-card-price{font-family:var(--font-h);font-size:0.95rem;font-weight:700;}
.f-card-from{font-size:0.65rem;font-weight:400;color:var(--ink4);margin-right:0.2rem;}
.f-card-btn{width:32px;height:32px;border-radius:50%;background:var(--ink);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--t);}
.f-card-btn:hover{background:var(--green);transform:rotate(90deg);}
.f-card-lab{margin-top:0.75rem;padding-top:0.75rem;border-top:1px solid var(--border);font-size:0.6rem;color:var(--ink4);display:flex;align-items:center;gap:0.35rem;}
.f-info{padding:4rem 0;border-top:1px solid var(--border);}
.f-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;}
.f-info-title{font-family:var(--font-h);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;line-height:1.15;margin-bottom:1.25rem;}
.f-info-title span{color:var(--green);}
.f-info-text{font-size:0.88rem;color:var(--ink3);line-height:1.8;}
.f-info-text+.f-info-text{margin-top:0.85rem;}
.f-info-faq{display:flex;flex-direction:column;gap:0.75rem;}
.f-faq-item{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.f-faq-q{padding:1rem 1.25rem;font-family:var(--font-h);font-size:0.9rem;font-weight:700;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--ink);}
.f-faq-q::after{content:'+';font-size:1.2rem;font-weight:300;color:var(--ink3);transition:transform var(--t);}
.f-faq-item.open .f-faq-q::after{transform:rotate(45deg);}
.f-faq-a{padding:0 1.25rem;font-size:0.82rem;color:var(--ink3);line-height:1.7;max-height:0;overflow:hidden;transition:max-height 0.3s ease,padding 0.3s ease;}
.f-faq-item.open .f-faq-a{max-height:200px;padding:0 1.25rem 1rem;}
.f-legal{background:var(--bg2);border-top:1px solid var(--border);padding:1rem 0;}
.f-legal p{font-size:0.67rem;color:var(--ink4);text-align:center;line-height:1.6;max-width:900px;margin:0 auto;}

/* ══════════════════════════════════════════
   HASH CBD
══════════════════════════════════════════ */
.h-wrap{max-width:1280px;margin:0 auto;padding:0 clamp(1rem,4vw,3rem);}
.h-hero{background:linear-gradient(135deg,#3A2A15 0%,#241A0C 55%,#160E05 100%);padding:clamp(3rem,6vw,5rem) 0;position:relative;overflow:hidden;}
.h-hero-noise{position:absolute;inset:0;opacity:0.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px;}
.h-hero-glow{position:absolute;top:-100px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(140,94,42,0.2) 0%,transparent 65%);pointer-events:none;}
.h-hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr auto;align-items:center;gap:3rem;}
.h-hero-eyebrow{font-size:0.7rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--amber-pale);margin-bottom:1rem;display:flex;align-items:center;gap:0.6rem;}
.h-hero-eyebrow::before{content:'';display:block;width:20px;height:1px;background:var(--amber-pale);}
.h-hero-title{font-family:var(--font-h);font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;line-height:1.05;letter-spacing:-0.02em;color:#F5F1EB;margin-bottom:1rem;}
.h-hero-title span{color:var(--amber-pale);}
.h-hero-desc{font-size:0.95rem;color:rgba(245,241,235,0.6);line-height:1.75;max-width:520px;margin-bottom:2rem;}
.h-hero-badges{display:flex;flex-wrap:wrap;gap:0.5rem;}
.h-hero-badge{display:inline-flex;align-items:center;gap:0.35rem;padding:0.35rem 0.9rem;border:1px solid rgba(232,213,183,0.2);border-radius:100px;font-size:0.7rem;color:rgba(245,241,235,0.7);background:rgba(140,94,42,0.15);}
.h-hero-visual{min-width:220px;}
.h-hero-card{background:rgba(36,26,12,0.7);border:1px solid rgba(232,213,183,0.12);border-radius:16px;padding:1.5rem;backdrop-filter:blur(10px);}
.h-hero-card-title{font-family:var(--font-h);font-size:0.7rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--amber-pale);margin-bottom:1.25rem;}
.h-hero-card-item{display:flex;align-items:center;gap:0.75rem;margin-bottom:0.85rem;}
.h-hero-card-item:last-child{margin-bottom:0;}
.h-hero-card-dot{width:8px;height:8px;border-radius:50%;background:var(--amber-lt);flex-shrink:0;}
.h-hero-card-text{font-size:0.8rem;color:rgba(245,241,235,0.7);}
.h-hero-card-text strong{color:#F5F1EB;font-weight:600;}
.h-breadcrumb{padding:1.25rem 0 0;font-size:0.75rem;color:var(--ink4);}
.h-breadcrumb a{color:var(--ink3);text-decoration:none;}
.h-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);margin:2rem 0 1.5rem;border-radius:14px;overflow:hidden;}
.h-strip-item{background:var(--card);padding:1.25rem 1rem;text-align:center;}
.h-strip-icon{font-size:1.3rem;margin-bottom:0.4rem;}
.h-strip-title{font-family:var(--font-h);font-size:0.82rem;font-weight:700;margin-bottom:0.2rem;}
.h-strip-desc{font-size:0.7rem;color:var(--ink4);line-height:1.4;}
.h-products-title{font-family:var(--font-h);font-size:1.3rem;font-weight:800;margin-bottom:1.5rem;}
.h-products-title span{color:var(--amber);}
.h-list{display:flex;flex-direction:column;gap:1rem;padding-bottom:4rem;}
.h-item{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;display:grid;grid-template-columns:280px 1fr auto;align-items:center;text-decoration:none;color:inherit;transition:all var(--t);}
.h-item:hover{border-color:var(--border2);transform:translateX(4px);box-shadow:0 8px 40px rgba(28,27,24,0.08);}
.h-item-img{height:200px;overflow:hidden;position:relative;}
.h-item-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;}
.h-item:hover .h-item-img img{transform:scale(1.04);}
.h-item-badge{position:absolute;top:0.65rem;left:0.65rem;background:var(--amber);color:#fff;font-size:0.6rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;padding:0.22rem 0.65rem;border-radius:100px;}
.h-item-body{padding:1.5rem 2rem;}
.h-item-type{font-size:0.62rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--amber);margin-bottom:0.35rem;}
.h-item-name{font-family:var(--font-h);font-size:1.4rem;font-weight:800;margin-bottom:0.3rem;line-height:1.2;}
.h-item-desc{font-size:0.83rem;color:var(--ink3);line-height:1.65;margin-bottom:1rem;max-width:400px;}
.h-item-tags{display:flex;flex-wrap:wrap;gap:0.35rem;}
.h-item-tag{font-size:0.62rem;padding:0.2rem 0.6rem;border:1px solid var(--border2);border-radius:100px;color:var(--ink3);}
.h-item-action{padding:1.5rem;display:flex;flex-direction:column;align-items:flex-end;gap:0.75rem;min-width:160px;}
.h-item-price{font-family:var(--font-h);font-size:1.1rem;font-weight:700;text-align:right;}
.h-item-from{font-size:0.65rem;font-weight:400;color:var(--ink4);display:block;margin-bottom:0.1rem;}
.h-item-btn{display:inline-flex;align-items:center;gap:0.4rem;padding:0.65rem 1.25rem;background:var(--ink);color:#fff;border:none;border-radius:100px;font-family:var(--font-b);font-size:0.78rem;font-weight:600;cursor:pointer;transition:background var(--t);text-decoration:none;white-space:nowrap;}
.h-item-btn:hover{background:var(--amber);}
.h-item-lab{font-size:0.6rem;color:var(--ink4);}
.h-info{padding:4rem 0;border-top:1px solid var(--border);}
.h-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;}
.h-info-title{font-family:var(--font-h);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;line-height:1.15;margin-bottom:1.25rem;}
.h-info-title span{color:var(--amber);}
.h-info-text{font-size:0.88rem;color:var(--ink3);line-height:1.8;}
.h-info-text+.h-info-text{margin-top:0.85rem;}
.h-tipos{display:flex;flex-direction:column;gap:0.75rem;}
.h-tipo{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1rem 1.25rem;}
.h-tipo-title{font-family:var(--font-h);font-size:0.9rem;font-weight:700;margin-bottom:0.4rem;display:flex;align-items:center;gap:0.5rem;}
.h-tipo-dot{width:8px;height:8px;border-radius:50%;background:var(--amber);flex-shrink:0;}
.h-tipo-desc{font-size:0.78rem;color:var(--ink3);line-height:1.6;}
.h-legal{background:var(--bg2);border-top:1px solid var(--border);padding:1rem 0;}
.h-legal p{font-size:0.67rem;color:var(--ink4);text-align:center;line-height:1.6;max-width:900px;margin:0 auto;}

/* ══════════════════════════════════════════
   PÁGINAS LEGALES
══════════════════════════════════════════ */
.legal-wrap{max-width:800px;margin:3rem auto;padding:0 clamp(1rem,4vw,3rem);font-family:var(--font-b);color:var(--ink);line-height:1.75;}
.legal-wrap h1{font-family:var(--font-h)!important;font-size:clamp(1.8rem,4vw,2.5rem)!important;font-weight:800!important;color:var(--ink)!important;margin-bottom:2rem!important;padding-bottom:1.5rem!important;border-bottom:1px solid var(--border)!important;}
.legal-wrap h2{font-size:1.1rem!important;font-weight:700!important;color:var(--ink)!important;margin:2rem 0 0.75rem!important;}
.legal-wrap h3{font-size:0.95rem!important;font-weight:600!important;color:var(--ink2)!important;margin:1.5rem 0 0.5rem!important;}
.legal-wrap p{font-size:0.92rem!important;color:var(--ink2)!important;line-height:1.8!important;margin-bottom:1rem!important;}
.legal-wrap ul,.legal-wrap ol{font-size:0.92rem!important;color:var(--ink2)!important;padding-left:1.5rem!important;margin-bottom:1rem!important;}
.legal-wrap li{margin-bottom:0.4rem!important;line-height:1.7!important;}
.legal-wrap strong{font-weight:600!important;color:var(--ink)!important;}
.legal-wrap a{color:var(--green)!important;}
.legal-wrap table{width:100%!important;border-collapse:collapse!important;font-size:0.83rem!important;margin:1.25rem 0!important;}
.legal-wrap table thead{background:var(--ink)!important;color:#fff!important;}
.legal-wrap table th{padding:0.75rem 1rem!important;text-align:left!important;font-weight:600!important;font-size:0.78rem!important;}
.legal-wrap table tbody tr:nth-child(even){background:var(--card)!important;}
.legal-wrap table td{padding:0.65rem 1rem!important;color:var(--ink2)!important;border-bottom:1px solid var(--border)!important;vertical-align:top!important;}
.legal-wrap em{color:var(--ink4)!important;font-size:0.82rem!important;}

/* ══════════════════════════════════════════
   ANIMACIONES
══════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(18px);transition:opacity 0.6s var(--ease),transform 0.6s var(--ease);}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:1050px){
  .hero-grid{grid-template-columns:1fr;max-width:700px;margin:0 auto;}
  .hero-right{display:none;}
  #home-prod-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .f-hero-inner{grid-template-columns:1fr;}.f-hero-stats{display:none;}
  .f-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:900px){
  .h-item{grid-template-columns:200px 1fr;}.h-item-action{display:none;}
  .h-strip{grid-template-columns:1fr 1fr;}
  .h-info-grid{grid-template-columns:1fr;}
  .h-hero-inner{grid-template-columns:1fr;}.h-hero-visual{display:none;}
}
@media(max-width:780px){
  .cats-grid{grid-template-columns:1fr 1fr;}
  #home-prod-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem!important;}
  .blog-grid{grid-template-columns:1fr;}
  .info-inner{grid-template-columns:1fr 1fr;}
  .info-item{border-right:none;border-bottom:1px solid var(--border);}
  .nl-inner{grid-template-columns:1fr;gap:2rem;}
  .nl-form{flex-direction:column;}
  .f-grid{grid-template-columns:repeat(2,1fr);}
  .f-info-grid{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .h-item{grid-template-columns:1fr;}.h-item-img{height:180px;}
  .h-strip{grid-template-columns:1fr 1fr;}
}
@media(max-width:520px){
  .cats-grid{grid-template-columns:1fr;}
  #home-prod-grid{gap:0.75rem!important;}
  .info-inner{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .f-grid{gap:0.75rem;}
  .h-prod-body{padding:0.85rem;}
}
/* ══════════════════════════════════════════
   CARRITO & CHECKOUT — WooCommerce
══════════════════════════════════════════ */

/* ── WRAPPER COMPARTIDO ─────────────────── */
.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content {
  padding: 0 !important;
}

/* Breadcrumb WC */
.woocommerce-breadcrumb {
  max-width: 1100px;
  margin: 0 auto;
  padding: 1.5rem clamp(1rem,4vw,3rem) 0;
  font-size: 0.75rem;
  color: var(--ink4);
}
.woocommerce-breadcrumb a { color: var(--ink3); text-decoration: none; }
.woocommerce-breadcrumb a:hover { color: var(--ink); }

/* Avisos */
.woocommerce-notices-wrapper {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 clamp(1rem,4vw,3rem);
}
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
  border-radius: 12px !important;
  border-left: 3px solid var(--green) !important;
  background: var(--green-pale) !important;
  color: var(--green) !important;
  font-size: 0.85rem !important;
  padding: 0.85rem 1.25rem !important;
  margin-bottom: 1rem !important;
  list-style: none !important;
}
.woocommerce-error {
  background: #fee !important;
  border-color: #e53 !important;
  color: #c00 !important;
}

/* ══════════════════════════════════════════
   CARRITO
══════════════════════════════════════════ */

/* Header del carrito */
.woocommerce-cart-page-header {
  background: var(--ink);
  padding: clamp(2rem,4vw,3rem) 0;
  margin-bottom: 0;
}
.woocommerce-cart-page-header .inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 clamp(1rem,4vw,3rem);
}
.woocommerce-cart-page-header h1 {
  font-family: var(--font-h) !important;
  font-size: clamp(1.6rem,3vw,2.2rem) !important;
  font-weight: 800 !important;
  color: #F5F1EB !important;
  margin-bottom: 0.3rem !important;
}
.woocommerce-cart-page-header p {
  font-size: 0.82rem !important;
  color: rgba(245,241,235,0.5) !important;
}

/* Layout principal carrito */
.woocommerce-cart .woocommerce {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2rem clamp(1rem,4vw,3rem) 5rem;
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 2rem;
  align-items: start;
}

/* ── Tabla ── */
.woocommerce-cart-form {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
}

/* Header tabla */
.woocommerce-cart-form table.shop_table thead {
  background: var(--bg2) !important;
}
.woocommerce-cart-form table.shop_table thead th {
  padding: 1rem 1.25rem !important;
  font-family: var(--font-h) !important;
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--ink4) !important;
  border-bottom: 1px solid var(--border) !important;
  background: transparent !important;
}

/* Filas */
.woocommerce-cart-form table.shop_table tbody tr {
  border-bottom: 1px solid var(--border) !important;
  transition: background var(--t) !important;
}
.woocommerce-cart-form table.shop_table tbody tr:last-child {
  border-bottom: none !important;
}
.woocommerce-cart-form table.shop_table tbody tr:hover {
  background: var(--bg2) !important;
}
.woocommerce-cart-form table.shop_table td {
  padding: 1.25rem !important;
  vertical-align: middle !important;
}

/* Imagen */
.woocommerce-cart-form .product-thumbnail {
  width: 90px !important;
}
.woocommerce-cart-form .product-thumbnail img {
  width: 80px !important;
  height: 80px !important;
  object-fit: cover !important;
  border-radius: 12px !important;
  border: 1px solid var(--border) !important;
  display: block !important;
}

/* Nombre */
.woocommerce-cart-form .product-name a {
  font-family: var(--font-h) !important;
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
  text-decoration: none !important;
}
.woocommerce-cart-form .product-name a:hover { color: var(--green) !important; }
.woocommerce-cart-form .product-name dl.variation {
  font-size: 0.75rem !important;
  color: var(--ink4) !important;
  margin-top: 0.3rem !important;
}
.woocommerce-cart-form .product-name dl.variation dt,
.woocommerce-cart-form .product-name dl.variation dd {
  display: inline !important;
  margin: 0 !important;
  font-weight: 500 !important;
}

/* Precio */
.woocommerce-cart-form .product-price,
.woocommerce-cart-form .product-subtotal {
  font-family: var(--font-h) !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  color: var(--ink) !important;
}

/* Cantidad */
.woocommerce-cart-form .product-quantity .qty {
  width: 68px !important;
  padding: 0.55rem 0.5rem !important;
  text-align: center !important;
  border: 1.5px solid var(--border2) !important;
  border-radius: 100px !important;
  background: var(--bg) !important;
  font-family: var(--font-b) !important;
  font-size: 0.88rem !important;
  color: var(--ink) !important;
  outline: none !important;
  transition: border-color var(--t) !important;
}
.woocommerce-cart-form .product-quantity .qty:focus {
  border-color: var(--green) !important;
}

/* Botón eliminar */
.woocommerce-cart-form a.remove {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 30px !important;
  height: 30px !important;
  border-radius: 50% !important;
  background: var(--bg2) !important;
  color: var(--ink4) !important;
  font-size: 1rem !important;
  text-decoration: none !important;
  border: 1px solid var(--border) !important;
  transition: all var(--t) !important;
  line-height: 1 !important;
}
.woocommerce-cart-form a.remove:hover {
  background: #fee2e2 !important;
  color: #dc2626 !important;
  border-color: #fca5a5 !important;
}

/* Cupón + actualizar */
.woocommerce-cart-form .actions {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  padding: 1.1rem 1.25rem !important;
  background: var(--bg2) !important;
  border-top: 1px solid var(--border) !important;
  flex-wrap: wrap !important;
}
.woocommerce-cart-form .coupon {
  display: flex !important;
  gap: 0.5rem !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}
.woocommerce-cart-form #coupon_code {
  padding: 0.6rem 1rem !important;
  border: 1.5px solid var(--border2) !important;
  border-radius: 100px !important;
  background: var(--card) !important;
  font-family: var(--font-b) !important;
  font-size: 0.82rem !important;
  color: var(--ink) !important;
  outline: none !important;
  width: 170px !important;
  transition: border-color var(--t) !important;
}
.woocommerce-cart-form #coupon_code:focus {
  border-color: var(--green) !important;
}
.woocommerce-cart-form #coupon_code::placeholder { color: var(--ink4) !important; }
.woocommerce-cart-form .coupon .button,
.woocommerce-cart-form button[name="update_cart"] {
  padding: 0.6rem 1.25rem !important;
  background: transparent !important;
  color: var(--ink2) !important;
  border: 1.5px solid var(--border2) !important;
  border-radius: 100px !important;
  font-family: var(--font-b) !important;
  font-size: 0.78rem !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: all var(--t) !important;
}
.woocommerce-cart-form .coupon .button:hover,
.woocommerce-cart-form button[name="update_cart"]:hover {
  border-color: var(--ink) !important;
  color: var(--ink) !important;
}

/* ── Panel totales carrito ── */
.cart_totals {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r) !important;
  overflow: hidden !important;
  position: sticky !important;
  top: 76px !important;
}
.cart_totals h2 {
  font-family: var(--font-h) !important;
  font-size: 0.88rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--ink4) !important;
  padding: 1.1rem 1.25rem !important;
  background: var(--bg2) !important;
  border-bottom: 1px solid var(--border) !important;
  margin: 0 !important;
}
.cart_totals .shop_table {
  width: 100% !important;
  border-collapse: collapse !important;
  padding: 0 !important;
}
.cart_totals .shop_table tr {
  border-bottom: 1px solid var(--border) !important;
}
.cart_totals .shop_table tr:last-child { border-bottom: none !important; }
.cart_totals .shop_table th {
  padding: 1rem 1.25rem !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  color: var(--ink2) !important;
  vertical-align: middle !important;
  width: 45% !important;
  text-align: left !important;
}
.cart_totals .shop_table td {
  padding: 1rem 1.25rem !important;
  font-family: var(--font-h) !important;
  font-weight: 700 !important;
  font-size: 0.88rem !important;
  color: var(--ink) !important;
  text-align: right !important;
  vertical-align: middle !important;
}
.cart_totals .order-total th,
.cart_totals .order-total td {
  padding-top: 1.1rem !important;
  padding-bottom: 1.1rem !important;
  font-size: 1.05rem !important;
  border-top: 2px solid var(--border2) !important;
}
.cart_totals .wc-proceed-to-checkout {
  padding: 1.25rem !important;
  background: var(--bg2) !important;
  border-top: 1px solid var(--border) !important;
}
.cart_totals .checkout-button {
  display: block !important;
  width: 100% !important;
  padding: 0.9rem !important;
  background: var(--ink) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 100px !important;
  font-family: var(--font-b) !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  text-align: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: background var(--t) !important;
  letter-spacing: 0.02em !important;
}
.cart_totals .checkout-button:hover { background: var(--green) !important; }

/* Trust badges bajo el botón de carrito */
.cart_totals .wc-proceed-to-checkout::after {
  content: '🔒 Pago seguro · 🚚 Envío discreto · ↩️ 14 días devolución';
  display: block;
  font-size: 0.65rem;
  color: var(--ink4);
  text-align: center;
  margin-top: 0.75rem;
  line-height: 1.6;
}

/* Carrito vacío */
.woocommerce-cart .cart-empty {
  font-size: 1rem !important;
  color: var(--ink3) !important;
  text-align: center !important;
  padding: 3rem !important;
  grid-column: 1/-1 !important;
}
.woocommerce-cart .return-to-shop {
  text-align: center !important;
  grid-column: 1/-1 !important;
  padding-bottom: 3rem !important;
}
.woocommerce-cart .return-to-shop .button {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.4rem !important;
  padding: 0.75rem 1.75rem !important;
  background: var(--ink) !important;
  color: #fff !important;
  border-radius: 100px !important;
  font-family: var(--font-b) !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: background var(--t) !important;
}
.woocommerce-cart .return-to-shop .button:hover { background: var(--green) !important; }

/* ══════════════════════════════════════════
   CHECKOUT
══════════════════════════════════════════ */

/* Layout principal checkout */
.woocommerce-checkout .woocommerce {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2rem clamp(1rem,4vw,3rem) 5rem;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 2rem;
  align-items: start;
}

/* Columna izquierda (formulario) */
.woocommerce-checkout #customer_details {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

/* Bloques del formulario */
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout .woocommerce-additional-fields {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 1.75rem;
}

/* Títulos de sección */
.woocommerce-checkout h3 {
  font-family: var(--font-h) !important;
  font-size: 0.88rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--ink4) !important;
  margin-bottom: 1.25rem !important;
  padding-bottom: 0.75rem !important;
  border-bottom: 1px solid var(--border) !important;
}

/* Labels */
.woocommerce-checkout label {
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  color: var(--ink2) !important;
  display: block !important;
  margin-bottom: 0.4rem !important;
}
.woocommerce-checkout .required { color: var(--green) !important; }

/* Inputs */
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="password"],
.woocommerce-checkout select,
.woocommerce-checkout textarea {
  width: 100% !important;
  padding: 0.8rem 1rem !important;
  border: 1.5px solid var(--border2) !important;
  border-radius: 12px !important;
  background: var(--bg) !important;
  font-family: var(--font-b) !important;
  font-size: 0.88rem !important;
  color: var(--ink) !important;
  outline: none !important;
  transition: border-color var(--t) !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}
.woocommerce-checkout input:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout textarea:focus {
  border-color: var(--green) !important;
  box-shadow: 0 0 0 3px rgba(58,92,58,0.08) !important;
}
.woocommerce-checkout .woocommerce-invalid input,
.woocommerce-checkout .woocommerce-invalid select {
  border-color: #dc2626 !important;
}

/* Grid 2 columnas en campos de formulario */
.woocommerce-checkout .form-row-first {
  float: left !important;
  width: 48% !important;
}
.woocommerce-checkout .form-row-last {
  float: right !important;
  width: 48% !important;
}
.woocommerce-checkout .form-row-wide { clear: both !important; }
.woocommerce-checkout .form-row { margin-bottom: 1rem !important; }

/* Checkbox "misma dirección" */
.woocommerce-checkout #ship-to-different-address label {
  font-family: var(--font-b) !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  color: var(--ink2) !important;
  cursor: pointer !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  display: inline !important;
}

/* ── Columna derecha (resumen + pago) ── */
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  position: sticky;
  top: 76px;
}
.woocommerce-checkout h3#order_review_heading {
  font-size: 0.88rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--ink4) !important;
  padding: 1.1rem 1.25rem !important;
  background: var(--bg2) !important;
  border-bottom: 1px solid var(--border) !important;
  margin: 0 !important;
}

/* Tabla resumen */
.woocommerce-checkout table.shop_table.woocommerce-checkout-review-order-table {
  width: 100% !important;
  border-collapse: collapse !important;
  padding: 0 !important;
}
.woocommerce-checkout table.shop_table thead th {
  padding: 0.85rem 1.25rem !important;
  font-family: var(--font-h) !important;
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--ink4) !important;
  border-bottom: 1px solid var(--border) !important;
  background: var(--bg2) !important;
}
.woocommerce-checkout table.shop_table tbody tr,
.woocommerce-checkout table.shop_table tfoot tr {
  border-bottom: 1px solid var(--border) !important;
}
.woocommerce-checkout table.shop_table tbody tr:last-child,
.woocommerce-checkout table.shop_table tfoot tr:last-child {
  border-bottom: none !important;
}
.woocommerce-checkout table.shop_table tbody td,
.woocommerce-checkout table.shop_table tfoot th,
.woocommerce-checkout table.shop_table tfoot td {
  padding: 0.9rem 1.25rem !important;
  font-size: 0.85rem !important;
  vertical-align: middle !important;
}
.woocommerce-checkout table.shop_table tfoot th {
  font-weight: 600 !important;
  color: var(--ink2) !important;
}
.woocommerce-checkout table.shop_table tfoot td {
  font-family: var(--font-h) !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
  text-align: right !important;
}
.woocommerce-checkout table.shop_table tfoot .order-total th,
.woocommerce-checkout table.shop_table tfoot .order-total td {
  font-size: 1.05rem !important;
  padding-top: 1.1rem !important;
  padding-bottom: 1.1rem !important;
  border-top: 2px solid var(--border2) !important;
}

/* Métodos de pago */
.woocommerce-checkout #payment {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}
.woocommerce-checkout #payment .payment_methods {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border-top: 1px solid var(--border) !important;
}
.woocommerce-checkout #payment .payment_methods .wc_payment_method {
  border-bottom: 1px solid var(--border) !important;
}
.woocommerce-checkout #payment .payment_methods label {
  display: flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
  padding: 1rem 1.25rem !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
  cursor: pointer !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}
.woocommerce-checkout #payment .payment_methods label img {
  height: 24px !important;
  width: auto !important;
  border-radius: 4px !important;
}
.woocommerce-checkout #payment .payment_box {
  font-size: 0.8rem !important;
  color: var(--ink3) !important;
  padding: 0.75rem 1.25rem 1rem !important;
  background: var(--bg2) !important;
  border-top: 1px solid var(--border) !important;
  line-height: 1.6 !important;
}
.woocommerce-checkout #payment .place-order {
  padding: 1.25rem !important;
  background: var(--bg2) !important;
  border-top: 1px solid var(--border) !important;
}
.woocommerce-checkout #place_order {
  display: block !important;
  width: 100% !important;
  padding: 1rem !important;
  background: var(--ink) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 100px !important;
  font-family: var(--font-b) !important;
  font-size: 0.92rem !important;
  font-weight: 700 !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: background var(--t) !important;
  letter-spacing: 0.02em !important;
}
.woocommerce-checkout #place_order:hover { background: var(--green) !important; }

/* Trust bajo "Finalizar pedido" */
.woocommerce-checkout #payment .place-order::after {
  content: '🔒 Pago seguro y encriptado · THC <0.2% · Envío discreto';
  display: block;
  font-size: 0.65rem;
  color: var(--ink4);
  text-align: center;
  margin-top: 0.75rem;
  line-height: 1.6;
}

/* ── RESPONSIVE ─────────────────────── */
@media(max-width:860px){
  .woocommerce-cart .woocommerce,
  .woocommerce-checkout .woocommerce {
    grid-template-columns: 1fr !important;
  }
  .cart_totals,
  .woocommerce-checkout #order_review {
    position: static !important;
  }
  .woocommerce-checkout .form-row-first,
  .woocommerce-checkout .form-row-last {
    width: 100% !important;
    float: none !important;
  }
}

/* ══════════════════════════════════════════
   CARRITO — FIXES LAYOUT ALTERNATIVO
══════════════════════════════════════════ */

/* Nombre del producto — fuente y color correctos */
.woocommerce-cart .product-name a,
.woocommerce-cart td.product-name a,
.woocommerce-cart .cart_item .product-name a,
.woocommerce td.product-name a {
  font-family: var(--font-h) !important;
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
  text-decoration: none !important;
}
.woocommerce-cart .product-name a:hover,
.woocommerce td.product-name a:hover {
  color: var(--green) !important;
}
.woocommerce-cart .product-name,
.woocommerce td.product-name {
  font-family: var(--font-h) !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
}

/* Botón "Finalizar compra" — versión link y botón */
.woocommerce-cart a.checkout-button,
.woocommerce-cart .checkout-button,
.woocommerce a.checkout-button,
.woocommerce .checkout-button,
.cart_totals a.checkout-button,
.wc-proceed-to-checkout a,
.wc-proceed-to-checkout .button {
  display: block !important;
  width: 100% !important;
  padding: 0.9rem 1.5rem !important;
  background: var(--ink) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 100px !important;
  font-family: var(--font-b) !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  text-align: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: background var(--t) !important;
  letter-spacing: 0.02em !important;
  box-sizing: border-box !important;
}
.woocommerce-cart a.checkout-button:hover,
.woocommerce-cart .checkout-button:hover,
.woocommerce .checkout-button:hover,
.wc-proceed-to-checkout a:hover,
.wc-proceed-to-checkout .button:hover {
  background: var(--green) !important;
  color: #fff !important;
}

/* Panel totales — contenedor y título */
.cart_totals,
.woocommerce .cart_totals {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r) !important;
  overflow: hidden !important;
}
.cart_totals h2 {
  background: var(--bg2) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 1rem 1.25rem !important;
  margin: 0 !important;
  font-family: var(--font-h) !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--ink4) !important;
}

/* Total estimado label + precio */
.cart_totals .order-total th,
.cart_totals .order-total .woocommerce-Price-amount {
  font-family: var(--font-h) !important;
  font-weight: 800 !important;
  font-size: 1.05rem !important;
  color: var(--ink) !important;
}

/* Tabla dentro del panel totales */
.cart_totals table.shop_table th {
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  color: var(--ink3) !important;
  padding: 0.85rem 1.25rem !important;
  text-align: left !important;
}
.cart_totals table.shop_table td {
  font-family: var(--font-h) !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
  padding: 0.85rem 1.25rem !important;
  text-align: right !important;
}
.cart_totals table.shop_table .order-total td {
  font-size: 1.1rem !important;
}

/* Tabla principal del carrito */
.woocommerce-cart-form,
.woocommerce form.woocommerce-cart-form {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r) !important;
  overflow: hidden !important;
}
.woocommerce-cart table.shop_table thead th {
  background: var(--bg2) !important;
  font-family: var(--font-h) !important;
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--ink4) !important;
  padding: 1rem 1.25rem !important;
  border-bottom: 1px solid var(--border) !important;
}
.woocommerce-cart table.shop_table tbody td {
  padding: 1.1rem 1.25rem !important;
  border-bottom: 1px solid var(--border) !important;
  vertical-align: middle !important;
}
.woocommerce-cart table.shop_table img {
  width: 80px !important;
  height: 80px !important;
  object-fit: cover !important;
  border-radius: 12px !important;
  border: 1px solid var(--border) !important;
}
.woocommerce-cart table.shop_table .product-price,
.woocommerce-cart table.shop_table .product-subtotal {
  font-family: var(--font-h) !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
}

/* ══════════════════════════════════════════
   BLOG — Página de listado
══════════════════════════════════════════ */

/* Header */
.blog-page-header {
  background: var(--ink);
  padding: clamp(2.5rem,5vw,4rem) 0;
  margin-bottom: 0;
}
.blog-page-eyebrow {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(245,241,235,0.4);
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.blog-page-eyebrow::before {
  content: '';
  display: block;
  width: 16px;
  height: 1px;
  background: rgba(245,241,235,0.4);
}
.blog-page-title {
  font-family: var(--font-h);
  font-size: clamp(1.8rem,4vw,3rem);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: #F5F1EB;
  margin-bottom: 0.75rem;
}
.blog-page-desc {
  font-size: 0.9rem;
  color: rgba(245,241,235,0.5);
  line-height: 1.7;
  max-width: 520px;
}

/* Grid */
.blog-page-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: auto auto;
  gap: 1.25rem;
  padding: 2.5rem 0 2rem;
}

/* Card principal (grande) */
.blog-page-card--main {
  grid-row: 1 / 3;
}
.blog-page-card--main .blog-page-img {
  aspect-ratio: 3/2;
}
.blog-page-card--main .blog-page-post-title {
  font-size: 1.25rem !important;
}
.blog-page-card--main .blog-page-excerpt {
  display: block !important;
}

/* Card base */
.blog-page-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  transition: all var(--t);
}
.blog-page-card:hover {
  border-color: var(--border2);
  transform: translateY(-3px);
  box-shadow: 0 10px 40px rgba(28,27,24,0.09);
}

/* Imagen */
.blog-page-img {
  aspect-ratio: 16/9;
  background: var(--bg2);
  position: relative;
  overflow: hidden;
}
.blog-page-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s var(--t);
}
.blog-page-card:hover .blog-page-img img {
  transform: scale(1.03);
}
.blog-page-label {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  background: rgba(28,27,24,0.75);
  backdrop-filter: blur(8px);
  color: rgba(255,255,255,0.85);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.25rem 0.7rem;
  border-radius: 100px;
}

/* Body */
.blog-page-body {
  padding: 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.blog-page-meta {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.blog-page-cat {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--green);
}
.blog-page-date,
.blog-page-read {
  font-size: 0.68rem;
  color: var(--ink4);
}
.blog-page-date::before,
.blog-page-read::before {
  content: '·';
  margin-right: 0.6rem;
  color: var(--border2);
}
.blog-page-post-title {
  font-family: var(--font-h);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--ink);
  margin: 0;
}
.blog-page-excerpt {
  font-size: 0.8rem;
  color: var(--ink3);
  line-height: 1.65;
  display: none;
  margin-top: 0.25rem;
}
.blog-page-link {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--green);
  margin-top: auto;
  padding-top: 0.5rem;
}

/* CTA al final */
.blog-page-cta {
  margin-bottom: 4rem;
}
.blog-page-cta-inner {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: clamp(1.75rem,4vw,2.5rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}
.blog-page-cta-eyebrow {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 0.4rem;
}
.blog-page-cta-title {
  font-family: var(--font-h);
  font-size: clamp(1.1rem,2vw,1.4rem);
  font-weight: 800;
  color: var(--ink);
  margin-bottom: 0.4rem;
  line-height: 1.2;
}
.blog-page-cta-desc {
  font-size: 0.82rem;
  color: var(--ink3);
  line-height: 1.6;
  max-width: 460px;
}
.blog-page-cta-btns {
  display: flex;
  gap: 0.75rem;
  flex-shrink: 0;
  flex-wrap: wrap;
}

/* ══════════════════════════════════════════
   BLOG — Entrada individual (single post)
══════════════════════════════════════════ */
.single-post-wrap {
  max-width: 740px;
  margin: 0 auto;
  padding: 2.5rem clamp(1rem,4vw,3rem) 5rem;
}
.single-post-back {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  color: var(--ink3);
  text-decoration: none;
  margin-bottom: 2rem;
  transition: color var(--t);
}
.single-post-back:hover { color: var(--ink); }
.single-post-meta {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
}
.single-post-cat {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--green);
  background: var(--green-pale);
  padding: 0.25rem 0.75rem;
  border-radius: 100px;
}
.single-post-date,
.single-post-read {
  font-size: 0.72rem;
  color: var(--ink4);
}
.single-post-title {
  font-family: var(--font-h);
  font-size: clamp(1.6rem,3.5vw,2.4rem);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 1.5rem;
}
.single-post-img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: var(--r);
  margin-bottom: 2rem;
  border: 1px solid var(--border);
}
.single-post-content {
  font-size: 0.95rem;
  color: var(--ink2);
  line-height: 1.85;
}
.single-post-content h2 {
  font-family: var(--font-h);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ink);
  margin: 2rem 0 0.75rem;
  line-height: 1.25;
}
.single-post-content h3 {
  font-family: var(--font-h);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ink);
  margin: 1.5rem 0 0.6rem;
}
.single-post-content p {
  margin-bottom: 1.1rem;
}
.single-post-content ul,
.single-post-content ol {
  padding-left: 1.5rem;
  margin-bottom: 1.1rem;
}
.single-post-content li {
  margin-bottom: 0.4rem;
  line-height: 1.7;
}
.single-post-content strong { font-weight: 700; color: var(--ink); }
.single-post-content a { color: var(--green); }
.single-post-content blockquote {
  border-left: 3px solid var(--green);
  padding: 1rem 1.5rem;
  background: var(--card);
  border-radius: 0 12px 12px 0;
  margin: 1.5rem 0;
  font-style: italic;
  color: var(--ink3);
}

/* Related posts bajo el artículo */
.single-post-related {
  border-top: 1px solid var(--border);
  margin-top: 3rem;
  padding-top: 2rem;
}
.single-post-related-title {
  font-family: var(--font-h);
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 1.25rem;
}
.single-post-related-grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 1rem;
}
.single-post-related-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  transition: all var(--t);
}
.single-post-related-card:hover {
  border-color: var(--border2);
  transform: translateY(-2px);
}
.single-post-related-img {
  aspect-ratio: 16/9;
  background: var(--bg2);
  overflow: hidden;
}
.single-post-related-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.single-post-related-body {
  padding: 1rem;
}
.single-post-related-cat {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 0.3rem;
}
.single-post-related-name {
  font-family: var(--font-h);
  font-size: 0.88rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--ink);
}

/* Responsive blog */
@media(max-width:780px){
  .blog-page-grid { grid-template-columns: 1fr; }
  .blog-page-card--main { grid-row: auto; }
  .blog-page-card--main .blog-page-post-title { font-size: 1.05rem !important; }
  .blog-page-cta-inner { flex-direction: column; }
  .single-post-related-grid { grid-template-columns: 1fr; }
}