/*
Theme Name: PBN Base
Theme URI: https://github.com/playjoy-co/private-blog-network
Description: First-party base theme for the iGaming review network. No third-party code. Fast (system fonts, one small CSS file, no jQuery), accessible (WCAG AA), and security-conscious (all output escaped). Brand child themes override the CSS custom properties below.
Author: PBN
Version: 0.2.0
Requires at least: 6.7
Requires PHP: 8.2
Text Domain: pbn
*/

/* ==========================================================================
   0. FONTS — self-hosted (first-party, no CDN). Latin variable subsets.
   ========================================================================== */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('//blog.wing.ph/app/themes/pbn-base/assets/fonts/inter-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+2000-206F, U+2074, U+20AC, U+2122, U+2212, U+FEFF, U+FFFD;
}

/* ==========================================================================
   1. DESIGN TOKENS
   Child themes override --blogwing-accent etc. via their own :root. Everything in
   this stylesheet is built on these names — treat them as a public contract.
   ========================================================================== */
:root {
  /* Brand / accent */
  --blogwing-accent: #2563b8;          /* refined editorial blue */
  --blogwing-accent-ink: #ffffff;      /* text on accent surfaces */
  --blogwing-accent-2: #0e9f8e;        /* secondary / teal highlight */

  /* Neutral palette (light) */
  --blogwing-bg: #f7f8fa;              /* page background */
  --blogwing-surface: #ffffff;        /* cards, header, raised surfaces */
  --blogwing-ink: #16202c;            /* primary text */
  --blogwing-muted: #5a6675;          /* secondary text / meta */
  --blogwing-border: #e3e8ef;         /* hairlines, dividers */

  /* ---------------------------------------------------------------------
     READABILITY CONTRACT — header & footer surfaces.
     The wordmark (.blogwing-site-title) renders in BOTH the header and the footer.
     A child theme that wants a dark header MUST retune these tokens rather
     than hardcoding `.blogwing-site-title a { color:#fff }`, which would leak white
     text into a light footer (white-on-white). Set *-bg and its matching *-ink
     together so text always has contrast against its own region.
     --------------------------------------------------------------------- */
  --blogwing-header-bg: color-mix(in srgb, var(--blogwing-surface) 88%, transparent);
  --blogwing-header-ink: var(--blogwing-ink);        /* site title + nav + toggle in the header */
  --blogwing-header-border: var(--blogwing-border);
  --blogwing-footer-bg: var(--blogwing-surface);
  --blogwing-footer-ink: var(--blogwing-muted);      /* footer body text + links */
  --blogwing-footer-title-ink: var(--blogwing-ink);  /* footer wordmark + column titles */
  --blogwing-footer-border: var(--blogwing-border);

  /* Status */
  --blogwing-success: #1d8a4e;
  --blogwing-warning: #b7791f;
  --blogwing-danger:  #c53030;

  /* Shape & depth */
  --blogwing-radius: 10px;
  --blogwing-radius-lg: 18px;
  --blogwing-shadow: 0 1px 2px rgba(16, 32, 44, .06), 0 2px 8px rgba(16, 32, 44, .05);
  --blogwing-shadow-lg: 0 10px 30px -8px rgba(16, 32, 44, .18), 0 4px 12px rgba(16, 32, 44, .06);

  /* Typography — self-hosted Inter for UI/body; brands override the heading face. */
  --blogwing-font: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
  --blogwing-font-heading: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  --blogwing-font-features: "cv11", "ss01";  /* Inter stylistic sets: single-storey a, etc. */

  /* Layout widths */
  --blogwing-max: 720px;              /* comfortable reading column */
  --blogwing-wide: 1120px;            /* page shell */

  /* Fluid type scale (clamp: min, preferred vw-based, max) */
  --blogwing-step--1: clamp(0.83rem, 0.80rem + 0.15vw, 0.92rem);
  --blogwing-step-0:  clamp(1.00rem, 0.96rem + 0.20vw, 1.13rem);
  --blogwing-step-1:  clamp(1.20rem, 1.13rem + 0.35vw, 1.42rem);
  --blogwing-step-2:  clamp(1.44rem, 1.32rem + 0.60vw, 1.80rem);
  --blogwing-step-3:  clamp(1.73rem, 1.54rem + 0.95vw, 2.28rem);
  --blogwing-step-4:  clamp(2.07rem, 1.78rem + 1.45vw, 2.89rem);
  --blogwing-step-5:  clamp(2.49rem, 2.05rem + 2.20vw, 3.66rem);

  /* Spacing scale */
  --blogwing-space-1: 0.25rem;
  --blogwing-space-2: 0.5rem;
  --blogwing-space-3: 0.75rem;
  --blogwing-space-4: 1rem;
  --blogwing-space-5: 1.5rem;
  --blogwing-space-6: 2rem;
  --blogwing-space-7: 3rem;
  --blogwing-space-8: 4.5rem;
}

