/*
Theme Name: WorldInSport Magazine
Theme URI: https://worldinsport.com
Author: WorldInSport
Author URI: https://worldinsport.com
Description: A sleek, lightweight sports magazine theme built for Core Web Vitals and Google Discover-friendly layouts.
Version: 1.1.6.41.3
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: worldinsport-magazine
Tags: news, blog, two-columns, right-sidebar, custom-logo, custom-menu, featured-images, rtl-language-support, sticky-post, theme-options, translation-ready
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
*/

:root{
  --wisp-primary:#0b1b3b; /* navy */
  --wisp-text:#111827;
  --wisp-on-primary:#ffffff;
  --wisp-border:#ff4fa3; /* pink outline */
  --wisp-header-border:#ffffff; /* header outline */
  --wisp-accent:#ff5a1f; /* orange/red accent */
  --wisp-surface:#ffffff;
  --wisp-muted:#f3f4f6; /* light grey */
  /* Newsticker colours (Customizer overrides these via inline CSS vars). */
  --wisp-ticker-bg:#07152f;
  --wisp-ticker-text:#ffffff;
  --wisp-ticker-hover:#ff4fa3;
  --wisp-ticker-dot:#ffffff;
  /* Hero meta colours (Customizer overrides these via inline CSS vars). */
  --wisp-hero-meta-text:#ffffff;
  --wisp-hero-meta-dot:#ffffff;
  --wisp-hero-meta-hover:#ff4fa3;
  --wisp-radius:14px;
  /* Dynamic UI offsets (set via CSS/JS). */
  --wisp-adminbar-height:0px;
  --wisp-ticker-height:0px;
  /* Mobile Customizer defaults */
  --wisp-mobile-hero-primary-max:520px;
  --wisp-mobile-hero-secondary-max:340px;
  --wisp-mobile-hero-gap:10px;
  --wisp-mobile-latest-gap:10px;
  --wisp-mobile-ticker-font:13px;
  --wisp-mobile-ticker-gap:4px;
  --wisp-mobile-footer-align:left;
  --wisp-mobile-footer-follow-justify:flex-start;
  --wisp-mobile-footer-cats-wrap:nowrap;
  --wisp-mobile-footer-cats-overflow:auto;
}

