/* ============================================================
   TU ESPACIO COZY — Design System v2.1
   Fraunces (display) + Syne (labels) + Lora (body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,700;0,9..144,900;1,9..144,300;1,9..144,400&family=Syne:wght@400;500;600;700;800&family=Lora:ital,wght@0,400;0,500;1,400&display=swap');

:root {
  --cream:#F6F1E9; --cream-dark:#EDE5D8; --cream-deeper:#E3D8C8;
  --espresso:#1C150D; --espresso-mid:#2E2318; --espresso-soft:#4A3728;
  --amber:#C8782A; --amber-light:#DFA05A; --amber-pale:#F5E8D4;
  --sage:#6B8C6E; --sage-light:#A8C4AA; --sage-pale:#DCE9DC;
  --rose:#C08070; --white:#FDFAF6;
  --text-primary:#1C150D; --text-mid:#5C4A38; --text-muted:#9C8878; --text-pale:#C4B4A4;
  --f-display:'Fraunces',Georgia,serif;
  --f-label:'Syne',system-ui,sans-serif;
  --f-body:'Lora',Georgia,serif;
  --s1:.25rem; --s2:.5rem; --s3:.75rem; --s4:1rem; --s5:1.25rem; --s6:1.5rem;
  --s8:2rem; --s10:2.5rem; --s12:3rem; --s16:4rem; --s20:5rem; --s24:6rem;
  --max-w:1280px; --max-w-text:740px; --gutter:clamp(1.25rem,4vw,2.5rem);
  --r-sm:4px; --r-md:10px; --r-lg:20px; --r-xl:32px; --r-full:9999px;
  --sh-sm:0 2px 12px rgba(28,21,13,.07); --sh-md:0 6px 32px rgba(28,21,13,.10);
  --sh-lg:0 16px 64px rgba(28,21,13,.13); --sh-xl:0 32px 96px rgba(28,21,13,.16);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --t-fast:200ms; --t-base:350ms; --t-slow:600ms;
  --ticker-h:34px; --header-h:68px;
  --bar-total:calc(var(--ticker-h) + var(--header-h));
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
/* Ensure [hidden] always wins over display rules set by component CSS */
[hidden]{display:none!important}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:var(--f-body);font-size:1rem;line-height:1.75;color:var(--text-primary);background:var(--cream);-webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%}
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.022;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23n)'/%3E%3C/svg%3E")}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;background:none;border:none}
ul,ol{list-style:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.container{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--gutter)}
.container--text{max-width:var(--max-w-text)}

/* Global text overflow prevention */
p,h1,h2,h3,h4,li,a,span,td,th{overflow-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s2);font-family:var(--f-label);font-size:.6875rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.875rem 2rem;border-radius:var(--r-full);border:2px solid transparent;cursor:pointer;white-space:nowrap;text-decoration:none;transition:all var(--t-base) var(--ease-out)}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--espresso);color:var(--cream);border-color:var(--espresso)}
.btn-primary:hover{background:var(--espresso-soft);border-color:var(--espresso-soft);transform:translateY(-2px);box-shadow:0 8px 32px rgba(28,21,13,.25)}
.btn-outline{background:transparent;color:var(--espresso);border-color:var(--espresso)}
.btn-outline:hover{background:var(--espresso);color:var(--cream);transform:translateY(-2px)}
.btn-amber{background:var(--amber);color:var(--white);border-color:var(--amber)}
.btn-amber:hover{background:var(--espresso);border-color:var(--espresso);transform:translateY(-2px);box-shadow:0 8px 32px rgba(200,120,42,.3);color:var(--white)}
.btn-ghost{background:transparent;color:var(--text-mid);border-color:var(--cream-deeper)}
.btn-ghost:hover{border-color:var(--espresso);color:var(--espresso)}
.btn-affiliate{display:inline-flex;align-items:center;gap:var(--s3);font-family:var(--f-label);font-size:.6875rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.75rem 1.75rem;border-radius:var(--r-full);background:var(--amber);color:var(--white);border:2px solid var(--amber);transition:all var(--t-base) var(--ease-out)}
.btn-affiliate:hover{background:var(--espresso);border-color:var(--espresso);transform:translateY(-2px);box-shadow:0 8px 24px rgba(200,120,42,.35);color:var(--white)}
.btn-affiliate-sm{font-family:var(--f-label);font-size:.5625rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);border-bottom:1.5px solid var(--amber);padding-bottom:1px;transition:color var(--t-fast),border-color var(--t-fast)}
.btn-affiliate-sm:hover{color:var(--espresso);border-color:var(--espresso)}
.btn-block{width:100%}

/* TICKER */
.ticker-outer{position:fixed;top:0;left:0;right:0;z-index:300;height:var(--ticker-h);background:var(--espresso);overflow:hidden;display:flex;align-items:center}
.ticker-wrap{overflow:hidden;white-space:nowrap;width:100%}
.ticker-track{display:inline-flex;animation:ticker 30s linear infinite}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{display:inline-flex;align-items:center;gap:var(--s5);font-family:var(--f-label);font-size:.5rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(246,241,233,.4);padding-right:var(--s8)}
.ticker-item span{color:var(--amber);font-size:.375rem}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* HEADER */
.site-header{position:fixed;top:var(--ticker-h);left:0;right:0;z-index:200;height:var(--header-h);transition:background var(--t-slow) var(--ease-out),box-shadow var(--t-slow)}
.site-header.scrolled{background:rgba(246,241,233,.93);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);box-shadow:0 1px 0 rgba(28,21,13,.08),0 4px 24px rgba(28,21,13,.05)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%}
.site-logo{display:flex;flex-direction:column;line-height:1;gap:2px;text-decoration:none}
.logo-eyebrow{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--amber)}
.logo-main{font-family:var(--f-display);font-size:1.375rem;font-weight:400;font-style:italic;color:var(--espresso);letter-spacing:-.03em}
.site-nav{display:flex;align-items:center}
.nav-list{display:flex;align-items:center;gap:.125rem;list-style:none}
.nav-link{font-family:var(--f-label);font-size:.5625rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mid);padding:var(--s2) var(--s3);border-radius:var(--r-full);transition:color var(--t-fast),background var(--t-fast)}
.nav-link:hover{color:var(--espresso);background:var(--cream-dark)}
.nav-cta{font-family:var(--f-label);font-size:.5rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.5rem 1.25rem;border-radius:var(--r-full);background:var(--espresso);color:var(--cream);border:1.5px solid var(--espresso);transition:all var(--t-base) var(--ease-out);text-decoration:none;display:inline-flex;align-items:center}
.nav-cta:hover{background:var(--amber);border-color:var(--amber);transform:translateY(-1px);color:var(--white)}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;padding:var(--s3);border-radius:var(--r-md);cursor:pointer}
.ham-line{display:block;width:22px;height:1.5px;background:var(--espresso);border-radius:2px;transform-origin:center;transition:transform var(--t-base) var(--ease-out),opacity var(--t-base),width var(--t-base)}
.ham-line:last-child{width:14px}
.hamburger.active .ham-line:first-child{transform:translateY(6.5px) rotate(45deg);width:22px}
.hamburger.active .ham-line:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.active .ham-line:last-child{transform:translateY(-6.5px) rotate(-45deg);width:22px}