/* Dark mode: override neutrals + depth only. Accent flows from :root so child
   overrides keep working in both schemes. */
@media (prefers-color-scheme: dark) {
  :root {
    --blogwing-bg: #0f1419;
    --blogwing-surface: #161d26;
    --blogwing-ink: #e8edf3;
    --blogwing-muted: #9aa7b6;
    --blogwing-border: #283441;
    --blogwing-accent: #5b9be8;        /* lighter for contrast on dark; child themes may re-override */
    --blogwing-shadow: 0 1px 2px rgba(0, 0, 0, .4), 0 2px 8px rgba(0, 0, 0, .35);
    --blogwing-shadow-lg: 0 12px 34px -8px rgba(0, 0, 0, .6), 0 4px 12px rgba(0, 0, 0, .4);
  }
}

/* ==========================================================================
   2. MODERN RESET
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
  -moz-tab-size: 4;
  tab-size: 4;
}
body {
  font-family: var(--blogwing-font);
  font-size: var(--blogwing-step-0);
  line-height: 1.65;
  color: var(--blogwing-ink);
  background: var(--blogwing-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: var(--blogwing-font-features, normal);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; }
h1, h2, h3, h4 {
  font-family: var(--blogwing-font-heading);
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: -0.022em;
  text-wrap: balance;
}
p, li { text-wrap: pretty; }
ul, ol { padding-left: 1.25em; }
:where(h1, h2, h3, h4, p, ul, ol, figure, blockquote, pre, table) + :where(h2, h3) { margin-top: var(--blogwing-space-6); }

/* ==========================================================================
   3. LAYOUT PRIMITIVES
   ========================================================================== */
.blogwing-container { width: 100%; max-width: var(--blogwing-max); margin-inline: auto; padding-inline: var(--blogwing-space-5); }
.blogwing-shell     { width: 100%; max-width: var(--blogwing-wide); margin-inline: auto; padding-inline: var(--blogwing-space-5); }
.blogwing-main { flex: 1 0 auto; padding-block: var(--blogwing-space-7); width: 100%; }

/* Visually hidden but available to assistive tech */
.blogwing-visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0);
  white-space: nowrap; border: 0;
}

/* Skip link */
.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--blogwing-accent); color: var(--blogwing-accent-ink);
  padding: var(--blogwing-space-3) var(--blogwing-space-4); border-radius: 0 0 var(--blogwing-radius) 0;
  z-index: 1000; text-decoration: none; font-weight: 600;
}
.skip-link:focus { left: 0; }

/* ==========================================================================
   4. LINKS, FOCUS, TYPOGRAPHY HELPERS
   ========================================================================== */
a { color: var(--blogwing-accent); text-decoration-thickness: 1px; text-underline-offset: 0.16em; }
a:hover { text-decoration-color: color-mix(in srgb, var(--blogwing-accent) 55%, transparent); }

:focus-visible {
  outline: 3px solid var(--blogwing-accent);
  outline-offset: 2px;
  border-radius: 3px;
}

::selection { background: color-mix(in srgb, var(--blogwing-accent) 22%, transparent); }

.blogwing-eyebrow {
  font-family: var(--blogwing-font);
  font-size: var(--blogwing-step--1);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blogwing-accent);
}

/* ==========================================================================
   5. BUTTONS
   ========================================================================== */
