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

/* =========================================================================
   DESIGN TOKENS — white-first, editorial, soft deliberate radii
   Direction: reduce pink, lean on whitespace, serif titles, hairlines.
   Radii are tiered: ~4px on small UI, ~8px on cards/tiles, ~16-24px on
   featured/decorative blocks. Pills only for true pills (avatars, dots).
   ========================================================================= */
:root{
  /* Surfaces */
  --canvas:#FFFFFF;          /* primary page background */
  --off-white:#F2E7DD;       /* alternating sections, warm vanilla */
  --cream:#EDE0D4;           /* product image backdrops, deeper vanilla */
  --petal:#FCFBFA;           /* near-white, used sparingly (hover, promo) */
  --blush:#F2D6CE;           /* soft blush — hover surfaces */
  --header-bg:#F2E7DD;       /* kept as token alias for backward compat */

  /* Text */
  --ink:#1A1A1A;             /* near-black neutral */
  --burgundy:#111111;        /* deep black for logo + brand headings */
  --body-text:#404040;       /* dark gray for body copy */
  --rose-text:#6B6B6B;       /* medium gray for metadata + secondary */

  /* Brand accents */
  --brand:#A75F37;           /* copper — CTAs, buttons, interactive hover */
  --brand-deep:#8C4E28;      /* deeper copper for button hover states */
  --rose:#C4847A;            /* dusty rose — editorial accents, emphasis, signatures */
  --rose-deep:#A8625A;       /* deeper rose for hover on rose elements */
  --fb-blue:#1877F2;

  /* Lines */
  --border:rgba(0,0,0,0.1);
  --border-strong:rgba(0,0,0,0.18);

  /* Typography */
  --serif:'Gilda Display','Cormorant Garamond',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;

  /* Layout */
  --page-x:2rem;
  --max-w:90rem;

  /* Radius — soft editorial. Pills stay pill only for true pills (avatars, dots). */
  --radius-sm:0.25rem;
  --radius-card:0.5rem;
  --radius-pill:9999px;

  /* Shadow — flat, lifts only on interaction */
  --shadow-card:none;
  --shadow-card-hover:0 6px 22px rgba(41,36,33,0.07);

  --transition:250ms cubic-bezier(.4,0,.2,1);
}

/* Shared inline-SVG arrow icon — emitted by the `hwr_arrow_icon()` PHP
   helper so every CTA gets the exact same SVG markup (real DOM node,
   not a pseudo-element). This rule only handles the slide-on-hover
   transition; per-CTA hover rules below set the slide direction. */
.hwr-arrow{flex-shrink:0;transition:transform var(--transition)}

body{font-family:var(--sans);background:var(--canvas);color:var(--body-text);overflow-x:hidden;font-size:1rem;line-height:1.6;font-kerning:normal;-webkit-font-smoothing:antialiased;font-synthesis:none}
a{text-decoration:none;color:inherit}

/* === SITE CONSTRAINT === */
.section-wrap,.team-section{max-width:var(--max-w);margin-left:auto;margin-right:auto}

/* =========================================================================
   PAGE RHYTHM — white / cream / white (no more pink washes)
   ========================================================================= */
#page-home{background:var(--canvas)}
#page-home .team-section{background:var(--off-white);max-width:none;border-top:1px solid var(--border)}
#page-home .team-section .team-intro,
#page-home .team-section .leaders-row,
#page-home .team-section .team-rest-row{max-width:var(--max-w);margin-left:auto;margin-right:auto}
#page-home .about-donna-inner{background:var(--blush);border-color:rgba(196,132,122,0.22)}

/* =========================================================================
   ALERT BAR
   ========================================================================= */
.alert-bar{background:var(--rose-deep);color:#fff;text-align:center;padding:0.5rem var(--page-x);font-size:0.75rem;font-weight:500;letter-spacing:0.03em}
.alert-bar a{color:#fff;text-decoration:underline;text-underline-offset:3px;font-weight:600}
.alert-bar a:hover{opacity:0.8}

/* =========================================================================
   NAV — white, hairline, serif logo
   ========================================================================= */
.site-header{position:sticky;top:0;z-index:350;background:#fff;border-bottom:1px solid var(--border);transition:box-shadow var(--transition)}
.site-header.scrolled{box-shadow:0 1px 0 var(--border),0 6px 18px rgba(41,36,33,0.04)}
.nav-bar{display:flex;align-items:center;gap:1.5rem;padding:0 var(--page-x);height:3.75rem;max-width:var(--max-w);margin:0 auto;position:relative}
.nav-logo{display:inline-flex;align-items:center;flex-shrink:0;color:var(--ink);line-height:1;text-decoration:none;transition:color var(--transition)}
.nav-logo:hover{color:var(--brand)}
.nav-logo-mark{display:block;height:1rem;width:auto;color:inherit}
.nav-links{display:flex;align-items:center;gap:1.25rem}
.nav-link{font-family:var(--sans);font-size:0.75rem;font-weight:600;color:var(--ink);padding:1.375rem 0;background:none;border:none;display:inline-flex;align-items:center;gap:0.375rem;cursor:pointer;transition:color var(--transition);white-space:nowrap;letter-spacing:0.12em;text-transform:uppercase}
.nav-link:hover{color:var(--brand)}
.nav-link svg{opacity:0.55;transition:opacity var(--transition),transform var(--transition)}
.nav-link:hover svg{opacity:1}
.nav-dropdown-wrap:hover .nav-link,
.nav-dropdown-wrap.is-open .nav-link{color:var(--brand)}
.nav-dropdown-wrap:hover .nav-link svg,
.nav-dropdown-wrap.is-open .nav-link svg{opacity:1;transform:rotate(180deg)}

/* -- Nav Dropdowns -- */
.nav-dropdown-wrap{position:relative}
.nav-dropdown{display:none;position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--border);border-radius:0 0 var(--radius-sm) var(--radius-sm);padding:0.625rem 0;box-shadow:0 12px 32px rgba(41,36,33,0.08);z-index:1000;min-width:11rem}
.nav-dropdown-wrap:hover .nav-dropdown,
.nav-dropdown-wrap:focus-within .nav-dropdown,
.nav-dropdown-wrap.is-open .nav-dropdown{display:block}
.nav-dropdown a:not(.nav-mega-viewall){display:block;padding:0.4375rem 1.125rem;font-size:0.8125rem;color:var(--body-text);font-weight:400;transition:color 150ms,background 150ms}
.nav-dropdown a:not(.nav-mega-viewall):hover{color:var(--brand);background:var(--off-white)}

/* -- Mega Menu -- */
.nav-mega-wrap{position:static}
.nav-mega{position:absolute;top:100%;left:0;right:0;padding:1.375rem 1.75rem 1.25rem;border-radius:0 0 var(--radius-card) var(--radius-card);box-shadow:0 20px 56px rgba(41,36,33,0.12);border:1px solid var(--border);border-top:none}
.nav-mega-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:0.875rem;padding-bottom:0.875rem;border-bottom:1px solid var(--border)}
.nav-mega-eyebrow{font-family:var(--sans);font-size:0.625rem;font-weight:700;color:var(--rose);letter-spacing:0.18em;text-transform:uppercase;display:inline-flex;align-items:center;gap:0.625rem}
.nav-mega-eyebrow::before{content:'';width:1.875rem;height:1.5px;background:var(--rose);flex-shrink:0}
.nav-mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0.125rem}
.nav-mega-item{display:flex;align-items:center;justify-content:space-between;gap:0.5rem;padding:0.5rem 0.75rem;border-radius:var(--radius-sm);transition:background 180ms ease,padding 180ms ease;text-decoration:none}
.nav-mega-item:hover{background:var(--off-white);padding-left:0.875rem}
.nav-mega-name{font-family:var(--serif);font-size:0.9375rem;font-weight:400;color:var(--ink);line-height:1.2;letter-spacing:-0.005em;transition:color 150ms}
.nav-mega-item:hover .nav-mega-name{color:var(--brand)}
.nav-mega-arrow{font-family:var(--sans);font-size:0.875rem;color:var(--rose-text);opacity:0;transform:translateX(-4px);transition:opacity 180ms ease,transform 180ms ease;flex-shrink:0}
.nav-mega-item:hover .nav-mega-arrow{opacity:1;transform:translateX(0);color:var(--brand)}
.nav-mega-viewall{display:inline-flex;align-items:center;gap:0.5rem;font-family:var(--sans);font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:0.16em;color:var(--ink);background:var(--off-white);padding:0.5rem 0.875rem;border-radius:var(--radius-sm);transition:background var(--transition),color var(--transition);text-decoration:none;flex-shrink:0}
.nav-mega-viewall:hover{background:var(--ink);color:#fff}
.nav-mega-viewall:hover .hwr-arrow{transform:translateX(3px);color:#fff}
@media(max-width:64rem){
  .nav-mega-grid{grid-template-columns:repeat(3,1fr)}
  .nav-mega-name{font-size:0.9375rem}
}

/* -- Nav Search -- */
.nav-search{position:relative;margin-left:auto;width:15rem;height:2rem;flex-shrink:0}
.nav-search-icon{position:absolute;right:0.75rem;top:50%;transform:translateY(-50%);color:var(--rose-text);pointer-events:none;z-index:1}
.nav-search-input{position:absolute;right:0;top:0;width:100%;height:100%;padding:0.4375rem 2.25rem 0.4375rem 0.875rem;border:none;border-bottom:1px solid var(--border);font-family:var(--sans);font-size:0.75rem;color:var(--ink);background:transparent;outline:none;letter-spacing:0.02em;transition:border-color var(--transition)}
.nav-search-input::placeholder{color:var(--rose-text);font-weight:400;letter-spacing:0.08em;text-transform:uppercase;font-size:0.6875rem}
.nav-search-input:focus{border-bottom-color:var(--brand)}
.nav-search-input:focus-visible{outline:none;border-bottom-color:var(--brand);border-bottom-width:1.5px;padding-bottom:calc(0.4375rem - 0.5px)}

/* =========================================================================
   HOMEPAGE HERO — exact-match implementation of the client mockup.
   Cream canvas, banner image bleeds to the right viewport edge with a soft
   cream-into-image gradient on its left so there is no visible seam.
   Two cards below use the same image-right + gradient-fade pattern.
   Closes with an italic copper "Handpicked products I use and love" line.
   ========================================================================= */
.hp-hero{background:var(--canvas);padding:0}

/* Banner — contained inside max-w, tighter editorial height */
.hp-hero-banner-wrap{max-width:var(--max-w);margin:0 auto;padding:0 var(--page-x)}
.hp-hero-banner{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr);gap:0;align-items:stretch;min-height:30.5rem;border-radius:var(--radius-card);overflow:hidden;background:var(--off-white)}
.hp-hero-banner-text{padding:1.75rem 1.5rem 1.75rem 5rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;max-width:30rem;position:relative;z-index:2}
.hp-hero-eyebrow{font-family:var(--sans);font-size:0.625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.22em;color:var(--ink);margin-bottom:0.875rem}
.hp-hero-title{font-family:var(--serif);font-weight:400;font-size:clamp(1.875rem,3.75vw,3rem);color:var(--ink);line-height:1;letter-spacing:-0.015em;margin-bottom:0.875rem}
.hp-hero-divider{display:block;width:2rem;height:1.5px;background:var(--brand);margin-bottom:0.875rem}
.hp-hero-sub{font-family:var(--sans);font-size:0.875rem;color:var(--body-text);line-height:1.5;margin-bottom:1.125rem;max-width:16rem}
.hp-hero-cta{display:inline-flex;align-items:center;gap:0.5rem;font-family:var(--sans);font-size:0.625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.18em;color:#fff;background:var(--brand);padding:0.8125rem 1.125rem;border-radius:var(--radius-sm);transition:background var(--transition)}
.hp-hero-cta:hover{background:var(--brand-deep)}
.hp-hero-cta:hover .hwr-arrow{transform:translateX(3px)}

.hp-hero-banner-image{margin:0;position:relative;overflow:hidden;align-self:stretch}
.hp-hero-banner-image img{position:absolute;inset:0;display:block;width:100%;height:100%;object-fit:cover;object-position:center 2%}
.hp-hero-banner-image::before{content:'';position:absolute;inset:0;background:linear-gradient(to right,var(--off-white) 0%,var(--off-white) 4%,rgba(242,231,221,0.88) 12%,rgba(242,231,221,0.5) 22%,rgba(242,231,221,0.15) 32%,rgba(242,231,221,0) 44%);z-index:1;pointer-events:none}

/* Cards row */
.hp-hero-cards-wrap{max-width:var(--max-w);margin:0 auto;padding:0 var(--page-x)}
.hp-hero-cards{display:grid;grid-template-columns:1fr 1fr;gap:0.5rem;margin-top:0.5rem}
.hp-hero-card{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr);background:var(--off-white);border-radius:var(--radius-card);overflow:hidden;text-decoration:none;min-height:12rem;transition:transform var(--transition)}
.hp-hero-card:hover{transform:translateY(-1px)}
.hp-hero-card-text{padding:1.375rem 1rem 1.375rem 1.5rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;position:relative;z-index:2;min-width:290px}
.hp-hero-card-eyebrow{font-family:var(--sans);font-size:0.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.2em;color:var(--ink);margin-bottom:0.625rem;padding-bottom:0.4375rem;border-bottom:1px solid var(--ink);align-self:flex-start}
.hp-hero-card-title{font-family:var(--serif);font-weight:400;font-size:clamp(1.25rem,1.65vw,1.5rem);color:var(--ink);line-height:1.05;letter-spacing:-0.01em;margin-bottom:0.5rem}
.hp-hero-card-sub{font-family:var(--sans);font-size:0.75rem;color:var(--body-text);line-height:1.5;margin-bottom:0.875rem;max-width:13rem}
.hp-hero-card-cta{display:inline-flex;align-items:center;gap:0.5rem;font-family:var(--sans);font-size:0.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.18em;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:0.25rem;transition:color var(--transition),border-color var(--transition)}
.hp-hero-card:hover .hp-hero-card-cta{color:var(--brand);border-bottom-color:var(--brand)}
.hp-hero-card:hover .hp-hero-card-cta .hwr-arrow{transform:translateX(3px)}
.hp-hero-card-image{margin:0;position:relative;overflow:hidden;align-self:stretch}
.hp-hero-card-image img{display:block;width:100%;height:100%;object-fit:cover;object-position:center 20%}
.hp-hero-card-image::before{content:'';position:absolute;inset:0;background:linear-gradient(to right,var(--off-white) 0%,var(--off-white) 4%,rgba(242,231,221,0.85) 14%,rgba(242,231,221,0.4) 26%,rgba(242,231,221,0.1) 38%,rgba(242,231,221,0) 50%);z-index:1;pointer-events:none}

/* Tagline */
.hp-hero-tagline{display:flex;align-items:center;justify-content:center;gap:0.625rem;padding:1.25rem 0 0.5rem;color:var(--brand);font-family:var(--serif);font-style:italic;font-size:1.25rem;line-height:1;letter-spacing:0.005em}
.hp-hero-tagline-heart{font-style:normal;font-size:1.0625rem;line-height:1;color:var(--brand)}

/* =========================================================================
   SECTION HEAD — editorial magazine style
   ========================================================================= */
.section-wrap{padding:4.5rem var(--page-x)}
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:0.5rem;gap:1.5rem;flex-wrap:wrap}
.section-head h2{font-family:var(--serif);font-size:clamp(2rem,3.25vw,2.75rem);font-weight:400;color:var(--ink);line-height:1.05;letter-spacing:-0.005em}
.section-head h2 em{color:var(--rose);font-style:normal}
.section-sub{font-size:0.9375rem;color:var(--rose-text);margin-bottom:2rem;line-height:1.6;max-width:42rem;font-family:var(--sans)}
.see-all{display:inline-flex;align-items:center;gap:0.5rem;font-family:var(--sans);font-size:0.8125rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:#fff;background:var(--brand);padding:0.875rem 1.5rem;border-radius:var(--radius-sm);text-decoration:none;border:none;box-shadow:0 1px 0 rgba(0,0,0,0.04);transition:background var(--transition),transform var(--transition),box-shadow var(--transition)}
.see-all::after{content:"\2192";font-size:1rem;display:inline-block;transition:transform var(--transition)}
.see-all:hover{background:var(--brand-deep);color:#fff;box-shadow:0 4px 12px rgba(167,95,55,0.25);transform:translateY(-1px)}
.see-all:hover::after{transform:translateX(4px)}
.see-all:focus-visible{outline:2px solid var(--brand-deep);outline-offset:3px}

/* Eyebrow (used on about page) */
.eyebrow{font-size:0.6875rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--rose);font-weight:600;margin-bottom:0.75rem;display:flex;align-items:center;gap:0.625rem}
.eyebrow::before{content:'';width:1.875rem;height:1.5px;background:var(--rose)}

/* =========================================================================
   FEATURED STAFF PICKS — horizontal scroll of editorial pick-cards
   4 cards fill the view; the 5th peeks ~3rem on the right as a scroll cue
   ========================================================================= */
.featured-section{padding-bottom:1.5rem}
.featured-scroll-wrap{position:relative;margin-top:1.5rem}
/* right-edge fade gradient — suggests more content beyond */
.featured-scroll-wrap::after{content:'';position:absolute;top:0;right:0;bottom:1rem;width:4rem;background:linear-gradient(to right,transparent,#fff 80%);pointer-events:none;z-index:5}
.featured-picks-row{display:flex;gap:1.25rem;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;padding:0.25rem 0 1rem}
.featured-picks-row::after{content:'';flex:0 0 1rem;align-self:stretch}
.featured-picks-row::-webkit-scrollbar{display:none}
/* Cards stay between 15rem (cramped floor) and 18rem (max), tracking ~23% of container.
   Result: 4 cards on wide desktop, 3-4 on small desktop, 2-3 on tablet — never squeezed. */
.featured-picks-row .pick-card{flex:0 0 clamp(15rem, 23%, 18rem);scroll-snap-align:start;animation:none;min-width:0}
.scroll-arrow{position:absolute;top:calc(50% - 0.5rem);transform:translateY(-50%);z-index:10;width:2.5rem;height:2.5rem;border-radius:50%;background:#fff;border:1px solid var(--border);box-shadow:0 2px 12px rgba(41,36,33,0.14),0 0 0 1px rgba(41,36,33,0.06);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);color:var(--ink)}
.scroll-arrow:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.scroll-arrow:active{transform:translateY(-50%) scale(0.94)}
.scroll-left{left:-0.75rem}
.scroll-right{right:-0.75rem}
.featured-scroll-wrap.no-scroll::after{display:none}
/* No-scroll mode (≤4 items): grid on wide screens, real carousel below tablet. */
.no-scroll .featured-picks-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));gap:1.25rem;overflow:visible;scroll-snap-type:none;padding:0.25rem 0 0}
.no-scroll .featured-picks-row::after{content:none}
.no-scroll .featured-picks-row .pick-card{flex:initial;width:auto;min-width:0;max-width:18rem;scroll-snap-align:none}
/* Hide arrows in grid mode — they're only useful when the row scrolls. */
.no-scroll .scroll-arrow{display:none}

/* Below wide desktop: no-scroll mode becomes a swipeable carousel.
   Threshold is 80rem because that's the smallest width where 4 cards reliably fit in one row;
   below that the auto-fit grid produces awkward 3+1 / 2+2 wraps. */
@media(max-width:80rem){
  .no-scroll .featured-picks-row{display:flex;grid-template-columns:none;gap:1.25rem;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;padding:0.25rem 0 1rem}
  .no-scroll .featured-picks-row::after{content:'';flex:0 0 1rem;align-self:stretch}
  .no-scroll .featured-picks-row::-webkit-scrollbar{display:none}
  .no-scroll .featured-picks-row .pick-card{flex:0 0 clamp(15rem,30%,18rem);scroll-snap-align:start}
  .no-scroll .scroll-arrow{display:flex}
  .featured-scroll-wrap.no-scroll::after{content:'';display:block;position:absolute;top:0;right:0;bottom:1rem;width:4rem;background:linear-gradient(to right,transparent,#fff 80%);pointer-events:none;z-index:5}
}
@media(max-width:48rem){
  .no-scroll .featured-picks-row .pick-card{flex:0 0 85%}
}

/* =========================================================================
   CATEGORY TILES — magazine-style, text-forward, typography-led
   ========================================================================= */
.category-section{background:var(--off-white);padding:5rem 0 5.5rem;width:100%}
.category-section-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--page-x)}
.category-section .section-head{margin-bottom:2.25rem}
.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.category-tile{position:relative;aspect-ratio:4/5;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;text-align:center;padding:1.75rem 1.25rem;color:#fff;text-decoration:none;background-color:var(--ink);isolation:isolate;border-radius:var(--radius-card)}
.category-tile-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 700ms cubic-bezier(0.2,0.7,0.2,1)}
.category-tile-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(41,36,33,0) 35%,rgba(41,36,33,0.55) 72%,rgba(41,36,33,0.88) 100%);transition:background var(--transition)}
.category-tile:hover .category-tile-image{transform:scale(1.06)}
.category-tile:hover .category-tile-overlay{background:linear-gradient(180deg,rgba(41,36,33,0.05) 25%,rgba(41,36,33,0.6) 65%,rgba(41,36,33,0.92) 100%)}
.category-tile-name,.category-tile-subtitle,.category-tile-divider,.category-tile-arrow{position:relative;z-index:1;width:100%}
.category-tile-name{font-family:var(--serif);font-weight:400;font-size:clamp(1.5rem,2.25vw,1.875rem);color:#fff;line-height:1.05;letter-spacing:-0.005em;text-shadow:0 1px 18px rgba(0,0,0,0.25)}
.category-tile-subtitle{font-family:var(--sans);font-size:0.6875rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.92);margin-top:0.625rem;line-height:1.4}
.category-tile-divider{display:flex;align-items:center;justify-content:center;gap:0.625rem;margin:0.875rem 0 0.625rem}
.category-tile-divider::before,.category-tile-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,0.55);max-width:3rem}
.category-tile-divider svg{width:12px;height:12px;color:rgba(255,255,255,0.95);flex-shrink:0}
.category-tile-arrow{font-family:var(--sans);font-size:0.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:0.18em;color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;opacity:0.92}
.category-tile:hover .category-tile-arrow .hwr-arrow{transform:translateX(4px)}
.category-tile:hover .category-tile-arrow{opacity:1}