/* MOBILE NAV */
.mobile-nav-overlay{position:fixed;inset:0;z-index:190;background:var(--espresso);display:flex;flex-direction:column;padding:calc(var(--bar-total) + var(--s8)) var(--gutter) var(--s12);transform:translateX(100%);transition:transform var(--t-slow) var(--ease-out);overflow-y:auto}
.mobile-nav-overlay.open{transform:translateX(0)}
.mobile-nav-close{position:absolute;top:calc(var(--bar-total) + var(--s4));right:var(--gutter);color:rgba(246,241,233,.5);padding:var(--s3);border-radius:var(--r-md);transition:color var(--t-fast),background var(--t-fast)}
.mobile-nav-close:hover{color:var(--cream);background:rgba(255,255,255,.06)}
.mobile-nav-list{flex:1;display:flex;flex-direction:column;justify-content:center;gap:var(--s1)}
.mobile-nav-link{display:block;font-family:var(--f-display);font-size:clamp(1.75rem,7vw,3rem);font-weight:300;font-style:italic;color:rgba(246,241,233,.6);letter-spacing:-.02em;padding:var(--s3) 0;border-bottom:1px solid rgba(255,255,255,.06);transition:color var(--t-base),transform var(--t-base) var(--ease-out)}
.mobile-nav-link:hover{color:var(--cream);transform:translateX(12px)}
.mobile-nav-footer{margin-top:var(--s8)}
.mobile-nav-tagline{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(246,241,233,.22)}

/* MAIN OFFSET */
main{padding-top:var(--bar-total)}

/* HERO */
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - var(--bar-total));position:relative;overflow:hidden}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:var(--s16) var(--s12) var(--s16) var(--gutter);background:var(--cream)}
.hero-overline{display:flex;align-items:center;gap:var(--s4);margin-bottom:var(--s6)}
.hero-overline-line{width:36px;height:1.5px;background:var(--amber);flex-shrink:0}
.hero-overline-text{font-family:var(--f-label);font-size:.5rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--amber)}
.hero-title{font-family:var(--f-display);font-size:clamp(2.5rem,5vw,5rem);font-weight:300;line-height:1.05;letter-spacing:-.03em;color:var(--espresso);margin-bottom:var(--s6)}
.hero-title em{font-style:italic;color:var(--amber)}
.hero-desc{font-family:var(--f-body);font-size:1.0625rem;color:var(--text-mid);line-height:1.8;max-width:44ch;margin-bottom:var(--s8)}
.hero-actions{display:flex;align-items:center;gap:var(--s4);flex-wrap:wrap;margin-bottom:var(--s10)}
.hero-stats{display:flex;gap:var(--s10);padding-top:var(--s6);border-top:1px solid var(--cream-deeper)}
.hero-stat-num{display:block;font-family:var(--f-display);font-size:1.875rem;font-weight:700;color:var(--espresso);line-height:1}
.hero-stat-label{display:block;font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-top:4px}
.hero-right{position:relative;overflow:hidden;background:var(--cream-dark)}
.hero-image{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform 10s ease}
.hero:hover .hero-image{transform:scale(1.04)}
.hero-floating-card{position:absolute;bottom:var(--s10);left:-1.5rem;background:var(--white);border-radius:var(--r-lg);padding:var(--s4) var(--s5);box-shadow:var(--sh-xl);display:flex;align-items:center;gap:var(--s4);max-width:240px;animation:floatCard 5s ease-in-out infinite;z-index:10}
@keyframes floatCard{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-10px) rotate(0deg)}}
.hero-card-dot{width:42px;height:42px;border-radius:var(--r-md);background:var(--amber-pale);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.hero-card-label{display:block;font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);margin-bottom:3px}
.hero-card-title{font-family:var(--f-display);font-size:.9375rem;font-weight:400;color:var(--espresso);line-height:1.2}

/* SECTION HELPERS */
.section-label{font-family:var(--f-label);font-size:.5rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);display:block}
.section-num{font-family:var(--f-display);font-size:clamp(3rem,8vw,6rem);font-weight:900;color:var(--cream-deeper);line-height:1;letter-spacing:-.05em;user-select:none;flex-shrink:0}
.section-title{font-family:var(--f-display);font-size:clamp(1.75rem,3vw,2.75rem);font-weight:300;color:var(--espresso);line-height:1.1;letter-spacing:-.02em}
.section-title em{font-style:italic;color:var(--amber)}
.section-title-block{flex:1}

/* CATEGORIES */
.categories-section{padding:var(--s20) 0;background:var(--cream);overflow-x:clip;overflow-y:visible}
.categories-header{display:flex;align-items:flex-end;gap:var(--s6);margin-bottom:var(--s10)}
.cats-scroll-wrap{display:flex;gap:var(--s5);overflow-x:auto;padding-bottom:var(--s4);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-inline:var(--gutter)}
.cats-scroll-wrap::-webkit-scrollbar{display:none}
.cat-card{flex:0 0 220px;scroll-snap-align:start;position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4;text-decoration:none;display:block;background:var(--cream-deeper)}
.cat-card-img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow) var(--ease-out)}
.cat-card:hover .cat-card-img{transform:scale(1.08)}
.cat-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,21,13,.88) 0%,rgba(28,21,13,.1) 55%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:var(--s6);transition:background var(--t-base)}
.cat-card:hover .cat-card-overlay{background:linear-gradient(to top,rgba(28,21,13,.94) 0%,rgba(28,21,13,.2) 55%,transparent 100%)}
.cat-card-tag{font-family:var(--f-label);font-size:.4375rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--amber-light);margin-bottom:var(--s2)}
.cat-card-name{font-family:var(--f-display);font-size:1.25rem;font-weight:300;font-style:italic;color:var(--cream);line-height:1.2;margin-bottom:var(--s2)}
.cat-card-count{font-family:var(--f-label);font-size:.45rem;font-weight:600;color:rgba(246,241,233,.45);letter-spacing:.08em}
.cat-card-arrow{position:absolute;top:var(--s4);right:var(--s4);width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:var(--cream);opacity:0;transform:translateY(4px);transition:all var(--t-base) var(--ease-out)}
.cat-card:hover .cat-card-arrow{opacity:1;transform:translateY(0)}