.blogwing-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--blogwing-space-2);
  padding: var(--blogwing-space-3) var(--blogwing-space-5);
  font-size: var(--blogwing-step-0); font-weight: 600; line-height: 1.1;
  border: 1px solid var(--blogwing-border);
  border-radius: var(--blogwing-radius);
  background: var(--blogwing-surface); color: var(--blogwing-ink);
  text-decoration: none;
  transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease, border-color .15s ease;
}
.blogwing-btn:hover { box-shadow: var(--blogwing-shadow); transform: translateY(-1px); }
.blogwing-btn:active { transform: translateY(0); }
.blogwing-btn--primary {
  background: var(--blogwing-accent); color: var(--blogwing-accent-ink); border-color: transparent;
}
.blogwing-btn--primary:hover { background: color-mix(in srgb, var(--blogwing-accent) 88%, #000); }

/* ==========================================================================
   6. TAGS / CATEGORY CHIPS
   ========================================================================== */
.blogwing-chip {
  display: inline-flex; align-items: center;
  padding: 0.2em 0.7em;
  font-family: var(--blogwing-font);
  font-size: var(--blogwing-step--1); font-weight: 600; line-height: 1.4;
  letter-spacing: 0.02em;
  color: var(--blogwing-accent);
  background: color-mix(in srgb, var(--blogwing-accent) 10%, var(--blogwing-surface));
  border: 1px solid color-mix(in srgb, var(--blogwing-accent) 22%, transparent);
  border-radius: 999px;
  text-decoration: none;
}
a.blogwing-chip:hover { background: color-mix(in srgb, var(--blogwing-accent) 18%, var(--blogwing-surface)); }
.blogwing-tags { display: flex; flex-wrap: wrap; gap: var(--blogwing-space-2); list-style: none; padding: 0; }

/* ==========================================================================
   7. HEADER + NAV
   ========================================================================== */
.blogwing-site-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--blogwing-header-bg);
  backdrop-filter: saturate(1.4) blur(8px);
  border-bottom: 1px solid var(--blogwing-header-border);
}
.blogwing-site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--blogwing-space-5);
  padding-block: var(--blogwing-space-4);
}
.blogwing-site-branding { display: flex; align-items: center; gap: var(--blogwing-space-3); min-width: 0; }
.blogwing-site-title { font-family: var(--blogwing-font-heading); font-size: var(--blogwing-step-1); margin: 0; line-height: 1.1; }
/* Wordmark color is REGION-scoped (header vs footer) so a dark header never
   leaks white text into a light footer. See the readability contract in :root. */
.blogwing-site-header .blogwing-site-title a { color: var(--blogwing-header-ink); text-decoration: none; }
.blogwing-site-branding .custom-logo-link { display: block; }
.blogwing-site-branding img.custom-logo { max-height: 48px; width: auto; }

.blogwing-nav-toggle {
  display: none; /* shown only on small screens, and only when JS removes [hidden] */
  align-items: center; gap: var(--blogwing-space-2);
  background: transparent; border: 1px solid currentColor;
  border-radius: var(--blogwing-radius); padding: var(--blogwing-space-2) var(--blogwing-space-3);
  color: var(--blogwing-header-ink); font-weight: 600; font-size: var(--blogwing-step--1);
}
.blogwing-nav-toggle__bars { display: inline-block; width: 18px; height: 12px; position: relative; }
.blogwing-nav-toggle__bars::before,
.blogwing-nav-toggle__bars::after,
.blogwing-nav-toggle__bars span {
  content: ""; position: absolute; left: 0; right: 0; height: 2px;
  background: currentColor; border-radius: 2px;
}
.blogwing-nav-toggle__bars::before { top: 0; }
.blogwing-nav-toggle__bars span { top: 5px; }
.blogwing-nav-toggle__bars::after { bottom: 0; }

.blogwing-nav ul { list-style: none; display: flex; flex-wrap: wrap; align-items: center; gap: var(--blogwing-space-3) var(--blogwing-space-5); margin: 0; padding: 0; }
.blogwing-nav a {
  color: var(--blogwing-header-ink); text-decoration: none; font-weight: 500; font-size: var(--blogwing-step-0);
  padding-block: var(--blogwing-space-1);
}
.blogwing-nav a:hover { color: var(--blogwing-accent); }
.blogwing-nav .current-menu-item > a { color: var(--blogwing-accent); }

/* ==========================================================================
   8. CARDS + POST GRID
   ========================================================================== */