/* =========================================================================
   RETAILER STRIP — quiet wordmark row
   ========================================================================= */
.retailer-strip{background:var(--canvas);border-bottom:1px solid var(--border);padding:2rem var(--page-x)}
.retailer-strip-inner{max-width:var(--max-w);margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:2.5rem 3rem}
.retailer-label{font-family:var(--sans);font-size:0.625rem;text-transform:uppercase;letter-spacing:0.22em;color:var(--rose-text);font-weight:600;white-space:nowrap}
.retailer-wordmark{font-family:var(--serif);font-weight:400;font-size:clamp(1.125rem,1.5vw,1.375rem);color:var(--ink);letter-spacing:-0.01em;text-decoration:none;transition:color var(--transition),opacity var(--transition);opacity:0.7}
.retailer-wordmark:hover{color:var(--brand);opacity:1}

/* ============================================================
   Archive — top filter bar with dropdown facets
   ============================================================ */
.archive-empty{text-align:center;padding:4rem 1rem;color:var(--rose-text);font-family:var(--serif);font-size:1.125rem}

/* Bar wrapper — block container; the filter-bar-row inside lays out the
   pills (left) and meta (right). A second row, .filter-bar-chips, sits
   below it whenever any filter is active. */
.filter-bar{margin:0 0 1.75rem;padding:0 0 1rem;border-bottom:1px solid var(--border);font-family:var(--sans)}
.filter-bar-row{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}
.filter-bar-pills{display:flex;align-items:center;gap:0.5rem;flex-wrap:wrap;min-width:0}
.filter-bar-meta{display:flex;align-items:center;gap:1rem;flex-shrink:0;margin-left:auto}
.filter-bar-count{font-size:0.6875rem;text-transform:uppercase;letter-spacing:0.14em;color:var(--rose-text);font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}
.filter-bar-clear{font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--brand);text-decoration:none;border-bottom:1px solid transparent;padding-bottom:1px;transition:border-color var(--transition);white-space:nowrap}
.filter-bar-clear:hover{border-bottom-color:var(--brand)}

/* Facet pill — always shows its default label ("Category"). When at least
   one option is checked, .is-set adds a count badge but the pill stays
   visually quiet so the chip row below carries the "what's selected" job. */