/* FEATURED */
.featured-section{padding:var(--s20) 0;background:var(--espresso-mid);position:relative;overflow:hidden}
.featured-section::before{content:'COZY';position:absolute;right:-.05em;top:50%;transform:translateY(-50%);font-family:var(--f-display);font-size:clamp(8rem,18vw,20rem);font-weight:900;color:rgba(255,255,255,.025);line-height:1;pointer-events:none;letter-spacing:-.05em;user-select:none}
.featured-inner{display:grid;grid-template-columns:1fr 420px;gap:var(--s16);align-items:center;position:relative;z-index:1}
.featured-content{order:1}
.featured-meta{display:flex;align-items:center;gap:var(--s4);margin-bottom:var(--s6)}
.featured-badge{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:var(--s1) var(--s4);border-radius:var(--r-full);background:var(--amber);color:var(--white)}
.featured-date{font-family:var(--f-label);font-size:.5rem;font-weight:500;color:rgba(246,241,233,.35);letter-spacing:.08em}
.featured-title{font-family:var(--f-display);font-size:clamp(1.75rem,3.5vw,3rem);font-weight:300;font-style:italic;color:var(--cream);line-height:1.15;margin-bottom:var(--s5);letter-spacing:-.02em}
.featured-title a{color:inherit;transition:color var(--t-fast)}
.featured-title a:hover{color:var(--amber-light)}
.featured-excerpt{font-size:1rem;color:rgba(246,241,233,.55);line-height:1.8;margin-bottom:var(--s8);max-width:52ch}
.featured-cta{display:inline-flex;align-items:center;gap:var(--s4)}
.featured-read-link{font-family:var(--f-label);font-size:.5625rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(246,241,233,.5);display:flex;align-items:center;gap:var(--s3);transition:color var(--t-fast)}
.featured-read-link:hover{color:var(--cream)}
.featured-read-arrow{width:32px;height:32px;border-radius:50%;border:1px solid rgba(246,241,233,.2);display:flex;align-items:center;justify-content:center;transition:all var(--t-base) var(--ease-out)}
.featured-read-link:hover .featured-read-arrow{background:var(--amber);border-color:var(--amber)}
.featured-image-wrap{order:2;position:relative;border-radius:var(--r-xl);overflow:hidden;aspect-ratio:3/4;box-shadow:var(--sh-xl)}
.featured-image{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow) var(--ease-out)}
.featured-image-wrap:hover .featured-image{transform:scale(1.04)}
.featured-img-tag{position:absolute;top:var(--s4);left:var(--s4);background:rgba(28,21,13,.8);backdrop-filter:blur(12px);border-radius:var(--r-full);padding:var(--s2) var(--s4);font-family:var(--f-label);font-size:.4375rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--cream)}

/* POSTS */
.posts-section{padding:var(--s20) 0;background:var(--cream)}
.posts-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:var(--s12);gap:var(--s6)}
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5)}
.post-card{background:var(--white);border-radius:var(--r-lg);overflow:hidden;transition:transform var(--t-base) var(--ease-out),box-shadow var(--t-base);text-decoration:none;display:block;position:relative}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.post-card-image-wrap{overflow:hidden;background:var(--cream-deeper)}
.post-card-image{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform var(--t-slow) var(--ease-out)}
.post-card:hover .post-card-image{transform:scale(1.06)}
.post-card-body{padding:var(--s5) var(--s6) var(--s6)}
.post-category-tag{font-family:var(--f-label);font-size:.4375rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);text-decoration:none;transition:color var(--t-fast)}
.post-category-tag:hover{color:var(--espresso)}
.post-card-title{font-family:var(--f-display);font-size:1.3rem;font-weight:300;line-height:1.25;color:var(--espresso);margin:var(--s3) 0;letter-spacing:-.01em;transition:color var(--t-fast)}
.post-card:hover .post-card-title,.post-card-title-link:hover{color:var(--amber)}
.post-card-title-link{color:inherit;text-decoration:none}
.post-card-excerpt{font-size:.875rem;color:var(--text-mid);line-height:1.7;margin-bottom:var(--s4);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post-meta{display:flex;align-items:center;gap:var(--s3)}
.post-meta-item{font-family:var(--f-label);font-size:.4375rem;font-weight:600;letter-spacing:.08em;color:var(--text-pale);text-transform:uppercase}
.post-meta-sep{color:var(--cream-deeper)}
.post-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--cream-deeper)}

/* AFFILIATE */
.affiliate-section{padding:var(--s20) 0;background:var(--cream-dark);position:relative;overflow:hidden}
.affiliate-section::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--amber),var(--rose),var(--sage),var(--amber));background-size:200% 100%;animation:shimmer 4s linear infinite}
@keyframes shimmer{from{background-position:0%}to{background-position:200%}}
.affiliate-header{display:grid;grid-template-columns:1fr auto;align-items:end;gap:var(--s8);margin-bottom:var(--s12)}
.affiliate-disclosure-note{font-family:var(--f-label);font-size:.45rem;font-weight:600;letter-spacing:.08em;color:var(--text-muted)}
.affiliate-disclosure-note a{color:var(--amber);text-decoration:underline}
.affiliate-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5)}
.affiliate-card{background:var(--white);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--t-base) var(--ease-out),box-shadow var(--t-base)}
.affiliate-card:hover{transform:translateY(-8px);box-shadow:var(--sh-xl)}
.affiliate-card-img-wrap{overflow:hidden;background:var(--cream-deeper);position:relative}
.affiliate-card-img{width:100%;aspect-ratio:1;object-fit:cover;transition:transform var(--t-slow) var(--ease-out)}
.affiliate-card:hover .affiliate-card-img{transform:scale(1.07)}
.affiliate-card-badge{position:absolute;top:var(--s4);left:var(--s4);font-family:var(--f-label);font-size:.4375rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:var(--s1) var(--s3);border-radius:var(--r-full);background:var(--espresso);color:var(--cream)}
.affiliate-card-body{padding:var(--s5) var(--s6) var(--s6);display:flex;flex-direction:column;flex:1}
.affiliate-card-cat{font-family:var(--f-label);font-size:.4375rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:var(--s3)}
.affiliate-card-title{font-family:var(--f-display);font-size:1.25rem;font-weight:300;color:var(--espresso);line-height:1.2;margin-bottom:var(--s2)}
.affiliate-stars{color:var(--amber);font-size:.75rem;letter-spacing:2px;margin-bottom:var(--s3)}
.affiliate-card-desc{font-size:.875rem;color:var(--text-mid);line-height:1.7;margin-bottom:var(--s5);flex:1}
.affiliate-card-note{font-family:var(--f-label);font-size:.4375rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-pale);margin-top:var(--s3)}

