/*
 * sfb-shared.css  -  Sex For Beginners Design System
 * Enqueued on every page. No page-specific rules here.
 *
 * TABLE OF CONTENTS
 *  1.  Design Tokens
 *  2.  Google Fonts Import
 *  3.  Reset & Base
 *  4.  Layout helpers
 *  5.  Header & Navigation
 *  6.  Search Overlay
 *  7.  Breadcrumb
 *  8.  Section Anatomy
 *  9.  Cards (standard, featured, horizontal, position, tool)
 * 10.  Grids
 * 11.  Sidebar & Widgets
 * 12.  Newsletter Strip
 * 13.  Pagination
 * 14.  Footer
 * 15.  Back to Top
 * 16.  Prose / the_content() Typography
 * 17.  FluentForm Overrides
 * 18.  Responsive
 * 19.  Soledad / Lusty Parent Overrides
 */

/* ============================================================
   1. DESIGN TOKENS
============================================================ */
:root {
  --coral:   #E8536A;
  --navy:    #2D3A6B;
  --dark:    #1A1C2E;
  --magenta: #C2185B;
  --gold:    #C8956C;
  --blush:   #FDE8EE;
  --smoke:   #F7F4F6;
  --border:  #ECE6EC;
  --t1:      #1A1426;
  --t2:      #5C5068;
  --t3:      #9B8FA8;
  --serif:   'Playfair Display', Georgia, serif;
  --sans:    'DM Sans', system-ui, sans-serif;
  --ease:    cubic-bezier(.25,.8,.25,1);
}

/* ============================================================
   2. GOOGLE FONTS
   Loaded via wp_enqueue_style() in functions.php - not @import.
============================================================ */

/* ============================================================
   3. RESET & BASE
============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);color:var(--t1);background:#fff;line-height:1.6;overflow-x:hidden}
img,video{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:var(--sans)}

/* ============================================================
   4. LAYOUT
============================================================ */
.sfb-wrap{max-width:1200px;margin:0 auto;padding:0 clamp(16px,4vw,48px)}
.sfb-wrap--text{max-width:860px;margin:0 auto;padding:0 clamp(16px,4vw,48px)}