.blogwing-grid {
  display: grid; gap: var(--blogwing-space-6);
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 320px), 1fr));
  margin-block: var(--blogwing-space-6);
}
.blogwing-card {
  display: flex; flex-direction: column;
  background: var(--blogwing-surface);
  border: 1px solid var(--blogwing-border);
  border-radius: var(--blogwing-radius-lg);
  overflow: hidden;
  box-shadow: var(--blogwing-shadow);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.blogwing-card:hover { transform: translateY(-4px); box-shadow: var(--blogwing-shadow-lg); border-color: color-mix(in srgb, var(--blogwing-accent) 30%, var(--blogwing-border)); }
.blogwing-card__media { display: block; aspect-ratio: 16 / 9; overflow: hidden; background: color-mix(in srgb, var(--blogwing-ink) 6%, var(--blogwing-surface)); }
.blogwing-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.blogwing-card:hover .blogwing-card__media img { transform: scale(1.04); }
/* Branded fallback when a post has no featured image. */
.blogwing-thumb-fallback {
  display: flex; align-items: center; justify-content: center; width: 100%; height: 100%;
  background:
    radial-gradient(120% 120% at 0% 0%, color-mix(in srgb, var(--blogwing-accent) 78%, #fff) 0%, transparent 60%),
    linear-gradient(135deg, var(--blogwing-accent), color-mix(in srgb, var(--blogwing-accent) 55%, #000));
}
.blogwing-thumb-fallback__label {
  color: var(--blogwing-accent-ink); font-family: var(--blogwing-font-heading); font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em; font-size: var(--blogwing-step-1);
  text-align: center; padding: 0 1rem; opacity: .95;
}
.blogwing-card:hover .blogwing-thumb-fallback { filter: brightness(1.05); }
.blogwing-card__body { display: flex; flex-direction: column; gap: var(--blogwing-space-3); padding: var(--blogwing-space-5); flex: 1 0 auto; }
.blogwing-card__title { font-size: var(--blogwing-step-1); margin: 0; }
.blogwing-card__title a { color: var(--blogwing-ink); text-decoration: none; }
.blogwing-card__title a:hover { color: var(--blogwing-accent); }
.blogwing-card__excerpt { color: var(--blogwing-muted); margin: 0; font-size: var(--blogwing-step-0); }
.blogwing-card__meta { margin-top: auto; padding-top: var(--blogwing-space-2); color: var(--blogwing-muted); font-size: var(--blogwing-step--1); }

/* ==========================================================================
   9. ENTRY META
   ========================================================================== */
.blogwing-entry-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--blogwing-space-2) var(--blogwing-space-3);
  color: var(--blogwing-muted); font-size: var(--blogwing-step--1); margin: 0;
}
.blogwing-entry-meta__sep { opacity: .5; }
.blogwing-entry-meta a { color: var(--blogwing-muted); }
.blogwing-entry-meta a:hover { color: var(--blogwing-accent); }

/* ==========================================================================
   10. SINGLE / PAGE ARTICLE
   ========================================================================== */
.blogwing-article-header { margin-bottom: var(--blogwing-space-6); display: flex; flex-direction: column; gap: var(--blogwing-space-4); }
.blogwing-entry-title { font-size: var(--blogwing-step-4); margin: 0; }
.blogwing-page-title { font-size: var(--blogwing-step-3); margin: 0 0 var(--blogwing-space-5); }

.blogwing-featured { margin: var(--blogwing-space-6) 0; }
.blogwing-featured img { width: 100%; border-radius: var(--blogwing-radius-lg); box-shadow: var(--blogwing-shadow); }
.blogwing-featured figcaption { margin-top: var(--blogwing-space-2); color: var(--blogwing-muted); font-size: var(--blogwing-step--1); text-align: center; }

/* Prose / vertical rhythm in article body */
.blogwing-prose { font-size: var(--blogwing-step-1); }
.blogwing-prose > * + * { margin-top: var(--blogwing-space-5); }
.blogwing-prose h2 { font-size: var(--blogwing-step-3); margin-top: var(--blogwing-space-7); }
.blogwing-prose h3 { font-size: var(--blogwing-step-2); margin-top: var(--blogwing-space-6); }
.blogwing-prose ul, .blogwing-prose ol { padding-left: 1.4em; }
.blogwing-prose li + li { margin-top: var(--blogwing-space-2); }
.blogwing-prose img { border-radius: var(--blogwing-radius); box-shadow: var(--blogwing-shadow); }
.blogwing-prose a { font-weight: 500; }
.blogwing-prose blockquote {
  margin-inline: 0;
  padding: var(--blogwing-space-2) var(--blogwing-space-5);
  border-left: 4px solid var(--blogwing-accent);
  color: var(--blogwing-muted); font-style: italic;
  font-size: var(--blogwing-step-1);
}
.blogwing-prose pre {
  background: color-mix(in srgb, var(--blogwing-ink) 92%, #000); color: #f4f6f8;
  padding: var(--blogwing-space-4); border-radius: var(--blogwing-radius); overflow-x: auto;
  font-size: var(--blogwing-step--1);
}
.blogwing-prose code { font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace; font-size: 0.9em; }
.blogwing-prose :not(pre) > code { background: color-mix(in srgb, var(--blogwing-ink) 8%, var(--blogwing-surface)); padding: 0.1em 0.4em; border-radius: 5px; }
.blogwing-prose table { width: 100%; border-collapse: collapse; font-size: var(--blogwing-step-0); }
.blogwing-prose th, .blogwing-prose td { border: 1px solid var(--blogwing-border); padding: var(--blogwing-space-3); text-align: left; }
.blogwing-prose th { background: color-mix(in srgb, var(--blogwing-ink) 4%, var(--blogwing-surface)); }

.blogwing-article-footer {
  margin-top: var(--blogwing-space-7);
  padding-top: var(--blogwing-space-5);
  border-top: 1px solid var(--blogwing-border);
  display: flex; flex-direction: column; gap: var(--blogwing-space-4);
}
.blogwing-article-footer__label { font-weight: 600; font-family: var(--blogwing-font); font-size: var(--blogwing-step--1); color: var(--blogwing-muted); }

/* ==========================================================================
   11. PAGINATION
   ========================================================================== */
.blogwing-pagination { margin-top: var(--blogwing-space-7); }
.blogwing-pagination .nav-links { display: flex; flex-wrap: wrap; gap: var(--blogwing-space-2); justify-content: center; }
.blogwing-pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 2.6em; padding: var(--blogwing-space-2) var(--blogwing-space-3);
  border: 1px solid var(--blogwing-border); border-radius: var(--blogwing-radius);
  background: var(--blogwing-surface); color: var(--blogwing-ink);
  text-decoration: none; font-weight: 600;
}
.blogwing-pagination .page-numbers:hover { border-color: var(--blogwing-accent); color: var(--blogwing-accent); }
.blogwing-pagination .page-numbers.current { background: var(--blogwing-accent); color: var(--blogwing-accent-ink); border-color: transparent; }
.blogwing-pagination .page-numbers.dots { border-color: transparent; background: transparent; }

/* ==========================================================================
   12. SEARCH FORM
   ========================================================================== */
.blogwing-search-form { display: flex; gap: var(--blogwing-space-2); width: 100%; }
.blogwing-search-form__field { flex: 1 1 auto; }
.blogwing-search-form input[type="search"] {
  width: 100%;
  padding: var(--blogwing-space-3) var(--blogwing-space-4);
  border: 1px solid var(--blogwing-border); border-radius: var(--blogwing-radius);
  background: var(--blogwing-surface); color: var(--blogwing-ink);
}
.blogwing-search-form input[type="search"]::placeholder { color: var(--blogwing-muted); }

/* ==========================================================================
   13. PAGE / 404 / SEARCH HEADERS
   ========================================================================== */
.blogwing-archive-header { margin-bottom: var(--blogwing-space-6); }
.blogwing-archive-title { font-size: var(--blogwing-step-3); margin: 0 0 var(--blogwing-space-3); }
.blogwing-archive-description { color: var(--blogwing-muted); max-width: var(--blogwing-max); }

.blogwing-empty { text-align: center; padding-block: var(--blogwing-space-7); }
.blogwing-empty__title { font-size: var(--blogwing-step-3); margin-bottom: var(--blogwing-space-4); }
.blogwing-empty p { color: var(--blogwing-muted); margin-bottom: var(--blogwing-space-5); }
.blogwing-empty .blogwing-search-form { max-width: 420px; margin-inline: auto; }

.blogwing-404-code { font-family: var(--blogwing-font-heading); font-size: var(--blogwing-step-5); color: var(--blogwing-accent); line-height: 1; }

/* ==========================================================================
   14. FOOTER
   ========================================================================== */
.blogwing-site-footer {
  background: var(--blogwing-footer-bg);
  border-top: 1px solid var(--blogwing-footer-border);
  margin-top: var(--blogwing-space-8);
  padding-block: var(--blogwing-space-7) var(--blogwing-space-6);
  color: var(--blogwing-footer-ink); font-size: var(--blogwing-step-0);
}
.blogwing-footer-cols {
  display: grid; gap: var(--blogwing-space-6);
  grid-template-columns: 1.4fr repeat(auto-fit, minmax(160px, 1fr));
  margin-bottom: var(--blogwing-space-6);
}
.blogwing-footer-col__title { font-family: var(--blogwing-font); font-size: var(--blogwing-step--1); text-transform: uppercase; letter-spacing: 0.06em; color: var(--blogwing-footer-title-ink); margin-bottom: var(--blogwing-space-3); }
.blogwing-footer-brand .blogwing-site-title { font-size: var(--blogwing-step-2); }
/* Footer wordmark is region-scoped to the footer ink (mirrors the header rule). */
.blogwing-site-footer .blogwing-site-title a { color: var(--blogwing-footer-title-ink); text-decoration: none; }
.blogwing-footer-brand p { margin-top: var(--blogwing-space-3); max-width: 36ch; }
.blogwing-footer-tagline { font-weight: 600; color: var(--blogwing-footer-title-ink); }
.blogwing-footer-text { opacity: .85; }
.blogwing-footer-social { flex-direction: row !important; flex-wrap: wrap; gap: var(--blogwing-space-4) !important; margin-top: var(--blogwing-space-3) !important; }
.blogwing-footer-nav--primary { margin-top: var(--blogwing-space-3); }
.blogwing-footer-nav--primary ul { list-style: none; display: flex; flex-direction: row; flex-wrap: wrap; gap: var(--blogwing-space-2) var(--blogwing-space-4); margin: 0; padding: 0; }
.blogwing-footer-nav--primary a { color: var(--blogwing-footer-ink); text-decoration: none; font-size: var(--blogwing-step--1); }
.blogwing-footer-nav--primary a:hover { color: var(--blogwing-accent); }
.blogwing-site-footer nav ul, .blogwing-footer-col ul { list-style: none; display: flex; flex-direction: column; gap: var(--blogwing-space-2); margin: 0; padding: 0; }
.blogwing-site-footer a { color: var(--blogwing-footer-ink); text-decoration: none; }
.blogwing-site-footer a:hover { color: var(--blogwing-accent); text-decoration: underline; text-underline-offset: 0.16em; }
.blogwing-footer-bottom {
  border-top: 1px solid var(--blogwing-footer-border);
  padding-top: var(--blogwing-space-5);
  font-size: var(--blogwing-step--1);
}

/* ==========================================================================
   15. RESPONSIVE — mobile nav
   ========================================================================== */
@media (max-width: 720px) {
  .blogwing-entry-title { font-size: var(--blogwing-step-3); }

  /* Toggle visible on mobile (JS removes [hidden]; without JS it stays hidden
     and the nav remains fully visible — progressive enhancement). */
  .blogwing-nav-toggle:not([hidden]) { display: inline-flex; }

  /* Only collapse the nav once JS has flagged the header as enhanced. */
  .blogwing-site-header.is-enhanced .blogwing-nav { display: none; }
  .blogwing-site-header.is-enhanced .blogwing-nav.is-open { display: block; }

  .blogwing-site-header.is-enhanced .blogwing-nav.is-open {
    position: absolute; left: 0; right: 0; top: 100%;
    background: var(--blogwing-header-bg);
    border-bottom: 1px solid var(--blogwing-header-border);
    box-shadow: var(--blogwing-shadow-lg);
    padding: var(--blogwing-space-4) var(--blogwing-space-5);
  }
  .blogwing-site-header.is-enhanced .blogwing-nav.is-open ul {
    flex-direction: column; align-items: stretch; gap: 0;
  }
  .blogwing-site-header.is-enhanced .blogwing-nav.is-open li { border-bottom: 1px solid color-mix(in srgb, var(--blogwing-header-ink) 18%, transparent); }
  .blogwing-site-header.is-enhanced .blogwing-nav.is-open li:last-child { border-bottom: 0; }
  .blogwing-site-header.is-enhanced .blogwing-nav.is-open a { display: block; padding-block: var(--blogwing-space-3); }
}

/* ==========================================================================
   16. MOTION PREFERENCES
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
}

/*
Theme Name: Wing Blog
Theme URI: https://blog.wing.ph
Description: Brand child theme for blog.wing.ph — a premium, dark "gold-on-carbon" sportsbook / casino review brand. Child of the first-party PBN Base theme. Carbon-black canvas, gunmetal surfaces, platinum text, a metallic-gold accent + gold winged wordmark, with emerald (win) and crimson (alert) status colours. Condensed Oswald headings. No third-party CSS/JS, no build step.
Author: PBN
Template: blogwing-base
Version: 0.4.0
Text Domain: pbn
*/

/* Self-hosted condensed display face for a bold headline voice. */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 500 700;
  font-display: swap;
  src: url('//blog.wing.ph/app/themes/wing-blog/assets/fonts/oswald-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+2000-206F, U+2074, U+20AC, U+2122, U+2212, U+FEFF, U+FFFD;
}

/* ============================================================
   WING BLOG — design tokens
   Premium dark casino/sportsbook: gold on carbon. Platinum text,
   gunmetal panels, charcoal hairlines; emerald = win, crimson = alert.
   Built on the shared --blogwing-* token contract.
   ============================================================ */
:root {
  /* Accent — metallic gold (the wordmark colour) */
  --blogwing-accent: #d4af37;        /* gold; on carbon ≈ 8.5:1 */
  --blogwing-accent-ink: #0a0a0a;    /* carbon text ON gold buttons (gold is light) */
  --blogwing-accent-2: #1f1f1f;      /* gunmetal secondary */
  --blogwing-gold-1: #f7e9a0;        /* gradient stops for the wordmark / CTAs */
  --blogwing-gold-2: #d4af37;
  --blogwing-gold-3: #a97b1a;

  /* Header & footer (readability contract — carbon band, platinum/gold ink) */
  --blogwing-header-bg: #0a0a0a;
  --blogwing-header-ink: #e0e0e0;            /* nav = platinum */
  --blogwing-header-border: #333333;
  --blogwing-footer-bg: #0a0a0a;
  --blogwing-footer-ink: #9ca3af;            /* steel body/links */
  --blogwing-footer-title-ink: #d4af37;      /* gold footer wordmark */
  --blogwing-footer-border: #333333;

  /* Surfaces & ink — carbon canvas, gunmetal panels, platinum text */
  --blogwing-bg: #0a0a0a;            /* carbon black */
  --blogwing-surface: #1f1f1f;       /* gunmetal */
  --blogwing-ink: #e0e0e0;           /* platinum (on carbon ≈ 16:1) */
  --blogwing-muted: #9ca3af;         /* steel (on carbon ≈ 8.9:1, AA) */
  --blogwing-border: #333333;        /* charcoal hairline */

  /* Status — emerald win, crimson alert */
  --blogwing-success: #10b981;
  --blogwing-warning: #d4af37;
  --blogwing-danger:  #ef4444;

  /* Shape & depth — slightly softened for a refined, premium feel */
  --blogwing-radius: 6px;
  --blogwing-radius-lg: 12px;
  --blogwing-shadow: 0 1px 2px rgba(0, 0, 0, .6);
  --blogwing-shadow-lg: 0 16px 40px -10px rgba(0, 0, 0, .8);

  /* Type — condensed Oswald headings, clean sans body */
  --blogwing-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --blogwing-font-heading: 'Oswald', "Arial Narrow", "Roboto Condensed", system-ui, -apple-system, Helvetica, Arial, sans-serif;

  --blogwing-max: 760px;
  --blogwing-wide: 1080px;
  --blogwing-space-1: 4px;  --blogwing-space-2: 8px;  --blogwing-space-3: 12px; --blogwing-space-4: 16px;
  --blogwing-space-5: 24px; --blogwing-space-6: 32px; --blogwing-space-7: 48px; --blogwing-space-8: 64px;
}

/* Keep the dark palette even where the base would swap to its own dark-mode neutrals. */
@media (prefers-color-scheme: dark) {
  :root {
    --blogwing-bg: #0a0a0a; --blogwing-surface: #1f1f1f; --blogwing-ink: #e0e0e0;
    --blogwing-muted: #9ca3af; --blogwing-border: #333333; --blogwing-accent: #d4af37;
  }
}

/* ============================================================
   Base surface
   ============================================================ */
body {
  background:
    radial-gradient(1200px 480px at 50% -120px, rgba(212, 175, 55, .07), transparent 60%),
    var(--blogwing-bg);
  color: var(--blogwing-ink);
  -webkit-font-smoothing: antialiased;
}

a { color: var(--blogwing-accent); text-underline-offset: 2px; }
a:hover { color: var(--blogwing-gold-1); text-decoration: underline; }
::selection { background: rgba(212, 175, 55, .28); }
hr { border-color: var(--blogwing-border); }

/* ============================================================
   Headings — condensed, confident, platinum
   ============================================================ */
.blogwing-entry-title,
.blogwing-card h2,
.blogwing-entry-content h2,
.blogwing-entry-content h3 {
  font-family: var(--blogwing-font-heading);
  font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--blogwing-ink);
}
.blogwing-entry-title { font-size: 40px; line-height: 1.06; }
.blogwing-entry-content h2 { border-left: 3px solid var(--blogwing-accent); padding-left: 12px; }

/* ============================================================
   Header — carbon band, gold hairline, GOLD WINGED WORDMARK
   ============================================================ */
.blogwing-site-header {
  background: var(--blogwing-header-bg);
  border-bottom: 1px solid var(--blogwing-header-border);
  position: relative;
}
/* Thin gold gradient strip along the bottom edge — premium signature. */
.blogwing-site-header::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--blogwing-gold-2) 20%, var(--blogwing-gold-1) 50%, var(--blogwing-gold-2) 80%, transparent);
  pointer-events: none;
}