/* GUIDE BANNER */
.guide-banner{background:var(--amber);padding:var(--s12) 0;position:relative;overflow:hidden}
.guide-banner::before{content:'→';position:absolute;right:4%;top:50%;transform:translateY(-50%);font-family:var(--f-display);font-size:clamp(6rem,15vw,14rem);color:rgba(255,255,255,.12);line-height:1;pointer-events:none}
.guide-banner-inner{display:flex;align-items:center;gap:var(--s12);justify-content:space-between}
.guide-banner-label{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.65);display:block;margin-bottom:var(--s3)}
.guide-banner-title{font-family:var(--f-display);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:300;font-style:italic;color:var(--white);line-height:1.1;letter-spacing:-.02em}
.guide-banner-cta{flex-shrink:0;background:var(--espresso);color:var(--cream);border:2px solid var(--espresso);font-family:var(--f-label);font-size:.5625rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:1rem 2.25rem;border-radius:var(--r-full);cursor:pointer;white-space:nowrap;transition:all var(--t-base) var(--ease-out);text-decoration:none;display:inline-flex;align-items:center;gap:var(--s3)}
.guide-banner-cta:hover{background:var(--white);border-color:var(--white);color:var(--amber);transform:translateY(-2px)}

/* PINTEREST */
.pinterest-section{padding:var(--s20) 0;background:var(--cream)}
.pinterest-header{margin-bottom:var(--s10);text-align:center}
.pinterest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s4);margin-bottom:var(--s10)}
.pin-card{position:relative;border-radius:var(--r-lg);overflow:hidden;display:block;text-decoration:none;background:var(--cream-deeper)}
.pin-card:nth-child(2){margin-top:var(--s8)}
.pin-card:nth-child(4){margin-top:-2rem}
.pin-card-img{width:100%;aspect-ratio:2/3;object-fit:cover;transition:transform var(--t-slow) var(--ease-out)}
.pin-card:hover .pin-card-img{transform:scale(1.06)}
.pin-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,21,13,.82) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:var(--s5);opacity:0;transition:opacity var(--t-base)}
.pin-card:hover .pin-card-overlay{opacity:1}
.pin-card-title{font-family:var(--f-display);font-size:1.1rem;font-weight:300;font-style:italic;color:var(--cream);line-height:1.3;margin-bottom:var(--s2)}
.pin-card-link{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-light)}
.pinterest-follow{text-align:center}

/* NEWSLETTER */
.newsletter-section{background:var(--espresso-mid);padding:var(--s24) 0;position:relative;overflow:hidden}
.newsletter-inner{display:grid;grid-template-columns:1fr 1fr;gap:var(--s20);align-items:center;position:relative;z-index:1}
.newsletter-eyebrow{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);display:flex;align-items:center;gap:var(--s4);margin-bottom:var(--s5)}
.newsletter-eyebrow::before{content:'';width:28px;height:1.5px;background:var(--amber)}
.newsletter-title{font-family:var(--f-display);font-size:clamp(2rem,4vw,3.25rem);font-weight:300;font-style:italic;color:var(--cream);line-height:1.1;margin-bottom:var(--s5);letter-spacing:-.02em}
.newsletter-desc{font-size:1rem;color:rgba(246,241,233,.5);line-height:1.8}
.newsletter-form{display:flex;flex-direction:column;gap:var(--s4)}
.newsletter-input-wrap{display:flex;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.1);border-radius:var(--r-full);overflow:hidden;transition:border-color var(--t-fast),background var(--t-fast);min-width:0}
.newsletter-input-wrap:focus-within{border-color:var(--amber);background:rgba(255,255,255,.08)}
.newsletter-input{flex:1;min-width:0;background:transparent;border:none;outline:none;padding:.9375rem 1rem .9375rem 1.5rem;font-family:var(--f-body);font-size:.9375rem;color:var(--cream)}
.newsletter-input::placeholder{color:rgba(246,241,233,.3)}
.newsletter-btn{flex-shrink:0;font-family:var(--f-label);font-size:.5rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:0 1.25rem;min-width:5rem;background:var(--amber);color:var(--white);border:none;cursor:pointer;transition:background var(--t-fast);white-space:nowrap}
.newsletter-btn:hover{background:var(--amber-light)}
.newsletter-fine{font-family:var(--f-label);font-size:.45rem;font-weight:600;letter-spacing:.08em;color:rgba(246,241,233,.28)}
/* hidden by default — JS removes the [hidden] attr to reveal */
.newsletter-success{display:none;align-items:center;gap:var(--s3);font-family:var(--f-label);font-size:.625rem;font-weight:700;letter-spacing:.1em;color:var(--sage-light);padding:var(--s5);border:1px solid rgba(168,196,170,.3);border-radius:var(--r-lg);background:rgba(168,196,170,.08)}
.newsletter-success:not([hidden]){display:flex}

/* FOOTER */
.site-footer{background:var(--espresso);padding:var(--s16) 0 var(--s10)}
.footer-top{display:grid;grid-template-columns:1.8fr 1fr 1fr;gap:var(--s12);padding-bottom:var(--s12);border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:var(--s10)}
.footer-brand-name{font-family:var(--f-display);font-size:1.875rem;font-weight:300;font-style:italic;color:rgba(246,241,233,.9);letter-spacing:-.03em;line-height:1;margin-bottom:var(--s5);display:block}
.footer-brand-desc{font-size:.875rem;color:rgba(246,241,233,.38);line-height:1.75;max-width:30ch;margin-bottom:var(--s6)}
.footer-social{display:flex;gap:var(--s3)}
.footer-social-link{width:38px;height:38px;border-radius:var(--r-md);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(246,241,233,.45);transition:all var(--t-fast)}
.footer-social-link:hover{border-color:var(--amber);color:var(--amber);background:rgba(200,120,42,.08)}
.footer-col-title{font-family:var(--f-label);font-size:.4375rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(246,241,233,.28);margin-bottom:var(--s5)}
.footer-links{display:flex;flex-direction:column;gap:var(--s3)}
.footer-link{font-size:.875rem;color:rgba(246,241,233,.48);font-weight:300;transition:color var(--t-fast),transform var(--t-fast);display:inline-block}
.footer-link:hover{color:var(--cream);transform:translateX(4px)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:var(--s6);flex-wrap:wrap}
.footer-disclosure{font-size:.75rem;color:rgba(246,241,233,.22);line-height:1.6;max-width:68ch}
.footer-disclosure a{color:rgba(246,241,233,.38);text-decoration:underline}
.footer-copy{font-family:var(--f-label);font-size:.4375rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(246,241,233,.2);white-space:nowrap}