.filter-pill{position:relative}
.filter-pill-btn{display:inline-flex;align-items:center;gap:0.4375rem;background:#fff;border:1px solid var(--border);border-radius:999px;padding:0 0.875rem;min-height:2rem;cursor:pointer;list-style:none;font-size:0.8125rem;color:var(--ink);line-height:1.25;transition:border-color var(--transition),background var(--transition),box-shadow var(--transition);user-select:none}
.filter-pill-btn::-webkit-details-marker{display:none}
.filter-pill-btn:hover{border-color:var(--ink);background:var(--off-white)}
.filter-pill-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.filter-pill[open] > .filter-pill-btn{border-color:var(--ink);background:var(--off-white);box-shadow:0 1px 2px rgba(41,36,33,0.04)}
.filter-pill.is-set > .filter-pill-btn{border-color:var(--ink)}

.filter-pill-label{font-weight:inherit}
.filter-pill-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.125rem;height:1.125rem;padding:0 0.3125rem;border-radius:999px;background:var(--brand);color:#fff;font-size:0.6875rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1}
.filter-pill-chevron{color:currentColor;opacity:0.7;transition:transform 200ms ease;flex-shrink:0}
.filter-pill[open] > .filter-pill-btn .filter-pill-chevron{transform:rotate(180deg)}

/* Popover form — checkboxes inside; submitting applies all selected at
   once. Without JS the form GETs ?cat[]=…&store[]=…; main.js hijacks
   submit and rewrites to ?cat=fashion,beauty for cleaner URLs. */
.filter-pop{position:absolute;top:calc(100% + 0.5rem);left:0;z-index:60;min-width:15rem;max-width:min(20rem,calc(100vw - 2rem));background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:0 12px 32px rgba(41,36,33,0.12);padding:0.375rem;animation:filterPopIn 160ms ease;display:flex;flex-direction:column;gap:0.375rem}
@keyframes filterPopIn{from{opacity:0;transform:translateY(-4px)} to{opacity:1;transform:translateY(0)}}
.filter-pop-list{list-style:none;padding:0;margin:0;max-height:18rem;overflow-y:auto;display:flex;flex-direction:column;gap:0.0625rem}

.filter-opt{display:flex;align-items:center;gap:0.625rem;padding:0.4375rem 0.625rem;border-radius:var(--radius-sm);font-size:0.8125rem;color:var(--body-text);transition:background var(--transition),color var(--transition);line-height:1.3;cursor:pointer}
.filter-opt:hover{background:var(--off-white);color:var(--ink)}
.filter-opt input[type="checkbox"]{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.filter-opt-check{display:inline-flex;align-items:center;justify-content:center;width:1rem;height:1rem;border:1.5px solid var(--border-strong);border-radius:0.25rem;background:#fff;color:#fff;flex-shrink:0;transition:background var(--transition),border-color var(--transition)}
.filter-opt-check svg{opacity:0;transition:opacity 120ms ease}
.filter-opt-label{flex:1;min-width:0;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}
.filter-opt-count{font-size:0.6875rem;color:var(--rose-text);font-variant-numeric:tabular-nums;flex-shrink:0}
.filter-opt.is-checked,
.filter-opt:has(input[type="checkbox"]:checked){background:var(--off-white);color:var(--ink);font-weight:600}
.filter-opt.is-checked .filter-opt-count,
.filter-opt:has(input[type="checkbox"]:checked) .filter-opt-count{color:var(--brand)}
.filter-opt.is-checked .filter-opt-check,
.filter-opt:has(input[type="checkbox"]:checked) .filter-opt-check{background:var(--ink);border-color:var(--ink)}
.filter-opt.is-checked .filter-opt-check svg,
.filter-opt:has(input[type="checkbox"]:checked) .filter-opt-check svg{opacity:1}
.filter-opt input[type="checkbox"]:focus-visible + .filter-opt-check{outline:2px solid var(--brand);outline-offset:2px}

/* Footer of the popover. With JS the Apply button is hidden (CSS rule
   below) and changes auto-submit after a short debounce, so only Clear
   remains and right-aligns itself. Without JS, Apply stays visible to
   the right of Clear so the form is still submittable. */
.filter-pop-actions{display:flex;align-items:center;justify-content:flex-end;gap:0.625rem;padding:0.5rem 0.5rem 0.25rem;border-top:1px solid var(--border)}
.filter-pop-clear{font-size:0.75rem;font-weight:600;color:var(--rose-text);text-decoration:underline;text-decoration-color:transparent;text-underline-offset:2px;transition:color var(--transition),text-decoration-color var(--transition)}
.filter-pop-clear:hover{color:var(--ink);text-decoration-color:currentColor}
.filter-pop-clear.is-disabled{opacity:0.4;text-decoration:none;cursor:default}
html.js .filter-pop-apply{display:none}
.filter-pop-apply{background:var(--ink);color:#fff;border:0;border-radius:999px;padding:0.4375rem 1rem;font:inherit;font-size:0.75rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;cursor:pointer;transition:background var(--transition)}
.filter-pop-apply:hover{background:#3a302c}
.filter-pop-apply:focus-visible{outline:2px solid var(--brand);outline-offset:2px}

/* Chip row — one chip per individual selected value; clicking a chip's
   × removes only that value (precomputed server-side). Sits as its own
   row beneath .filter-bar-row, so users see exactly what's applied.
   The × is a plain glyph (no badge background) at ~55% opacity, going
   to full on hover — same pattern as Material chips, Antd tags, etc. */
.filter-bar-chips{display:flex;align-items:center;gap:0.4375rem;flex-wrap:wrap;margin-top:0.875rem}
.filter-chip{display:inline-flex;align-items:center;gap:0.5rem;background:var(--ink);color:#fff;border-radius:999px;padding:0.375rem 0.75rem 0.375rem 0.875rem;font-size:0.75rem;font-weight:600;line-height:1;text-decoration:none;transition:background var(--transition)}
.filter-chip:hover{background:#3a302c;color:#fff}
.filter-chip:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.filter-chip-x{display:inline-flex;align-items:center;justify-content:center;width:0.875rem;height:0.875rem;color:#fff;opacity:0.55;transition:opacity var(--transition),transform var(--transition);flex-shrink:0}
.filter-chip:hover .filter-chip-x{opacity:1;transform:rotate(90deg)}

/* Archive grid — stacked specificity (.picks-grid.picks-grid--archive) so this
   rule wins over the generic .picks-grid declarations and their @media overrides
   defined later in the file. */
.picks-grid.picks-grid--archive{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(16rem,1fr));
  justify-content:start;
  gap:1.75rem 1.25rem;
  container-type:inline-size;
  container-name:archive-grid;
}

/* ----- Mobile: meta drops below the pills, popovers can grow ----- */
@media(max-width:48rem){
  .filter-bar-row{gap:0.625rem}
  .filter-bar-meta{margin-left:0;width:100%;justify-content:space-between;padding-top:0.5rem;border-top:1px dashed var(--border)}
  .filter-pill-btn{padding:0 0.75rem;font-size:0.75rem;min-height:1.875rem}
  .filter-pop{min-width:13rem;max-width:calc(100vw - 1.5rem)}
  .filter-pop-list{max-height:55vh}
  .filter-bar-chips{margin-top:0.625rem}
}

/* ----- Phone (≤ 32rem): popover becomes a bottom sheet -----
   Anchored-to-pill popovers overflow horizontally on narrow screens
   when the pill is mid- or right-aligned. The bottom-sheet pattern
   is the mobile standard for filter UI (Etsy, Nordstrom, ASOS,
   Airbnb): full-width, fixed to bottom, backdrop, slide-up. The
   ::before drag-handle is purely decorative; tapping the backdrop
   closes via the existing outside-click handler in main.js. */
@media(max-width:32rem){
  .filter-pill[open]>.filter-pop{
    position:fixed;
    inset:auto 0 0 0;
    top:auto;
    z-index:100;
    width:100%;
    max-width:100%;
    min-width:0;
    margin:0;
    padding:0.75rem 1rem max(1rem,env(safe-area-inset-bottom));
    border-radius:1.25rem 1.25rem 0 0;
    border-bottom:0;
    box-shadow:0 -8px 32px rgba(41,36,33,0.18);
    animation:filterSheetIn 240ms cubic-bezier(0.2,0.8,0.2,1);
    gap:0.5rem;
  }
  .filter-pill[open]>.filter-pop::before{
    content:'';
    display:block;
    width:2.5rem;
    height:0.25rem;
    background:rgba(41,36,33,0.18);
    border-radius:999px;
    margin:0 auto 0.5rem;
  }
  .filter-pill[open]>.filter-pop .filter-pop-list{max-height:55vh}
  .filter-pill[open]>.filter-pop .filter-opt{padding:0.625rem;font-size:0.9375rem}
  .filter-pill[open]>.filter-pop .filter-pop-actions{padding:0.625rem 0.25rem 0;justify-content:space-between}
  .filter-pill[open]>.filter-pop .filter-pop-clear{font-size:0.8125rem}

  /* Scrim — pointer-events:none lets the tap fall through to <body>,
     where main.js's outside-click handler closes the open pill. */
  body:has(.filter-pill[open])::before{
    content:'';
    position:fixed;
    inset:0;
    background:rgba(41,36,33,0.45);
    z-index:99;
    animation:filterScrimIn 200ms ease;
    pointer-events:none;
  }
  body:has(.filter-pill[open]){overflow:hidden}
}

@keyframes filterSheetIn{
  from{transform:translateY(100%)}
  to{transform:translateY(0)}
}
@keyframes filterScrimIn{
  from{opacity:0}
  to{opacity:1}
}
@media(prefers-reduced-motion:reduce){
  .filter-pill[open]>.filter-pop{animation:none}
  body:has(.filter-pill[open])::before{animation:none}
}

/* ============================================================
   Filter loading state — top progress bar + dimmed cards
   ============================================================
   When the user toggles a filter, JS adds body.is-filter-loading and
   appends #hwr-loading-bar. The bar is a thin indeterminate progress
   indicator at the very top of the viewport (Linear/Vercel pattern);
   the cards under it dim slightly to signal "stale" content without
   any layout shift or content swap. */
.hwr-loading-bar{position:fixed;top:0;left:0;right:0;height:2px;background:rgba(160,100,80,0.12);z-index:9999;overflow:hidden;pointer-events:none}
.hwr-loading-bar::before{content:'';position:absolute;top:0;left:-40%;width:40%;height:100%;background:linear-gradient(90deg,transparent,var(--brand),transparent);animation:hwr-loading-bar 1.1s ease-in-out infinite}
@keyframes hwr-loading-bar{
  0%{left:-40%}
  100%{left:100%}
}
.is-filter-loading .filter-bar{pointer-events:none;opacity:0.7;transition:opacity 200ms ease}
.is-filter-loading .archive-pagination{opacity:0.4;pointer-events:none;transition:opacity 200ms ease}
.is-filter-loading .picks-grid--archive{pointer-events:none}
.is-filter-loading .picks-grid--archive>.pick-card{opacity:0.45;transition:opacity 220ms ease}
.is-filter-loading .picks-grid--archive>.pick-card:hover{transform:none;border-color:var(--border);box-shadow:none}
@media(prefers-reduced-motion:reduce){
  .hwr-loading-bar::before{animation:none;left:0;width:100%;opacity:0.55}
  .is-filter-loading .picks-grid--archive>.pick-card{transition:none}
}

/* =========================================================================
   FIND CARDS — soft 8px radius, hairline border, no shadow at rest
   ========================================================================= */
.picks-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem 1.75rem}
.pick-card{background:#fff;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-card);transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition);display:flex;flex-direction:column}
.pick-card:hover{transform:translateY(-3px);border-color:var(--border-strong);box-shadow:var(--shadow-card-hover)}
.card-img-wrap{width:100%;height:12rem;position:relative;overflow:hidden;background:var(--cream)}
.card-img-wrap::before{content:"";position:absolute;inset:-10px;background:var(--card-bg-img) center/cover no-repeat;filter:blur(20px) saturate(1.2);opacity:0.45;z-index:0}
.featured-picks-row .card-img-wrap{height:10rem}
.card-badge-promoted{position:absolute;top:0.75rem;left:0.75rem;font-size:0.625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;background:var(--ink);color:#fff;padding:0.25rem 0.6875rem;border-radius:var(--radius-sm);z-index:2}
.card-photo{width:100%;height:100%;object-fit:contain;display:block;position:relative;z-index:1}
.card-img-link{display:block;text-decoration:none;color:inherit}

/* Card body uses gap for spacing so the rhythm holds whether or not
   .card-note is rendered. Children no longer carry their own
   margin-bottom — gap is the single source of truth. */
.card-body{flex:1;display:flex;flex-direction:column;gap:0.625rem;padding:1rem 1.125rem 1rem;min-width:0}
.picks-grid .card-body{padding:1.25rem 1.25rem 1rem}
.card-title-link{text-decoration:none;color:inherit}
.card-title-link:hover .card-title{color:var(--brand)}

/* Unified meta line — store · category, both linked, same muted
   uppercase treatment so they read as a coherent breadcrumb above
   the title rather than two unrelated chunks. */
.card-meta{display:flex;align-items:center;gap:0.4375rem;font-size:0.625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.14em;color:var(--muted);min-width:0;line-height:1.2}
.card-meta-link{color:inherit;text-decoration:none;transition:color var(--transition);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.card-meta-link:hover{color:var(--brand)}
.card-meta-sep{opacity:0.45;flex-shrink:0}

.card-time{font-size:0.625rem;color:var(--rose-text);display:inline-flex;align-items:center;gap:0.375rem;letter-spacing:0.04em}
.recency-dot{width:0.375rem;height:0.375rem;border-radius:50%;background:var(--rose);flex-shrink:0;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
.card-title{font-family:var(--sans);font-size:1rem;font-weight:600;line-height:1.3;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;letter-spacing:-0.01em}
.card-note{font-size:0.8125rem;color:var(--rose-text);line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.cta-btn{display:inline-flex;align-items:center;justify-content:center;gap:0.375rem;background:var(--ink);border:1px solid var(--ink);border-radius:var(--radius-sm);padding:0.5625rem 1.125rem;font-size:0.6875rem;color:#fff;cursor:pointer;font-family:var(--sans);font-weight:700;transition:all var(--transition);text-align:center;letter-spacing:0.14em;text-transform:uppercase;flex-shrink:0;align-self:flex-start;text-decoration:none;white-space:nowrap}

/* Pin the CTA to the bottom of the body (so all CTAs in a row line
   up even when notes/excerpts vary in length). margin-top:auto
   consumes the remaining flex space; the gap above keeps a minimum
   breathing room from the preceding sibling — so even cards without
   .card-note get sensible space between title and CTA. */
.card-body>.cta-btn{margin-top:auto;align-self:flex-start}
.card-actions .cta-btn{padding:0.5rem 0.875rem;font-size:0.625rem}
.cta-btn:hover{background:var(--brand);border-color:var(--brand);color:#fff}
.cta-btn:hover .hwr-arrow{transform:translateX(3px)}
.cta-btn:active{transform:scale(0.97)}

/* -- Card Actions Row (CTA + Promo Code inline) -- */
.card-actions{display:flex;align-items:center;gap:0.5rem;margin-top:auto;flex-wrap:nowrap;justify-content:space-between}
.promo-code-pill{display:inline-flex;align-items:stretch;border:1px dashed var(--border-strong);border-radius:var(--radius-sm);overflow:hidden;background:#fff;height:1.875rem;flex-shrink:1;min-width:0}
.promo-code-value{font-family:var(--sans);font-size:0.625rem;font-weight:700;color:var(--ink);padding:0 0.5rem;letter-spacing:0.06em;line-height:1.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.promo-copy-btn{background:var(--off-white);color:var(--ink);border:none;border-left:1px dashed var(--border-strong);padding:0 0.625rem;font-family:var(--sans);font-size:0.5625rem;font-weight:700;cursor:pointer;transition:background 200ms,color 200ms;letter-spacing:0.1em;text-transform:uppercase;flex-shrink:0}
.promo-copy-btn:hover{background:var(--ink);color:#fff}
.promo-copy-btn:active{transform:scale(0.96)}
.promo-copy-btn.ok{background:#16a34a;color:#fff;border-left-color:#16a34a}

.posted-by{display:flex;align-items:center;gap:0.5rem;padding:0.875rem 1.25rem 1rem;margin-top:auto;position:relative}
.posted-by::before{content:'';position:absolute;top:0;left:1.25rem;right:1.25rem;height:1px;background:var(--border)}
.poster-avatar{width:1.75rem;height:1.75rem;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border)}
.poster-name{font-family:var(--sans);font-size:0.8125rem;font-weight:600;color:var(--ink);letter-spacing:0.005em}
.poster-role{font-size:0.5625rem;color:var(--rose-text);letter-spacing:0.08em;text-transform:uppercase;font-weight:600;margin-top:0.0625rem}

/* =========================================================================
   NEWSLETTER CTA — editorial pull-quote, full-width band above footer
   ========================================================================= */
.newsletter-cta-section{padding:5.5rem var(--page-x);background:var(--blush);border-top:1px solid rgba(196,132,122,0.25);border-bottom:1px solid rgba(196,132,122,0.25)}
.newsletter-cta-inner{max-width:36rem;margin:0 auto;text-align:center}
.newsletter-cta-inner .eyebrow{justify-content:center}
.newsletter-cta-headline{font-family:var(--serif);font-size:clamp(2.25rem,4vw,3.25rem);font-weight:400;color:var(--ink);line-height:1.05;letter-spacing:-0.015em;margin:0 0 0.875rem}
.newsletter-cta-headline em{color:var(--rose);font-style:italic}
.newsletter-cta-sub{font-size:1rem;color:var(--rose-text);line-height:1.55;margin:0 auto 2rem;max-width:32rem}
.newsletter-cta-form{max-width:30rem;margin:0 auto}
.newsletter-cta-fields{display:flex;gap:0;width:100%}
.newsletter-cta-fields input{flex:1;border:1px solid rgba(196,132,122,0.5);border-right:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm);outline:none;padding:0.875rem 1.125rem;background:#fff;color:var(--ink);font-family:var(--sans);font-size:0.9375rem;min-width:0;transition:border-color var(--transition)}
.newsletter-cta-fields input::placeholder{color:var(--rose-text);letter-spacing:0.03em}
.newsletter-cta-fields input:focus{border-color:var(--brand)}
.newsletter-cta-fields input:focus + button{border-color:var(--brand);background:var(--brand)}
.newsletter-cta-fields button{background:var(--ink);color:#fff;border:1px solid var(--ink);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:0.875rem 1.75rem;font-size:0.75rem;font-family:var(--sans);font-weight:700;cursor:pointer;letter-spacing:0.18em;text-transform:uppercase;transition:all var(--transition);white-space:nowrap}
.newsletter-cta-fields button:hover{background:var(--brand);border-color:var(--brand)}
.newsletter-cta-fields button:active{transform:scale(0.97)}
.newsletter-cta-fields input:disabled{background:rgba(255,255,255,0.55);border-color:rgba(0,0,0,0.12);color:var(--rose-text);cursor:not-allowed}
.newsletter-cta-fields input:disabled::placeholder{color:rgba(0,0,0,0.3)}
.newsletter-cta-fields button:disabled{background:rgba(0,0,0,0.3);border-color:rgba(0,0,0,0.12);color:rgba(255,255,255,0.7);cursor:not-allowed;transform:none}
.newsletter-cta-fields button:disabled:hover{background:rgba(0,0,0,0.3);border-color:rgba(0,0,0,0.12)}
.newsletter-cta-trust{font-size:0.75rem;color:var(--rose-text);line-height:1.5;margin:0.875rem 0 0;letter-spacing:0.02em}
.newsletter-cta-trust strong{color:var(--ink);font-weight:700}
.newsletter-cta-secondary{position:relative;margin-top:1rem;min-height:2.875rem}
.newsletter-cta-secondary .capture-phone-reveal{position:absolute;inset:0;margin-top:0;display:flex;align-items:center;justify-content:center}
.newsletter-cta-secondary .capture-phone-reveal .newsletter-cta-fields{width:100%}
.newsletter-cta-flourish{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;margin:0;font-family:var(--serif);font-size:0.9375rem;color:var(--rose);letter-spacing:0.01em;transition:opacity 320ms ease;pointer-events:none}
.newsletter-cta-flourish em{font-style:italic;color:var(--rose)}
.newsletter-cta-secondary .capture-phone-reveal.revealed ~ .newsletter-cta-flourish{opacity:0}
.sms-opt-in{display:flex;align-items:center;gap:0.4375rem;font-size:0.75rem;color:var(--rose-text);margin-top:0.625rem;cursor:pointer;transition:color var(--transition)}
.sms-opt-in:hover{color:var(--ink)}
.sms-opt-in input[type="checkbox"]{accent-color:var(--brand);width:0.875rem;height:0.875rem;cursor:pointer}

/* =========================================================================
   TEAM SECTION
   ========================================================================= */
.team-section{padding:4.5rem var(--page-x);background:var(--off-white);border-top:1px solid var(--border)}
.team-intro{text-align:center;margin-bottom:2.5rem}
.team-intro h2{font-family:var(--serif);font-size:clamp(2rem,3.25vw,2.75rem);font-weight:400;color:var(--ink);margin-bottom:0.5rem;line-height:1.05;letter-spacing:-0.005em}
.team-intro h2 em{font-family:'Sacramento',cursive;font-style:normal;color:var(--rose);font-size:1.15em;letter-spacing:0.02em}
.team-intro p{font-size:0.9375rem;color:var(--rose-text);max-width:34rem;margin:0 auto;line-height:1.6;font-family:var(--sans)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.team-card{background:#fff;padding:1.75rem 1.25rem;text-align:center;border:1px solid var(--border);transition:transform var(--transition),box-shadow var(--transition)}
.team-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card-hover)}
.team-avatar{width:4.5rem;height:4.5rem;border-radius:50%;object-fit:cover;margin:0 auto 0.75rem;display:block;border:1px solid var(--border)}
.team-name{font-family:var(--serif);font-size:1.0625rem;font-weight:400;color:var(--ink);margin-bottom:0.25rem;letter-spacing:0}
.team-role{font-size:0.625rem;color:var(--rose);font-weight:700;text-transform:uppercase;letter-spacing:0.14em;margin-bottom:0.375rem}
.team-badge{font-size:0.75rem;color:var(--rose-text);line-height:1.5}
.team-more{display:flex;justify-content:center;margin-top:1.5rem}
.meet-team-link{font-size:0.6875rem;color:var(--ink);font-weight:700;letter-spacing:0.16em;text-transform:uppercase;transition:color var(--transition);border-bottom:1px solid var(--ink);padding-bottom:0.25rem}
.meet-team-link:hover{color:var(--brand);border-bottom-color:var(--brand)}

/* =========================================================================
   ABOUT DONNA (homepage)
   ========================================================================= */
.about-donna-section{padding:2rem var(--page-x) 3rem;background:transparent;border:none;border-radius:0;margin:0}
.about-donna-inner{background:var(--blush);border:1px solid rgba(196,132,122,0.18);border-radius:1.5rem;padding:3rem;max-width:72rem;margin:0 auto;display:flex;align-items:center;gap:3rem}
.about-donna-photo{flex-shrink:0;width:8.5rem}
.about-donna-photo img{width:8.5rem;height:13rem;object-fit:cover;object-position:center 8%;border-radius:50%;border:none;box-shadow:0 0 0 4px var(--blush),0 0 0 7px var(--rose),0 6px 24px rgba(167,95,55,0.2)}
.about-donna-content{flex:1;max-width:44rem}
.about-donna-content .eyebrow{margin-bottom:0.875rem}
.about-donna-content h2{font-family:var(--serif);font-size:clamp(1.625rem,2.5vw,2.125rem);font-weight:400;color:var(--ink);margin-bottom:0.875rem;line-height:1.1;letter-spacing:-0.005em}
.about-donna-content h2 em{color:var(--rose);font-style:normal}
.about-donna-content p:not(.donna-signature){font-size:0.9rem;color:var(--body-text);line-height:1.65;margin-bottom:0.375rem}
.donna-signature{font-family:'Sacramento',cursive;font-size:2rem;color:var(--rose-deep);line-height:1;margin-top:1.25rem;margin-bottom:1.25rem;letter-spacing:0.03em}
.about-donna-link{display:inline-flex;align-items:center;gap:0.375rem;font-size:0.6875rem;font-weight:700;color:var(--body-text);transition:color var(--transition),border-color var(--transition);letter-spacing:0.14em;text-transform:uppercase;border:none;border-bottom:1px solid var(--border-strong);padding-bottom:0.125rem}
.about-donna-link:hover{color:var(--brand);border-bottom-color:var(--brand)}
.about-donna-link:hover .hwr-arrow{transform:translateX(3px)}

/* =========================================================================
   STICKY NEWSLETTER — more visible on load (Donna's "in your face" note),
   rose surface, rounded top corners
   ========================================================================= */
.sticky-newsletter-backdrop{position:fixed;inset:0;background:rgba(26,26,26,0.45);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:189;cursor:pointer;animation:stickyBackdropIn 400ms ease both}
.sticky-newsletter-backdrop.dismissing{animation:stickyBackdropOut 350ms ease forwards}
@keyframes stickyBackdropIn{from{opacity:0}to{opacity:1}}
@keyframes stickyBackdropOut{from{opacity:1}to{opacity:0}}
.sticky-newsletter{position:fixed;bottom:0;left:0;right:0;z-index:190;background:var(--off-white);border-top:1px solid rgba(196,132,122,0.5);box-shadow:0 -12px 40px rgba(0,0,0,0.18);transform:translateY(0);opacity:1;transition:transform 300ms cubic-bezier(.4,0,.2,1),opacity 300ms cubic-bezier(.4,0,.2,1);animation:slideUp 400ms cubic-bezier(.4,0,.2,1) both}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes slideDown{from{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:0}}
.sticky-newsletter.dismissing{animation:slideDown 350ms cubic-bezier(.4,0,.2,1) forwards}
.sticky-newsletter-inner{max-width:24rem;margin:0 auto;padding:1.625rem var(--page-x) 1.75rem;display:flex;flex-direction:column;align-items:center;text-align:center}
.sticky-newsletter-avatar{width:2.75rem;height:2.75rem;border-radius:50%;object-fit:cover;border:1px solid rgba(196,132,122,0.4);box-shadow:0 0 0 3px var(--off-white),0 0 0 4px var(--rose);margin-bottom:0.875rem}
.sticky-newsletter-headline{font-family:var(--serif);font-weight:400;font-size:clamp(1.375rem,2.25vw,1.625rem);color:var(--ink);line-height:1.15;letter-spacing:-0.005em;margin:0 0 0.375rem}
.sticky-newsletter-headline em{color:var(--rose);font-style:italic}
.sticky-newsletter-sub{font-family:var(--sans);font-size:0.8125rem;color:var(--rose-text);line-height:1.5;margin:0 0 1.125rem;max-width:20rem}
.sticky-newsletter-form{width:100%;display:flex;flex-direction:column}
.sticky-newsletter-input{display:block;width:100%;border:1px solid rgba(196,132,122,0.5);border-radius:var(--radius-sm);outline:none;padding:0.75rem 0.875rem;background:#fff;color:var(--ink);font-family:var(--sans);font-size:0.875rem;transition:border-color var(--transition);margin-bottom:0.5rem}
.sticky-newsletter-input::placeholder{color:var(--rose-text);letter-spacing:0.02em}
.sticky-newsletter-input:focus{border-color:var(--brand)}
.sticky-newsletter-input:disabled{background:rgba(255,255,255,0.55);border-color:rgba(0,0,0,0.12);color:var(--rose-text);cursor:not-allowed}
.sticky-newsletter-input:disabled::placeholder{color:rgba(0,0,0,0.3)}
.sticky-newsletter-cta{display:block;width:100%;background:var(--ink);color:#fff;border:1px solid var(--ink);border-radius:var(--radius-sm);padding:0.75rem 1rem;font-size:0.6875rem;font-family:var(--sans);font-weight:700;cursor:pointer;letter-spacing:0.18em;text-transform:uppercase;transition:all var(--transition)}
.sticky-newsletter-cta:hover{background:var(--brand);border-color:var(--brand)}
.sticky-newsletter-cta:active{transform:scale(0.98)}
.sticky-newsletter-cta:disabled{background:rgba(0,0,0,0.3);border-color:rgba(0,0,0,0.12);color:rgba(255,255,255,0.7);cursor:not-allowed;transform:none}
.sticky-newsletter-cta:disabled:hover{background:rgba(0,0,0,0.3);border-color:rgba(0,0,0,0.12)}
.sticky-newsletter-trust{font-family:var(--sans);font-size:0.6875rem;color:var(--rose-text);line-height:1.4;margin:0.625rem 0 0;letter-spacing:0.04em}
.sticky-newsletter-divider{display:flex;align-items:center;gap:0.875rem;margin:1.25rem 0 0.875rem;color:var(--ink);font-family:var(--serif);font-style:italic;font-size:0.875rem;line-height:1.3;letter-spacing:0}
.sticky-newsletter-divider::before,.sticky-newsletter-divider::after{content:'';flex:1;height:1px;background:rgba(196,132,122,0.4)}
.sticky-newsletter-divider span{flex-shrink:0;text-align:center}
.sticky-newsletter-form .capture-phone-reveal{visibility:visible;opacity:0;pointer-events:none;max-height:0;overflow:hidden;margin-top:0;transition:max-height 380ms cubic-bezier(.4,0,.2,1),opacity 280ms ease 80ms}
.sticky-newsletter-form .capture-phone-reveal.revealed{visibility:visible;opacity:1;pointer-events:auto;max-height:18rem}
.sticky-newsletter-close{background:transparent;border:none;color:var(--rose-text);cursor:pointer;width:1.75rem;height:1.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:opacity var(--transition),color var(--transition),transform var(--transition);flex-shrink:0;position:absolute;top:0.625rem;right:0.625rem;opacity:0.55;z-index:1}
.sticky-newsletter-close:hover{opacity:1;color:var(--ink)}
.sticky-newsletter-close:active{transform:scale(0.92)}

/* =========================================================================
   FOOTER — off-white / editorial
   ========================================================================= */
footer{padding:4rem 0 2rem;background:var(--off-white);border-top:1px solid var(--border)}
.footer-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--page-x)}
.footer-columns{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2.5rem}
.footer-col{display:flex;flex-direction:column;gap:0.5rem}
.footer-col-brand{padding-right:2rem}
.footer-logo{display:inline-flex;align-items:center;color:var(--ink);margin-bottom:0.25rem;text-decoration:none;line-height:1;transition:color var(--transition)}
.footer-logo:hover{color:var(--brand)}
.footer-logo-mark{display:block;height:1rem;width:auto;color:inherit}
.footer-tagline{font-size:0.625rem;color:var(--rose-text);text-transform:uppercase;letter-spacing:0.18em;margin-bottom:0.625rem;font-weight:600}
.footer-blurb{font-size:0.8125rem;color:var(--body-text);line-height:1.6;margin-bottom:1rem}
.footer-social{display:flex;gap:0.5rem}
.footer-social a{width:2.25rem;height:2.25rem;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:all var(--transition)}
.footer-social a:hover{background:var(--ink);border-color:var(--ink);color:#fff}
.footer-social a svg{width:15px;height:15px}
.footer-col-title{font-size:0.625rem;text-transform:uppercase;letter-spacing:0.18em;color:var(--ink);font-weight:700;margin-bottom:0.5rem}
.footer-col a{font-size:0.8125rem;color:var(--body-text);transition:color 150ms;padding:0.1875rem 0;align-self:flex-start}
.footer-col a:hover{color:var(--brand)}

.footer-bottom{border-top:1px solid var(--border);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem}
.footer-disclosure{font-size:0.6875rem;color:var(--rose-text);line-height:1.6;max-width:38rem;opacity:0.85}
.footer-copy{font-size:0.6875rem;color:var(--rose-text);white-space:nowrap;letter-spacing:0.04em}

/* =========================================================================
   ABOUT PAGE — retained from previous pass, re-aligned to new tokens
   ========================================================================= */
#page-about{background:var(--canvas)}
#page-about .about-letter{background:var(--off-white)}
#page-about .team-section-about{background:var(--canvas);border-top:1px solid var(--border)}
#page-about .brands-section{background:var(--off-white);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
#page-about .affiliates-section{background:#fff}
#page-about .about-fb-strip{background:var(--fb-blue)}

/* -- Hero -- */
.about-hero{padding:3.5rem 0 5rem}
.about-hero-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--page-x);display:flex;justify-content:center;gap:3.5rem;align-items:start}
.about-hero-content{padding-top:0.5rem;max-width:36rem}
.about-hero-photo{position:relative;width:18rem;max-width:100%;aspect-ratio:3/4;flex-shrink:0}
.about-hero-photo::before{content:'';position:absolute;inset:1.25rem -1.25rem -1.25rem 1.25rem;border:1px solid var(--rose);z-index:0;pointer-events:none}
.about-hero-photo img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;object-position:center top;display:block;border:1px solid var(--border);background:var(--cream)}
.about-hero-photo-tag{position:absolute;z-index:2;left:50%;bottom:-0.875rem;transform:translateX(-50%);display:inline-flex;align-items:center;gap:0.4375rem;background:#fff;border:1px solid var(--ink);padding:0.4375rem 0.9375rem;font-size:0.625rem;font-weight:700;color:var(--ink);letter-spacing:0.14em;text-transform:uppercase;white-space:nowrap}
.about-hero-photo-tag .recency-dot{background:var(--rose)}
.about-hero-content h1{font-family:var(--serif);font-size:clamp(2.75rem,5vw,3.875rem);font-weight:400;line-height:1.02;color:var(--ink);margin:0.875rem 0 1.25rem;letter-spacing:-0.01em}
.about-hero-content h1 em{color:var(--rose);font-style:normal}
.about-hero-lead{font-size:1.0625rem;line-height:1.7;color:var(--body-text);margin-bottom:0.875rem;max-width:34rem}
.about-hero-lead strong{color:var(--ink);font-weight:700}
.about-hero-content p{font-size:0.9375rem;line-height:1.7;color:var(--body-text);margin-bottom:0.75rem;max-width:34rem}
.about-hero-content p em{color:var(--ink);font-family:var(--serif);font-weight:400}
.about-hero-sig{font-family:'Sacramento',cursive;font-size:2.25rem;font-style:normal;color:var(--rose-deep);font-weight:400;margin-top:1.5rem;line-height:1;letter-spacing:0.03em}

/* -- Stats strip -- */
.about-stats-section{padding:0 var(--page-x);margin-top:-2.75rem;margin-bottom:-2.75rem;position:relative;z-index:5}
.about-stats-strip{max-width:52rem;margin:0 auto;background:#fff;border:1px solid var(--ink);padding:1.5rem 0.75rem;display:grid;grid-template-columns:repeat(4,1fr);box-shadow:0 12px 36px rgba(41,36,33,0.1)}
.stat-cell{text-align:center;padding:0.125rem 0.75rem;border-right:1px solid var(--border)}
.stat-cell:last-child{border-right:none}
.stat-cell strong{display:block;font-family:var(--serif);font-size:clamp(1.625rem,2.5vw,2.25rem);font-weight:400;color:var(--ink);letter-spacing:-0.005em;line-height:1;font-style:normal}
.stat-cell span{font-size:0.625rem;color:var(--rose-text);text-transform:uppercase;letter-spacing:0.14em;margin-top:0.5rem;display:block;font-weight:600}

/* -- Letter from Donna -- */
.about-letter{padding:5.5rem var(--page-x) 4.5rem}
.about-letter-inner{max-width:64rem;margin:0 auto;display:grid;grid-template-columns:18rem 1fr;gap:3rem;align-items:start}
.donna-portrait-wrap{position:relative;position:sticky;top:5rem}
.donna-portrait{width:100%;max-width:18rem;aspect-ratio:3/4;object-fit:cover;object-position:top;border:1px solid var(--border)}
.portrait-caption{background:var(--blush);border:1px solid rgba(196,132,122,0.22);padding:1rem 1.125rem;margin-top:1rem;max-width:18rem;border-radius:var(--radius-sm)}
.portrait-caption p{font-size:0.8125rem;color:var(--body-text);line-height:1.6;font-family:var(--serif)}
.letter-col .eyebrow{margin-bottom:1rem}
.letter-col h2{font-family:var(--serif);font-size:clamp(2.125rem,3.5vw,2.875rem);font-weight:400;color:var(--ink);margin-bottom:1.75rem;line-height:1.05;letter-spacing:-0.005em}
.letter-col h2 em{color:var(--rose);font-style:normal}
.letter-col p{font-size:0.9375rem;line-height:1.8;color:var(--body-text);margin-bottom:1.125rem}
.letter-col p strong{color:var(--ink);font-weight:700}
.letter-sig{font-family:'Sacramento',cursive;font-size:2.25rem;font-style:normal;color:var(--rose-deep);font-weight:400;margin-top:1.75rem;line-height:1;letter-spacing:0.03em}
.letter-cta{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap}
.letter-browse-btn{display:inline-flex;align-items:center;background:var(--ink);color:#fff;padding:0.875rem 1.75rem;font-size:0.6875rem;font-weight:700;font-family:var(--sans);transition:background var(--transition),transform 100ms;letter-spacing:0.18em;text-transform:uppercase;border:1px solid var(--ink);border-radius:var(--radius-sm)}
.letter-browse-btn:hover{background:var(--brand);border-color:var(--brand)}
.letter-browse-btn:active{transform:scale(0.97)}

/* === TEAM SECTION SHARED COMPONENTS (used on home + about) === */
.leaders-row{display:flex;justify-content:center;align-items:center;gap:1.25rem;margin:1.5rem auto 2.5rem;padding:0 var(--page-x)}
.leader-nav-btn{width:2.5rem;height:2.5rem;border-radius:50%;background:#fff;border:1px solid var(--border);box-shadow:0 2px 10px rgba(0,0,0,0.08);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);flex-shrink:0;transition:all var(--transition)}
.leader-nav-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.leader-card{background:#fff;border:1px solid var(--border);border-radius:1rem;box-shadow:0 4px 20px rgba(0,0,0,0.07);display:flex;flex-direction:row;align-items:center;text-align:left;gap:1.75rem;padding:1.75rem 2rem;max-width:34rem;width:100%}
.leader-avatar{width:5rem;height:5rem;border-radius:50%;object-fit:cover;object-position:center 10%;border:none;box-shadow:0 0 0 3px var(--off-white),0 0 0 5px var(--rose);flex-shrink:0}
.leader-info{display:flex;flex-direction:column;gap:0.125rem;min-width:0}
.leader-name{font-family:var(--serif);font-weight:400;font-size:1.25rem;color:var(--ink);letter-spacing:-0.01em;line-height:1.2}
.leader-role{font-size:0.5625rem;text-transform:uppercase;letter-spacing:0.18em;color:var(--rose-text);font-weight:600;margin-bottom:0.25rem}
.leader-quote{font-family:var(--sans);font-style:italic;font-size:0.9rem;color:var(--body-text);line-height:1.6;margin:0}


.team-rest-row{display:flex;flex-wrap:wrap;justify-content:center;gap:1.25rem 0rem;max-width:56rem;margin:0 auto}
.team-rest-row-single{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:0.25rem 0.5rem;max-width:64rem}
.team-rest-row-single::-webkit-scrollbar{display:none}
.team-rest-row-single .rest-member{flex-shrink:0}
.rest-member{display:flex;flex-direction:column;align-items:center;gap:0.4375rem;text-align:center;width:4rem;cursor:default}
.rest-avatar{width:3.5rem;height:3.5rem;border-radius:50%;object-fit:cover;border:2px solid var(--border);transition:transform var(--transition),box-shadow var(--transition)}
.rest-avatar-initials{width:3.5rem;height:3.5rem;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:400;font-size:1rem;transition:transform var(--transition);letter-spacing:-0.02em}
.rest-member:hover .rest-avatar,.rest-member:hover .rest-avatar-initials{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,0.12)}
.rest-name{font-family:var(--sans);font-size:0.6875rem;color:var(--rose-text);font-weight:400;line-height:1.3;margin-top:0.125rem}
.rest-more{text-decoration:none;cursor:pointer}
.rest-avatar-you{width:3.5rem;height:3.5rem;border-radius:50%;background:transparent;border:2px dashed var(--rose);color:var(--rose);display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-weight:600;font-size:1rem;transition:all var(--transition)}
.rest-more:hover .rest-avatar-you{background:var(--rose);color:#fff;border-style:solid;transform:translateY(-3px)}
.rest-more .rest-name{color:var(--rose);font-weight:600}

/* -- Team masthead list (homepage + about) -- */
.team-section-about{padding:4rem var(--page-x)}
.masthead-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0.25rem 2.5rem;max-width:62rem;margin:0 auto;padding-top:1rem}
.masthead-row{display:grid;grid-template-columns:2.25rem 1fr;align-items:center;gap:0.875rem;padding:0.75rem 0.625rem;border-radius:var(--radius-card);text-decoration:none;color:inherit;transition:background var(--transition)}
.masthead-row:hover{background:rgba(0,0,0,0.03)}
.masthead-avatar{width:2.25rem;height:2.25rem;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border)}
.masthead-avatar-initials{width:2.25rem;height:2.25rem;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:400;font-size:0.75rem;flex-shrink:0;letter-spacing:-0.02em}
.masthead-name{font-family:var(--serif);font-weight:400;font-size:0.9375rem;color:var(--ink);line-height:1.2;letter-spacing:-0.01em}

/* -- For Brands -- */
.brands-section{padding:5rem 0}
.brands-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--page-x);text-align:center}
.brands-content .eyebrow{justify-content:center;margin-bottom:1rem}
.brands-content h2{font-family:var(--serif);font-size:clamp(2.125rem,3.5vw,2.875rem);font-weight:400;color:var(--ink);margin-bottom:1rem;line-height:1.05;letter-spacing:-0.005em}
.brands-content h2 em{color:var(--rose);font-style:normal}
.brands-lead{font-size:1.0625rem;color:var(--body-text);max-width:38rem;margin:0 auto 2.5rem;line-height:1.65}
.brands-lead strong{color:var(--ink);font-weight:700}
.brand-features{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:56rem;margin:0 auto 2.5rem}
.brand-feature{background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);padding:1.75rem 1.25rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:0.625rem;transition:transform var(--transition),box-shadow var(--transition)}
.brand-feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-card-hover)}
.brand-feature-icon{width:2.5rem;height:2.5rem;border:1px solid var(--border);color:var(--rose);display:flex;align-items:center;justify-content:center;margin-bottom:0.25rem}
.brand-feature strong{font-family:var(--serif);font-size:1.125rem;font-weight:400;color:var(--ink);letter-spacing:0}
.brand-feature span{font-size:0.8125rem;color:var(--body-text);line-height:1.6}
.brands-cta{display:inline-flex;align-items:center;gap:0.5rem;background:var(--ink);color:#fff;padding:0.875rem 1.75rem;font-size:0.6875rem;font-weight:700;font-family:var(--sans);transition:background var(--transition),transform 100ms;letter-spacing:0.18em;text-transform:uppercase;border:1px solid var(--ink);border-radius:var(--radius-sm)}
.brands-cta:hover{background:var(--brand);border-color:var(--brand)}
.brands-cta:active{transform:scale(0.97)}

/* -- FB strip -- */
.about-fb-strip{background:var(--off-white);padding:2.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.fb-strip-inner{max-width:38rem;margin:0 auto;text-align:center}
.fb-strip-inner p{font-size:0.9375rem;color:var(--body-text);line-height:1.7;margin-bottom:1rem}
.fb-strip-inner p strong{color:var(--ink);font-weight:700}
.fb-strip-link{font-size:0.6875rem;color:var(--fb-blue);font-weight:700;letter-spacing:0.16em;text-transform:uppercase;transition:opacity var(--transition);border-bottom:1px solid var(--fb-blue);padding-bottom:0.25rem}
.fb-strip-link:hover{opacity:0.7}

/* -- Affiliates -- */
.affiliates-section{padding:0 0 2rem}
.affiliates-inner{max-width:var(--max-w);margin:0 auto;padding:4rem var(--page-x);text-align:center}
.affiliates-inner .eyebrow{margin-bottom:1rem}
.affiliates-section h3{font-family:var(--serif);font-size:clamp(1.625rem,2.5vw,2rem);font-weight:400;color:var(--ink);margin-bottom:0.75rem;letter-spacing:-0.005em}
.affiliates-section p{font-size:0.9375rem;color:var(--body-text);max-width:36rem;margin:0 auto 1.75rem;line-height:1.65}
.partner-logos{display:flex;justify-content:center;flex-wrap:wrap;gap:0.625rem}
.partner-chip{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:0.5rem 1.125rem;font-family:var(--serif);font-size:0.9375rem;font-weight:400;color:var(--ink);letter-spacing:0;transition:all var(--transition)}
.partner-chip:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* === ANIMATIONS === */
@keyframes fadeUp{from{opacity:0;transform:translateY(0.75rem)}to{opacity:1;transform:translateY(0)}}
.pick-card{animation:fadeUp 0.4s cubic-bezier(.4,0,.2,1) both}
.pick-card:nth-child(1){animation-delay:0.03s}
.pick-card:nth-child(2){animation-delay:0.09s}
.pick-card:nth-child(3){animation-delay:0.15s}
.pick-card:nth-child(4){animation-delay:0.21s}
.pick-card:nth-child(5){animation-delay:0.27s}
.pick-card:nth-child(6){animation-delay:0.33s}
.pick-card:nth-child(7){animation-delay:0.39s}
.pick-card:nth-child(8){animation-delay:0.45s}

/* === ACCESSIBILITY === */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}}
:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
button:focus-visible,a:focus-visible,input:focus-visible{outline-offset:2px}

/* === RESPONSIVE === */
@media(max-width:64rem){
  .hp-hero{padding:0}
  .hp-hero-banner-wrap{padding:0 var(--page-x)}
  .hp-hero-banner{grid-template-columns:1fr;min-height:auto;gap:0}
  .hp-hero-banner-text{order:2;max-width:none;padding:1.5rem 1.25rem 1.75rem;align-items:flex-start}
  .hp-hero-banner-image{order:1;aspect-ratio:16/10;max-height:24rem;min-height:auto;margin:0;width: 100%;}
  .hp-hero-banner-image img{object-position:center 5%}
  .hp-hero-banner-image::before{background:linear-gradient(to bottom,transparent 0%,transparent 65%,rgba(242,231,221,0.3) 85%,var(--off-white) 100%)}
  .hp-hero-cards{grid-template-columns:1fr 1fr;gap:0.5rem;margin-top:0.5rem}
  .hp-hero-card{grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);min-height:13rem}
  .hp-hero-card-text{padding:1.5rem 1.25rem;min-width:0}
  .category-grid{grid-template-columns:repeat(2,1fr);gap:0.75rem}
  .category-section{padding:3.5rem 0 4rem}
  .picks-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .footer-columns{grid-template-columns:1fr 1fr 1fr;gap:1.75rem}
  .newsletter-cta-section{padding:4rem var(--page-x)}
  .footer-col-brand{grid-column:1 / -1;padding-right:0}
  .footer-bottom{flex-direction:column;text-align:center;gap:0.75rem;align-items:center}
  .about-hero-inner{flex-direction:column;align-items:center;gap:2.5rem}
  .about-hero-photo{width:18rem;max-width:100%}
  .about-letter-inner{grid-template-columns:1fr;gap:2rem;max-width:38rem}
  .donna-portrait-wrap{position:static;display:flex;flex-direction:column;align-items:center}
  .donna-portrait{max-width:18rem}
  .portrait-caption{max-width:18rem}
  .about-stats-strip{grid-template-columns:repeat(2,1fr);row-gap:1.25rem;padding:1.5rem 1rem}
  .stat-cell:nth-child(2n){border-right:none}
  .stat-cell:nth-child(-n+2){border-bottom:1px solid var(--border);padding-bottom:1.25rem}
  .masthead-grid{grid-template-columns:repeat(2,1fr);gap:0 2rem}
  .brand-features{grid-template-columns:1fr;max-width:32rem}
  .sticky-newsletter-inner{padding:1.25rem var(--page-x) 1.5rem;max-width:none}
  .sticky-newsletter-headline{font-size:1.25rem}
}

/* =========================================================================
   ROUND 3 ADDITIONS — search overlay, mobile drawer, two-step capture,
   page-header, breadcrumbs, single-find, author hero, team grid, contact, 404
   Decisions captured in project-details/design-decisions.md (Round 3).
   ========================================================================= */

/* -- Nav: search button (replaces inline input) + hamburger -- */
.nav-icon-btn{background:none;border:none;cursor:pointer;color:var(--ink);width:2.25rem;height:2.25rem;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}
.nav-icon-btn:hover{background:var(--off-white);color:var(--brand)}
.nav-search-btn{margin-left:auto}
.nav-hamburger{display:none}
@media(max-width:64rem){
  .nav-search{display:none}
  .nav-search-btn{display:inline-flex}
}
@media(max-width:48rem){
  .nav-links{display:none}
  .nav-hamburger{display:inline-flex;margin-left:auto}
  .nav-search-btn{margin-left:0}
}

/* -- Mobile drawer (off-canvas) -- */
.mobile-drawer{position:fixed;inset:0;z-index:400;visibility:hidden;pointer-events:none}
.mobile-drawer.open{visibility:visible;pointer-events:auto}
.mobile-drawer-scrim{position:absolute;inset:0;background:rgba(26,20,18,0.4);opacity:0;transition:opacity 220ms ease}
.mobile-drawer.open .mobile-drawer-scrim{opacity:1}
.mobile-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(86vw,22rem);background:#fff;padding:0;display:flex;flex-direction:column;transform:translateX(100%);transition:transform 260ms cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:-16px 0 48px rgba(0,0,0,0.10);border-top:3px solid var(--brand)}

.mobile-drawer.open .mobile-drawer-panel{transform:translateX(0)}

/* Header */
.mobile-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 0.5rem}
.mobile-drawer-logo{display:inline-flex;align-items:center;color:var(--ink);text-decoration:none}
.mobile-drawer-logo-mark{display:block;height:0.75rem;width:auto;color:inherit}
.mobile-drawer-close{background:none;border:none;width:2.25rem;height:2.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--rose-text);transition:color 150ms,background 150ms}
.mobile-drawer-close:hover{color:var(--ink);background:var(--off-white)}

/* Primary nav links */
.mobile-drawer-nav{display:flex;flex-direction:column;padding:0;border-top:1px solid var(--border)}
.mobile-drawer-nav a{font-family:var(--serif);font-size:1.125rem;font-weight:400;color:var(--ink);padding:0.875rem 1.5rem;text-decoration:none;line-height:1.25;letter-spacing:-0.005em;transition:color 150ms,background 150ms;border-bottom:1px solid var(--border)}
.mobile-drawer-nav a:last-child{border-bottom:none}
.mobile-drawer-nav a:hover,.mobile-drawer-nav a:active{color:var(--brand);background:var(--off-white)}

/* Search trigger */
.mobile-drawer-search{display:flex;align-items:center;gap:0.875rem;width:100%;margin:0;padding:0.875rem 1.5rem;background:transparent;border:none;border-bottom:1px solid var(--border);border-radius:0;color:var(--ink);font-family:var(--serif);font-size:1.125rem;font-weight:400;letter-spacing:-0.005em;cursor:pointer;transition:color 150ms,background 150ms;text-align:left;box-shadow:none}
.mobile-drawer-search:hover{color:var(--brand);background:var(--off-white)}
.mobile-drawer-search svg{flex-shrink:0;color:var(--rose);opacity:0.85;transition:color 150ms,opacity 150ms}
.mobile-drawer-search:hover svg{color:var(--brand);opacity:1}

/* Browse accordions */
.mobile-drawer-browse{padding:0;display:flex;flex-direction:column}
.mobile-drawer-accordion{border-bottom:1px solid var(--border)}
.mobile-drawer-accordion{border-bottom:1px solid var(--border)}
.mobile-drawer-accordion:last-child{border-bottom:none}
.mobile-drawer-accordion-trigger{font-family:var(--serif);font-size:1.125rem;font-weight:400;color:var(--ink);padding:0.875rem 1.5rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;list-style:none;user-select:none;letter-spacing:-0.005em;transition:color 150ms,background 150ms}
.mobile-drawer-accordion-trigger:hover{color:var(--brand);background:var(--off-white)}
.mobile-drawer-accordion-trigger::-webkit-details-marker{display:none}
.mobile-drawer-chevron{color:var(--rose);opacity:0.7;transition:transform 220ms ease,opacity 150ms,color 150ms}
.mobile-drawer-accordion-trigger:hover .mobile-drawer-chevron{opacity:1;color:var(--brand)}
.mobile-drawer-accordion[open] .mobile-drawer-chevron{transform:rotate(180deg);opacity:1;color:var(--brand)}
.mobile-drawer-accordion-body{display:flex;flex-direction:column;padding:0.25rem 1.5rem 0.875rem 2.25rem;background:var(--canvas)}
.mobile-drawer-accordion-body a{padding:0.4375rem 0;font-size:0.9375rem;color:var(--body-text);font-family:var(--sans);font-weight:400;text-decoration:none;transition:color 150ms}
.mobile-drawer-accordion-body a:hover{color:var(--brand)}
.mobile-drawer-viewall{display:inline-flex;align-items:center;gap:0.4375rem;font-family:var(--serif);font-size:1rem;font-weight:400;font-style:italic;text-transform:none;letter-spacing:0;color:var(--rose);margin-top:0.625rem;padding:0.25rem 0;text-decoration:none;transition:color 150ms}
.mobile-drawer-viewall:hover{color:var(--brand)}
.mobile-drawer-viewall:hover .hwr-arrow{transform:translateX(3px)}

/* Footer utility links */
.mobile-drawer-foot{margin-top:auto;padding:1rem 1.5rem 2rem;padding-bottom:calc(2rem + env(safe-area-inset-bottom));border-top:1px solid var(--border);display:flex;flex-direction:column;gap:0.375rem}
.mobile-drawer-foot a{font-size:0.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:0.14em;color:var(--rose-text);padding:0.3125rem 0;text-decoration:none;transition:color 150ms}
.mobile-drawer-foot a:hover{color:var(--brand)}

/* -- Full-screen search overlay -- */
.search-overlay{position:fixed;inset:0;z-index:500;display:none;flex-direction:column;background:rgba(255,255,255,0.98);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:0 var(--page-x) 4rem;animation:fadeIn 180ms ease;overflow-y:auto}
.search-overlay.open{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* Close button — absolute top-right */
.search-overlay-close{position:fixed;top:1.25rem;right:var(--page-x);z-index:1;background:none;border:none;width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--rose-text);transition:color 150ms,background 150ms}
.search-overlay-close:hover{color:var(--ink);background:var(--off-white)}

/* Header — search input, pushed down from top */
.search-overlay-head{max-width:900px;margin:0 auto;width:100%;padding-top:5rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}
.search-overlay-form{width:100%;display:flex}
.search-overlay-input-wrap{flex:1;display:flex;align-items:center;gap:0.75rem;border-bottom:2px solid var(--border);padding:0.5rem 0;transition:border-color var(--transition)}
.search-overlay-input-wrap:focus-within{border-color:var(--brand)}
.search-overlay-input-icon{color:var(--rose-text);flex-shrink:0}
.search-overlay-input{flex:1;font-family:var(--sans);font-size:1.25rem;font-weight:400;color:var(--ink);background:transparent;border:none;outline:none;padding:0.375rem 0;letter-spacing:0}
.search-overlay-input::placeholder{color:var(--rose-text);font-style:normal}
.search-overlay-input::-webkit-search-cancel-button,
.search-overlay-input::-webkit-search-decoration{-webkit-appearance:none;appearance:none;display:none}
.search-overlay-input::-ms-clear{display:none;width:0;height:0}

/* Body — default: centered single column (empty state) */
.search-overlay-body{flex:1;max-width:900px;margin:0 auto;width:100%;padding-top:2.5rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}
.search-overlay-main{width:100%;text-align:center}
.search-empty-prompt{color:var(--ink);font-family:var(--serif);font-size:1.125rem;line-height:1.5;margin:0;padding:0.5rem 0 0;opacity:0.6}

/* Sidebar — default: centered two-column browse grid */
.search-overlay-sidebar{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;padding-top:0.5rem}

/* Body — active: two-column layout when results appear */
.search-overlay-body.has-results{max-width:900px;display:grid;grid-template-columns:1fr 18rem;gap:3rem;align-items:start}
.search-overlay-body.has-results .search-overlay-main{text-align:left}
.search-overlay-body.has-results .search-overlay-sidebar{grid-template-columns:1fr;gap:2rem;position:sticky;top:2rem;padding:1rem 0 1rem 2rem;border-left:1px solid var(--border)}

/* Live results */
.search-results-live{display:flex;flex-direction:column;gap:2rem;width:100%}
.search-results-live .search-result-group{display:flex;flex-direction:column;gap:0}
.search-result-group h4{font-family:var(--serif);font-size:1.375rem;font-weight:400;letter-spacing:-0.005em;color:var(--ink);margin-bottom:0.875rem;padding-bottom:0.5rem;border-bottom:1px solid var(--border);display:flex;align-items:baseline;gap:0.875rem;justify-content:space-between}
.search-result-group-more{display:inline-flex;align-items:center;gap:0.5rem;font-family:var(--sans);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--brand-deep);text-decoration:none;white-space:nowrap;padding:0.25rem 0;border-bottom:1px solid transparent;transition:color var(--transition),border-color var(--transition)}
.search-result-group-more:hover{color:var(--brand);border-bottom-color:currentColor;text-decoration:none}
.search-result-group-more-arrow{display:inline-block;transition:transform var(--transition)}
.search-result-group-more:hover .search-result-group-more-arrow{transform:translateX(4px)}
.search-result-item{display:flex;align-items:center;gap:1rem;padding:0.75rem 0.5rem;border-radius:var(--radius-sm);transition:background var(--transition);text-decoration:none}
.search-result-item + .search-result-item{border-top:1px solid var(--border)}
.search-result-item:hover{background:var(--off-white)}
.search-result-thumb{position:relative;width:3.5rem;height:3.5rem;background:var(--cream);flex-shrink:0;overflow:hidden;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-family:var(--serif);color:var(--ink);font-size:1.25rem}
.search-result-thumb::before{content:"";position:absolute;inset:-4px;background:var(--card-bg-img) center/cover no-repeat;filter:blur(8px) saturate(1.2);opacity:0.5;z-index:0}
.search-result-thumb img{width:100%;height:100%;object-fit:contain;position:relative;z-index:1}
.search-result-thumb.avatar{border-radius:50%}
.search-result-thumb.avatar::before{display:none}
.search-result-thumb.avatar img{object-fit:cover}
.search-result-text{flex:1;min-width:0}
.search-result-title{font-family:var(--serif);font-size:1rem;color:var(--ink);line-height:1.25;display:block;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;margin-bottom:0.125rem}
.search-result-meta{font-size:0.6875rem;color:var(--rose-text);text-transform:uppercase;letter-spacing:0.12em;font-weight:600}

/* Browse chips */
.search-aside-block h4{font-family:var(--serif);font-size:1.125rem;font-weight:400;letter-spacing:-0.005em;color:var(--ink);margin-bottom:0.875rem;padding-bottom:0.5rem;border-bottom:1px solid var(--border)}
.search-aside-block .chip-row{display:flex;flex-wrap:wrap;gap:0.4375rem}
.search-chip{font-size:0.75rem;color:var(--ink);background:var(--off-white);padding:0.375rem 0.625rem;border-radius:var(--radius-sm);font-family:var(--sans);font-weight:500;letter-spacing:0.02em;cursor:pointer;transition:background var(--transition),color var(--transition);text-decoration:none}
.search-chip:hover{background:var(--ink);color:#fff}
.search-empty{color:var(--rose-text);font-family:var(--serif);font-size:1.125rem;padding:2rem 0;text-align:center}
.search-loading{padding:2rem 0;text-align:center;color:var(--rose-text);font-size:0.875rem;letter-spacing:0.04em}

@media(max-width:48rem){
  .search-overlay-head{padding-top:3.5rem}
  .search-overlay-sidebar{grid-template-columns:1fr;gap:1.75rem}
  .search-overlay-body.has-results{grid-template-columns:1fr;gap:2rem}
  .search-overlay-body.has-results .search-overlay-sidebar{position:static;border-left:none;padding:0;border-top:1px solid var(--border);padding-top:1.5rem}
}

/* -- Newsletter capture: inline disable-and-reveal -- */
.capture-note{font-family:var(--sans);font-size:0.6875rem;color:var(--muted);margin-top:0.5rem;letter-spacing:0.01em;line-height:1.4;transition:color 300ms ease,opacity 600ms ease,max-height 600ms ease,margin 600ms ease}
.capture-note.is-success{color:#15803d;font-weight:600;font-size:0.75rem}
.capture-note.is-fading{opacity:0;max-height:0;margin-top:0;overflow:hidden;pointer-events:none}
.capture-phone-reveal{visibility:hidden;opacity:0;pointer-events:none;margin-top:0.75rem;transition:opacity 300ms ease,visibility 0s linear 300ms}
.capture-phone-reveal.revealed{visibility:visible;opacity:1;pointer-events:auto;transition:opacity 300ms ease}
.capture-error{font-family:var(--sans);font-size:0.75rem;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);padding:0.5rem 0.75rem;margin-top:0.5rem;line-height:1.4}
form.is-submitting{opacity:0.7;pointer-events:none}

.sticky-newsletter-form .capture-note{margin:0.625rem 0 0;font-size:0.6875rem;text-align:center}

/* -- Page header (used on Browse, Category, Store, Author, Team, Contact, Search) -- */
.page-header{padding:2rem var(--page-x) 1.5rem;background:var(--canvas)}
.page-header-inner{max-width:var(--max-w);margin:0 auto;display:flex;flex-direction:column;gap:0.625rem}
.page-header .eyebrow{margin-bottom:0;justify-content:flex-start}
.page-header h1{font-family:var(--serif);font-size:clamp(2.25rem,4vw,3.25rem);font-weight:400;color:var(--ink);line-height:1.05;letter-spacing:-0.01em}
.page-header h1 em{color:var(--rose);font-style:normal}
.page-header-lead{font-size:1.0625rem;color:var(--body-text);line-height:1.6;max-width:46rem}
.page-header-meta{font-size:0.75rem;color:var(--rose-text);text-transform:uppercase;letter-spacing:0.14em;font-weight:600;margin-top:0.5rem}

/* -- Breadcrumbs -- */
.breadcrumb{padding:2.75rem var(--page-x) 0;max-width:var(--max-w);margin:0 auto;font-family:var(--sans);font-size:0.6875rem;color:var(--rose-text);letter-spacing:0.12em;text-transform:uppercase;font-weight:600;display:flex;align-items:center;gap:0.5rem;flex-wrap:wrap}
.breadcrumb a{color:var(--rose-text);transition:color var(--transition)}
.breadcrumb a:hover{color:var(--brand)}
.breadcrumb .sep{opacity:0.5}
.breadcrumb .current{color:var(--ink)}

/* -- Active filter chips (Browse, Category, Store) -- */
.active-filters{display:flex;flex-wrap:wrap;align-items:center;gap:0.5rem;margin-bottom:1.25rem}
.active-filter-label{font-size:0.625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.16em;color:var(--rose-text);margin-right:0.25rem}
.active-filter-chip{display:inline-flex;align-items:center;gap:0.4375rem;background:var(--off-white);border:1px solid var(--border);padding:0.375rem 0.625rem 0.375rem 0.75rem;font-size:0.75rem;color:var(--ink);font-weight:600;letter-spacing:0.02em;border-radius:var(--radius-sm)}
.active-filter-chip button{background:none;border:none;cursor:pointer;color:var(--rose-text);width:1rem;height:1rem;display:flex;align-items:center;justify-content:center;padding:0;border-radius:50%;transition:background var(--transition),color var(--transition)}
.active-filter-chip button:hover{background:var(--ink);color:#fff}
.active-filter-clear{font-family:var(--sans);font-size:0.6875rem;color:var(--brand);text-transform:uppercase;letter-spacing:0.14em;font-weight:700;background:none;border:none;cursor:pointer;padding:0.25rem 0.5rem;margin-left:auto}
.active-filter-clear:hover{text-decoration:underline}

/* -- Load more button -- */
.load-more-wrap{display:flex;justify-content:center;padding:2.5rem 0 1rem}
.load-more-btn{background:#fff;border:1px solid var(--ink);color:var(--ink);padding:0.875rem 2.25rem;font-size:0.6875rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;cursor:pointer;border-radius:var(--radius-sm);font-family:var(--sans);transition:all var(--transition);display:inline-flex;align-items:center;gap:0.5rem}
.load-more-btn:hover{background:var(--ink);color:#fff}
.load-more-btn:hover .hwr-arrow{transform:translateY(2px)}

/* -- Single Find page -- */
.single-find-section{padding:1.5rem 0 4rem}
.single-find-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--page-x);display:grid;grid-template-columns:1.15fr 1fr;gap:3.5rem;align-items:start}
.single-find-gallery{display:flex;flex-direction:column;gap:0.75rem;position:sticky;top:5rem}
.single-find-main-img{position:relative;aspect-ratio:1;background:var(--cream);border:1px solid var(--border);overflow:hidden;border-radius:var(--radius-card);display:flex;align-items:center;justify-content:center}
.single-find-main-img::before{content:"";position:absolute;inset:-10px;background:var(--card-bg-img) center/cover no-repeat;filter:blur(20px) saturate(1.2);opacity:0.45;z-index:0}
.single-find-main-img img{width:100%;height:100%;object-fit:contain;position:relative;z-index:1}
.single-find-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:0.625rem}
.single-find-thumb{aspect-ratio:1;background:var(--cream);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:border-color var(--transition)}
.single-find-thumb:hover,.single-find-thumb.active{border-color:var(--ink)}
.single-find-thumb img{width:100%;height:100%;object-fit:contain}
.single-find-content{display:flex;flex-direction:column;gap:1.25rem}
.single-find-meta{display:flex;align-items:center;gap:0.625rem;font-size:0.6875rem;color:var(--rose-text);text-transform:uppercase;letter-spacing:0.14em;font-weight:600}
.single-find-meta a{color:var(--brand);text-decoration:none}
.single-find-meta a:hover{text-decoration:underline}
.single-find-meta-dot{width:0.1875rem;height:0.1875rem;border-radius:50%;background:var(--rose-text);opacity:0.55;flex-shrink:0}
.single-find-content h1{font-family:var(--serif);font-size:clamp(1.875rem,3vw,2.625rem);font-weight:400;color:var(--ink);line-height:1.1;letter-spacing:-0.01em}
/* Byline: only the avatar + name are clickable; the meta line beside it is plain text. */
.single-find-posted{display:flex;align-items:center;gap:0.875rem;padding:0.875rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-family:var(--sans);font-size:0.8125rem;color:var(--body-text);flex-wrap:wrap}
.single-find-posted-link{display:inline-flex;align-items:center;gap:0.75rem;text-decoration:none;color:inherit;padding:0.25rem 0.5rem 0.25rem 0.25rem;margin:-0.25rem -0.5rem -0.25rem -0.25rem;border-radius:999px;transition:background var(--transition)}
.single-find-posted-link:hover{background:var(--off-white)}
.single-find-posted-link:hover .single-find-posted-name{color:var(--brand)}
.single-find-posted-link:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.single-find-posted-avatar{width:2.5rem;height:2.5rem;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border)}
.single-find-posted-name-block{display:flex;flex-direction:column;gap:0.0625rem;line-height:1.2}
.single-find-posted-eyebrow{font-size:0.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.14em;color:var(--rose-text)}
.single-find-posted-name{font-family:var(--sans);font-weight:600;color:var(--ink);font-size:0.875rem;letter-spacing:0.005em;transition:color var(--transition)}
.single-find-posted-meta{display:flex;align-items:center;gap:0.4375rem;color:var(--rose-text);font-size:0.75rem;margin-left:auto}
@media(max-width:36rem){
  .single-find-posted-meta{margin-left:0;width:100%;padding-left:3.25rem}
}
.single-find-description{font-family:var(--serif);font-size:1.125rem;color:var(--body-text);line-height:1.6}
.single-find-description-extra{font-size:0.9375rem;line-height:1.7;color:var(--body-text)}
.single-find-promo{background:var(--blush);border:1px solid rgba(196,132,122,0.25);padding:1.25rem 1.5rem;border-radius:var(--radius-card);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.single-find-promo-left{display:flex;flex-direction:column;gap:0.125rem}
.single-find-promo-eyebrow{font-size:0.625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.16em;color:var(--rose-deep)}
.single-find-promo-code{font-family:var(--serif);font-size:1.625rem;color:var(--ink);letter-spacing:0.05em}
.single-find-promo-note{font-size:0.75rem;color:var(--body-text)}
.single-find-promo-copy{background:var(--ink);color:#fff;border:none;padding:0.75rem 1.5rem;font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:0.16em;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);font-family:var(--sans)}
.single-find-promo-copy:hover{background:var(--brand)}
.single-find-promo-copy.ok{background:#16a34a}
.single-find-cta-row{display:flex;flex-direction:column;gap:0.75rem;margin-top:0.5rem}
.single-find-cta{display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;background:var(--ink);color:#fff;padding:1.125rem 2rem;font-size:0.8125rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;border-radius:var(--radius-sm);transition:all var(--transition);font-family:var(--sans);text-decoration:none;border:1px solid var(--ink)}
.single-find-cta:hover{background:var(--brand);border-color:var(--brand)}
.single-find-cta:hover .hwr-arrow{transform:translateX(4px)}
.single-find-disclosure{font-size:0.75rem;color:var(--rose-text);line-height:1.55;padding:0.875rem 0 0;border-top:1px solid var(--border);margin-top:1rem}
.single-find-tags{display:flex;flex-wrap:wrap;gap:0.4375rem;margin-top:0.5rem}
.single-find-tag{font-size:0.6875rem;color:var(--ink);background:var(--off-white);padding:0.375rem 0.75rem;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:0.1em;font-weight:600;text-decoration:none;transition:background var(--transition),color var(--transition)}
.single-find-tag:hover{background:var(--ink);color:#fff}
.single-find-related{padding:4rem 0;border-top:1px solid var(--border)}
.single-find-related-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--page-x)}
.single-find-related--similar{background:var(--canvas)}
.single-find-related--author{background:var(--canvas)}
.single-find-related--similar + .single-find-related--author{border-top:1px solid rgba(41,36,33,0.08)}
@media(max-width:64rem){
  .single-find-inner{grid-template-columns:1fr;gap:2rem}
  .single-find-gallery{position:static}
}

/* -- Author hero (author archive page) -- */
.author-hero{padding:3.5rem var(--page-x) 2.5rem;background:var(--off-white);border-bottom:1px solid var(--border)}
.author-hero-inner{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:auto 1fr;gap:2.25rem;align-items:center}
.author-hero-avatar{width:8rem;height:8rem;border-radius:50%;object-fit:cover;border:1px solid var(--border);box-shadow:0 0 0 4px var(--off-white),0 0 0 6px var(--rose),0 6px 24px rgba(167,95,55,0.18)}
.author-hero-text .eyebrow{margin-bottom:0.625rem;justify-content:flex-start}
.author-hero-text h1{font-family:var(--serif);font-size:clamp(2rem,3.25vw,2.875rem);font-weight:400;color:var(--ink);line-height:1.05;letter-spacing:-0.01em;margin-bottom:0.375rem}
.author-hero-role{font-size:0.75rem;color:var(--rose);text-transform:uppercase;letter-spacing:0.18em;font-weight:700;margin-bottom:0.875rem}
.author-hero-bio{font-size:1rem;color:var(--body-text);line-height:1.65;max-width:42rem;margin-bottom:1rem}
.author-hero-stats{display:flex;gap:2rem;font-family:var(--sans);font-size:0.6875rem;color:var(--rose-text);text-transform:uppercase;letter-spacing:0.14em;font-weight:600}
.author-hero-stat strong{font-family:var(--serif);font-size:1.25rem;color:var(--ink);font-weight:400;display:block;margin-bottom:0.125rem;letter-spacing:0;text-transform:none}
@media(max-width:48rem){
  .author-hero-inner{grid-template-columns:1fr;text-align:center;justify-items:center}
  .author-hero-text .eyebrow{justify-content:center}
  .author-hero-stats{justify-content:center}
}

/* -- Team page grid -- */
.team-page-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;max-width:var(--max-w);margin:0 auto;padding:1rem var(--page-x) 4rem}
.team-page-card{background:#fff;border:1px solid var(--border);padding:clamp(1rem, 3vw, 1.75rem) clamp(0.75rem, 2.5vw, 1.5rem);display:flex;flex-direction:column;align-items:center;text-align:center;gap:0.5rem;transition:transform var(--transition),box-shadow var(--transition);border-radius:var(--radius-card);text-decoration:none;color:inherit;min-width:0}
.team-page-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}
.team-page-card-avatar{width:clamp(3.5rem, 8vw, 5.5rem);height:clamp(3.5rem, 8vw, 5.5rem);border-radius:50%;object-fit:cover;margin-bottom:0.625rem;border:1px solid var(--border);box-shadow:0 0 0 3px var(--canvas),0 0 0 5px var(--rose)}
.team-page-card-avatar-initials{width:clamp(3.5rem, 8vw, 5.5rem);height:clamp(3.5rem, 8vw, 5.5rem);border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:400;font-size:clamp(1rem, 2.5vw, 1.625rem);margin-bottom:0.625rem;letter-spacing:-0.02em;box-shadow:0 0 0 3px var(--canvas),0 0 0 5px var(--rose)}
.team-page-card-name{font-family:var(--serif);font-size:clamp(0.9375rem, 2vw, 1.25rem);font-weight:400;color:var(--ink);line-height:1.15;overflow-wrap:break-word;word-break:break-word}
.team-page-card-role{font-size:0.6875rem;color:var(--rose);text-transform:uppercase;letter-spacing:0.14em;font-weight:700;margin-bottom:0.375rem}
.team-page-card-bio{font-size:0.8125rem;color:var(--rose-text);line-height:1.55;max-width:18rem}
.team-page-card-link{font-size:0.625rem;color:var(--ink);text-transform:uppercase;letter-spacing:0.16em;font-weight:700;border-bottom:1px solid var(--ink);padding-bottom:0.125rem;margin-top:0.5rem}
@media(max-width:64rem){
  .team-page-grid{grid-template-columns:repeat(3,1fr);gap:1rem}
}
@media(max-width:48rem){
  .team-page-grid{grid-template-columns:repeat(2,1fr);gap:0.875rem}
}
@media(max-width:26rem){
  .team-page-grid{grid-template-columns:1fr;max-width:16rem;margin:0 auto}
}

/* -- Team page sections (hero, founder spotlight, roster head) -- */
.team-page-wrap{background:var(--canvas)}
.team-page-hero{padding:4rem var(--page-x) 2rem;text-align:center}
.team-page-hero-inner{max-width:42rem;margin:0 auto}
.team-page-hero .eyebrow{justify-content:center;margin-bottom:1rem}
.team-page-hero-title{font-family:var(--serif);font-weight:400;font-size:clamp(2.25rem,5vw,3.75rem);line-height:1.05;letter-spacing:-0.015em;color:var(--ink);margin:0 0 1rem}
.team-page-hero-title em{color:var(--rose);font-style:italic}
.team-page-hero-sub{font-family:var(--sans);font-size:1.0625rem;color:var(--rose-text);line-height:1.55;margin:0 auto;max-width:32rem}

.team-page-roster{padding:1.5rem var(--page-x) 5rem;text-align:center}
.team-page-roster-head{max-width:42rem;margin:0 auto 2rem}
.team-page-roster-sub{font-family:var(--sans);font-size:0.9375rem;color:var(--rose-text);line-height:1.5;margin:0}
.team-page-roster .team-page-grid{padding:0;text-align:left}

@media(max-width:48rem){
  .team-page-hero{padding:3rem var(--page-x) 1.5rem}
}

/* -- Taxonomy directory (category + store index pages) -- */
.taxonomy-directory{max-width:var(--max-w);margin:0 auto}
.taxonomy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.taxonomy-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);text-decoration:none;color:inherit;transition:transform var(--transition),box-shadow var(--transition)}
.taxonomy-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card-hover)}
.taxonomy-card-name{font-family:var(--serif);font-size:1.125rem;font-weight:400;color:var(--ink);line-height:1.2;flex:1;min-width:0}
.taxonomy-card-count{font-size:0.6875rem;color:var(--rose-text);text-transform:uppercase;letter-spacing:0.12em;font-weight:600;white-space:nowrap}
.taxonomy-card-arrow{color:var(--rose-text);flex-shrink:0}
.taxonomy-card:hover .taxonomy-card-arrow .hwr-arrow{transform:translateX(3px)}
@media(max-width:64rem){
  .taxonomy-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:32rem){
  .taxonomy-grid{grid-template-columns:1fr}
}

/* -- Contact page — letter-from-Donna hero + brand-styled form -- */
#page-contact{background:var(--canvas)}

.contact-hero{padding:4.5rem var(--page-x) 4rem;background:var(--canvas);text-align:center}
.contact-hero-inner{max-width:38rem;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.contact-hero-avatar{width:5rem;height:5rem;border-radius:50%;object-fit:cover;border:1px solid rgba(196,132,122,0.4);box-shadow:0 0 0 4px var(--canvas),0 0 0 5px var(--rose);margin-bottom:1.25rem}
.contact-hero .eyebrow{justify-content:center;margin-bottom:0.875rem}
.contact-hero-headline{font-family:var(--serif);font-weight:400;font-size:clamp(2.25rem,4.5vw,3.5rem);line-height:1.05;letter-spacing:-0.015em;color:var(--ink);margin:0 0 1rem}
.contact-hero-headline em{color:var(--rose);font-style:italic}
.contact-hero-lead{font-family:var(--sans);font-size:1.0625rem;color:var(--rose-text);line-height:1.6;margin:0 0 1.5rem;max-width:32rem}
.contact-hero-meta{font-family:var(--sans);font-size:0.75rem;letter-spacing:0.04em;color:var(--rose-text);margin:0 0 2.25rem;display:flex;align-items:center;gap:0.5rem}
.contact-hero-socials{display:flex;gap:0.875rem;flex-wrap:wrap;justify-content:center;width:100%}

.contact-social-pill{display:flex;align-items:center;gap:0.875rem;padding:1rem 1.25rem;background:var(--canvas);border:1px solid rgba(196,132,122,0.35);border-radius:var(--radius-card);text-decoration:none;color:inherit;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);flex:1 1 16rem;min-width:14rem;max-width:20rem;text-align:left}
.contact-social-pill:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover);border-color:var(--rose)}
.contact-social-icon{flex-shrink:0;color:var(--ink);opacity:0.85}
.contact-social-pill:hover .contact-social-icon{color:var(--rose);opacity:1}
.contact-social-text{display:flex;flex-direction:column;gap:0.125rem;min-width:0}
.contact-social-title{font-family:var(--serif);font-size:1rem;font-weight:400;color:var(--ink);line-height:1.2;letter-spacing:-0.005em}
.contact-social-meta{font-family:var(--sans);font-size:0.6875rem;color:var(--rose-text);letter-spacing:0.03em;line-height:1.4}

.contact-form-section{padding:4rem var(--page-x) 5rem;background:var(--off-white);border-top:1px solid var(--border)}
.contact-form-inner{max-width:38rem;margin:0 auto}
.contact-form-head{text-align:center;margin-bottom:2rem}
.contact-form-head .eyebrow{justify-content:center;margin-bottom:0.75rem}
.contact-form-head h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.75rem,3vw,2.25rem);line-height:1.1;letter-spacing:-0.005em;color:var(--ink);margin:0 0 0.5rem}
.contact-form-head h2 em{color:var(--rose);font-style:italic}
.contact-form-sub{font-family:var(--sans);font-size:0.9375rem;color:var(--rose-text);margin:0;line-height:1.5}
.contact-form-empty{font-family:var(--sans);font-size:0.875rem;color:var(--rose-text);font-style:italic;text-align:center;padding:2rem 0}

/* Editor content (paragraphs above the form shortcode) — spacing + brand voice */
.contact-form-content > p,
.contact-form-content > div > p:first-child{font-family:var(--sans);font-size:0.9375rem;color:var(--rose-text);line-height:1.65;margin:0 0 1.5rem;text-align:center}

/* Gravity Forms overrides — full brand-match inside .contact-form-content. Mirrors the styling of .newsletter-cta-* and .sticky-newsletter-* forms. */
.contact-form-content .gform_wrapper{font-family:var(--sans);max-width:none;margin-top:1.75rem}
.contact-form-content .gform_wrapper form{margin:0}
.contact-form-content .gform_wrapper .gform_fields,
.contact-form-content .gform_wrapper ul.gform_fields{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1.125rem}
.contact-form-content .gform_wrapper .gfield{padding:0;margin:0;width:100%}
.contact-form-content .gform_wrapper .gfield_label{font-family:var(--sans);font-size:0.8125rem;font-weight:600;color:var(--ink);letter-spacing:0;text-transform:none;margin:0 0 0.4375rem;display:block;line-height:1.3}
.contact-form-content .gform_wrapper .gfield_required{color:var(--rose);margin-left:0.125rem;font-weight:400}
.contact-form-content .gform_wrapper .gfield_description{font-family:var(--sans);font-size:0.75rem;color:var(--rose-text);line-height:1.5;margin-top:0.4375rem;padding:0}
.contact-form-content .gform_wrapper .ginput_container{margin:0;padding:0}
.contact-form-content .gform_wrapper input[type="text"],
.contact-form-content .gform_wrapper input[type="email"],
.contact-form-content .gform_wrapper input[type="tel"],
.contact-form-content .gform_wrapper input[type="url"],
.contact-form-content .gform_wrapper input[type="number"],
.contact-form-content .gform_wrapper input[type="password"],
.contact-form-content .gform_wrapper textarea,
.contact-form-content .gform_wrapper select{width:100%;max-width:none;border:1px solid rgba(196,132,122,0.5);border-radius:var(--radius-sm);padding:0.8125rem 0.9375rem;background:#fff;color:var(--ink);font-family:var(--sans);font-size:0.9375rem;line-height:1.5;transition:border-color var(--transition);outline:none;box-shadow:none;-webkit-appearance:none;appearance:none;margin:0}
.contact-form-content .gform_wrapper input::placeholder,
.contact-form-content .gform_wrapper textarea::placeholder{color:var(--rose-text);letter-spacing:0.02em;opacity:1}
.contact-form-content .gform_wrapper input:focus,
.contact-form-content .gform_wrapper textarea:focus,
.contact-form-content .gform_wrapper select:focus{border-color:var(--brand)}
.contact-form-content .gform_wrapper textarea{resize:vertical;min-height:9rem;font-family:var(--sans)}

/* Submit button — full-width, matches brand primary CTA. Uses !important to override Gravity Forms 2.7+ CSS-variable theming and inline styles. */
.contact-form-content .gform_wrapper .gform_footer,
.contact-form-content .gform_wrapper .gform_page_footer{margin:1.5rem 0 0 !important;padding:0 !important;display:block !important}
.contact-form-content .gform_wrapper .gform_footer .gform_button,
.contact-form-content .gform_wrapper .gform_page_footer .gform_button,
.contact-form-content .gform_wrapper .gform_footer input[type="submit"],
.contact-form-content .gform_wrapper .gform_page_footer input[type="submit"],
.contact-form-content .gform_wrapper .gform_button.button,
.contact-form-content .gform_wrapper button.gform_button,
.contact-form-content .gform_wrapper button.gform-theme-button,
.contact-form-content .gform_wrapper button.gform-theme-button--primary{display:block !important;width:100% !important;background:var(--ink) !important;color:#fff !important;border:1px solid var(--ink) !important;border-radius:var(--radius-sm) !important;padding:0.9375rem 1.5rem !important;font-size:0.6875rem !important;font-family:var(--sans) !important;font-weight:700 !important;cursor:pointer;letter-spacing:0.18em !important;text-transform:uppercase !important;transition:all var(--transition);white-space:nowrap;-webkit-appearance:none;appearance:none;margin:0 !important;box-shadow:none !important;line-height:1.2 !important;text-shadow:none !important;min-height:0 !important;height:auto !important}
.contact-form-content .gform_wrapper .gform_footer .gform_button:hover,
.contact-form-content .gform_wrapper .gform_page_footer .gform_button:hover,
.contact-form-content .gform_wrapper .gform_footer input[type="submit"]:hover,
.contact-form-content .gform_wrapper .gform_page_footer input[type="submit"]:hover,
.contact-form-content .gform_wrapper button.gform-theme-button:hover,
.contact-form-content .gform_wrapper button.gform-theme-button--primary:hover{background:var(--brand) !important;border-color:var(--brand) !important;color:#fff !important}
.contact-form-content .gform_wrapper .gform_footer .gform_button:active,
.contact-form-content .gform_wrapper .gform_page_footer .gform_button:active,
.contact-form-content .gform_wrapper .gform_footer input[type="submit"]:active,
.contact-form-content .gform_wrapper .gform_page_footer input[type="submit"]:active{transform:scale(0.99)}
.contact-form-content .gform_wrapper .gform_footer .gform_button:disabled,
.contact-form-content .gform_wrapper .gform_footer input[type="submit"]:disabled{background:rgba(0,0,0,0.3) !important;border-color:rgba(0,0,0,0.12) !important;color:rgba(255,255,255,0.7) !important;cursor:not-allowed;transform:none}

/* Character counter / "0 of 2000 max characters" + similar GF helpers */
.contact-form-content .gform_wrapper .charleft,
.contact-form-content .gform_wrapper .ginput_counter,
.contact-form-content .gform_wrapper [aria-live="polite"]{font-family:var(--sans);font-size:0.6875rem;color:var(--rose-text);margin-top:0.4375rem;letter-spacing:0.02em}

/* Validation states */
.contact-form-content .gform_wrapper .gfield.gfield_error input,
.contact-form-content .gform_wrapper .gfield.gfield_error textarea,
.contact-form-content .gform_wrapper .gfield.gfield_error select,
.contact-form-content .gform_wrapper .gfield_error input,
.contact-form-content .gform_wrapper .gfield_error textarea{border-color:#b91c1c;background:#fef2f2}
.contact-form-content .gform_wrapper .gfield_validation_message,
.contact-form-content .gform_wrapper .validation_message{font-family:var(--sans);font-size:0.75rem;color:#b91c1c;margin:0.4375rem 0 0;padding:0;background:none;border:none}
.contact-form-content .gform_wrapper .gform_validation_errors,
.contact-form-content .gform_wrapper .validation_error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;padding:0.75rem 1rem;border-radius:var(--radius-sm);margin-bottom:1.125rem;font-family:var(--sans);font-size:0.875rem;line-height:1.5}
.contact-form-content .gform_wrapper .gform_validation_errors h2{font-family:var(--sans);font-size:0.875rem;font-weight:600;color:#b91c1c;margin:0;padding:0;letter-spacing:0;text-transform:none}

/* Confirmation message after successful submit */
.contact-form-content .gform_confirmation_wrapper,
.contact-form-content .gform_confirmation_message{font-family:var(--serif);font-size:1.125rem;color:var(--ink);text-align:center;padding:2rem 0;line-height:1.5;margin:0}

/* Required-legend + ajax spinner alignment */
.contact-form-content .gform_wrapper .gform_required_legend{font-family:var(--sans);font-size:0.75rem;color:var(--rose-text);margin-bottom:0.875rem;display:block}
.contact-form-content .gform_wrapper .gform_ajax_spinner{margin-left:0.625rem;vertical-align:middle}

/* Honeypot/hidden inputs — never visible */
.contact-form-content .gform_wrapper .gform_validation_container,
.contact-form-content .gform_wrapper .gfield_visibility_hidden{display:none !important}

@media(max-width:32rem){
  .contact-hero{padding:3rem var(--page-x) 2.5rem}
  .contact-hero-socials{flex-direction:column;align-items:stretch}
  .contact-social-pill{max-width:none;flex:1 1 auto}
  .contact-form-section{padding:3rem var(--page-x) 4rem}
}

/* -- Search page (server-rendered fallback) -- */
.search-page{padding:1.5rem var(--page-x) 4rem;max-width:var(--max-w);margin:0 auto}
.search-page-input{display:flex;gap:0;margin-bottom:2rem}
.search-page-input input{flex:1;padding:1rem 1.25rem;border:1px solid var(--ink);border-right:none;font-family:var(--sans);font-size:1rem;color:var(--ink);background:#fff;outline:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm)}
.search-page-input input:focus{border-color:var(--brand)}
.search-page-input button{padding:1rem 1.75rem;background:var(--ink);color:#fff;border:1px solid var(--ink);font-size:0.6875rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;cursor:pointer;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-family:var(--sans);transition:all var(--transition)}
.search-page-input button:hover{background:var(--brand);border-color:var(--brand)}
.search-page-section{margin-bottom:3rem}
.search-page-section h2{font-family:var(--serif);font-size:1.625rem;font-weight:400;color:var(--ink);margin-bottom:1.25rem;letter-spacing:-0.005em;border-bottom:1px solid var(--border);padding-bottom:0.625rem}
.search-page-section h2 em{color:var(--rose-text);font-style:normal;font-size:0.625em;text-transform:uppercase;letter-spacing:0.18em;margin-left:0.5rem;font-weight:600;font-family:var(--sans)}
.search-term-strip{display:flex;flex-wrap:wrap;gap:0.625rem}
.search-term-card{display:flex;flex-direction:column;gap:0.1875rem;padding:0.875rem 1.125rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);min-width:10rem;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}
.search-term-card:hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}
.search-term-name{font-family:var(--serif);font-size:1.0625rem;color:var(--ink);line-height:1.2}
.search-term-count{font-size:0.625rem;text-transform:uppercase;letter-spacing:0.14em;color:var(--rose-text);font-weight:600}
.search-team-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(11rem,1fr));gap:1rem}
.search-team-card{display:flex;flex-direction:column;align-items:center;gap:0.25rem;padding:1.25rem 1rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);text-align:center;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}
.search-team-card:hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}
.search-team-avatar{width:3.5rem;height:3.5rem;border-radius:50%;object-fit:cover;border:1px solid var(--border);margin-bottom:0.375rem}
.search-team-name{font-family:var(--serif);font-size:1rem;color:var(--ink);line-height:1.15}
.search-team-role{font-size:0.625rem;text-transform:uppercase;letter-spacing:0.14em;color:var(--rose);font-weight:700}
.search-team-count{font-size:0.625rem;color:var(--rose-text);letter-spacing:0.04em;margin-top:0.125rem}

/* -- 404 page -- */
.not-found-page{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem var(--page-x);text-align:center;gap:1.25rem}
.not-found-page .eyebrow{justify-content:center;margin-bottom:0.5rem}
.not-found-page h1{font-family:var(--serif);font-size:clamp(3.5rem,7vw,5.5rem);font-weight:400;color:var(--ink);line-height:1;letter-spacing:-0.02em}
.not-found-page h1 em{color:var(--rose);font-style:normal}
.not-found-page p{font-size:1.0625rem;color:var(--body-text);max-width:34rem;line-height:1.6}
.not-found-cta-row{display:flex;flex-wrap:wrap;gap:0.75rem;justify-content:center;margin-top:1.25rem}
.not-found-cta{display:inline-flex;align-items:center;gap:0.5rem;background:var(--ink);color:#fff;padding:0.875rem 1.75rem;font-size:0.6875rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;border-radius:var(--radius-sm);text-decoration:none;border:1px solid var(--ink);transition:all var(--transition);font-family:var(--sans)}
.not-found-cta:hover{background:var(--brand);border-color:var(--brand)}
.not-found-cta.ghost{background:transparent;color:var(--ink)}
.not-found-cta.ghost:hover{background:var(--ink);color:#fff}

/* -- About FB strip — inverted Facebook-blue band: solid FB-blue background, white text + official Facebook brand mark (white circle + blue F) and button -- */
.about-fb-strip{position:relative;background:var(--fb-blue);padding:5rem 0 3rem;border-top:none;border-bottom:none}
.about-fb-strip-mark{position:absolute;top:1.75rem;left:50%;transform:translateX(-50%);width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 3px 8px rgba(0,0,0,0.18));pointer-events:none}
.about-fb-strip-mark svg{width:100%;height:100%;display:block}
.about-fb-strip .fb-strip-inner{padding-top:0}
.about-fb-strip .fb-strip-inner > .eyebrow{justify-content:center;color:rgba(255,255,255,0.9);margin-bottom:0.875rem}
.about-fb-strip .fb-strip-inner > .eyebrow::before{background:rgba(255,255,255,0.6)}
.about-fb-strip .fb-strip-headline{font-family:var(--serif);font-weight:400;font-size:clamp(1.75rem,3vw,2.5rem);color:#fff;line-height:1.15;letter-spacing:-0.005em;margin:0 0 1.75rem;text-align:center}
.about-fb-strip .fb-strip-headline em{font-style:italic;color:#fff}
.about-fb-strip .fb-strip-stats{display:flex;align-items:center;justify-content:center;gap:2.75rem;margin:0 0 1.75rem}
.about-fb-strip .fb-strip-stat{display:flex;flex-direction:column;align-items:center;gap:0.3125rem}
.about-fb-strip .fb-strip-stat-num{font-family:var(--serif);font-weight:400;font-size:clamp(2rem,3.5vw,2.75rem);color:#fff;line-height:1;letter-spacing:-0.01em}
.about-fb-strip .fb-strip-stat-label{font-family:var(--sans);font-size:0.625rem;color:rgba(255,255,255,0.85);text-transform:uppercase;letter-spacing:0.18em;font-weight:600}
.about-fb-strip .fb-strip-stat-divider{width:1px;height:2.5rem;background:rgba(255,255,255,0.3);flex-shrink:0}
.about-fb-strip .fb-strip-inner p{color:rgba(255,255,255,0.88);max-width:30rem;margin-left:auto;margin-right:auto}
.about-fb-strip .fb-strip-inner p strong{color:#fff}
.about-fb-strip .fb-strip-link{color:var(--fb-blue);background:#fff;border:1px solid #fff;border-bottom:1px solid #fff;padding:0.75rem 1.375rem;border-radius:var(--radius-sm);display:inline-flex;align-items:center;gap:0.5rem;text-decoration:none;margin-top:0.625rem;transition:background var(--transition),color var(--transition),transform var(--transition)}
.about-fb-strip .fb-strip-link:hover{background:rgba(255,255,255,0.92);color:var(--fb-blue);border-color:#fff;opacity:1}
.about-fb-strip .fb-strip-link:hover .hwr-arrow{transform:translateX(3px)}

/* -- Carousel section reuse on home (per-category / per-retailer) -- */
.carousel-section{padding-bottom:1rem}
.carousel-section .section-head{margin-bottom:0.5rem}

/* -- Adjustment: section-wrap for non-home pages -- */
.section-wrap-tight{padding:2rem var(--page-x);max-width:var(--max-w);margin-left:auto;margin-right:auto}

@media(max-width:48rem){
  :root{--page-x:1.25rem}
  .alert-bar{font-size:0.6875rem;padding:0.375rem var(--page-x)}
  .nav-bar{gap:0.5rem;padding:0.75rem var(--page-x)}
  .nav-bar .nav-search-btn{margin-left:auto}
  .nav-bar .nav-hamburger{margin-left:0.25rem}
  .nav-links{gap:1rem;order:2;width:100%;justify-content:center}
  .nav-search{order:3;width:100%;margin-left:0;height:2.25rem}
  .hp-hero{padding:0}
  .hp-hero-banner-wrap{padding:0 var(--page-x)}
  .hp-hero-banner-image{aspect-ratio:5/4;max-height:20rem}
  .hp-hero-banner-text{padding:1.25rem 1.25rem 1.5rem}
  .hp-hero-title{font-size:clamp(2.25rem,9vw,3rem)}
  .hp-hero-sub{font-size:1rem}
  .hp-hero-cta{padding:0.875rem 1.25rem;width:100%;justify-content:center}
  .hp-hero-cards-wrap{padding:0 var(--page-x)}
  .hp-hero-cards{grid-template-columns:1fr;gap:0.5rem;margin-top:0.5rem}
  .hp-hero-card{grid-template-columns:1fr;min-height:auto}
  .hp-hero-card-image{aspect-ratio:16/10;order:-1;}
  .hp-hero-card-image::before{background:linear-gradient(to bottom,transparent 0%,transparent 60%,rgba(242,231,221,0.35) 82%,var(--off-white) 100%)}
  .hp-hero-card-text{padding:1.5rem 1.25rem 1.75rem}
  .category-grid{grid-template-columns:1fr;gap:0.625rem}
  .category-tile{aspect-ratio:5/4;padding:1.25rem}
  .category-tile-name{font-size:1.5rem}
  .retailer-strip-inner{gap:1.25rem 1.75rem}
  .about-donna-section{padding:1.5rem var(--page-x) 2rem}
  .about-donna-inner{flex-direction:column;gap:1.5rem;text-align:center;align-items:center;padding:2rem 1.5rem}
  .about-donna-photo{width:7rem}
  .about-donna-photo img{width:7rem;height:10.75rem}
  .about-donna-link{align-self:center}
  .picks-grid{grid-template-columns:1fr 1fr;gap:1rem}
  .archive-head-row{gap:0.5rem}
  .store-affiliate-icon{width:2rem;height:2rem}
  .store-affiliate-icon::after{inset:-6px}
  .store-affiliate-icon svg{width:15px;height:15px}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .sticky-newsletter-close{top:0.5rem;right:0.5rem}
  .footer-columns{grid-template-columns:1fr 1fr;gap:1.5rem}
  .newsletter-cta-section{padding:3rem var(--page-x)}
  .newsletter-cta-fields{flex-direction:column;gap:0.5rem}
  .newsletter-cta-fields input{border-right:1px solid rgba(196,132,122,0.5);border-radius:var(--radius-sm)}
  .newsletter-cta-fields button{border-radius:var(--radius-sm)}
  .newsletter-cta-fields input:focus + button{border-color:var(--brand);background:var(--brand)}
  .sms-opt-in{justify-content:center}
  .about-hero{padding:2rem var(--page-x) 0}
  .about-hero-content{text-align:center}
  .about-hero-content h1{font-size:clamp(2rem,7vw,2.5rem)}
  .about-hero-lead,.about-hero-content p{margin-left:auto;margin-right:auto}
  .about-hero-photo{max-width:20rem}
  .about-stats-section{padding:1.5rem var(--page-x) 0}
  .about-stats-strip{grid-template-columns:repeat(2,1fr);padding:1.25rem 0.75rem}
  .stat-cell{padding:0.5rem}
  .letter-cta{justify-content:center}
  .letter-col{text-align:center}
  .letter-col p{text-align:left}
  .masthead-grid{grid-template-columns:1fr;max-width:24rem;gap:0}
  .leader-nav-btn{display:none}
  .leader-card{flex-direction:column;text-align:center;align-items:center;gap:0.875rem;padding:1.5rem 1.25rem;max-width:22rem}
  .leader-info{align-items:center}
  .team-rest-row{gap:0.875rem 1rem}
  .rest-member{width:3.5rem}
  .brands-section{padding:3rem var(--page-x)}
  .featured-picks-row .pick-card{flex:0 0 85%}
}

/* ============================================================
   WordPress template additions (Phase 5)
   These extend design/styles.css with classes only used by the
   PHP templates (archive headers, author bio, team grid, etc).
   When design/styles.css gets these too, this block goes away.
   ============================================================ */

.skip-link.screen-reader-text:focus{
  position:fixed;left:1rem;top:1rem;z-index:9999;background:var(--ink);color:#fff;
  padding:0.5rem 1rem;text-decoration:none;font-family:var(--sans);font-size:0.8125rem;
  font-weight:600;border-radius:var(--radius-sm);
}

.finds-archive{padding:2rem 0 4rem}
.finds-archive-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--page-x)}
.archive-head{margin-bottom:1.5rem}
.archive-head h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:400;color:var(--ink);letter-spacing:-0.01em;margin:0 0 0.5rem}
.archive-head h1 em{color:var(--rose);font-style:normal}

/* Heading row — flex center when affiliate icon is present.
   No flex-wrap: the icon must stay inline with the heading,
   never drop to its own line. The H1 text wraps naturally. */
.archive-head-row{display:flex;align-items:center;gap:0.875rem}

/* Store affiliate icon button — sits next to the heading.
   Shopping bag icon + tiny external-link badge, no visible text.
   Accessible name on the <a> via aria-label + screen-reader-text;
   tooltip via title attribute for sighted users. */
.store-affiliate-icon{
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;
  width:2.5rem;height:2.5rem;flex-shrink:0;
  color:var(--brand);
  background:transparent;
  border:1px solid var(--brand);
  border-radius:var(--radius-pill);
  text-decoration:none;
  transition:background var(--transition),color var(--transition),transform var(--transition);
}
.store-affiliate-icon:hover{background:var(--brand);color:#fff}
.store-affiliate-icon:active{transform:scale(0.95)}
.store-affiliate-icon:focus-visible{outline:2px solid var(--brand);outline-offset:3px}
.store-affiliate-icon::after{content:'';position:absolute;inset:-4px;border-radius:var(--radius-pill)}

.store-affiliate-icon svg{display:block;transition:transform var(--transition)}
.store-affiliate-icon:hover svg{transform:translate(1px,-1px)}

/* Load More + Continue (JS-enhanced archive pagination).
   The numbered .archive-pagination below remains as the no-JS fallback;
   main.js hides it via [hidden] once the Load More button is active. */
.archive-load-more-wrap{margin-top:3rem;display:flex;flex-direction:column;align-items:center;gap:1rem}
.archive-load-more{display:inline-flex;align-items:center;justify-content:center;gap:0.625rem;min-width:14rem;font-family:var(--sans);font-size:0.8125rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink);background:#fff;padding:1rem 2rem;border:1.5px solid var(--ink);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition)}
.archive-load-more:hover{background:var(--ink);color:#fff}
.archive-load-more:focus-visible{outline:2px solid var(--brand);outline-offset:3px}
.archive-load-more[disabled]{cursor:wait;opacity:0.7}
.archive-load-more.is-loading .archive-load-more-label{opacity:0.4}
.archive-load-more-spinner{width:1rem;height:1rem;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;display:none}
.archive-load-more.is-loading .archive-load-more-spinner{display:inline-block;animation:hwr-spin 700ms linear infinite}
.archive-load-more.has-error{border-color:var(--brand);color:var(--brand)}
.archive-load-more.has-error::before{content:"Retry: ";font-weight:700}
@keyframes hwr-spin{to{transform:rotate(360deg)}}
.archive-continue{display:inline-flex;align-items:center;gap:0.5rem;font-family:var(--sans);font-size:0.8125rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--brand-deep);text-decoration:none;padding:0.75rem 1.25rem;border-bottom:1px solid currentColor;transition:color var(--transition),transform var(--transition)}
.archive-continue:hover{color:var(--brand);transform:translateX(2px)}
.archive-load-more[hidden],.archive-continue[hidden],.archive-pagination[hidden]{display:none}

.archive-pagination{margin-top:3rem;display:flex;justify-content:center}
.archive-pagination .nav-links{display:flex;align-items:center;gap:0.375rem}
.archive-pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:2.25rem;height:2.25rem;padding:0 0.625rem;
  font-family:var(--sans);font-size:0.8125rem;font-weight:600;
  color:var(--rose-text);text-decoration:none;border-radius:999px;
  border:1px solid transparent;
  transition:color var(--transition),border-color var(--transition),background var(--transition);
}
.archive-pagination .page-numbers:hover{color:var(--ink);background:var(--off-white)}
.archive-pagination .page-numbers.current{color:#fff;background:var(--ink);border-color:var(--ink)}
.archive-pagination .page-numbers.current:hover{background:#3a302c}
.archive-pagination .prev,.archive-pagination .next{
  min-width:2.25rem;padding:0;border:1px solid var(--border);color:var(--ink);
}
.archive-pagination .prev svg,.archive-pagination .next svg{display:block}
.archive-pagination .prev:hover,.archive-pagination .next:hover{border-color:var(--ink);background:var(--off-white)}
.archive-pagination .dots{color:var(--rose-text);border:0;pointer-events:none;min-width:1.5rem;padding:0}

.author-page{padding-bottom:4rem}
.author-bio{background:var(--off-white);padding:0 0 3.5rem;border-bottom:1px solid var(--border);margin-bottom:2.5rem}
.author-bio>.breadcrumb{padding-top:2rem;padding-bottom:0;margin-bottom:2rem}
.author-bio-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--page-x);display:flex;align-items:flex-start;gap:2.5rem;flex-wrap:wrap}
.author-avatar{width:8.5rem;height:8.5rem;border-radius:50%;object-fit:cover;border:1px solid var(--border);box-shadow:0 0 0 4px var(--canvas),0 0 0 6px var(--rose);flex-shrink:0}
.author-meta{flex:1;min-width:18rem}
.author-meta h1{font-family:var(--serif);font-size:clamp(2.25rem,4vw,3rem);font-weight:400;color:var(--ink);margin:0.25rem 0 0.375rem;letter-spacing:-0.01em;line-height:1.05}
.author-fun-title{font-size:0.6875rem;color:var(--rose);text-transform:uppercase;letter-spacing:0.16em;font-weight:700;margin:0 0 0.875rem}
.author-bio-text{font-size:1rem;line-height:1.65;color:var(--body-text);max-width:48rem;margin:0 0 0.75rem}
.author-stat{font-size:0.75rem;color:var(--rose-text);text-transform:uppercase;letter-spacing:0.12em;font-weight:600;margin:0}

.team-page{padding:3rem var(--page-x) 1rem;max-width:var(--max-w);margin:0 auto}
.team-page-leaders{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem;max-width:var(--max-w);margin:0 auto 2.5rem;padding:0 var(--page-x)}
.team-page-lead{display:flex;flex-direction:column;align-items:center;text-align:center;width:18rem;text-decoration:none;color:inherit;background:#fff;border:1px solid var(--border);padding:2rem 1.5rem;border-radius:var(--radius-card);transition:transform var(--transition),box-shadow var(--transition)}
.team-page-lead:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}
.team-page-lead-avatar{width:7rem;height:7rem;border-radius:50%;object-fit:cover;margin-bottom:1rem;border:1px solid var(--border);box-shadow:0 0 0 3px var(--canvas),0 0 0 5px var(--rose)}
.team-page-lead-name{font-family:var(--serif);font-size:1.5rem;color:var(--ink);font-weight:400;line-height:1.1}
.team-page-lead-role{font-size:0.6875rem;color:var(--rose);text-transform:uppercase;letter-spacing:0.14em;font-weight:700;margin:0.375rem 0 0.625rem}
.team-page-lead-bio{font-size:0.875rem;color:var(--rose-text);line-height:1.55;margin:0}

.about-fb-strip-inner{max-width:var(--max-w);margin:0 auto;padding:0.5rem var(--page-x) 0;display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap}
.about-fb-stat{text-align:center}
.about-fb-stat-num{font-family:var(--serif);font-size:2rem;font-weight:400;color:var(--ink);line-height:1}
.about-fb-stat-label{font-size:0.6875rem;color:var(--rose-text);text-transform:uppercase;letter-spacing:0.12em;font-weight:600;margin-top:0.375rem}
.about-fb-cta{display:inline-flex;align-items:center;gap:0.5rem;background:var(--fb-blue);color:#fff;text-decoration:none;font-family:var(--sans);font-weight:600;letter-spacing:0.04em;padding:0.875rem 1.5rem;border-radius:999px;font-size:0.8125rem;transition:opacity var(--transition)}
.about-fb-cta:hover{opacity:0.9}

.about-letter-content{font-size:1rem;line-height:1.75;color:var(--body-text);grid-column:2}
.about-letter-content p{margin:0 0 1rem}
.donna-signature-large{font-family:var(--script,'Sacramento'),cursive;font-size:3rem;color:var(--rose);font-weight:400;margin-top:1.5rem}

.about-capture{background:var(--off-white);padding:4rem var(--page-x);border-top:1px solid var(--border);text-align:center}
.about-capture-inner{max-width:34rem;margin:0 auto}
.about-capture-inner h2{font-family:var(--serif);font-size:clamp(1.75rem,3vw,2.25rem);font-weight:400;color:var(--ink);margin:0.625rem 0;letter-spacing:-0.01em}
.about-capture-inner p{color:var(--rose-text);font-size:0.9375rem;margin:0 0 1.5rem}
.about-capture-form{display:inline-block;width:100%;max-width:24rem}
.about-capture-form input{width:100%;padding:0.875rem 1rem;border:1px solid var(--border);font-family:var(--sans);font-size:0.875rem;background:#fff;margin-bottom:0.625rem}
.about-capture-form input:focus{outline:none;border-color:var(--ink)}
.about-capture-form button[type="submit"],.about-capture-form button[data-action="sms"]{width:100%;padding:0.875rem;background:var(--ink);color:#fff;border:none;font-family:var(--sans);font-weight:600;letter-spacing:0.04em;font-size:0.8125rem;text-transform:uppercase;cursor:pointer;transition:opacity var(--transition)}
.about-capture-form button:hover{opacity:0.85}

/* -- Default Page template (legal pages, static content via WP editor) -- */
.page-default{background:var(--canvas)}
.page-default-head{padding:3.5rem var(--page-x) 1.5rem;text-align:center}
.page-default-head-inner{max-width:42rem;margin:0 auto}
.page-default-title{font-family:var(--serif);font-weight:400;font-size:clamp(2.25rem,4vw,3.25rem);line-height:1.05;letter-spacing:-0.015em;color:var(--ink);margin:0}
.page-default-meta{font-family:var(--sans);font-size:0.75rem;color:var(--rose-text);letter-spacing:0.04em;margin:0.875rem 0 0}
.page-default-content{padding:1.25rem var(--page-x) 5rem}
.page-default-content-inner{max-width:42rem;margin:0 auto;font-family:var(--sans);font-size:1rem;line-height:1.7;color:var(--body-text)}
.page-default-content-inner > *:first-child{margin-top:0}
.page-default-content-inner > *:last-child{margin-bottom:0}
.page-default-content-inner h2{font-family:var(--serif);font-weight:400;font-size:1.625rem;line-height:1.2;letter-spacing:-0.005em;color:var(--ink);margin:2.25rem 0 0.875rem}
.page-default-content-inner h3{font-family:var(--serif);font-weight:400;font-size:1.25rem;line-height:1.25;color:var(--ink);margin:1.75rem 0 0.625rem}
.page-default-content-inner h4{font-family:var(--sans);font-weight:700;font-size:0.8125rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink);margin:1.5rem 0 0.5rem}
.page-default-content-inner p{margin:0 0 1.125rem}
.page-default-content-inner a{color:var(--brand);text-decoration:underline;text-decoration-color:rgba(167,95,55,0.4);text-underline-offset:0.1875rem;transition:color 150ms,text-decoration-color 150ms}
.page-default-content-inner a:hover{color:var(--brand-deep);text-decoration-color:var(--brand-deep)}
.page-default-content-inner ul,.page-default-content-inner ol{margin:0 0 1.125rem;padding-left:1.25rem}
.page-default-content-inner li{margin:0.375rem 0}
.page-default-content-inner strong{color:var(--ink);font-weight:700}
.page-default-content-inner em{font-style:italic}
.page-default-content-inner blockquote{border-left:3px solid var(--rose);padding:0.5rem 0 0.5rem 1.25rem;margin:1.5rem 0;font-family:var(--serif);font-style:italic;color:var(--ink);font-size:1.125rem;line-height:1.5}
.page-default-content-inner hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}
.page-default-content-inner table{width:100%;border-collapse:collapse;margin:0 0 1.5rem;font-size:0.9375rem}
.page-default-content-inner table th,.page-default-content-inner table td{padding:0.625rem 0.875rem;text-align:left;border-bottom:1px solid var(--border)}
.page-default-content-inner table th{font-family:var(--sans);font-weight:700;color:var(--ink);background:var(--off-white)}
.page-default-content-inner img{max-width:100%;height:auto;border-radius:var(--radius-sm);margin:0.75rem 0}
.page-default-pagination{margin:2rem 0 0;padding:1.25rem 0 0;border-top:1px solid var(--border);font-family:var(--sans);font-size:0.875rem;color:var(--rose-text);display:flex;align-items:center;gap:0.625rem;flex-wrap:wrap}
.page-default-pagination-label{font-weight:700;text-transform:uppercase;letter-spacing:0.12em;font-size:0.6875rem}
.page-default-pagination a{color:var(--ink);padding:0.25rem 0.5rem;border-radius:var(--radius-sm);text-decoration:none;transition:background 150ms}
.page-default-pagination a:hover{background:var(--off-white)}

.section-404{padding:5rem var(--page-x);max-width:var(--max-w);margin:0 auto;text-align:center}
.section-404 h1{font-family:var(--serif);font-size:clamp(2.25rem,5vw,3.25rem);font-weight:400;color:var(--ink);margin:0.5rem 0;letter-spacing:-0.01em}

.hwr-searchform{display:flex;gap:0.5rem;align-items:stretch}
.hwr-searchform-input{flex:1;padding:0.875rem 1rem;border:1px solid var(--border);font-family:var(--sans);font-size:0.9375rem;background:#fff}
.hwr-searchform-input:focus{outline:none;border-color:var(--ink)}
.hwr-searchform-btn{padding:0.875rem 1.25rem;background:var(--ink);color:#fff;border:none;font-family:var(--sans);font-weight:600;letter-spacing:0.04em;font-size:0.8125rem;text-transform:uppercase;cursor:pointer;transition:opacity var(--transition)}
.hwr-searchform-btn:hover{opacity:0.85}

.hwr-archive-stat-banner{display:none}

@media (max-width:768px){
  .picks-grid{grid-template-columns:repeat(2,1fr);gap:1rem}
  .author-bio{padding-bottom:2.5rem}
  .author-bio-inner{flex-direction:column;align-items:center;text-align:center;gap:1.5rem}
  .author-meta{min-width:0;width:100%}
  .author-meta .eyebrow{justify-content:center}
  .author-avatar{width:6.5rem;height:6.5rem}
  .author-bio-text{margin-left:auto;margin-right:auto;text-align:left}
}
@media (max-width:480px){
  .picks-grid{grid-template-columns:1fr}
}