.blogwing-site-title { font-size: 26px; margin: 0; }
/* Gold winged wordmark: the wing mark + gold-gradient text. */
.blogwing-site-header .blogwing-site-title a {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--blogwing-font-heading);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .14em;
  background: linear-gradient(180deg, var(--blogwing-gold-1) 0%, var(--blogwing-gold-2) 48%, var(--blogwing-gold-3) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-decoration: none;
}
.blogwing-site-header .blogwing-site-title a::before {
  content: "";
  width: 46px; height: 29px; flex: 0 0 auto;
  background: url('//blog.wing.ph/app/themes/wing-blog/assets/logo-mark.svg') center/contain no-repeat;
  filter: drop-shadow(0 1px 4px rgba(212, 175, 55, .35));
}

/* Nav — platinum, gold underline on hover/active, generous tap targets */
.blogwing-nav a {
  color: var(--blogwing-header-ink);
  text-transform: uppercase;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .04em;
  padding: 6px 2px;
  border-bottom: 2px solid transparent;
}
.blogwing-nav a:hover,
.blogwing-nav .current-menu-item > a {
  color: var(--blogwing-gold-1);
  border-bottom-color: var(--blogwing-accent);
}

/* ============================================================
   Cards — gunmetal panel, gold rail, hover lift + gold edge
   ============================================================ */