/* ARTICLE */
.breadcrumb-nav{padding-top:var(--s6);overflow:hidden}
.breadcrumb-list{display:flex;align-items:center;gap:var(--s3);flex-wrap:wrap}
.breadcrumb-item,.breadcrumb-sep{font-family:var(--f-label);font-size:.45rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}
.breadcrumb-link{transition:color var(--t-fast)}
.breadcrumb-link:hover{color:var(--amber)}
.breadcrumb-current{color:var(--text-mid);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:20ch}
.article-header{padding:var(--s8) 0 var(--s12);overflow:hidden}
.article-header-meta{display:flex;align-items:center;gap:var(--s3);margin-bottom:var(--s6);flex-wrap:wrap}
.article-read-time,.article-date{font-family:var(--f-label);font-size:.45rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}
.article-title{font-family:var(--f-display);font-size:clamp(1.5rem,5vw,3.25rem);font-weight:300;font-style:italic;line-height:1.15;color:var(--espresso);margin-bottom:var(--s6);letter-spacing:-.025em;overflow-wrap:break-word;word-break:break-word}
.article-excerpt{font-size:1rem;color:var(--text-mid);font-style:italic;line-height:1.75;margin-bottom:var(--s8);border-left:3px solid var(--amber);padding-left:var(--s5);overflow-wrap:break-word}
.article-header-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--s3);flex-wrap:wrap}
.article-author{display:flex;align-items:center;gap:var(--s3);flex-shrink:0}
.author-avatar{width:36px;height:36px;border-radius:50%;background:var(--amber);color:var(--white);display:flex;align-items:center;justify-content:center;font-family:var(--f-label);font-size:.625rem;font-weight:700;flex-shrink:0}
.author-name{font-family:var(--f-label);font-size:.5rem;font-weight:600;color:var(--text-mid);letter-spacing:.04em}
.article-share{display:flex;align-items:center;gap:var(--s2);flex-wrap:wrap}
.share-label{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted)}
.share-btn{display:inline-flex;align-items:center;gap:var(--s2);font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:var(--s2) var(--s3);border-radius:var(--r-full);border:1.5px solid var(--cream-deeper);color:var(--text-mid);background:transparent;cursor:pointer;transition:all var(--t-fast);white-space:nowrap}
.share-btn:hover{border-color:var(--espresso);color:var(--espresso)}
.share-pinterest{color:#E60023;border-color:rgba(230,0,35,.25)}
.share-pinterest:hover{background:rgba(230,0,35,.06);border-color:#E60023}
.article-featured-image-wrap{margin-bottom:var(--s12)}
.article-featured-image{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--r-xl);box-shadow:var(--sh-lg)}
.article-image-caption{text-align:center;font-family:var(--f-label);font-size:.45rem;font-weight:600;letter-spacing:.1em;color:var(--text-pale);margin-top:var(--s4);text-transform:uppercase}
.article-layout{padding-bottom:var(--s20);overflow:hidden}
.article-body-grid{display:grid;grid-template-columns:1fr 290px;gap:var(--s16);align-items:start}
.article-content{min-width:0;overflow:hidden}
.article-body-content h2{font-family:var(--f-display);font-size:clamp(1.25rem,2.5vw,2rem);font-weight:300;font-style:italic;color:var(--espresso);margin:var(--s10) 0 var(--s5);letter-spacing:-.02em}
.article-body-content h3{font-family:var(--f-label);font-size:.8125rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--espresso);margin:var(--s8) 0 var(--s4)}
.article-body-content p{font-size:1.0625rem;line-height:1.875;color:var(--text-primary);margin-bottom:var(--s6)}
.article-body-content a{color:var(--amber);text-decoration:underline;text-underline-offset:3px;transition:color var(--t-fast);word-break:break-all}
.article-body-content a:hover{color:var(--espresso)}
.article-body-content ul,.article-body-content ol{padding-left:var(--s6);margin-bottom:var(--s6)}
.article-body-content ul{list-style:disc}.article-body-content ol{list-style:decimal}
.article-body-content li{font-size:1.0625rem;line-height:1.75;margin-bottom:var(--s2);color:var(--text-primary)}
.article-body-content blockquote{border-left:3px solid var(--amber);padding:var(--s5) var(--s6);margin:var(--s8) 0;background:var(--amber-pale);border-radius:0 var(--r-md) var(--r-md) 0}
.article-body-content blockquote p{font-family:var(--f-display);font-size:1.375rem;font-style:italic;color:var(--espresso-soft);margin:0}
.affiliate-disclosure-box{display:flex;gap:var(--s4);background:var(--amber-pale);border-left:3px solid var(--amber);border-radius:0 var(--r-md) var(--r-md) 0;padding:var(--s4) var(--s5);margin:var(--s8) 0}
.disclosure-icon{font-size:1rem;flex-shrink:0;margin-top:2px}
.disclosure-text{font-size:.875rem;color:var(--espresso-soft);line-height:1.7}
.disclosure-link{color:var(--amber);text-decoration:underline;font-size:.8125rem}
.toc-nav{background:var(--cream-dark);border-radius:var(--r-lg);padding:var(--s5) var(--s6);margin:var(--s8) 0;border:1px solid var(--cream-deeper);overflow:hidden}
.toc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--s4)}
.toc-title{font-family:var(--f-label);font-size:.5rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-mid)}
.toc-toggle{color:var(--text-muted);transition:transform var(--t-fast)}
.toc-list,.sidebar-toc-list{list-style:decimal;padding-left:var(--s5);display:flex;flex-direction:column;gap:var(--s2)}
.toc-list a,.sidebar-toc-list a{font-family:var(--f-label);font-size:.625rem;font-weight:500;color:var(--text-mid);text-decoration:none;transition:color var(--t-fast);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;word-break:normal;hyphens:none}
.toc-list a:hover,.sidebar-toc-list a:hover{color:var(--amber)}
.product-card-inline{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--cream-deeper);overflow:hidden;margin:var(--s8) 0;box-shadow:var(--sh-sm)}
.product-card-body{padding:var(--s6)}
.product-name{font-family:var(--f-display);font-size:1.375rem;font-weight:300;color:var(--espresso);margin-bottom:var(--s2)}
.product-stars{color:var(--amber);font-size:.875rem;margin-bottom:var(--s3);letter-spacing:2px}
.product-why{font-size:.9375rem;color:var(--text-mid);margin-bottom:var(--s4);line-height:1.7}
.best-for-box{background:var(--sage-pale);border:1px solid var(--sage-light);border-radius:var(--r-md);padding:var(--s4) var(--s5);margin-bottom:var(--s5)}
.best-for-box p{font-size:.875rem !important;margin-bottom:var(--s2) !important;color:var(--espresso-soft) !important;line-height:1.6 !important}
.best-for-box p:last-child{margin-bottom:0 !important}
.editors-pick-box{background:var(--espresso);border-radius:var(--r-lg);padding:var(--s8);margin:var(--s10) 0}
.editors-pick-header{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:var(--s5)}
.editors-pick-box p{font-size:1rem !important;color:rgba(246,241,233,.75) !important;margin-bottom:var(--s5) !important;line-height:1.8 !important}
/* Affiliate CTA buttons inside article body / product cards: keep contained, wrap text, never overflow */
.article-body-content .btn-affiliate,
.product-card-inline .btn-affiliate,
.editors-pick-box .btn-affiliate{display:flex;width:100%;max-width:100%;box-sizing:border-box;justify-content:center;text-align:center;white-space:normal;word-break:normal;overflow-wrap:break-word;line-height:1.3;padding:.875rem 1.25rem;letter-spacing:.08em;color:var(--white);text-decoration:none}
.article-body-content .btn-affiliate:hover,
.product-card-inline .btn-affiliate:hover,
.editors-pick-box .btn-affiliate:hover{color:var(--white);text-decoration:none}
.comparison-table-wrapper{overflow-x:auto;margin:var(--s8) 0;border-radius:var(--r-lg);box-shadow:var(--sh-sm)}
.comparison-table{width:100%;border-collapse:collapse;min-width:480px}
.comparison-table thead{background:var(--espresso)}
.comparison-table thead th{color:var(--cream);font-family:var(--f-label);font-size:.5rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:var(--s4) var(--s5);text-align:left}
.comparison-table tbody tr:nth-child(even){background:var(--cream-dark)}
.comparison-table tbody tr:nth-child(odd){background:var(--white)}
.comparison-table tbody td{padding:var(--s4) var(--s5);font-size:.9375rem;color:var(--text-primary);border-bottom:1px solid var(--cream-deeper)}
.faq-section{margin:var(--s10) 0}
.faq-item{border-bottom:1px solid var(--cream-deeper)}
.faq-question{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--s5) 0;font-family:var(--f-body);font-size:1.0625rem;font-weight:500;color:var(--espresso);text-align:left;cursor:pointer;background:none;border:none;gap:var(--s4);transition:color var(--t-fast)}
.faq-question:hover{color:var(--amber)}
.faq-question::after{content:'+';font-size:1.5rem;font-weight:300;flex-shrink:0;color:var(--amber);transition:transform var(--t-base) var(--ease-out)}
.faq-question.open::after{transform:rotate(45deg)}
.faq-answer{display:none;padding-bottom:var(--s5)}
.faq-answer.open{display:block}
.faq-answer p{font-size:1rem !important;color:var(--text-mid) !important;line-height:1.8 !important;margin:0 !important}
.article-sidebar{position:sticky;top:calc(var(--bar-total) + 2rem)}
.sidebar-widget{background:var(--cream-dark);border-radius:var(--r-lg);padding:var(--s5) var(--s6);margin-bottom:var(--s5);border:1px solid var(--cream-deeper)}
.sidebar-widget-title{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-mid);margin-bottom:var(--s4)}
.sidebar-product-list{display:flex;flex-direction:column;gap:var(--s4)}
.sidebar-product-item{display:flex;align-items:center;justify-content:space-between;gap:var(--s3)}
.sidebar-product-name{font-size:.875rem;color:var(--espresso);font-weight:400;flex:1}
.sidebar-newsletter-desc{font-size:.875rem;color:var(--text-mid);margin-bottom:var(--s4);line-height:1.6}
.sidebar-input{width:100%;padding:.625rem var(--s4);border:1.5px solid var(--cream-deeper);border-radius:var(--r-full);font-family:var(--f-body);font-size:.875rem;background:var(--white);color:var(--espresso);outline:none;transition:border-color var(--t-fast)}
.sidebar-input:focus{border-color:var(--amber)}
.article-updated-note{font-family:var(--f-label);font-size:.4375rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-pale);margin-top:var(--s10);padding-top:var(--s6);border-top:1px solid var(--cream-deeper)}
.article-footer-disclosure{margin-top:var(--s8);padding:var(--s4) var(--s5);background:var(--cream-dark);border-radius:var(--r-md);font-size:.75rem;color:var(--text-muted);line-height:1.6}
.article-footer-disclosure a{color:var(--amber)}
.related-posts-section{padding:var(--s16) 0 var(--s20);background:var(--cream-dark)}