/* WorldInSport Magazine - Main CSS (Core Web Vitals-friendly) */

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: var(--wisp-body-font, "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
  color: var(--wisp-text, #111827);
  background: var(--wisp-surface, #ffffff);
  line-height:1.6;
}

/* Admin bar offset (reliable across WP versions). */
body.admin-bar{--wisp-adminbar-height:32px;}
@media (max-width:782px){body.admin-bar{--wisp-adminbar-height:46px;}}

/* Ensure the WP admin toolbar always sits above sticky UI (ticker/header). */
#wpadminbar{position:fixed !important;top:0 !important;z-index:999999 !important;}
img{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
a:hover{color:var(--wisp-accent, #ff5a1f)}
.screen-reader-text{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:16px;top:16px;width:auto;height:auto;padding:10px 14px;background:#fff;border:2px solid var(--wisp-border, #ff4fa3);border-radius:10px;z-index:9999}

.wisp-container{max-width:1200px;margin:0 auto;padding:0 16px}
@media (min-width: 1024px){
  .wisp-container{padding:0 22px}
}

.site-header{background:var(--wisp-primary, #0b1b3b);color:var(--wisp-on-primary, #ffffff);border-bottom:2px solid var(--wisp-header-border, #ffffff);position:relative;z-index:99997}
/* If header is sticky, keep it below the sticky ticker + admin bar. */
.site-header.is-sticky{position:sticky;top:calc(var(--wisp-adminbar-height) + var(--wisp-ticker-height));z-index:99997}
.wisp-topbar{background:var(--wisp-primary, #0b1b3b)}
.wisp-topbar-inner{display:flex;align-items:center;gap:14px;justify-content:space-between;padding:12px 0}
.site-branding{display:flex;align-items:center;gap:10px;min-width:0}
.site-title{font-weight:800;letter-spacing:.5px}
.site-title{border:2px solid var(--wisp-header-border, #ffffff);padding:6px 10px;border-radius:12px}
.site-logo img{max-height:48px;width:auto}

/* Newspaper-style masthead title */
.newspaper-title{
  margin:0;
  padding:0;
  border:none;
  font-family: Georgia, "Times New Roman", Times, serif;
  font-weight:900;
  letter-spacing:1.2px;
  text-transform:uppercase;
  font-size:clamp(20px, 2.2vw, 34px);
  line-height:1.05;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.newspaper-title a{color:inherit}

.main-navigation ul{display:flex;gap:14px;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.main-navigation a{display:inline-flex;align-items:center;padding:10px 10px;border-radius:10px}
.main-navigation a:hover{background:rgba(255,255,255,.08);color:var(--wisp-on-primary, #ffffff)}
.wisp-nav-toggle{display:none;background:transparent;border:2px solid var(--wisp-header-border, #ffffff);color:var(--wisp-on-primary, #ffffff);border-radius:12px;padding:8px 10px}
.wisp-burger{display:inline-block;width:18px;height:2px;background:var(--wisp-on-primary, #ffffff);position:relative}
.wisp-burger:before,.wisp-burger:after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--wisp-on-primary, #ffffff)}
.wisp-burger:before{top:-6px}
.wisp-burger:after{top:6px}

.wisp-secondary-nav{background:rgba(255,255,255,.06);border-top:1px solid rgba(255,255,255,.12)}
.secondary-navigation ul{display:flex;gap:10px;list-style:none;margin:0;padding:10px 0;overflow:auto}
.secondary-navigation a{white-space:nowrap;border:2px solid transparent;border-radius:999px;padding:8px 12px}
.secondary-navigation a:hover{border-color:var(--wisp-header-border, #ffffff)}

.wisp-social-icons{display:flex;gap:8px}
.wisp-social-link{width:34px;height:34px;display:grid;place-items:center;border:2px solid var(--wisp-header-border, #ffffff);border-radius:10px;color:var(--wisp-on-primary, #ffffff)}
.wisp-social-link:hover{background:var(--wisp-accent, #ff5a1f);border-color:var(--wisp-accent, #ff5a1f);color:#fff}

.wisp-header-actions{display:flex;align-items:center;gap:10px}
.wisp-search-toggle{
  width:34px;height:34px;display:grid;place-items:center;
  background:transparent;
  border:2px solid var(--wisp-header-border, #ffffff);
  border-radius:10px;
  color:var(--wisp-on-primary, #ffffff);
  cursor:pointer
}
.wisp-search-toggle:hover{background:rgba(255,255,255,.08)}
.wisp-search-toggle .wisp-icon{width:18px;height:18px;display:block}

.wisp-search-panel{
  background:#07152f;
  border-top:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12)
}
.wisp-search-panel .search-form{margin:0;padding:10px 0}
.wisp-search-panel .search-field{border-color:rgba(17,24,39,.18)}
.wisp-search-panel .search-submit{color:var(--wisp-on-primary, #ffffff)}

@media (max-width: 900px){
  .wisp-nav-toggle{display:inline-flex}
  .wisp-nav-close,.wisp-search-close{display:inline-flex}
  .main-navigation{
    display:block;
    position:fixed;
    top:calc(var(--wisp-adminbar-height) + var(--wisp-ticker-height));
    left:0;bottom:0;
    width:min(86vw, 360px);
    background:var(--wisp-primary, #07152f);
    border-right:1px solid rgba(255,255,255,.14);
    padding:14px 14px 24px;
    overflow:auto;
    transform:translateX(-105%);
    transition:transform .22s ease;
    visibility:hidden;
    pointer-events:none;
    z-index:99991;
  }
  .site-header.is-open .main-navigation{
    transform:translateX(0);
    visibility:visible;
    pointer-events:auto;
  }
  .main-navigation ul{flex-direction:column;align-items:flex-start;padding:10px 0;gap:4px}
  .main-navigation a{width:100%;justify-content:space-between}
  .main-navigation .sub-menu{display:none;list-style:none;margin:6px 0 0 0;padding:0 0 0 12px;border-left:1px solid rgba(255,255,255,.16)}
  .main-navigation li.is-sub-open > .sub-menu{display:block}
  .wisp-submenu-toggle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;border:2px solid rgba(255,255,255,.22);background:transparent;color:var(--wisp-on-primary,#fff);margin-left:8px;flex:0 0 auto}
}

/* Ticker */
.wisp-ticker{background:var(--wisp-ticker-bg, #07152f);color:var(--wisp-ticker-text, #ffffff);border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12);position:sticky;top:var(--wisp-adminbar-height);z-index:99998}
.wisp-ticker-inner{display:flex;align-items:center;gap:10px;padding:6px 0}
.wisp-ticker-label{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--wisp-accent, #ff5a1f);color:#fff;
  padding:6px 10px;border-radius:999px;font-weight:800;font-size:12px;letter-spacing:.4px
}
.wisp-ticker-track{overflow:hidden;flex:1}
.wisp-ticker-items{display:inline-flex;gap:6px;white-space:nowrap;will-change:transform;animation:wispTicker var(--wisp-ticker-speed, 35s) linear infinite}
.wisp-ticker:hover .wisp-ticker-items{animation-play-state:paused}
.wisp-ticker-item{display:inline-flex;align-items:center;color:var(--wisp-ticker-text, var(--wisp-on-primary, #ffffff));opacity:.95;text-decoration:none}
.wisp-ticker-item::after{content:"•";color:var(--wisp-ticker-dot, currentColor);opacity:.75;margin-left:8px}
.wisp-ticker-item:hover{opacity:1;color:var(--wisp-ticker-hover, var(--wisp-accent, #ff5a1f));text-decoration:none}
@keyframes wispTicker{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* Sections */
.wisp-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin:26px 0 14px}
.wisp-section-title{
  margin:0;font-family:var(--wisp-headings-font, "Oswald", system-ui, sans-serif);
  letter-spacing:.4px;text-transform:uppercase
}
.wisp-link{font-weight:700;color:var(--wisp-accent, #ff5a1f)}

/* Hero */
/* Featured hero (1â2 latest posts) */
.wisp-hero{padding:0;margin:0 0 14px}
.wisp-hero-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.wisp-hero-grid--single{grid-template-columns:1fr}
/* Two-post hero: big primary + slightly smaller secondary */
.wisp-hero-grid--two{grid-template-columns:2fr 1fr;align-items:stretch}
@media (max-width: 900px){.wisp-hero-grid--two{grid-template-columns:1fr}}

/* Three-post hero: big primary (left) + two stacked (right) */
.wisp-hero-grid--three{grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;align-items:stretch}
.wisp-hero-grid--three .wisp-featured--primary{grid-row:1 / span 2}
.wisp-hero-grid--three .wisp-featured--secondary{grid-column:2;grid-row:1}
.wisp-hero-grid--three .wisp-featured--tertiary{grid-column:2;grid-row:2}
@media (max-width: 900px){
  .wisp-hero-grid--three{grid-template-columns:1fr;grid-template-rows:auto}
  .wisp-hero-grid--three .wisp-featured--primary{grid-row:auto}
}

/* Prevent hero layout shift: lock hero grid height on desktop.
   Using vw-based heights can shrink when the scrollbar appears.
   We use a stable vh-based clamp and let tiles fill the grid. */
@media (min-width: 901px){
  .wisp-hero-grid--three{height:clamp(420px, 58vh, 740px)}
  .wisp-hero-grid--three .wisp-featured{height:100%}
  .wisp-hero-grid--three .wisp-featured-media{height:100% !important;max-height:none !important}

  .wisp-hero-grid--two{height:clamp(360px, 54vh, 700px)}
  .wisp-hero-grid--two .wisp-featured{height:100%}
  .wisp-hero-grid--two .wisp-featured-media{height:100% !important;max-height:none !important}

  .wisp-hero-grid--single .wisp-featured-media{height:clamp(360px, 54vh, 700px);max-height:none}
}


.wisp-featured{
  position:relative;
  border-radius:var(--wisp-radius, 14px);
  overflow:hidden;
  box-shadow:none;
  /* Subtle outline so the rounded edges are always visible (fix: primary hero looked borderless). */
  border:1px solid rgba(255,255,255,.18);
}
.wisp-featured-media{
  position:relative;
  display:block;
  border-radius:var(--wisp-radius, 14px);
  overflow:hidden;
  height:clamp(220px, 26vw, 420px);
  max-height:420px;
  background:#000;
}
.wisp-featured-link{position:absolute;inset:0;z-index:1}
.wisp-featured--primary .wisp-featured-media{
  /* Slightly larger hero for better visual impact */
  height:clamp(340px, 36vw, 660px);
  max-height:660px;
}
.wisp-featured--secondary .wisp-featured-media,
.wisp-featured--tertiary .wisp-featured-media{
  height:clamp(160px, 18vw, 260px);
  max-height:260px;
}

/* In a two-post hero, keep both cards the same height on desktop.
   The secondary is âsmallerâ because it has less width. */
.wisp-hero-grid--two .wisp-featured--secondary .wisp-featured-media,
.wisp-featured--tertiary .wisp-featured-media{
  height:clamp(340px, 36vw, 660px);
  max-height:660px;
}
@media (max-width: 900px){
  .wisp-hero-grid--two .wisp-featured--secondary .wisp-featured-media,
.wisp-featured--tertiary .wisp-featured-media{
    height:clamp(180px, 22vw, 320px);
    max-height:340px;
  }
}

/* In a three-post hero, secondary/tertiary cards fill the right column rows. */
.wisp-hero-grid--three .wisp-featured--secondary .wisp-featured-media,
.wisp-hero-grid--three .wisp-featured--tertiary .wisp-featured-media{
  height:100%;
  max-height:none;
}
@media (max-width: 900px){
  .wisp-hero-grid--three .wisp-featured--secondary .wisp-featured-media,
  .wisp-hero-grid--three .wisp-featured--tertiary .wisp-featured-media{
    height:clamp(180px, 22vw, 320px);
    max-height:340px;
  }
}


.wisp-featured-media > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.wisp-featured-placeholder{width:100%;height:100%;background:linear-gradient(135deg, var(--wisp-muted, #f3f4f6), #e5e7eb)}

/* Overlay sits at the bottom only (keeps the image clean and clickable). */
.wisp-featured-overlay{
  position:absolute;
  inset:0;
  z-index:2;
  display:flex;
  align-items:flex-end;
  padding:0;
  color:#fff;
  text-align:left;
  pointer-events:none;
}
.wisp-featured-overlay::before{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:54%;
  background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.62) 55%, rgba(0,0,0,.82) 100%);
}
.wisp-featured--secondary .wisp-featured-overlay::before{height:58%}

.wisp-featured-overlay-inner{
  width:100%;
  padding:14px 16px 12px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:8px;
  position:relative;
  z-index:3;
  pointer-events:auto;
}

/* Bring the primary hero overlay slightly closer to the bottom edge. */
.wisp-featured--primary .wisp-featured-overlay-inner{padding-bottom:6px}

.wisp-featured-body{
  position:static;
  display:flex;
  flex-direction:column;
  gap:6px;
  max-width:72ch;
  text-shadow:0 2px 10px rgba(0,0,0,.55);
}

/* Category badge on hero cards */
.wisp-featured-badge{margin:0 0 4px}

/* Primary hero: keep the title higher but push the meta row closer to the bottom fade. */
.wisp-featured--primary .wisp-featured-body{min-height:128px}
.wisp-featured--primary .wisp-hero-meta{margin-top:auto}
@media (max-width: 900px){
  .wisp-featured--primary .wisp-featured-body{min-height:96px}
}

.wisp-featured-title{
  margin:1px 0 1px;
  max-width:28ch;
  font-size:clamp(24px, 3vw, 42px);
  line-height:1.1;
  font-family:var(--wisp-headings-font, "Oswald", system-ui, sans-serif);
  text-transform:uppercase;
  letter-spacing:.5px;
  /* Clamp long headlines and show an ellipsis ("...") */
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  overflow:hidden;
  text-overflow:ellipsis;
}
.wisp-featured-title a{color:var(--wisp-hero-title, #ffffff);text-decoration:none}
.wisp-featured-title a:hover{color:var(--wisp-hero-title-hover, var(--wisp-accent, #ff5a1f));text-decoration:none}
/* Hero title links: ensure no underline and colour change on hero hover */
.wisp-featured-title a{ text-decoration:none !important; }
.wisp-featured:hover .wisp-featured-title a,
.wisp-featured:focus-within .wisp-featured-title a{ color:var(--wisp-hero-title-hover, var(--wisp-accent, #ff5a1f)) !important; text-decoration:none !important; }

/* Title links: no underline, use hover colour instead */
.wisp-card-title a{color:inherit;text-decoration:none}
.wisp-card-title a:hover{color:var(--wisp-accent, #ff5a1f);text-decoration:none}

.wisp-hero-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;opacity:.98;color:var(--wisp-hero-meta-text, #ffffff)}
.wisp-hero-meta .wisp-meta-dot{color:var(--wisp-hero-meta-dot, currentColor);opacity:.78}
.wisp-hero-avatar{display:inline-flex;align-items:center;justify-content:center}
.wisp-hero-avatar img{position:static;width:26px;height:26px;border-radius:999px;border:1px solid rgba(255,255,255,.25)}
.wisp-hero-meta .wisp-meta-author a{color:inherit;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.wisp-hero-meta a:hover{color:var(--wisp-hero-meta-hover, var(--wisp-accent, #ff5a1f))}
.wisp-hero-meta .wisp-meta-date time{opacity:.92}
.wisp-hero-readtime{opacity:.92}
.wisp-featured--secondary .wisp-featured-title,
.wisp-featured--tertiary .wisp-featured-title{
  font-size:clamp(20px, 2.4vw, 32px);
  max-width:34ch;
  -webkit-line-clamp:2;
}

.wisp-featured-excerpt{
  margin:0;
  max-width:70ch;
  opacity:.95;
  display:-webkit-box;
  -webkit-line-clamp:1;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.wisp-badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:6px 10px;border-radius:999px;
  background:rgba(11,27,59,.92);
  border:2px solid var(--wisp-border, #ff4fa3);
  color:#fff;font-weight:800;font-size:12px;letter-spacing:.3px
}
.wisp-card-badge .wisp-badge{
  background:rgba(11,27,59,.92);
  color:#fff;
  border-color:rgba(255,255,255,.9);
  text-shadow:0 1px 0 rgba(0,0,0,.25)
}
.wisp-featured-badge .wisp-badge{background:rgba(11,27,59,.88);border-color:rgba(255,255,255,.9)}

.wisp-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:13px;line-height:1.25}
.wisp-meta-on-dark{opacity:.95}
.wisp-featured-meta{
  position:static;
  margin:2px 0 0;
  display:inline-flex;
  width:fit-content;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(0,0,0,.70);
  border:1px solid rgba(255,255,255,.22);
  text-shadow:0 2px 10px rgba(0,0,0,.60);
}
.wisp-meta-dot{opacity:.7}
.wisp-meta a{color:inherit;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.wisp-meta-avatar{display:inline-flex;align-items:center;justify-content:center;text-decoration:none!important}
.wisp-meta-avatar img{width:22px;height:22px;border-radius:999px;display:block;border:1px solid rgba(17,24,39,.18)}

/* Right aligned meta item (used for comment count on homepage cards) */
.wisp-meta-right{margin-left:auto;display:inline-flex;align-items:center;gap:6px}
.wisp-meta-comments{padding:2px 8px;border:1px solid rgba(17,24,39,.14);border-radius:999px;background:rgba(255,255,255,.7)}
.wisp-meta-comments .wisp-icon-comment{width:16px;height:16px;display:block;opacity:.85}
.wisp-meta-comments .wisp-meta-count{font-weight:700}


/* Homepage layout with sidebar */
.wisp-home-layout{display:grid;grid-template-columns:1fr;gap:22px}
@media (min-width: 980px){.wisp-home-layout{grid-template-columns:minmax(0, 1fr) 320px;align-items:start}}
.wisp-home-sidebar .widget-area{margin-top:4px}
@media (min-width: 980px){.wisp-home-sidebar .widget-area{position:sticky;top:92px}}
/* Keep post grid to 2 columns when sidebar is present */
@media (min-width: 1024px){.wisp-home-layout .wisp-grid{grid-template-columns:repeat(2, 1fr)}}

/* Homepage spacing */
body.home .wisp-latest, body.front-page .wisp-latest{padding-top:0}
/* Pull the first section heading closer to the hero on the homepage. */
body.home .wisp-latest .wisp-section-head,
body.front-page .wisp-latest .wisp-section-head{margin-top:8px}

/* Grid cards */
.wisp-latest{padding:0 0 28px}
.wisp-grid{display:grid;gap:16px;grid-template-columns:1fr}
@media (min-width: 720px){ .wisp-grid{grid-template-columns:repeat(2, 1fr)} }
@media (min-width: 1024px){ .wisp-grid{grid-template-columns:repeat(3, 1fr)} }

/* Homepage grid styles (selectable) */
.wisp-grid--cards{}

/* 1) Compact list: image left, text right */
.wisp-grid--compact{grid-template-columns:1fr;gap:14px}
.wisp-grid--compact .wisp-card{display:flex;align-items:stretch}
.wisp-grid--compact .wisp-card-media{flex:0 0 34%;max-width:34%}
.wisp-grid--compact .wisp-card-media img{height:100%;object-fit:cover}
.wisp-grid--compact .wisp-card-body{padding:12px 14px}
.wisp-grid--compact .wisp-card-excerpt{display:none}

/* 2) Photo grid: more posts, less text */
.wisp-grid--photo{grid-template-columns:repeat(2, 1fr);gap:12px}
@media (min-width: 900px){ .wisp-grid--photo{grid-template-columns:repeat(4, 1fr)} }
.wisp-grid--photo .wisp-card-media{aspect-ratio:1/1}
.wisp-grid--photo .wisp-card-media img{width:100%;height:100%;object-fit:cover}
.wisp-grid--photo .wisp-card-body{padding:10px 12px}
.wisp-grid--photo .wisp-meta,.wisp-grid--photo .wisp-card-excerpt{display:none}
.wisp-grid--photo .wisp-card-title{font-size:15px;line-height:1.25}

/* 3) Newspaper: lead story + clean headlines */
.wisp-grid--newspaper{grid-template-columns:1fr;gap:12px}
@media (min-width: 900px){ .wisp-grid--newspaper{grid-template-columns:repeat(2, 1fr);gap:18px} }
.wisp-grid--newspaper .wisp-card{border:none;border-bottom:1px solid rgba(17,24,39,.12);border-radius:0;box-shadow:none;background:transparent}
.wisp-grid--newspaper .wisp-card-body{padding:10px 0 14px}
.wisp-grid--newspaper .wisp-card-excerpt{display:none}
.wisp-grid--newspaper .wisp-card:nth-child(1){grid-column:1 / -1}
.wisp-grid--newspaper .wisp-card:nth-child(1) .wisp-card-excerpt{display:block}

/* 4) Split: two big columns */
.wisp-grid--split{grid-template-columns:1fr;gap:16px}
@media (min-width: 820px){ .wisp-grid--split{grid-template-columns:repeat(2, 1fr)} }
@media (min-width: 1100px){ .wisp-grid--split{grid-template-columns:repeat(2, 1fr)} }
.wisp-grid--split .wisp-card-title{font-size:20px}

/* 5) Mixed: first 3 as cards, rest as compact list */
.wisp-grid--mixed{grid-template-columns:1fr;gap:14px}
@media (min-width: 1024px){ .wisp-grid--mixed{grid-template-columns:repeat(3, 1fr);gap:16px} }
.wisp-grid--mixed .wisp-card:nth-child(n+4){grid-column:1 / -1;display:flex;align-items:stretch}
.wisp-grid--mixed .wisp-card:nth-child(n+4) .wisp-card-media{flex:0 0 26%;max-width:26%}
.wisp-grid--mixed .wisp-card:nth-child(n+4) .wisp-card-body{padding:12px 14px}
.wisp-grid--mixed .wisp-card:nth-child(n+4) .wisp-card-excerpt{display:none}

.wisp-card{
  border:1px solid rgba(17,24,39,.08);
  border-radius:var(--wisp-radius, 14px);
  overflow:hidden;
  background:#fff;
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  transition:transform .15s ease, box-shadow .15s ease
}
.wisp-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.10)}
.wisp-card-media{display:block;position:relative;background:var(--wisp-muted, #f3f4f6)}
.wisp-card-media img{display:block;width:100%;height:auto}
.wisp-card-placeholder{aspect-ratio:16/9;background:linear-gradient(135deg, var(--wisp-muted, #f3f4f6), #e5e7eb)}
.wisp-card-badge{position:absolute;left:12px;top:12px}
.wisp-card-body{padding:14px}
.wisp-card-title{
  margin:0 0 8px;
  font-family:var(--wisp-headings-font, "Oswald", system-ui, sans-serif);
  text-transform:uppercase;
  letter-spacing:.3px;
  line-height:1.15;
  font-size:18px
}
.wisp-card-excerpt{margin:10px 0 0;color:#374151}

/* Layout */
.wisp-layout{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width: 1024px){ .wisp-layout{grid-template-columns:1fr 320px;align-items:start} }
.wisp-content{min-width:0}
.wisp-sidebar .widget{padding:14px;border:1px solid rgba(17,24,39,.08);border-radius:var(--wisp-radius, 14px);background:#fff;margin-bottom:14px}
.widget-title{margin:0 0 10px;font-family:var(--wisp-headings-font, "Oswald", system-ui, sans-serif);text-transform:uppercase;letter-spacing:.3px}

/* Block-widget headings (eg Recent Comments) should match the sidebar headings */
.widget-area .wp-block-heading,
.widget-area .wp-block-latest-comments__title,
.widget-area .wp-block-latest-posts__title{
  margin:0 0 10px;
  font-family:var(--wisp-headings-font, "Oswald", system-ui, sans-serif);
  text-transform:uppercase;
  letter-spacing:.3px;
}

/* Single */
.wisp-single .entry-title{
  margin:10px 0 10px;
  font-family:var(--wisp-headings-font, "Oswald", system-ui, sans-serif);
  text-transform:uppercase;letter-spacing:.4px;
  line-height:1.08;font-size:clamp(26px, 2.4vw, 44px)
}
.wisp-feature-image{margin:14px 0 0}
.wisp-feature-image img{border-radius:var(--wisp-radius, 14px)}
.entry-content{margin:16px 0 0}
.entry-content > *{max-width:72ch}
.entry-content img{border-radius:14px}
.entry-content a{color:var(--wisp-link, var(--wisp-accent, #ff5a1f));text-decoration:underline;text-underline-offset:3px}
.entry-content a:hover{color:var(--wisp-link-hover, var(--wisp-accent, #ff5a1f))}
.entry-content h2, .entry-content h3, .entry-content h4, .entry-content h5{
  font-family:var(--wisp-headings-font, "Oswald", system-ui, sans-serif);
  text-transform:uppercase;letter-spacing:.3px;line-height:1.15;margin:26px 0 10px
}
.entry-content h2{font-size:28px}
.entry-content h3{font-size:22px}
.entry-content h4{font-size:18px}
.entry-content h5{font-size:16px}

.wisp-audio{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:14px}
.wisp-audio-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 12px;border-radius:12px;
  border:2px solid var(--wisp-border, #ff4fa3);
  background:transparent;color:var(--wisp-text, #111827);
  font-weight:800;cursor:pointer
}
.wisp-audio-btn:hover{background:rgba(255,79,163,.10)}
.wisp-audio-btn.is-secondary{border-color:rgba(17,24,39,.18)}
.wisp-audio-note{margin:0;font-size:13px}

/* Chips */
.wisp-chip{
  display:inline-flex;align-items:center;justify-content:center;
  padding:8px 12px;border-radius:999px;
  border:1px solid rgba(17,24,39,.12);
  background:#fff;
  font-weight:700;font-size:13px
}
.wisp-chip:hover{border-color:var(--wisp-border, #ff4fa3)}
.wisp-chip.is-active{border-color:var(--wisp-border, #ff4fa3);box-shadow:0 0 0 3px rgba(255,79,163,.18)}
.wisp-chip.is-static{cursor:default}
.wisp-tag-filter{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}

/* Author box */
.wisp-author-box{
  display:flex;gap:12px;align-items:flex-start;
  padding:14px;margin:18px 0 0;
  border:1px solid rgba(17,24,39,.08);
  border-radius:var(--wisp-radius, 14px);
  background:linear-gradient(180deg, #fff, rgba(243,244,246,.55))
}
.wisp-author-avatar{flex:0 0 auto}
.wisp-author-avatar img{border-radius:999px;width:104px;height:104px;object-fit:cover}
.wisp-author-name{margin:0;font-family:var(--wisp-headings-font, "Oswald", system-ui, sans-serif);text-transform:uppercase}
.wisp-author-bio{margin:6px 0 0;color:#374151}

@media (max-width: 520px){
  .wisp-author-avatar img{width:88px;height:88px}
}
.wisp-author-stats{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}

/* Related grid tweaks */
.wisp-grid-related{margin-top:12px;grid-template-columns:1fr}
@media (min-width: 720px){ .wisp-grid-related{grid-template-columns:repeat(2, 1fr)} }
@media (min-width: 1024px){ .wisp-grid-related{grid-template-columns:repeat(2, 1fr)} }
.wisp-related{margin:18px 0 0}
.wisp-related-pagination{margin-top:14px}

/* Hide image captions in card contexts like related/archives */
.wisp-card figcaption,
.wisp-card .wp-caption,
.wisp-card .wp-caption-text{display:none !important}

/* Footer */
.site-footer{margin-top:38px;background:#0a1734;color:#fff;border-top:2px solid var(--wisp-border, #ff4fa3)}
.wisp-footer-grid{display:grid;gap:16px;padding:22px 0}
/* Footer: brand (left), explore (center), contact (right). Make the 3rd column wider for long contact lines. */
@media (min-width: 900px){
  .wisp-footer-grid{grid-template-columns:minmax(0, 1fr) minmax(0, 1.7fr) minmax(0, 1.35fr);align-items:start}
}
.site-footer .widget{background:transparent;border:0;padding:0;margin:0}
.site-footer a:hover{color:var(--wisp-accent, #ff5a1f)}
.wisp-footer-bottom{padding:14px 0;border-top:1px solid rgba(255,255,255,.12)}
.wisp-footer-note{padding:10px 0 0;border-top:1px solid rgba(255,255,255,.12)}

/* Footer horizontal categories menu */
.wisp-footer-catsbar{padding:14px 0;border-top:1px solid rgba(255,255,255,.12)}
.wisp-footer-cats-menu{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;align-items:center}
.wisp-footer-cats-menu li{margin:0}
.wisp-footer-cats-menu a{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(0,0,0,.18);color:rgba(255,255,255,.95);text-decoration:none;font-weight:800;font-size:12px;letter-spacing:.2px}
.wisp-footer-cats-menu a:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.28);color:#fff}
.wisp-footer-explore-text{margin:0 0 10px;opacity:.92}
.wisp-footer-contact-extra{margin-top:10px;opacity:.92}
.wisp-muted{opacity:.82}

.wisp-footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.wisp-backtotop{font-weight:800;opacity:.9}
.wisp-backtotop:hover{opacity:1}

.wisp-footer-follow{margin-top:12px;display:flex;flex-direction:column;gap:10px;align-items:center;text-align:center}
.wisp-footer-follow-label{font-weight:900;text-transform:uppercase;letter-spacing:.3px;text-align:center}
.site-footer .wisp-social-icons{gap:10px;justify-content:center}
.site-footer .wisp-social-link{width:40px;height:40px;border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.06)}
.site-footer .wisp-social-link:hover{background:rgba(255,90,31,.14);border-color:rgba(255,90,31,.55)}


.wisp-footer-explore-3col{
  margin-top:12px;
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
@media (min-width: 820px){
  .wisp-footer-explore-3col{grid-template-columns:repeat(3, 1fr);gap:18px}
}

.wisp-footer-explore-4col{
  margin-top:12px;
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
@media (min-width: 560px){
  .wisp-footer-explore-4col{grid-template-columns:repeat(2, 1fr)}
}
@media (min-width: 820px){
  .wisp-footer-explore-4col{grid-template-columns:repeat(4, 1fr);gap:18px}
}

.wisp-footer-explore-col ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.wisp-footer-explore-col a{opacity:.9}
.wisp-footer-explore-col a:hover{opacity:1}
.wisp-footer-cats ul{list-style:none;margin:10px 0 0;padding:0;display:grid;gap:6px}
.wisp-footer-cats li{margin:0}
.wisp-footer-cats a{opacity:.9}
.wisp-footer-cats a:hover{opacity:1}


/* Search form */
.search-form{display:flex;gap:10px;align-items:center;flex-wrap:nowrap;margin-top:12px}
.search-form > label{flex:1;min-width:0}
.search-field{
  width:100%;min-width:0;
  padding:10px 12px;border-radius:12px;
  border:1px solid rgba(17,24,39,.18);
  background:#fff
}
.search-submit{
  padding:10px 14px;border-radius:12px;
  border:2px solid var(--wisp-border, #ff4fa3);
  background:transparent;font-weight:800;cursor:pointer
}
.search-submit:hover{background:rgba(255,79,163,.10)}
@media (max-width: 640px){
  .search-form{flex-wrap:wrap}
  .search-field{min-width:220px}
}

/* Pagination */
.wisp-pagination{margin:18px 0 0}
.wisp-pagination ul{list-style:none;margin:0;padding:0;display:flex;gap:8px;flex-wrap:wrap}
.wisp-pagination li{margin:0}
.wisp-pagination a,
.wisp-pagination span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:38px;height:38px;
  padding:0 12px;
  border-radius:12px;
  border:1px solid rgba(17,24,39,.14);
  background:#fff;
  font-weight:800
}
.wisp-pagination a:hover{border-color:var(--wisp-accent, #ff5a1f);color:var(--wisp-accent, #ff5a1f)}
.wisp-pagination .current{border-color:var(--wisp-border, #ff4fa3);box-shadow:0 0 0 3px rgba(255,79,163,.18)}
/* Accessibility: reduce motion */
@media (prefers-reduced-motion: reduce){
  .wisp-ticker-items{animation:none !important; transform:none !important}
}

/* Secondary menu: enforce horizontal layout */
.secondary-navigation ul,
.secondary-navigation .menu,
#secondary-menu{
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  gap:10px;
  list-style:none;
  margin:0;
  padding:10px 0;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.secondary-navigation li{flex:0 0 auto}


/* Homepage: keep 2-column grid when sidebar is enabled */
@media (min-width: 1024px){
  .wisp-home-layout .wisp-grid{grid-template-columns:repeat(2, 1fr)}
}


/* === Patch v1.1.6.1: Sidebar + Author Social + Archive fixes === */

/* Remove bullet points from sidebar widget lists */
.wisp-sidebar .widget-area ul,
.wisp-sidebar .widget-area ol{
  list-style:none;
  margin:0;
  padding:0;
}
.wisp-sidebar .widget-area li{margin:0 0 8px}
.wisp-sidebar .widget-area li:last-child{margin-bottom:0}

/* Hide image captions inside archive/related cards (and any nested figure markup) */
.wisp-card figcaption,
.wisp-card .wp-caption-text,
.wisp-card .wp-caption,
.wisp-related figcaption,
.wisp-related .wp-caption-text,
.wisp-related .wp-caption{
  display:none !important;
}

/* Author social icons row */
.wisp-author-social{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}
.wisp-author-social-link{
  width:36px;
  height:36px;
  border:1px solid rgba(17,24,39,.16);
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
}
.wisp-author-social-link:hover{border-color:var(--wisp-accent, #ff5a1f)}
.wisp-author-social-link .wisp-icon{width:18px;height:18px}

/* Archive alignment + better grids with sidebar */
.wisp-archive-head{margin:10px 0 16px}
.wisp-archive-title{margin:0 0 6px}
.wisp-archive-desc{margin:0;color:rgba(17,24,39,.75)}

/* Category archive header centered */
.category .wisp-archive-head--center{ text-align:center; }
.category .wisp-archive-head--center .wisp-archive-desc{ margin-left:auto; margin-right:auto; max-width:72ch; }

/* Category: force 2-column grid and keep it stable */
 (min-width: 720px){ .category .wisp-archive-grid--two{ grid-template-columns:repeat(2, 1fr); } }
 (min-width: 1024px){ .category .wisp-archive-grid--two{ grid-template-columns:repeat(2, 1fr); } }

.archive .wisp-layout,
.category .wisp-layout,
.tag .wisp-layout,
.search .wisp-layout,
.author .wisp-layout{
  padding-top:16px;
}

/* Archive card alignment (category / tag / author / search) */
.wisp-archive-grid .wisp-card{display:flex;flex-direction:column;height:100%}
.wisp-archive-grid .wisp-card-media{aspect-ratio:16/9;overflow:hidden}
.wisp-archive-grid .wisp-card-media img{width:100%;height:100%;object-fit:cover}
.wisp-archive-grid .wisp-card-body{display:flex;flex-direction:column;flex:1}
.wisp-archive-grid .wisp-card-title a{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}
.wisp-archive-grid .wisp-card-excerpt{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}
@media (min-width: 1024px){
  .archive .wisp-grid,
  .category .wisp-grid,
  .tag .wisp-grid,
  .search .wisp-grid,
  .author .wisp-grid,
  .date .wisp-grid,
  .post-type-archive .wisp-grid,
  .page-template-archives .wisp-grid{
    grid-template-columns:repeat(2, 1fr);
  }
}


/* Category archive: force 2-column grid (even on wide screens) */
@media (min-width: 1024px){
  .category .wisp-archive-grid{grid-template-columns:repeat(2, 1fr);}
}

/* Meta labels (Published/Updated) */
.wisp-meta-label{font-weight:800;margin-right:6px}


.comment-content a{color:var(--wisp-link, var(--wisp-accent, #ff5a1f));text-decoration:underline;text-underline-offset:3px}
.comment-content a:hover{color:var(--wisp-link-hover, var(--wisp-accent, #ff5a1f))}
/* Comments layout */
.comments-area{margin-top:26px}
.comment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.comment-list .comment-body{border:1px solid rgba(17,24,39,.12);border-radius:16px;padding:8px 10px;background:#fff}
.comment-list .comment-meta{font-size:13px;opacity:.9;display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:4px}
.comment-list .comment-author img{border-radius:999px}
.comment-list .comment-content{margin:0}
.comment-list .reply a{display:inline-flex;margin-top:4px}
.comment-respond{margin-top:18px}
.comment-respond input[type="text"],
.comment-respond input[type="email"],
.comment-respond input[type="url"],
.comment-respond textarea{width:100%;max-width:100%;border:1px solid rgba(17,24,39,.14);border-radius:14px;padding:10px 12px}
.comment-respond .form-submit input{border-radius:999px;padding:10px 14px;font-weight:800}


/* Single post pagination (<!--nextpage-->) */
.wisp-page-links{
  margin:18px 0 0;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
.wisp-page-link{
  display:inline-flex;
  padding:6px 10px;
  border:1px solid rgba(17,24,39,.14);
  border-radius:999px;
  font-weight:700;
  line-height:1;
}
.wisp-page-links a .wisp-page-link{cursor:pointer}
/* =========================
   Category archive fixes
   ========================= */

/* Center the category title/description header */
.category .wisp-archive-head--center{ text-align:center; }
.category .wisp-archive-head--center .wisp-archive-desc{ margin-left:auto; margin-right:auto; max-width:72ch; }

/* Keep category grids at 2 columns (2 per row) */
@media (min-width: 720px){
  .category .wisp-archive-grid,
  .category .wisp-archive-grid--two{
    grid-template-columns:repeat(2, 1fr);
  }
}
@media (min-width: 1024px){
  .category .wisp-archive-grid,
  .category .wisp-archive-grid--two{
    grid-template-columns:repeat(2, 1fr);
  }
}

/* =========================
   Mobile improvements (v1.1.6.37)
   ========================= */

@media (max-width: 640px){
  .wisp-container{padding:0 14px}

  /* Header: allow items to wrap cleanly */
  .wisp-topbar-inner{flex-wrap:wrap;gap:10px;padding:10px 0}
  .site-branding{min-width:0;flex:1 1 auto}
  .wisp-header-actions{gap:8px}
  .wisp-search-toggle{width:32px;height:32px;border-radius:10px}
  .wisp-social-link{width:32px;height:32px;border-radius:10px}

  /* Masthead title: allow 2-line wrap on small screens */
  .newspaper-title{white-space:normal;overflow:visible;text-overflow:clip;letter-spacing:1px}

  /* Secondary categories menu: tighter and scrollable */
  .secondary-navigation a{padding:6px 10px}
  .secondary-navigation ul{padding:8px 0;gap:8px}

  /* News ticker: tighter spacing for mobile */
  .wisp-ticker-inner{padding:5px 0;gap:8px}
  .wisp-ticker-label{padding:5px 8px;font-size:11px}
  .wisp-ticker-items{gap:var(--wisp-mobile-ticker-gap, 4px)}
  .wisp-ticker-item{font-size:var(--wisp-mobile-ticker-font, 13px)}
  .wisp-ticker-item::after{margin-left:6px}

  /* Hero: reduce overlay padding, keep text readable */
  .wisp-featured--primary .wisp-featured-media{height:clamp(260px, 70vw, var(--wisp-mobile-hero-primary-max, 520px));max-height:var(--wisp-mobile-hero-primary-max, 520px)}
  .wisp-hero-grid--three .wisp-featured--secondary .wisp-featured-media,
  .wisp-hero-grid--three .wisp-featured--tertiary .wisp-featured-media{height:clamp(200px, 54vw, var(--wisp-mobile-hero-secondary-max, 340px));max-height:var(--wisp-mobile-hero-secondary-max, 340px)}
  .wisp-featured-overlay-inner{padding:12px 12px 10px;gap:6px}
  .wisp-featured-title{font-size:clamp(20px, 6vw, 30px)}
  .wisp-featured--secondary .wisp-featured-title,
  .wisp-featured--tertiary .wisp-featured-title{font-size:clamp(18px, 5.6vw, 26px)}
  .wisp-hero-meta{font-size:12px;gap:6px}
  .wisp-hero-avatar img{width:24px;height:24px}
  .wisp-featured-badge .wisp-badge{padding:5px 9px;font-size:11px}

  /* Cards: improve tap targets & reduce visual noise */
  .wisp-card-body{padding:12px}
  .wisp-card-title{font-size:17px}
  .wisp-card-excerpt{margin-top:8px;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}

  /* Footer: stack nicely and keep category menu truly horizontal */
  .wisp-footer-grid{padding:18px 0;gap:18px;text-align:var(--wisp-mobile-footer-align, left)}
  .wisp-footer-bottom{justify-content:center}
  .wisp-footer-cats-menu{flex-wrap:var(--wisp-mobile-footer-cats-wrap, nowrap);overflow-x:var(--wisp-mobile-footer-cats-overflow, auto);justify-content:flex-start;-webkit-overflow-scrolling:touch;padding-bottom:6px}
  .wisp-footer-cats-menu::-webkit-scrollbar{display:none}
  .wisp-footer-cats-menu{scrollbar-width:none}
}

@media (max-width: 420px){
  /* Header: hide social icons (footer has Follow Us) to prevent crowding */
  .wisp-header-actions .wisp-social{display:none}
}

/* Card thumbnails: keep consistent ratio across grids (better alignment, esp. mobile) */
.wisp-card-media{overflow:hidden}
.wisp-card-media img{display:block;width:100%;height:100%;object-fit:cover}
.wisp-grid--cards .wisp-card-media,
.wisp-grid--newspaper .wisp-card-media{aspect-ratio:16/9}
.wisp-grid--compact .wisp-card-media,
.wisp-grid--mixed .wisp-card:nth-child(n+4) .wisp-card-media{aspect-ratio:auto}


/* ================================
   Mobile fixes (hero + footer)
   ================================ */
@media (max-width: 900px){
  /* Ensure multi-card hero layouts don't place cards into non-existent columns */
  .wisp-hero-grid--three{grid-template-columns:1fr !important;grid-template-rows:auto !important}
  .wisp-hero-grid--three .wisp-featured--primary{grid-column:1 !important;grid-row:auto !important}
  .wisp-hero-grid--three .wisp-featured--secondary,
  .wisp-hero-grid--three .wisp-featured--tertiary{grid-column:1 !important;grid-row:auto !important}

  .wisp-hero-grid--two{grid-template-columns:1fr !important}
  .wisp-hero-grid--two .wisp-featured--primary{grid-column:1 !important;grid-row:auto !important}
  .wisp-hero-grid--two .wisp-featured--secondary{grid-column:1 !important;grid-row:auto !important}

  /* Mobile hero card count (Customizer) */
  body.wisp-hero-mobile-1 .wisp-hero .wisp-featured--secondary,
  body.wisp-hero-mobile-1 .wisp-hero .wisp-featured--tertiary{display:none !important}
  body.wisp-hero-mobile-2 .wisp-hero .wisp-featured--tertiary{display:none !important}

  /* Reduce perceived empty space below hero */
  .wisp-hero{margin-bottom:var(--wisp-mobile-hero-gap, 10px) !important}
  body.home .wisp-latest .wisp-section-head,
  body.front-page .wisp-latest .wisp-section-head{margin-top:var(--wisp-mobile-latest-gap, 10px) !important}

  /* More balanced hero heights on small screens */
  .wisp-featured--primary .wisp-featured-media{height:clamp(300px, 72vw, var(--wisp-mobile-hero-primary-max, 520px)) !important;max-height:var(--wisp-mobile-hero-primary-max, 520px) !important}
  .wisp-featured--secondary .wisp-featured-media,
  .wisp-featured--tertiary .wisp-featured-media{height:clamp(190px, 55vw, var(--wisp-mobile-hero-secondary-max, 340px)) !important;max-height:var(--wisp-mobile-hero-secondary-max, 340px) !important}

  /* Footer: clean stacking + horizontal categories bar */
  .wisp-footer-grid{grid-template-columns:1fr !important;gap:18px !important;padding:18px 0 !important;text-align:var(--wisp-mobile-footer-align, left) !important}
  .site-footer ul{list-style:none;margin:0;padding:0}
  .site-footer .widget-title{text-align:var(--wisp-mobile-footer-align, left) !important}
  .wisp-footer-follow{justify-content:var(--wisp-mobile-footer-follow-justify, flex-start) !important}

  .wisp-footer-catsbar{padding:10px 0 !important}
  .wisp-footer-cats-menu{
    flex-wrap:var(--wisp-mobile-footer-cats-wrap, nowrap) !important;
    justify-content:flex-start !important;
    overflow-x:var(--wisp-mobile-footer-cats-overflow, auto) !important;
    -webkit-overflow-scrolling:touch;
    padding:0 0 8px !important;
  }
  .wisp-footer-cats-menu li{flex:0 0 auto}
  .wisp-footer-cats-menu::-webkit-scrollbar{display:none}
}

/* Smaller screens */
@media (max-width: 600px){
  .wisp-featured--primary .wisp-featured-media{height:clamp(280px, 80vw, var(--wisp-mobile-hero-primary-max, 520px)) !important;max-height:var(--wisp-mobile-hero-primary-max, 520px) !important}
}


/* Mobile menu & search improvements */
body.wisp-nav-open, body.wisp-search-open{overflow:hidden}
.wisp-nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:99990}
.wisp-nav-close,.wisp-search-close{background:transparent;border:2px solid rgba(255,255,255,.28);color:var(--wisp-on-primary,#fff);border-radius:12px;padding:8px 12px;display:none;align-items:center;justify-content:center;line-height:1;font-size:18px}
.wisp-search-close{margin:10px 0 0 auto}

.wisp-search-panel{position:fixed;left:0;right:0;top:calc(var(--wisp-adminbar-height) + var(--wisp-ticker-height));z-index:99992}
.wisp-search-panel .wisp-container{position:relative}
.wisp-search-panel .search-form{display:flex;gap:10px;align-items:center}
.wisp-search-panel .search-field{width:100%;min-width:0;font-size:16px;padding:12px 14px;border-radius:14px}
.wisp-search-panel .search-submit{padding:12px 14px;border-radius:14px}

.wisp-nav-backdrop[hidden]{display:none}

/* Post voting box */
.wisp-vote{
  margin: 18px 0 0;
  padding: 12px 14px;
  border: 1px solid rgba(17,24,39,.10);
  border-radius: var(--wisp-radius, 14px);
  background: #fff;
}

.wisp-vote__label{ font-weight: 900; margin: 0 0 10px; }

.wisp-vote__buttons{ display:flex; gap:10px; flex-wrap:wrap; }

.wisp-vote__btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:2px solid rgba(17,24,39,.14);
  background:transparent;
  font-weight:900;
  cursor:pointer;
}

.wisp-vote__btn:hover{ border-color: var(--wisp-border, #ff4fa3); }

.wisp-vote__btn.is-active{
  border-color: var(--wisp-border, #ff4fa3);
  box-shadow: 0 0 0 3px rgba(255,79,163,.18);
}

.wisp-vote__stats{ margin-top:10px; font-size:13px; opacity:.9; }
.wisp-vote__msg{ margin-top:8px; font-size:13px; opacity:.9; }
.wisp-vote__msg.is-error{ opacity:1; }