.blogwing-card {
  background: var(--blogwing-surface);
  border: 1px solid var(--blogwing-border);
  border-left: 3px solid var(--blogwing-accent);
  border-radius: var(--blogwing-radius);
  padding: 20px 22px;
  margin-bottom: 16px;
  box-shadow: var(--blogwing-shadow);
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.blogwing-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--blogwing-shadow-lg);
  border-color: var(--blogwing-accent);
}
.blogwing-card h2 { font-size: 22px; }
.blogwing-card h2 a { color: var(--blogwing-ink); }
.blogwing-card h2 a:hover { color: var(--blogwing-accent); }
.blogwing-card__excerpt, .blogwing-card__meta, .blogwing-entry-meta { color: var(--blogwing-muted); }
.blogwing-card .blogwing-entry-meta { margin-bottom: 8px; }
.blogwing-chip { color: var(--blogwing-accent); border-color: var(--blogwing-border); background: rgba(212,175,55,.08); }

/* ============================================================
   Buttons — gold gradient, carbon ink, premium
   ============================================================ */
.blogwing-btn {
  display: inline-block;
  background: linear-gradient(180deg, var(--blogwing-gold-1), var(--blogwing-gold-2) 55%, var(--blogwing-gold-3));
  color: var(--blogwing-accent-ink);
  font-family: var(--blogwing-font-heading);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: 15px;
  line-height: 1;
  padding: 14px 26px;
  border: 1px solid var(--blogwing-gold-3);
  border-radius: var(--blogwing-radius);
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 6px 18px -8px rgba(212, 175, 55, .6);
  transition: filter .12s ease, transform .08s ease, box-shadow .12s ease;
}
.blogwing-btn:hover { filter: brightness(1.08); transform: translateY(-1px); text-decoration: none; color: var(--blogwing-accent-ink); }
.blogwing-btn:active { transform: translateY(0); }
.blogwing-btn:focus-visible { outline: 3px solid var(--blogwing-gold-1); outline-offset: 2px; }
.blogwing-btn--ghost {
  background: transparent;
  color: var(--blogwing-accent);
  border: 1px solid var(--blogwing-accent);
  box-shadow: none;
}
.blogwing-btn--ghost:hover { background: rgba(212, 175, 55, .12); color: var(--blogwing-gold-1); filter: none; }