/* CATEGORY PAGE */
.category-hero{padding:var(--s12) 0;background:var(--espresso-mid);position:relative;overflow:hidden}
.category-hero-title{font-family:var(--f-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:300;font-style:italic;color:var(--cream);margin-bottom:var(--s4);letter-spacing:-.03em}
.category-hero-desc{font-size:1.0625rem;color:rgba(246,241,233,.52);max-width:55ch;margin-bottom:var(--s4);line-height:1.75}
.category-post-count{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--amber)}
.filter-bar{position:sticky;top:var(--bar-total);z-index:50;background:rgba(246,241,233,.93);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--cream-deeper);padding:var(--s4) 0}
.filter-bar-inner{display:flex;align-items:center;gap:var(--s3);overflow-x:auto;scrollbar-width:none}
.filter-bar-inner::-webkit-scrollbar{display:none}
.filter-pill{font-family:var(--f-label);font-size:.4375rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:var(--s2) var(--s5);border-radius:var(--r-full);background:var(--cream-deeper);color:var(--text-mid);text-decoration:none;white-space:nowrap;border:1.5px solid transparent;transition:all var(--t-fast)}
.filter-pill:hover{background:var(--espresso);color:var(--cream)}
.filter-pill--active{background:var(--espresso);color:var(--cream)}