/* ============================================================
   5. HEADER & NAVIGATION
============================================================ */
.sfb-header{
  background:var(--dark);position:sticky;top:0;z-index:200;
  box-shadow:0 1px 0 rgba(255,255,255,.06);transition:background .2s;
}
.sfb-header.is-scrolled{
  background:rgba(26,28,46,.94);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.admin-bar .sfb-header{top:32px}
@media screen and (max-width:782px){.admin-bar .sfb-header{top:46px}}

.sfb-header__inner{
  display:flex;align-items:center;
  justify-content:space-between;
  height:64px;gap:24px;
}
.sfb-logo img{height:42px;width:auto;display:block}

/* Desktop nav */
.sfb-nav{display:flex;align-items:center}
.sfb-nav a{
  font-size:13px;font-weight:500;
  color:rgba(255,255,255,.75);
  padding:8px 14px;display:block;
  transition:color .15s;white-space:nowrap;
}
.sfb-nav a:hover,
.sfb-nav a.sfb-active,
.sfb-nav .current-menu-item>a,
.sfb-nav .current-menu-ancestor>a{color:#fff}

/* Header search button */
.sfb-header__search{
  color:rgba(255,255,255,.6);padding:6px;border-radius:4px;
  display:flex;align-items:center;transition:color .15s;flex-shrink:0;
}
.sfb-header__search:hover{color:#fff}

/* Mobile toggle */
.sfb-nav-toggle{display:none;padding:6px;color:rgba(255,255,255,.8);flex-shrink:0}
.sfb-nav-toggle svg{display:block}

/* Mobile drawer */
.sfb-mobile-nav{
  display:none;flex-direction:column;
  background:#13152a;
  border-top:1px solid rgba(255,255,255,.05);
  padding:8px 0 16px;
}
.sfb-mobile-nav.is-open{display:flex}
.sfb-mobile-nav a{
  font-size:14px;font-weight:500;
  color:rgba(255,255,255,.75);
  padding:13px 20px;
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:color .15s,background .15s;
}
.sfb-mobile-nav a:hover,
.sfb-mobile-nav .current-menu-item>a{color:#fff;background:rgba(255,255,255,.04)}

/* ============================================================
   6. SEARCH OVERLAY
============================================================ */
.sfb-search-overlay{
  display:none;position:fixed;inset:0;z-index:500;
  background:rgba(13,12,22,.85);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  align-items:flex-start;justify-content:center;padding-top:120px;
}
.sfb-search-overlay.is-open{display:flex}
.sfb-search-overlay__box{
  width:100%;max-width:640px;
  margin:0 clamp(16px,4vw,32px);position:relative;
}
.sfb-search-overlay__input{
  width:100%;font-size:18px;
  padding:18px 56px 18px 22px;
  border:none;border-radius:6px;
  background:#ffffff !important;
  color:#1A1426 !important;
  outline:none;
  box-shadow:0 8px 40px rgba(0,0,0,.35);
  -webkit-text-fill-color:#1A1426 !important;
}
.sfb-search-overlay__input::placeholder{color:#9B8FA8 !important;opacity:1}
.sfb-search-overlay__submit{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  width:40px;height:40px;border-radius:4px;
  background:var(--coral);color:#fff;border:none;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .15s;
}
.sfb-search-overlay__submit:hover{background:var(--magenta)}
.sfb-search-overlay__close{
  position:absolute;top:-48px;right:0;
  color:rgba(255,255,255,.7);font-size:13px;font-weight:600;
  display:flex;align-items:center;gap:6px;
  cursor:pointer;transition:color .15s;background:none;border:none;
}
.sfb-search-overlay__close:hover{color:#fff}

/* ============================================================
   7. BREADCRUMB
============================================================ */
.sfb-breadcrumb{
  background:var(--smoke);
  border-bottom:1px solid var(--border);padding:10px 0;
}
.sfb-breadcrumb__inner{
  display:flex;align-items:center;gap:8px;
  font-size:12px;color:var(--t3);flex-wrap:wrap;
}
.sfb-breadcrumb__inner a{color:var(--t3);transition:color .14s}
.sfb-breadcrumb__inner a:hover{color:var(--coral)}
.sfb-breadcrumb__sep{font-size:10px;color:var(--border)}
.sfb-breadcrumb__current{color:var(--t2);font-weight:500}

/* ============================================================
   8. SECTION ANATOMY
============================================================ */
.sfb-section{padding:clamp(36px,5vw,64px) 0}
.sfb-section--smoke{background:var(--smoke)}
.sfb-section--dark{background:var(--dark)}
.sfb-divider{height:1px;background:var(--border);margin:0}

.sfb-section-head{
  display:flex;align-items:flex-end;
  justify-content:space-between;
  padding-bottom:14px;border-bottom:2px solid var(--t1);
  margin-bottom:24px;gap:12px;flex-wrap:wrap;
}
.sfb-section-head--dark{border-color:rgba(255,255,255,.15)}

.sfb-section-label{
  font-size:10px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--coral);
  display:block;margin-bottom:4px;
}
.sfb-section-label--gold{color:var(--gold)}

.sfb-section-title{
  font-family:var(--serif);
  font-size:clamp(1.35rem,2.2vw,1.8rem);
  font-weight:700;color:var(--t1);line-height:1.15;
}
.sfb-section-title--white{color:#fff}

.sfb-view-all{
  font-size:12px;font-weight:600;color:var(--coral);
  white-space:nowrap;display:inline-flex;align-items:center;
  gap:4px;letter-spacing:.03em;text-transform:uppercase;
  flex-shrink:0;transition:color .15s,gap .15s;
}
.sfb-view-all:hover{color:var(--magenta);gap:7px}
.sfb-view-all--gold{color:var(--gold)}
.sfb-view-all--gold:hover{color:#fff}
.sfb-view-all svg{width:13px;height:13px}

/* ============================================================
   9. CARDS
============================================================ */

/* Shared */
.sfb-card-thumb{overflow:hidden;background:var(--blush);flex-shrink:0}
.sfb-card-thumb img{width:100%;height:100% !important;object-fit:cover;transition:transform .5s var(--ease);display:block}
.sfb-card-cat{
  font-size:10px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--coral);
  display:block;margin-bottom:7px;
}

/* Standard vertical */
.sfb-card{
  display:block;border:1px solid var(--border);
  border-radius:6px;background:#fff;overflow:hidden;
  transition:box-shadow .22s var(--ease),transform .22s var(--ease),border-color .22s;
}
.sfb-card:hover{
  box-shadow:0 6px 28px rgba(45,58,107,.11);
  transform:translateY(-3px);border-color:transparent;
}
.sfb-card .sfb-card-thumb{aspect-ratio:16/9}
.sfb-card:hover .sfb-card-thumb img{transform:scale(1.06)}
.sfb-card__body{padding:16px 18px 20px}
.sfb-card__title{
  font-family:var(--serif);font-size:16px;font-weight:700;
  color:var(--navy);line-height:1.35;margin-bottom:9px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  transition:color .15s;
}
.sfb-card:hover .sfb-card__title{color:var(--coral)}
.sfb-card__title a{color:inherit}
.sfb-card__excerpt{
  font-size:13px;color:var(--t2);line-height:1.65;
  margin-bottom:12px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.sfb-card__meta{
  font-size:11px;color:var(--t3);
  display:flex;align-items:center;gap:7px;
}
.sfb-card__meta-dot{width:3px;height:3px;border-radius:50%;background:currentColor;flex-shrink:0}

/* Featured (image left, text right) */
.sfb-card--featured{
  display:grid;grid-template-columns:1.1fr 1fr;
  border-radius:6px;overflow:hidden;background:#fff;
  border:1px solid var(--border);
  box-shadow:0 2px 10px rgba(45,58,107,.06);
  transition:box-shadow .25s var(--ease),transform .25s var(--ease),border-color .22s;
  margin-bottom:24px;
}
.sfb-card--featured:hover{
  box-shadow:0 8px 30px rgba(45,58,107,.12);
  transform:translateY(-3px);border-color:transparent;
}
.sfb-card--featured .sfb-card-thumb{min-height:280px;aspect-ratio:unset}
.sfb-card--featured:hover .sfb-card-thumb img{transform:scale(1.04)}
.sfb-card--featured__body{
  padding:32px 32px 28px;
  display:flex;flex-direction:column;justify-content:center;
}
.sfb-card--featured__title{
  font-family:var(--serif);
  font-size:clamp(1.2rem,1.8vw,1.6rem);
  font-weight:700;color:var(--navy);line-height:1.3;
  margin-bottom:12px;transition:color .15s;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.sfb-card--featured:hover .sfb-card--featured__title{color:var(--coral)}
.sfb-card--featured__excerpt{
  font-size:14px;color:var(--t2);line-height:1.7;
  margin-bottom:16px;
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
}
.sfb-card--featured__meta{font-size:12px;color:var(--t3);display:flex;align-items:center;gap:8px}
.sfb-meta-dot{width:3px;height:3px;border-radius:50%;background:currentColor;flex-shrink:0}

.sfb-read-more{
  display:inline-flex;align-items:center;gap:5px;
  font-size:13px;font-weight:600;color:var(--coral);
  margin-top:12px;transition:gap .14s,color .14s;
}
.sfb-read-more:hover{gap:9px;color:var(--magenta)}
.sfb-read-more svg{width:13px}

/* Horizontal compact */
.sfb-card--horiz{
  display:flex !important;
  flex-direction:row !important;
  border-radius:6px;overflow:hidden;
  border:1px solid var(--border);background:#fff;
  transition:box-shadow .22s var(--ease),transform .22s var(--ease),border-color .2s;
  text-decoration:none;color:inherit;
}
.sfb-card--horiz:hover{
  box-shadow:0 6px 22px rgba(45,58,107,.11);
  transform:translateY(-2px);border-color:transparent;
}
.sfb-card--horiz .sfb-card-thumb{
  width:100px !important;
  min-height:80px;
  flex-shrink:0;
  overflow:hidden;
  background:var(--blush);
  aspect-ratio:unset !important;
}
.sfb-card--horiz .sfb-card-thumb img{
  width:100% !important;
  height:100% !important;
  object-fit:cover;
  display:block;
}
.sfb-card--horiz:hover .sfb-card-thumb img{transform:scale(1.07)}
.sfb-card--horiz__body{padding:12px 14px;display:flex;flex-direction:column;justify-content:center;flex:1;min-width:0}
.sfb-card--horiz__title{
  font-family:var(--serif);font-size:14px;font-weight:700;
  color:var(--navy);line-height:1.35;margin-bottom:6px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  transition:color .14s;
}
.sfb-card--horiz__title a{color:inherit;text-decoration:none}
.sfb-card--horiz:hover .sfb-card--horiz__title{color:var(--coral)}
.sfb-card--horiz__meta{font-size:11px;color:var(--t3)}

/* Position card */
.sfb-pos-card{
  display:block;border-radius:6px;overflow:hidden;
  position:relative;aspect-ratio:3/4;background:var(--blush);
  box-shadow:0 1px 4px rgba(45,58,107,.08);
  transition:box-shadow .22s var(--ease),transform .22s var(--ease);
}
.sfb-pos-card:hover{box-shadow:0 6px 20px rgba(45,58,107,.14);transform:translateY(-3px)}
.sfb-pos-card__img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;transition:transform .4s var(--ease);
}
.sfb-pos-card:hover .sfb-pos-card__img{transform:scale(1.07)}
.sfb-pos-card__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,8,20,.88) 0%,rgba(10,8,20,.08) 55%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:14px 12px;
}
.sfb-pos-card__name{
  font-family:var(--serif);font-size:13px;font-weight:700;
  color:#fff;line-height:1.2;display:block;
}

/* Tool card (light bg) */
.sfb-tool-card{
  display:flex;align-items:flex-start;gap:14px;
  padding:16px 18px;border:1px solid var(--border);
  border-radius:6px;background:var(--smoke);
  transition:box-shadow .2s var(--ease),border-color .2s,transform .2s var(--ease);
}
.sfb-tool-card:hover{box-shadow:0 4px 18px rgba(45,58,107,.09);border-color:transparent;transform:translateY(-2px)}
.sfb-tool-card__icon{
  font-size:20px;flex-shrink:0;width:40px;height:40px;
  border-radius:6px;background:var(--blush);
  display:flex;align-items:center;justify-content:center;
}
.sfb-tool-card__name{font-family:var(--serif);font-size:14px;font-weight:700;color:var(--navy);margin-bottom:3px;line-height:1.3}
.sfb-tool-card__desc{font-size:12px;color:var(--t3);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ============================================================
   10. GRIDS
============================================================ */
.sfb-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sfb-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.sfb-pos-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.sfb-tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.sfb-editorial{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
.sfb-editorial__stack{display:flex;flex-direction:column;gap:16px}

/* ============================================================
   11. SIDEBAR & WIDGETS
============================================================ */
.sfb-sidebar-layout{
  display:grid !important;
  grid-template-columns:1fr 280px !important;
  gap:48px;
  align-items:start;
}
.sfb-sidebar{
  position:sticky;
  top:84px;
  display:block !important;   /* override any parent display:none */
}

.sfb-widget{border:1px solid var(--border);border-radius:6px;background:var(--smoke);padding:20px 18px;margin-bottom:22px}
.sfb-widget:last-child{margin-bottom:0}
.sfb-widget__title{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--navy);padding-bottom:10px;border-bottom:2px solid var(--coral);margin-bottom:14px}

/* Numbered list */
.sfb-numbered{display:flex;flex-direction:column;counter-reset:sfb-num}
.sfb-numbered__item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);counter-increment:sfb-num}
.sfb-numbered__item:last-child{border-bottom:none;padding-bottom:0}
.sfb-numbered__item::before{content:counter(sfb-num);font-family:var(--serif);font-weight:700;font-size:20px;color:var(--coral);line-height:1;flex-shrink:0;width:20px;opacity:.35}
.sfb-numbered__item a{font-size:13px;font-weight:500;color:var(--navy);line-height:1.4;transition:color .14s}
.sfb-numbered__item a:hover{color:var(--coral)}

/* Category list */
.sfb-cat-list{display:flex;flex-direction:column}
.sfb-cat-list__item{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border)}
.sfb-cat-list__item:last-child{border-bottom:none;padding-bottom:0}
.sfb-cat-list__item a{font-size:13px;font-weight:500;color:var(--navy);transition:color .14s}
.sfb-cat-list__item:hover a{color:var(--coral)}
.sfb-cat-list__count{font-size:11px;color:var(--t3)}

/* Link list (quick-links, pages) */
.sfb-link-list{display:flex;flex-direction:column}
.sfb-link-list a{display:block;font-size:13px;font-weight:500;color:var(--navy);padding:9px 0;border-bottom:1px solid var(--border);transition:color .14s}
.sfb-link-list a:last-child{border-bottom:none;padding-bottom:0}
.sfb-link-list a:hover{color:var(--coral)}

/* Sidebar newsletter */
.sfb-widget__nl-title{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--navy);margin-bottom:6px}
.sfb-widget__nl-sub{font-size:12px;color:var(--t2);margin-bottom:14px;line-height:1.55}
.sfb-widget__nl-form{display:flex;flex-direction:column;gap:8px}
.sfb-widget__nl-input{font-size:13px;padding:10px 12px;border-radius:4px;border:1.5px solid var(--border);background:#fff;color:var(--t1);outline:none;transition:border-color .14s}
.sfb-widget__nl-input:focus{border-color:var(--coral)}
.sfb-widget__nl-btn{padding:10px 16px;border-radius:4px;background:var(--coral);color:#fff;font-weight:600;font-size:13px;border:none;cursor:pointer;transition:background .14s}
.sfb-widget__nl-btn:hover{background:var(--magenta)}

/* ============================================================
   12. NEWSLETTER STRIP
============================================================ */
.sfb-nl-strip{background:var(--blush);border-top:3px solid var(--coral);padding:32px 0}
.sfb-nl-strip__inner{display:flex;align-items:center;gap:32px;flex-wrap:wrap;justify-content:center;text-align:center}
.sfb-nl-strip__title{font-family:var(--serif);font-size:clamp(1.2rem,2vw,1.5rem);font-weight:700;color:var(--navy);margin-bottom:4px}
.sfb-nl-strip__sub{font-size:13px;color:var(--t2)}
.sfb-nl-strip__form{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.sfb-nl-strip__input{font-size:14px;padding:11px 16px;border-radius:4px;border:1.5px solid #d4c8d4;background:#fff;color:var(--t1);outline:none;min-width:240px;transition:border-color .15s}
.sfb-nl-strip__input:focus{border-color:var(--coral)}
.sfb-nl-strip__btn{padding:11px 22px;border-radius:4px;background:var(--coral);color:#fff;font-weight:600;font-size:14px;border:none;cursor:pointer;transition:background .15s;white-space:nowrap}
.sfb-nl-strip__btn:hover{background:var(--magenta)}

/* ============================================================
   13. PAGINATION
============================================================ */
.sfb-pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 0 4px}
.sfb-page-btn{
  min-width:38px;height:38px;border-radius:4px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:600;color:var(--t2);
  border:1px solid var(--border);background:#fff;
  padding:0 8px;gap:4px;
  transition:background .15s,color .15s,border-color .15s;
}
.sfb-page-btn:hover{background:var(--smoke);color:var(--navy)}
.sfb-page-btn.is-current{background:var(--coral);color:#fff;border-color:var(--coral)}
.sfb-page-btn--dots{border:none;background:none;cursor:default;color:var(--t3)}

/* ============================================================
   14. FOOTER
============================================================ */
.sfb-footer{background:var(--dark);color:rgba(255,255,255,.65);border-top:3px solid var(--coral)}
.sfb-footer__body{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding:clamp(40px,6vw,64px) 0 clamp(28px,4vw,44px)}
.sfb-footer__logo{height:38px;width:auto;margin-bottom:14px;display:block}
.sfb-footer__about{font-size:13px;line-height:1.7;color:rgba(255,255,255,.45);max-width:280px}
.sfb-footer__adult{margin-top:18px;padding:12px 14px;border-radius:4px;border:1px solid rgba(232,83,106,.2);background:rgba(232,83,106,.07);font-size:11.5px;line-height:1.65;color:rgba(255,255,255,.42)}
.sfb-footer__adult strong{color:var(--coral)}
.sfb-footer__col-title{font-family:var(--serif);font-size:14px;font-weight:700;color:#fff;margin-bottom:14px}
.sfb-footer__links{display:flex;flex-direction:column;gap:9px}
.sfb-footer__links a{font-size:13px;color:rgba(255,255,255,.5);transition:color .14s}
.sfb-footer__links a:hover{color:var(--coral)}
.sfb-footer__search{display:flex;gap:6px;margin-top:2px}
.sfb-footer__search-input{flex:1;font-size:13px;padding:9px 12px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:#fff;outline:none;transition:border-color .14s}
.sfb-footer__search-input::placeholder{color:rgba(255,255,255,.28)}
.sfb-footer__search-input:focus{border-color:var(--coral)}
.sfb-footer__search-btn{padding:9px 14px;border-radius:4px;background:var(--coral);color:#fff;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:background .14s}
.sfb-footer__search-btn:hover{background:var(--magenta)}
.sfb-footer__bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;border-top:1px solid rgba(255,255,255,.07);padding:18px 0;font-size:12px;color:rgba(255,255,255,.32)}
.sfb-footer__legal{display:flex;gap:16px;flex-wrap:wrap}
.sfb-footer__legal a{color:rgba(255,255,255,.38);font-size:12px;transition:color .14s}
.sfb-footer__legal a:hover{color:var(--coral)}

/* ============================================================
   15. BACK TO TOP
============================================================ */
.sfb-btt{position:fixed;bottom:24px;right:24px;width:40px;height:40px;border-radius:4px;background:var(--coral);color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;transform:translateY(6px);z-index:100;box-shadow:0 2px 12px rgba(232,83,106,.4)}
.sfb-btt.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.sfb-btt:hover{background:var(--magenta);color:#fff}

/* ============================================================
   16. PROSE / the_content() TYPOGRAPHY
   Wrap the_content() output in .sfb-prose
============================================================ */
.sfb-prose h2,.sfb-prose h3,.sfb-prose h4{font-family:var(--serif);color:var(--navy);line-height:1.25}
.sfb-prose h2{font-size:clamp(1.2rem,2vw,1.55rem);font-weight:700;margin:36px 0 12px}
.sfb-prose h3{font-size:1.05rem;font-weight:700;margin:24px 0 8px}
.sfb-prose h2:first-child,.sfb-prose h3:first-child{margin-top:0}
.sfb-prose p{font-size:16px;color:var(--t2);line-height:1.8;margin-bottom:20px}
.sfb-prose p:last-child{margin-bottom:0}
.sfb-prose ul,.sfb-prose ol{margin:0 0 20px 22px;display:flex;flex-direction:column;gap:8px}
.sfb-prose ul li{list-style:disc;font-size:15px;color:var(--t2);line-height:1.7}
.sfb-prose ol li{list-style:decimal;font-size:15px;color:var(--t2);line-height:1.7}
.sfb-prose strong{font-weight:600;color:var(--navy)}
.sfb-prose a{color:var(--coral);border-bottom:1px solid rgba(232,83,106,.25);transition:border-color .14s}
.sfb-prose a:hover{border-color:var(--coral)}
.sfb-prose blockquote{border-left:3px solid var(--coral);padding:14px 20px;margin:24px 0;background:var(--blush);border-radius:0 6px 6px 0}
.sfb-prose blockquote p{font-style:italic;margin:0}
.sfb-prose hr{border:none;border-top:1px solid var(--border);margin:32px 0}
.sfb-prose img{border-radius:6px;margin:24px 0}
.sfb-prose table{width:100%;border-collapse:collapse;font-size:14px;margin-bottom:20px}
.sfb-prose th{background:var(--smoke);font-weight:600;color:var(--navy);text-align:left;padding:10px 14px;border:1px solid var(--border)}
.sfb-prose td{padding:9px 14px;border:1px solid var(--border);color:var(--t2);vertical-align:top}
.sfb-prose tr:nth-child(even) td{background:var(--smoke)}

/* ============================================================
   17. FLUENTFORM OVERRIDES
============================================================ */
.sfb-fluentform .ff-el-input--label label{font-family:var(--sans)!important;font-size:13px!important;font-weight:600!important;color:var(--t1)!important;margin-bottom:6px!important}
.sfb-fluentform input[type="text"],
.sfb-fluentform input[type="email"],
.sfb-fluentform textarea,
.sfb-fluentform select{font-family:var(--sans)!important;font-size:14px!important;border:1.5px solid var(--border)!important;border-radius:4px!important;padding:11px 14px!important;color:var(--t1)!important;transition:border-color .14s!important;box-shadow:none!important}
.sfb-fluentform input:focus,.sfb-fluentform textarea:focus,.sfb-fluentform select:focus{border-color:var(--coral)!important;outline:none!important}
.sfb-fluentform .ff-btn-submit{background:var(--coral)!important;border:none!important;border-radius:4px!important;font-family:var(--sans)!important;font-weight:600!important;font-size:14px!important;padding:12px 28px!important;cursor:pointer!important;transition:background .14s!important}
.sfb-fluentform .ff-btn-submit:hover{background:var(--magenta)!important}

/* ============================================================
   18. RESPONSIVE
============================================================ */
@media (max-width:1100px){
  .sfb-footer__body{grid-template-columns:1fr 1fr}
  .sfb-sidebar-layout{grid-template-columns:1fr}
  .sfb-sidebar{display:none}
  .sfb-pos-grid{grid-template-columns:repeat(4,1fr)}
}

@media (max-width:768px){
  .sfb-nav,.sfb-header__search{display:none}
  .sfb-nav-toggle{display:flex}
  .sfb-card--featured{grid-template-columns:1fr}
  .sfb-card--featured .sfb-card-thumb{min-height:200px;aspect-ratio:16/9}
  .sfb-card--featured__body{padding:22px}
  .sfb-grid-3{grid-template-columns:repeat(2,1fr)}
  .sfb-grid-2{grid-template-columns:1fr}
  .sfb-editorial{grid-template-columns:1fr}
  .sfb-pos-grid{grid-template-columns:repeat(3,1fr)}
  .sfb-tools-grid{grid-template-columns:1fr}
  .sfb-footer__body{grid-template-columns:1fr;gap:28px}
  .sfb-footer__about{max-width:none}
  .sfb-footer__bottom{flex-direction:column;text-align:center}
  .sfb-footer__legal{justify-content:center}
  .sfb-nl-strip__inner{flex-direction:column}
  .sfb-nl-strip__input{min-width:unset;width:100%}
}

@media (max-width:480px){
  .sfb-grid-3{grid-template-columns:1fr}
  .sfb-pos-grid{grid-template-columns:repeat(2,1fr)}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important}
}

/* ============================================================
   19. SOLEDAD / LUSTY PARENT OVERRIDES
   Hide parent elements we replace with our own.
============================================================ */
#header,.penci-header-wrap{display:none!important}
#footer,.penci-footer{display:none!important}
.penci-breadcrumb.single-breadcrumb{display:none}

/* ============================================================
   PAGE-SPECIFIC STYLES
   Previously inlined in template files via add_action('wp_head').
   Moved here so they load correctly via wp_enqueue_style().
============================================================ */

/* ---- Homepage hero ---- */
.sfb-site-hero{background:var(--dark);padding:44px 0 40px;border-bottom:1px solid rgba(255,255,255,.06)}
.sfb-site-hero__inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.sfb-site-hero__eyebrow{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:12px}
.sfb-site-hero__title{font-family:var(--serif);font-size:clamp(1.9rem,3.2vw,3rem);font-weight:700;color:#fff;line-height:1.18;margin-bottom:16px}
.sfb-site-hero__title em{font-style:italic;color:var(--coral)}
.sfb-site-hero__desc{font-size:15px;font-weight:300;color:rgba(240,236,245,.68);line-height:1.75;margin-bottom:28px;max-width:460px}
.sfb-site-hero__btns{display:flex;gap:12px;flex-wrap:wrap}
.sfb-btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--sans);font-weight:600;font-size:14px;padding:11px 24px;border-radius:999px;border:2px solid transparent;transition:all .22s var(--ease);text-decoration:none;white-space:nowrap}
.sfb-btn--primary{background:linear-gradient(135deg,#E8536A,#C2185B);color:#fff;box-shadow:0 3px 14px rgba(232,83,106,.35)}
.sfb-btn--primary:hover{color:#fff;filter:brightness(1.08);box-shadow:0 5px 20px rgba(232,83,106,.48);transform:translateY(-1px)}
.sfb-btn--ghost{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:rgba(240,236,245,.85)}
.sfb-btn--ghost:hover{background:rgba(255,255,255,.14);color:#fff}
.sfb-site-hero__cats{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sfb-hcat{display:block;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px 18px;transition:background .2s,border-color .2s,transform .2s var(--ease);text-decoration:none}
.sfb-hcat:hover{background:rgba(232,83,106,.14);border-color:rgba(232,83,106,.35);transform:translateY(-2px)}
.sfb-hcat__icon{font-size:22px;margin-bottom:8px;display:block}
.sfb-hcat__label{font-family:var(--serif);font-size:15px;font-weight:700;color:#fff;display:block;margin-bottom:3px}
.sfb-hcat__sub{font-size:12px;color:rgba(240,236,245,.45)}

/* ---- Category hero ---- */
.sfb-cat-hero{background:var(--dark);padding:44px 0 40px;border-bottom:1px solid rgba(255,255,255,.06)}
.sfb-cat-hero__inner{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center}
.sfb-cat-hero__eyebrow{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:10px}
.sfb-cat-hero__title{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:900;color:#fff;line-height:1.1;margin-bottom:14px}
.sfb-cat-hero__desc{font-size:15px;color:rgba(240,236,245,.6);line-height:1.7;max-width:560px}
.sfb-cat-hero__meta{margin-top:20px}
.sfb-cat-hero__count{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:rgba(255,255,255,.5)}
.sfb-cat-hero__count svg{color:var(--coral)}
.sfb-cat-hero__stats{display:flex;flex-direction:column;gap:20px;flex-shrink:0}
.sfb-cat-hero__stat{text-align:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:18px 24px;min-width:120px}
.sfb-cat-hero__stat-val{font-family:var(--serif);font-size:2rem;font-weight:900;color:var(--coral);display:block;line-height:1}
.sfb-cat-hero__stat-lbl{font-size:11px;color:rgba(255,255,255,.45);margin-top:4px;font-weight:500}
.sfb-cat-grid{margin-bottom:40px}

/* ---- Single post ---- */
.sfb-post-header{margin-bottom:28px}
.sfb-post-cat{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--coral);display:inline-block;margin-bottom:12px;transition:color .14s}
.sfb-post-cat:hover{color:var(--magenta)}
.sfb-post-title{font-family:var(--serif);font-size:clamp(1.75rem,3.5vw,2.6rem);font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:16px}
.sfb-post-intro{font-size:17px;color:var(--t2);line-height:1.75;padding-bottom:20px;border-bottom:1px solid var(--border)}
.sfb-post-img{width:100%;border-radius:6px;overflow:hidden;margin-bottom:32px;background:var(--blush)}
.sfb-post-img img{width:100%;height:auto;display:block}
.sfb-post-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:48px;padding-top:32px;border-top:2px solid var(--t1)}
.sfb-post-nav__item{display:flex;flex-direction:column;gap:6px;padding:18px 20px;border:1px solid var(--border);border-radius:6px;background:#fff;text-decoration:none;transition:box-shadow .2s var(--ease),border-color .2s,transform .2s var(--ease)}
.sfb-post-nav__item:hover{box-shadow:0 4px 20px rgba(45,58,107,.09);border-color:transparent;transform:translateY(-2px)}
.sfb-post-nav__item--next{text-align:right}
.sfb-post-nav__label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);display:flex;align-items:center;gap:5px}
.sfb-post-nav__item--next .sfb-post-nav__label{justify-content:flex-end}
.sfb-post-nav__title{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--navy);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .14s}
.sfb-post-nav__item:hover .sfb-post-nav__title{color:var(--coral)}

/* ---- Page / Tool hero ---- */
.sfb-page-hero{background:var(--dark);padding:44px 0 40px;border-bottom:1px solid rgba(255,255,255,.06)}
.sfb-page-hero__title{font-family:var(--serif);font-size:clamp(1.75rem,3.5vw,2.8rem);font-weight:900;color:#fff;line-height:1.15;margin-bottom:10px}
.sfb-tool-hero__eyebrow{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:12px}
.sfb-tool-hero__sub{font-size:15px;color:rgba(240,236,245,.6);max-width:580px;line-height:1.7;margin-top:10px}
.sfb-tool-content>*:first-child{margin-top:0}
.sfb-tool-content .wpcf7,.sfb-tool-content .ff-el-group{margin-bottom:16px}

/* ---- Additional responsive rules ---- */
@media(max-width:1024px){
  .sfb-site-hero__inner{grid-template-columns:1fr}
  .sfb-site-hero__cats{display:none}
  .sfb-cat-hero__inner{grid-template-columns:1fr}
  .sfb-cat-hero__stats{flex-direction:row}
}
@media(max-width:768px){
  .sfb-cat-hero__stats{display:none}
  .sfb-post-nav{grid-template-columns:1fr}
  .sfb-post-nav__item--next{text-align:left}
  .sfb-post-nav__item--next .sfb-post-nav__label{justify-content:flex-start}
}
@media(max-width:480px){
  .sfb-site-hero__btns{flex-direction:column}
}

/* ============================================================
   SOLEDAD PARENT OVERRIDES
   Soledad sets aggressive resets on common elements.
   These rules ensure our components display correctly.
============================================================ */

/* Soledad resets img max-width - restore it inside our cards */
.sfb-card img,
.sfb-card--featured img,
.sfb-card--horiz img,
.sfb-pos-card img,
.sfb-post-img img { max-width:100%; height:auto; display:block; }

/* Soledad often sets article { display:block } which breaks grid children */
.sfb-sidebar-layout > * { min-width:0; }

/* Ensure our dark sections actually have dark bg regardless of parent body bg */
.sfb-site-hero,
.sfb-cat-hero,
.sfb-page-hero,
.sfb-section--dark,
.sfb-header,
.sfb-footer { background-color:var(--dark) !important; }

/* sfb-site-hero and sfb-cat-hero need their own colours */
.sfb-section--smoke { background-color:var(--smoke) !important; }

/* Soledad sets a { color } globally - override for our nav and cards */
.sfb-nav a,
.sfb-mobile-nav a { color:rgba(255,255,255,.75) !important; text-decoration:none !important; }
.sfb-nav a:hover,
.sfb-mobile-nav a:hover,
.sfb-nav a.sfb-active { color:#fff !important; }

/* Card title links */
.sfb-card__title a,
.sfb-card--featured__title,
.sfb-card--horiz__title a { color:var(--navy) !important; text-decoration:none !important; }

/* Soledad may zero out padding/margin on section - restore ours */
.sfb-section { padding-top:clamp(36px,5vw,64px) !important; padding-bottom:clamp(36px,5vw,64px) !important; }

/* Ensure wrap is centred even if Soledad sets .wrap width differently */
.sfb-wrap { max-width:1200px !important; margin-left:auto !important; margin-right:auto !important; padding-left:clamp(16px,4vw,48px) !important; padding-right:clamp(16px,4vw,48px) !important; }
.sfb-wrap--text { max-width:860px !important; }

/* Position grid */
.sfb-pos-grid { display:grid !important; grid-template-columns:repeat(6,1fr) !important; gap:12px; }

/* sfb-grid-3 */
.sfb-grid-3 { display:grid !important; grid-template-columns:repeat(3,1fr) !important; gap:20px; }

/* sfb-grid-2 */
.sfb-grid-2 { display:grid !important; grid-template-columns:repeat(2,1fr) !important; gap:22px; }

/* Editorial layout */
.sfb-editorial { display:grid !important; grid-template-columns:1fr 1fr !important; gap:28px; align-items:start; }

/* Tools grid */
.sfb-tools-grid { display:grid !important; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)) !important; gap:14px; }

/* Featured card grid */
.sfb-card--featured { display:grid !important; grid-template-columns:1.1fr 1fr !important; }

/* Responsive overrides must also use !important to beat parent */
@media (max-width:1100px) {
  .sfb-sidebar-layout { grid-template-columns:1fr !important; }
  .sfb-sidebar { display:none !important; }
  .sfb-pos-grid { grid-template-columns:repeat(4,1fr) !important; }
  .sfb-footer__body { grid-template-columns:1fr 1fr !important; }
}
@media (max-width:768px) {
  .sfb-nav,.sfb-header__search { display:none !important; }
  .sfb-nav-toggle { display:flex !important; }
  .sfb-card--featured { grid-template-columns:1fr !important; }
  .sfb-grid-3 { grid-template-columns:repeat(2,1fr) !important; }
  .sfb-grid-2 { grid-template-columns:1fr !important; }
  .sfb-editorial { grid-template-columns:1fr !important; }
  .sfb-pos-grid { grid-template-columns:repeat(3,1fr) !important; }
  .sfb-tools-grid { grid-template-columns:1fr !important; }
  .sfb-footer__body { grid-template-columns:1fr !important; }
  .sfb-site-hero__cats { display:none !important; }
  .sfb-cat-hero__stats { display:none !important; }
}
@media (max-width:480px) {
  .sfb-grid-3 { grid-template-columns:1fr !important; }
  .sfb-pos-grid { grid-template-columns:repeat(2,1fr) !important; }
}

/* Category description - may contain p tags from WP editor */
.sfb-cat-hero__desc p {
  font-size:15px;
  color:rgba(240,236,245,.6);
  line-height:1.7;
  margin-bottom:0;
}
.sfb-cat-hero__desc p + p { margin-top:10px; }

/* ============================================================
   PAGINATE_LINKS() OUTPUT STYLES
   WordPress paginate_links( type:'list' ) outputs a <ul class="page-numbers">
============================================================ */
.sfb-pagination ul.page-numbers {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  list-style:none;
  margin:0;
  padding:0;
}
.sfb-pagination .page-numbers li { display:flex; }
.sfb-pagination .page-numbers a,
.sfb-pagination .page-numbers span {
  min-width:38px;
  height:38px;
  border-radius:4px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:600;
  color:var(--t2);
  border:1px solid var(--border);
  background:#fff;
  padding:0 10px;
  gap:4px;
  transition:background .15s,color .15s,border-color .15s;
  text-decoration:none;
}
.sfb-pagination .page-numbers a:hover { background:var(--smoke);color:var(--navy) }
.sfb-pagination .page-numbers span.current {
  background:var(--coral);
  color:#fff;
  border-color:var(--coral);
}
.sfb-pagination .page-numbers .dots {
  border:none;background:none;color:var(--t3);
}
.sfb-pagination .page-numbers svg { display:inline-block; vertical-align:middle; }

/* ============================================================
   NEWSLETTER STRIP - FLUENTFORM LAYOUT
   Override FluentForms defaults inside the strip
============================================================ */
.sfb-nl-strip__fluentform {
  min-width: 320px;
  flex: 1;
  max-width: 500px;
}
.sfb-nl-strip__fluentform .ff-el-group { margin-bottom: 8px !important; }
.sfb-nl-strip__fluentform .ff-el-group:last-child { margin-bottom: 0 !important; }
.sfb-nl-strip__fluentform input[type="email"],
.sfb-nl-strip__fluentform input[type="text"] {
  background: #fff !important;
  border: 1.5px solid #d4c8d4 !important;
  border-radius: 4px !important;
  padding: 11px 16px !important;
  font-size: 14px !important;
  color: var(--t1) !important;
  width: 100% !important;
}
.sfb-nl-strip__fluentform input:focus {
  border-color: var(--coral) !important;
  outline: none !important;
  box-shadow: none !important;
}
.sfb-nl-strip__fluentform .ff-btn-submit {
  background: var(--coral) !important;
  border: none !important;
  border-radius: 4px !important;
  color: #fff !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  padding: 11px 22px !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: background .15s !important;
}
.sfb-nl-strip__fluentform .ff-btn-submit:hover { background: var(--magenta) !important; }

/* ============================================================
   CONTACT FORM FIELD BORDERS
   Fields were blending into the light background
============================================================ */
.sfb-fluentform input[type="text"],
.sfb-fluentform input[type="email"],
.sfb-fluentform input[type="tel"],
.sfb-fluentform textarea,
.sfb-fluentform select,
.page-template-page .fluentform input[type="text"],
.page-template-page .fluentform input[type="email"],
.page-template-page .fluentform textarea {
  border: 1.5px solid #c8b8cc !important;
  border-radius: 4px !important;
  background: #fff !important;
  padding: 11px 14px !important;
  font-size: 14px !important;
  color: var(--t1) !important;
  box-shadow: none !important;
  width: 100% !important;
  transition: border-color .14s !important;
}
.sfb-fluentform input:focus,
.sfb-fluentform textarea:focus,
.sfb-fluentform select:focus,
.page-template-page .fluentform input:focus,
.page-template-page .fluentform textarea:focus {
  border-color: var(--coral) !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(232,83,106,.12) !important;
}

/* ============================================================
   TOOLS INDEX PAGE  (template-tools-index.php)
============================================================ */
.sfb-tools-index-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
}
.sfb-tool-index-card {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  padding: 22px 20px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  text-decoration: none;
  color: inherit;
  transition: box-shadow .22s var(--ease), transform .22s var(--ease), border-color .2s;
}
.sfb-tool-index-card:hover {
  box-shadow: 0 6px 28px rgba(45,58,107,.1);
  transform: translateY(-3px);
  border-color: transparent;
}
.sfb-tool-index-card__icon {
  font-size: 28px;
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: 10px;
  background: var(--blush);
  display: flex;
  align-items: center;
  justify-content: center;
}
.sfb-tool-index-card__body { flex: 1; min-width: 0; }
.sfb-tool-index-card__title {
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 6px;
  line-height: 1.3;
  transition: color .14s;
}
.sfb-tool-index-card:hover .sfb-tool-index-card__title { color: var(--coral); }
.sfb-tool-index-card__desc {
  font-size: 13px;
  color: var(--t2);
  line-height: 1.6;
  margin-bottom: 10px;
}
.sfb-tool-index-card__cta {
  font-size: 12px;
  font-weight: 600;
  color: var(--coral);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: gap .14s;
}
.sfb-tool-index-card:hover .sfb-tool-index-card__cta { gap: 7px; }
@media (max-width: 600px) {
  .sfb-tools-index-grid { grid-template-columns: 1fr; }
}

/* end of sfb-shared.css */

/* ============================================================
   SEARCH RESULTS PAGE  (search.php)
============================================================ */

/* Hero */
.sfb-search-hero {
  background: var(--dark);
  padding: clamp(32px,5vw,56px) 0 clamp(28px,4vw,44px);
  border-bottom: 1px solid rgba(255,255,255,.06);
  text-align: center;
}
.sfb-search-hero__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}
.sfb-search-hero__term {
  font-family: var(--serif);
  font-size: clamp(1.6rem,3vw,2.4rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 8px;
}
.sfb-search-hero__count {
  font-size: 13px;
  color: rgba(255,255,255,.45);
  margin-bottom: 24px;
}
.sfb-search-hero__form {
  display: inline-flex;
  gap: 8px;
  max-width: 560px;
  width: 100%;
}
.sfb-search-hero__input {
  flex: 1;
  font-family: var(--sans);
  font-size: 15px;
  padding: 12px 18px;
  border: none;
  border-radius: 6px;
  background: rgba(255,255,255,.1);
  color: #fff;
  outline: none;
  transition: background .15s;
}
.sfb-search-hero__input::placeholder { color: rgba(255,255,255,.35); }
.sfb-search-hero__input:focus { background: rgba(255,255,255,.16); }
.sfb-search-hero__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 20px;
  border-radius: 6px;
  background: var(--coral);
  color: #fff;
  font-family: var(--sans);
  font-weight: 600;
  font-size: 14px;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s;
  flex-shrink: 0;
}
.sfb-search-hero__btn:hover { background: var(--magenta); }

/* No results state */
.sfb-no-results {
  text-align: center;
  padding: clamp(40px,6vw,80px) 0;
  max-width: 560px;
  margin: 0 auto;
}
.sfb-no-results__icon {
  font-size: 52px;
  margin-bottom: 16px;
}
.sfb-no-results__title {
  font-family: var(--serif);
  font-size: clamp(1.4rem,2.5vw,2rem);
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 12px;
}
.sfb-no-results__sub {
  font-size: 15px;
  color: var(--t2);
  line-height: 1.7;
  margin-bottom: 32px;
}
.sfb-no-results__cats {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.sfb-no-results__cat-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 999px;
  border: 1.5px solid var(--border);
  background: var(--smoke);
  font-size: 13px;
  font-weight: 600;
  color: var(--navy);
  transition: background .15s, border-color .15s, color .15s;
  text-decoration: none;
}
.sfb-no-results__cat-link:hover {
  background: var(--blush);
  border-color: var(--coral);
  color: var(--coral);
}
.sfb-no-results__cat-link span {
  font-size: 11px;
  color: var(--t3);
  font-weight: 400;
}

/* Responsive */
@media (max-width: 768px) {
  .sfb-search-hero__form {
    flex-direction: column;
    padding: 0 clamp(16px,4vw,32px);
  }
}

/* ============================================================
   NEWSLETTER STRIP - FLUENTFORM OVERRIDES
   FluentForm [id="2"] renders inside .sfb-nl-strip__form
   Override its defaults to match the blush strip background.
============================================================ */
.sfb-nl-strip__form { flex: 1; min-width: 280px; max-width: 480px; }

/* Hide FluentForm's default heading/description if any */
.sfb-nl-strip__form .ff-el-group label,
.sfb-nl-strip__form .ff-form-header { display: none !important; }

/* Input field */
.sfb-nl-strip__form .ff-el-input--content input[type="email"],
.sfb-nl-strip__form .ff-el-input--content input[type="text"],
.sfb-nl-strip__form input[type="email"],
.sfb-nl-strip__form input[type="text"] {
  background: #fff !important;
  border: 1.5px solid #d4c8d4 !important;
  border-radius: 4px !important;
  padding: 11px 16px !important;
  font-size: 14px !important;
  font-family: var(--sans) !important;
  color: var(--t1) !important;
  width: 100% !important;
  box-shadow: none !important;
  transition: border-color .15s !important;
}
.sfb-nl-strip__form input[type="email"]:focus,
.sfb-nl-strip__form input[type="text"]:focus {
  border-color: var(--coral) !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Submit button */
.sfb-nl-strip__form .ff-btn-submit,
.sfb-nl-strip__form button[type="submit"] {
  background: var(--coral) !important;
  border: none !important;
  border-radius: 4px !important;
  color: #fff !important;
  font-family: var(--sans) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  padding: 11px 24px !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: background .15s !important;
  margin-top: 8px !important;
}
.sfb-nl-strip__form .ff-btn-submit:hover,
.sfb-nl-strip__form button[type="submit"]:hover {
  background: var(--magenta) !important;
}

/* Success/error messages */
.sfb-nl-strip__form .ff-message-success {
  color: var(--navy) !important;
  font-weight: 600 !important;
  padding: 12px 0 !important;
}
.sfb-nl-strip__form .ff-errors-wrap { margin-top: 4px !important; }
.sfb-nl-strip__form .error { color: var(--magenta) !important; font-size: 12px !important; }

/* Spacing between fields */
.sfb-nl-strip__form .ff-el-group { margin-bottom: 8px !important; }
.sfb-nl-strip__form .ff-el-group:last-child { margin-bottom: 0 !important; }

/* Responsive: stack on mobile */
@media (max-width: 768px) {
  .sfb-nl-strip__inner { flex-direction: column; text-align: center; }
  .sfb-nl-strip__form { max-width: 100%; width: 100%; }
  .sfb-nl-strip__text { text-align: center; }
}

/* ============================================================
   CATEGORY DESCRIPTION - COLLAPSIBLE READ MORE
============================================================ */
.sfb-cat-hero__desc-wrap { position: relative; }

.sfb-cat-hero__desc {
  font-size: 15px;
  color: rgba(240,236,245,.6);
  line-height: 1.7;
  max-width: 560px;
  /* Collapsed: show 3 lines */
  max-height: 4.8em; /* 3 lines x 1.6em line-height */
  overflow: hidden;
  transition: max-height .35s ease;
}

.sfb-cat-hero__desc.is-open {
  max-height: 40em; /* large enough for any description */
}

/* Fade out gradient at bottom when collapsed */
.sfb-cat-hero__desc:not(.is-open)::after {
  content: '';
  position: absolute;
  bottom: 28px; /* above the button */
  left: 0;
  right: 0;
  height: 2.5em;
  background: linear-gradient(to bottom, transparent, var(--dark));
  pointer-events: none;
}

.sfb-cat-hero__readmore {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 600;
  color: var(--coral);
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px 0 0;
  transition: color .14s;
  letter-spacing: .03em;
  text-transform: uppercase;
}
.sfb-cat-hero__readmore:hover { color: #fff; }
.sfb-cat-hero__readmore svg {
  transition: transform .25s ease;
}
.sfb-cat-hero__readmore[aria-expanded="true"] svg {
  transform: rotate(180deg);
}

/* p tags inside the description */
.sfb-cat-hero__desc p {
  font-size: 15px;
  color: rgba(240,236,245,.6);
  line-height: 1.7;
  margin-bottom: 0;
}
.sfb-cat-hero__desc p + p { margin-top: 10px; }