/* Status helpers — emerald win / crimson alert (intuitive at-a-glance) */
.blogwing-win, .blogwing-up { color: var(--blogwing-success); font-weight: 700; }
.blogwing-loss, .blogwing-down, .blogwing-alert { color: var(--blogwing-danger); font-weight: 700; }

/* ============================================================
   Media, code, pagination, search — dark-surface aware
   ============================================================ */
.blogwing-entry-content img,
.blogwing-featured img { border-radius: var(--blogwing-radius-lg); }
.blogwing-card__media { background: #161616; }

.blogwing-prose :not(pre) > code { background: #161616; color: var(--blogwing-gold-1); }
.blogwing-search-form input[type="search"] {
  background: var(--blogwing-surface); color: var(--blogwing-ink); border: 1px solid var(--blogwing-border);
}

.blogwing-pagination a,
.blogwing-pagination span {
  border: 1px solid var(--blogwing-border);
  border-radius: var(--blogwing-radius);
  color: var(--blogwing-ink);
  font-weight: 700;
}
.blogwing-pagination a:hover { border-color: var(--blogwing-accent); color: var(--blogwing-accent); }
.blogwing-pagination .current {
  background: var(--blogwing-accent); color: var(--blogwing-accent-ink); border-color: var(--blogwing-accent);
}

/* ============================================================
   Footer — carbon, gold top hairline, gold wordmark
   ============================================================ */
.blogwing-site-footer { position: relative; }
.blogwing-site-footer::before {
  content: "";
  position: absolute; left: 0; right: 0; top: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--blogwing-gold-2) 20%, var(--blogwing-gold-1) 50%, var(--blogwing-gold-2) 80%, transparent);
}
.blogwing-site-footer a:hover { color: var(--blogwing-gold-1); }