/* SEARCH */
.search-hero{padding:var(--s12) 0;background:var(--espresso-mid);text-align:center}
.search-hero-title{font-family:var(--f-display);font-size:clamp(1.75rem,4vw,3rem);font-weight:300;font-style:italic;color:var(--cream);margin-bottom:var(--s8);letter-spacing:-.02em}
.search-hero-title em{font-style:normal;color:var(--amber)}
.search-form-main{max-width:560px;margin:0 auto}
.search-form-wrap{display:flex;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.12);border-radius:var(--r-full);overflow:hidden;transition:border-color var(--t-fast)}
.search-form-wrap:focus-within{border-color:var(--amber)}
.search-input-main{flex:1;background:transparent;border:none;outline:none;padding:.9375rem 1.5rem;font-family:var(--f-body);font-size:1rem;color:var(--cream)}
.search-input-main::placeholder{color:rgba(246,241,233,.3)}
.search-submit-btn{padding:0 var(--s6);color:var(--amber);display:flex;align-items:center;background:none;border:none;cursor:pointer;transition:color var(--t-fast)}
.search-submit-btn:hover{color:var(--amber-light)}
.search-result-count{font-family:var(--f-label);font-size:.5rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(246,241,233,.4);margin-top:var(--s5)}
.search-results-section{padding:var(--s16) 0 var(--s20)}
.search-suggestion-pills{display:flex;flex-wrap:wrap;gap:var(--s3);justify-content:center;margin-top:var(--s4)}
.suggestion-pill{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:var(--s2) var(--s5);border-radius:var(--r-full);border:1.5px solid rgba(246,241,233,.15);color:rgba(246,241,233,.6);text-decoration:none;transition:all var(--t-fast)}
.suggestion-pill:hover{background:var(--amber);border-color:var(--amber);color:var(--white)}
.search-browse{padding-top:var(--s10)}

/* PAGINATION */
.pagination{margin-top:var(--s16);text-align:center}
.pagination-inner{display:flex;justify-content:center;align-items:center;gap:var(--s3);flex-wrap:wrap;margin-bottom:var(--s4)}
.pagination-btn{font-family:var(--f-label);font-size:.5rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.625rem 1.25rem;border-radius:var(--r-full);border:1.5px solid var(--cream-deeper);color:var(--text-mid);text-decoration:none;transition:all var(--t-fast)}
.pagination-btn:hover{border-color:var(--espresso);color:var(--espresso)}
.pagination-btn--disabled{opacity:.35;cursor:not-allowed}
.pagination-pages{display:flex;gap:var(--s2)}
.pagination-page{width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--f-label);font-size:.625rem;font-weight:600;color:var(--text-mid);text-decoration:none;transition:all var(--t-fast)}
.pagination-page:hover{background:var(--cream-deeper);color:var(--espresso)}
.pagination-page--active{background:var(--espresso);color:var(--cream)}
.pagination-ellipsis{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-pale)}
.pagination-info{font-family:var(--f-label);font-size:.45rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}

/* STATIC PAGES */
.page-hero{padding:var(--s12) 0;background:var(--espresso-mid)}
.page-hero-title{font-family:var(--f-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:300;font-style:italic;color:var(--cream);letter-spacing:-.03em;margin-bottom:var(--s4)}
.page-hero-desc{font-size:1.0625rem;color:rgba(246,241,233,.52);max-width:50ch;line-height:1.75}
.page-hero-meta{font-family:var(--f-label);font-size:.45rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(246,241,233,.32)}
.page-content{padding:var(--s16) 0 var(--s24)}
.prose-content h2{font-family:var(--f-display);font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:300;font-style:italic;color:var(--espresso);margin:var(--s10) 0 var(--s4);letter-spacing:-.02em}
.prose-content h2:first-child{margin-top:0}
.prose-content p{font-size:1.0625rem;color:var(--text-mid);line-height:1.85;margin-bottom:var(--s5)}
.prose-content a{color:var(--amber);text-decoration:underline}
.prose-content a:hover{color:var(--espresso)}
.prose-content ul{list-style:disc;padding-left:var(--s6);margin-bottom:var(--s6)}
.prose-content li{font-size:1.0625rem;color:var(--text-mid);line-height:1.75;margin-bottom:var(--s2)}
.legal-notice{background:rgba(200,120,42,.08);border:1px solid rgba(200,120,42,.25);border-radius:var(--r-md);padding:var(--s4) var(--s5);font-family:var(--f-label);font-size:.5625rem;font-weight:600;color:var(--amber);margin-bottom:var(--s8);letter-spacing:.04em}
.about-stats-row{display:flex;gap:var(--s12);margin-bottom:var(--s12);padding-bottom:var(--s12);border-bottom:1px solid var(--cream-deeper)}
.about-stat-number{display:block;font-family:var(--f-display);font-size:clamp(2.5rem,5vw,4rem);font-weight:700;color:var(--amber);line-height:1;margin-bottom:var(--s2)}
.about-stat-label{font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5);margin:var(--s8) 0}
.value-card{background:var(--cream-dark);border-radius:var(--r-lg);padding:var(--s6)}
.value-icon{font-size:1.5rem;display:block;margin-bottom:var(--s4)}
.value-title{font-family:var(--f-display);font-size:1.25rem;font-weight:300;font-style:italic;color:var(--espresso);margin-bottom:var(--s3)}
.value-desc{font-size:.9375rem;color:var(--text-mid);line-height:1.7}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--s16);align-items:start}
.contact-info{display:flex;flex-direction:column;gap:var(--s6)}
.contact-info-item{display:flex;gap:var(--s4);align-items:flex-start}
.contact-info-icon{font-size:1.25rem;flex-shrink:0;margin-top:2px}
.contact-info-label{font-family:var(--f-label);font-size:.4375rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:4px}
.contact-info-value{font-size:1.0625rem;color:var(--text-primary);line-height:1.5}
.contact-info-value a{color:var(--amber);text-decoration:underline}
.contact-info-note{font-size:.875rem;color:var(--text-muted);line-height:1.7;padding:var(--s4);background:var(--cream-dark);border-radius:var(--r-md)}
.contact-form{display:flex;flex-direction:column;gap:var(--s5)}
.contact-form-success{background:rgba(107,140,110,.1);border:1px solid var(--sage-light);border-radius:var(--r-md);padding:var(--s4) var(--s5);font-family:var(--f-label);font-size:.5625rem;font-weight:700;letter-spacing:.08em;color:var(--sage)}
.contact-form-error{background:rgba(200,120,42,.08);border:1px solid rgba(200,120,42,.3);border-radius:var(--r-md);padding:var(--s4) var(--s5);font-size:.875rem;color:var(--amber)}
.form-group{display:flex;flex-direction:column;gap:var(--s2)}
.form-label{font-family:var(--f-label);font-size:.5rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-mid)}
.form-input,.form-select,.form-textarea{width:100%;padding:.75rem var(--s5);border:1.5px solid var(--cream-deeper);border-radius:var(--r-md);font-family:var(--f-body);font-size:1rem;color:var(--text-primary);background:var(--white);outline:none;transition:border-color var(--t-fast),box-shadow var(--t-fast);line-height:1.5}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(200,120,42,.10)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-pale)}
.form-textarea{resize:vertical;min-height:140px}
.other-categories-section{padding:var(--s12) 0}
.other-cats-pills{display:flex;flex-wrap:wrap;gap:var(--s3)}
.other-cat-pill{display:inline-flex;align-items:center;gap:var(--s3);font-family:var(--f-label);font-size:.45rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:var(--s3) var(--s5);border-radius:var(--r-full);border:1.5px solid var(--cream-deeper);color:var(--text-mid);text-decoration:none;transition:all var(--t-fast);background:var(--white)}
.other-cat-pill:hover{border-color:var(--espresso);color:var(--espresso)}
.other-cat-count{font-size:.4rem;background:var(--cream-deeper);padding:1px 6px;border-radius:var(--r-full);color:var(--text-muted)}
.empty-state{text-align:center;padding:var(--s20) var(--s8)}
.empty-state-icon{font-size:3rem;margin-bottom:var(--s5)}
.empty-state-title{font-family:var(--f-display);font-size:2rem;font-weight:300;font-style:italic;color:var(--espresso);margin-bottom:var(--s4)}
.empty-state-desc{color:var(--text-mid);margin-bottom:var(--s8)}
.categories-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s5)}
.category-card{background:var(--white);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);transition:transform var(--t-base),box-shadow var(--t-base);text-decoration:none;display:block}
.category-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.category-card-image-wrap{aspect-ratio:1;overflow:hidden;background:var(--cream-deeper)}
.category-card-image{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.category-card:hover .category-card-image{transform:scale(1.04)}
.category-card-body{padding:var(--s4) var(--s5)}
.category-card-name{font-family:var(--f-display);font-size:1.1rem;font-weight:300;color:var(--espresso);margin-bottom:var(--s1)}
.category-card-count{font-family:var(--f-label);font-size:.4rem;font-weight:600;letter-spacing:.08em;color:var(--text-pale);text-transform:uppercase}

/* REVEAL */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity var(--t-slow) var(--ease-out),transform var(--t-slow) var(--ease-out)}
[data-reveal].revealed{opacity:1;transform:translateY(0)}
[data-reveal="left"]{transform:translateX(-28px)}
[data-reveal="left"].revealed{transform:translateX(0);opacity:1}
[data-reveal="right"]{transform:translateX(28px)}
[data-reveal="right"].revealed{transform:translateX(0);opacity:1}
[data-reveal="scale"]{transform:scale(.94)}
[data-reveal="scale"].revealed{transform:scale(1);opacity:1}

/* RESPONSIVE */
@media(max-width:1100px){
  .hero{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-left{padding:var(--s16) var(--gutter);text-align:center}
  .hero-overline,.hero-actions,.hero-stats{justify-content:center}
  .hero-desc{margin-inline:auto}
  .featured-inner{grid-template-columns:1fr}
  .featured-image-wrap{order:-1;aspect-ratio:16/9}
  .featured-section::before{display:none}
  .site-nav{display:none}
  .hamburger{display:flex}
  .posts-grid{grid-template-columns:repeat(2,1fr)}
  .affiliate-grid{grid-template-columns:repeat(2,1fr)}
  .pinterest-grid{grid-template-columns:repeat(2,1fr)}
  .pin-card:nth-child(2),.pin-card:nth-child(4){margin-top:0}
  .newsletter-inner{grid-template-columns:1fr;gap:var(--s10)}
  .footer-top{grid-template-columns:1fr 1fr}
  .article-body-grid{grid-template-columns:1fr}
  .article-sidebar{position:static}
  .article-content{min-width:0;width:100%}
  .values-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .categories-header{flex-direction:column;align-items:flex-start;gap:var(--s3)}
  .categories-grid{grid-template-columns:repeat(2,1fr)}
  .affiliate-header{grid-template-columns:1fr}
}
@media(max-width:640px){
  :root{--ticker-h:28px;--header-h:56px}
  .posts-grid{grid-template-columns:1fr}
  .affiliate-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:var(--s8)}
  .footer-bottom{flex-direction:column;text-align:center}
  .guide-banner-inner{flex-direction:column;gap:var(--s6);text-align:center}
  .about-stats-row{flex-wrap:wrap;gap:var(--s6)}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%}
  .categories-grid{grid-template-columns:1fr 1fr}
  /* Newsletter: stack input+button on small screens */
  .newsletter-section .container{overflow:hidden}
  .newsletter-input-wrap{flex-direction:column;border-radius:var(--r-lg);overflow:visible;border:none;background:transparent;gap:var(--s3)}
  .newsletter-input{background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.1);border-radius:var(--r-full);padding:.875rem 1.25rem;width:100%;color:var(--cream)}
  .newsletter-input:focus{border-color:var(--amber)}
  .newsletter-btn{width:100%;padding:.875rem 1.25rem;border-radius:var(--r-full);min-height:44px}
  .newsletter-input-wrap:focus-within{border-color:transparent;background:transparent}
  /* Article page mobile fixes */
  .article-header-footer{flex-direction:column;align-items:flex-start;gap:var(--s4)}
  .article-share{gap:var(--s2)}
  .share-btn svg{display:none} /* icon only on very small - show text */
  .article-body-content p,.article-body-content li{font-size:1rem}
  .article-body-content h2{font-size:clamp(1.25rem,4vw,1.75rem)}
  .article-featured-image{border-radius:var(--r-lg)}
  .affiliate-disclosure-box{padding:var(--s4)}
  .toc-list a,.sidebar-toc-list a{white-space:normal;overflow:visible;text-overflow:clip}
  .product-card-inline{margin-inline:0}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition-duration:.01ms !important}
  [data-reveal]{opacity:1;transform:none}
}
