/* ============================================================
   Jobie Bradley Art — comic-book-pop redesign
   Bangers + Permanent Marker + Inter
   Hot pink / electric cyan / sun yellow on ink black
   Halftone dots, action lines, comic-panel cards, 3D buttons
   ============================================================ */

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

:root {
  /* ── Palette ───────────────────────────────────────── */
  /* Spider-Man-inspired base + classic comic accents */
  --ink:        #0a0a0a;
  --ink-2:      #161616;
  --ink-3:      #222;
  --paper:      #f8f6f1;
  --paper-2:    #ece9e1;

  /* Spider-Man primaries */
  --spider-red:    #ed1d24;
  --spider-red-2:  #ff3b3b;
  --spider-blue:   #2864b5;
  --spider-blue-2: #1a3a78;
  --spider-navy:   #0a1738;     /* deep base, just shy of black */
  --spider-bg:     #08112a;     /* darker bluer body base for readability */

  --pink:       #ff2e7d;
  --pink-2:     #ff5b9b;
  --cyan:       #00d9ff;
  --cyan-2:     #66e8ff;
  --yellow:     #ffe600;
  --yellow-2:   #fff170;
  --red:        var(--spider-red);
  --green:      #00e676;

  --accent:     var(--pink);
  --accent-2:   var(--cyan);
  --accent-3:   var(--yellow);

  --text:       #ffffff;
  --text-dim:   #c9c9d4;
  --text-muted: #8b8ba0;

  /* ── Typography ────────────────────────────────────── */
  --font-display: 'Bangers', 'Anton', system-ui, sans-serif;
  --font-marker:  'Permanent Marker', 'Bangers', cursive;
  --font-body:    'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;

  --max-width: 1200px;
  --radius: 8px;
  --radius-lg: 16px;

  --nav-h: 70px;
  --hard-shadow: 6px 6px 0 0 var(--ink);
  --hard-shadow-lg: 10px 10px 0 0 var(--ink);

  --halftone-light:
    radial-gradient(circle, rgba(255,255,255,.06) 1.2px, transparent 1.4px) 0 0 / 14px 14px;
  --halftone-pink:
    radial-gradient(circle, rgba(255,46,125,.18) 1.2px, transparent 1.4px) 0 0 / 14px 14px;
  --halftone-yellow:
    radial-gradient(circle, rgba(255,230,0,.22) 1.2px, transparent 1.4px) 0 0 / 14px 14px;

  /* Classic Ben-Day dot — softer/blurrier edges + lower contrast for readability.
     Wider transparent fade radius creates a blur-like halo without GPU filters. */
  --benday-red:
    radial-gradient(circle, rgba(255,55,62,.28) 2.2px, transparent 4.4px) 0 0 / 16px 16px;
  --benday-red-strong:
    radial-gradient(circle, rgba(255,55,62,.42) 2.4px, transparent 4.6px) 0 0 / 16px 16px;
  --benday-blue:
    radial-gradient(circle, rgba(74,148,255,.26) 2.8px, transparent 5px) 8px 8px / 22px 22px;
  --benday-yellow:
    radial-gradient(circle, rgba(253,185,19,.28) 2.2px, transparent 4.4px) 0 0 / 16px 16px;
}

@keyframes hue-sweep {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}
@keyframes float-slow {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
@keyframes blink { 50% { opacity: 0; } }

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--nav-h) + 8px);
}
body {
  font-family: var(--font-body);
  color: var(--text);
  font-size: 1.125rem;       /* base 18px — larger body text everywhere */
  font-weight: 500;          /* Inter 500 — bolder default for paragraph text */
  line-height: 1.7;
  overflow-x: hidden;
  /* Layered Spider-Man Ben-Day texture (background shorthand so the
     `<gradient> X Y / W H` form parses — invalid inside background-image).
       1. red halftone dots (large, classic Lichtenstein/comic feel)
       2. blue offset dots for depth (bigger grid, dimmer)
       3. red glow at upper-left + blue glow at lower-right corner
       4. base navy/blue color underneath (last layer carries bg-color)
  */
  background:
    radial-gradient(ellipse at 10% 6%, rgba(255,46,52,.32),  transparent 42%),
    radial-gradient(ellipse at 92% 96%, rgba(74,148,255,.30), transparent 44%),
    radial-gradient(ellipse at 70% 30%, rgba(255,46,52,.10), transparent 35%),
    var(--benday-blue),
    var(--benday-red) var(--spider-bg);
  background-attachment: fixed;
}

/* ── Typography ─────────────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  margin: 0 0 0.9em;        /* bottom rhythm under every heading */
}
h1 { font-size: clamp(3rem, 8vw, 6rem); }
h2 { font-size: clamp(2.4rem, 5.5vw, 4rem); }
h3 { font-size: clamp(1.75rem, 3vw, 2.4rem); margin-bottom: 0.7em; }
h4 { font-size: 1.45rem; margin-bottom: 0.6em; }
p { margin-bottom: 1.2em; }
p + h2, p + h3, p + h4 { margin-top: 1.6em; }    /* extra breathing when text precedes a heading */
ul + h2, ul + h3, ol + h2, ol + h3 { margin-top: 1.6em; }
.section > .container > p:last-child,
.section > .container > .prose:last-child { margin-bottom: 0; }
strong { color: var(--yellow); font-weight: 700; }
em { color: var(--cyan); font-style: normal; font-family: var(--font-marker); }
a { color: var(--cyan); text-decoration: none; transition: color .15s ease; }
a:hover { color: var(--yellow); }

img { max-width: 100%; height: auto; display: block; }

.container { max-width: var(--max-width); margin: 0 auto; padding: 0 24px; }

.section { padding: 7rem 0 6rem; position: relative; }
.section + .section { margin-top: 0; }
.section-title {
  text-align: center;
  margin-bottom: 4rem;
  margin-top: 0;
  font-size: clamp(2.6rem, 6vw, 4.4rem);
  background: linear-gradient(
    90deg, var(--pink), var(--yellow), var(--cyan), var(--pink)
  );
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: hue-sweep 8s linear infinite;
  display: inline-block;
  width: 100%;
  transform: skewX(-3deg);
  /* Two-stop shadow: dark base + accent glow so it reads on bright + dark bgs */
  filter:
    drop-shadow(3px 3px 0 var(--title-shadow, #06091a))
    drop-shadow(0 0 12px rgba(0,0,0,.55));
}

/* ── Page-header (inner pages) — match section-title aesthetic ── */
.page-header {
  text-align: center;
  padding: 5rem 1.5rem 2rem;
  position: relative;
}
.page-header h1 {
  font-size: clamp(3rem, 8vw, 5.4rem);
  margin: 0 0 0.6em;
  background: linear-gradient(
    90deg, var(--pink), var(--yellow), var(--cyan), var(--pink)
  );
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: hue-sweep 8s linear infinite;
  display: inline-block;
  /* Roomier line-height + padding-bottom so background-clip:text doesn't
     clip descenders (Y in BIOGRAPHY/GALLERY) or the rotated lower edge. */
  line-height: 1.25;
  padding: 0.05em 0.15em 0.2em;
  transform: skewX(-3deg) rotate(-1deg);
  filter:
    drop-shadow(3px 3px 0 var(--title-shadow, #06091a))
    drop-shadow(0 0 14px rgba(0,0,0,.55));
}
.page-header > p {
  font-family: var(--font-marker);
  font-size: clamp(1.2rem, 2.4vw, 1.6rem);
  color: var(--yellow);
  letter-spacing: .04em;
  margin: 0 auto 1rem;
  max-width: 60ch;
  text-shadow: 2px 2px 0 var(--ink);
}

/* ── Navigation ────────────────────────────────────── */
.navbar {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  min-height: var(--nav-h);
  padding: 0.6rem 1.4rem;
  background: var(--ink);
  border-bottom: 3px solid var(--pink);
  box-shadow: 0 4px 0 0 var(--ink-2), 0 6px 24px rgba(255,46,125,.18);
}
.nav-brand a {
  font-family: var(--font-display);
  font-size: 1.8rem;
  letter-spacing: .08em;
  color: var(--paper);
  text-shadow: 2px 2px 0 var(--pink);
}
.nav-brand a:hover {
  color: var(--yellow);
  text-shadow: 2px 2px 0 var(--cyan);
}
.nav-links {
  display: flex; list-style: none; gap: 1.6rem; margin: 0; padding: 0;
}
.nav-links a {
  font-family: var(--font-display);
  font-size: 1.2rem;
  letter-spacing: .14em;
  color: var(--paper);
  padding: 0.4rem 0.5rem;
  position: relative;
}
.nav-links a::after {
  content: ''; position: absolute; left: 50%; right: 50%; bottom: -2px;
  height: 3px; background: var(--yellow);
  transition: left .2s ease, right .2s ease;
}
.nav-links a:hover::after, .nav-links a.active::after { left: 0; right: 0; }
.nav-links a:hover { color: var(--yellow); }
.nav-links a.active { color: var(--cyan); }
.nav-toggle {
  display: none;
  background: none; border: 0; cursor: pointer;
  width: 36px; height: 28px; padding: 0;
}
.nav-toggle span {
  display: block; height: 4px; background: var(--pink); border-radius: 2px;
  margin: 4px 0; transition: transform .2s ease, opacity .2s ease;
}
@media (max-width: 760px) {
  .navbar { flex-wrap: wrap; padding: 0.6rem 1rem; }
  .nav-toggle { display: block; }
  .nav-links {
    display: none; width: 100%; flex-direction: column; gap: 0;
    margin-top: 0.6rem;
  }
  .nav-links.open { display: flex; }
  .nav-links li { border-top: 1px solid var(--ink-3); }
  .nav-links a { display: block; padding: 0.8rem 0.4rem; }
}

/* ── Hero ──────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 78vh;
  display: grid; place-items: center;
  padding: 4rem 1.5rem;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(255,46,52,.45), transparent 55%),
    radial-gradient(ellipse at 70% 70%, rgba(74,148,255,.40), transparent 55%),
    radial-gradient(ellipse at center, rgba(17,32,74,.30), transparent 70%);
  overflow: hidden;
  isolation: isolate;
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    repeating-conic-gradient(
      from 0deg at 50% 50%,
      transparent 0deg 9deg,
      rgba(255,255,255,.025) 9deg 10deg
    );
  z-index: -1;
  animation: float-slow 10s ease-in-out infinite;
}
.hero::after {
  content: '';
  position: absolute; inset: 0;
  background: var(--benday-red-strong);
  z-index: -1; opacity: .85;
  mix-blend-mode: screen;
  mask-image: radial-gradient(circle at 50% 50%, transparent 22%, black 60%);
}
.hero-overlay { display: none; }
.hero-content { text-align: center; position: relative; }
.hero-title {
  font-family: var(--font-display);
  font-size: clamp(3.5rem, 11vw, 8rem);
  line-height: .92;
  letter-spacing: 0.04em;
  background: linear-gradient(
    90deg, var(--pink) 0%, var(--yellow) 35%, var(--cyan) 70%, var(--pink) 100%
  );
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: hue-sweep 6s linear infinite;
  filter: drop-shadow(4px 4px 0 var(--ink)) drop-shadow(8px 8px 0 rgba(255,46,125,.4));
  margin: 0 0 1rem;
  transform: rotate(-1deg);
}
.hero-subtitle {
  font-family: var(--font-marker);
  font-size: clamp(2rem, 5vw, 3.4rem);
  color: var(--yellow);
  letter-spacing: .08em;
  margin: 0 0 2rem;
  transform: rotate(2deg);
  text-shadow: 3px 3px 0 var(--ink);
  display: inline-block;
}
.hero-tagline {
  font-family: var(--font-body);
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  color: var(--text-dim);
  margin: 0 auto 3rem;
  max-width: 60ch;
  letter-spacing: .04em;
  font-weight: 600;
  line-height: 1.7;
}
.hero-cta { display: flex; gap: 1.2rem; justify-content: center; flex-wrap: wrap; margin-top: 0.5rem; }

/* ── Buttons (3D press) ─────────────────────────────── */
.btn {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 1.25rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 1.05rem 2rem;
  border: 3px solid var(--ink);
  border-radius: 4px;
  cursor: pointer;
  text-decoration: none;
  position: relative;
  transition: transform .12s ease, box-shadow .12s ease, background .15s ease, color .15s ease;
  box-shadow: var(--hard-shadow);
}
.btn:hover  { transform: translate(-2px, -2px); box-shadow: 8px 8px 0 0 var(--ink); text-decoration: none; }
.btn:active { transform: translate(4px, 4px);   box-shadow: 0 0 0 0 var(--ink); }
.btn-primary  { background: var(--pink);   color: var(--paper); }
.btn-primary:hover  { background: var(--yellow); color: var(--ink); }
.btn-outline  { background: transparent;   color: var(--cyan); border-color: var(--cyan); box-shadow: 6px 6px 0 0 var(--cyan); }
.btn-outline:hover  { background: var(--cyan); color: var(--ink); box-shadow: 8px 8px 0 0 var(--ink); border-color: var(--ink); }
.btn-secondary { background: var(--ink-2); color: var(--yellow); }
.btn-secondary:hover { background: var(--yellow); color: var(--ink); }

/* ── About preview / highlights ────────────────────── */
.about-preview {
  background:
    linear-gradient(180deg, transparent 0%, rgba(17,32,74,.30) 100%);
}
.about-preview::before {
  content: ''; position: absolute; inset: 0;
  background: var(--benday-red); opacity: .85; pointer-events: none;
  mix-blend-mode: screen;
}
.about-grid {
  display: grid;
  grid-template-columns: 1fr;       /* single-column for vertical mobile-first flow */
  gap: 3rem;
  align-items: center;
  max-width: 760px;                 /* keeps text readable on wide screens */
  margin: 0 auto;
}
.about-text p { font-size: 1.2rem; font-weight: 600; line-height: 1.85; margin-bottom: 1.4em; }
.about-text p:last-of-type { margin-bottom: 1.8em; }   /* extra gap before the CTA button */
.about-highlights { display: grid; gap: 1.4rem; }

.highlight-card {
  display: flex; flex-direction: column; align-items: flex-start; gap: .55rem;
  padding: 1.4rem 1.5rem;
  background: var(--paper);
  color: var(--ink);
  border: 3px solid var(--ink);
  border-radius: var(--radius);
  box-shadow: var(--hard-shadow);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
  position: relative; overflow: hidden;
}
.highlight-card:nth-child(odd)  { transform: rotate(-1deg); }
.highlight-card:nth-child(even) { transform: rotate(1deg); }
.highlight-card:hover { transform: rotate(0) translate(-2px, -3px); box-shadow: var(--hard-shadow-lg); }
.highlight-card::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: var(--halftone-pink); opacity: .35;
}
.highlight-number {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 4vw, 3.4rem);
  line-height: 1;
  background: linear-gradient(135deg, var(--pink), var(--red));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  letter-spacing: .04em;
}
.highlight-card:nth-child(2) .highlight-number {
  background: linear-gradient(135deg, var(--cyan), #0080ff);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.highlight-card:nth-child(3) .highlight-number {
  background: linear-gradient(135deg, var(--yellow), #ff8400);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.highlight-label {
  font-family: var(--font-display);
  font-size: 1.15rem;
  letter-spacing: .14em;
  color: var(--ink-2);
  opacity: .8;
}

@media (max-width: 760px) {
  .about-grid { gap: 2rem; }
}

/* ── Services grid (comic-panel cards) ─────────────── */
.services {
  background:
    linear-gradient(180deg, rgba(40,100,181,.18), rgba(237,29,36,.14));
}
.services::before {
  content: ''; position: absolute; inset: 0;
  background: var(--benday-blue); opacity: .95; pointer-events: none;
  mix-blend-mode: screen;
}
.services-grid {
  display: grid;
  grid-template-columns: 1fr;        /* single-column vertical stack */
  gap: 1.6rem;
  margin-top: 2rem;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
.service-card {
  background: var(--paper);
  color: var(--ink);
  border: 3px solid var(--ink);
  border-radius: var(--radius);
  padding: 2.2rem 1.6rem 2rem;
  text-align: center;
  position: relative; overflow: hidden;
  box-shadow: var(--hard-shadow);
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease;
}
.service-card:nth-child(4n+1) { transform: rotate(-1.5deg); }
.service-card:nth-child(4n+2) { transform: rotate(1deg); }
.service-card:nth-child(4n+3) { transform: rotate(-0.5deg); }
.service-card:nth-child(4n+4) { transform: rotate(1.5deg); }
.service-card:hover {
  transform: rotate(0) translate(-3px, -3px);
  box-shadow: var(--hard-shadow-lg);
  background: var(--paper-2);
}
.service-card::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: var(--halftone-yellow); opacity: .35;
  mix-blend-mode: multiply;
}
.service-icon {
  font-size: 3rem;
  margin-bottom: 1rem;
  position: relative;
  display: inline-block;
  filter: drop-shadow(2px 2px 0 var(--pink));
}
.service-card h3 {
  color: var(--ink);
  margin-bottom: 1rem;
  letter-spacing: .04em;
}
.services .service-card p { color: #333; font-size: 1.15rem; line-height: 1.7; margin: 0; font-weight: 600; }

/* ── Instagram + CTA section ───────────────────────── */
.instagram-section {
  background: linear-gradient(180deg, rgba(17,32,74,.35), rgba(14,26,61,.45));
}
.instagram-section::before {
  content: ''; position: absolute; inset: 0;
  background: var(--benday-red); opacity: .85; pointer-events: none;
  mix-blend-mode: screen;
}
.instagram-section .section-desc {
  text-align: center; color: var(--text-dim);
  margin-top: -2rem; margin-bottom: 3rem;
  font-size: 1.2rem;
  font-weight: 600;
}
.instagram-feed {
  display: grid;
  grid-template-columns: 1fr;        /* single-column vertical */
  gap: 1.2rem;
  margin-bottom: 3rem;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
.ig-placeholder {
  text-align: center; padding: 3rem; color: var(--text-muted);
  border: 3px dashed var(--ink-3); border-radius: var(--radius);
}
.ig-follow { text-align: center; }

.cta-section {
  background:
    radial-gradient(ellipse at 50% 50%, rgba(255,46,52,.30), transparent 60%);
  text-align: center;
}
.cta-section::before {
  content: ''; position: absolute; inset: 0;
  background: var(--benday-red); opacity: .85; pointer-events: none;
  mix-blend-mode: screen;
}
.cta-box {
  background: linear-gradient(135deg, var(--pink), var(--cyan));
  border: 4px solid var(--ink);
  border-radius: var(--radius-lg);
  padding: 3.5rem 2.5rem;
  max-width: 720px;
  margin: 0 auto;
  position: relative;
  box-shadow: var(--hard-shadow-lg);
  transform: rotate(-0.5deg);
  overflow: hidden;
}
.cta-box::before {
  content: ''; position: absolute; inset: 0;
  background: var(--halftone-light); opacity: .8;
  pointer-events: none;
}
/* Bumped specificity (.section .cta-box h2) so .section h2 doesn't override.
   Bright comic green fill + offset black shadow → high contrast on the pink/cyan gradient. */
.section .cta-box h2 {
  color: #2eff6e;
  -webkit-text-fill-color: #2eff6e;
  margin: 0 0 1.6rem;
  transform: skewX(-3deg) rotate(-1deg);
  display: inline-block;
  font-size: clamp(2.6rem, 5.5vw, 4.2rem);
  text-shadow: 4px 4px 0 var(--ink), 6px 6px 0 var(--ink);
  position: relative;
}
.section .cta-box p {
  color: var(--ink);
  font-weight: 600;
  font-size: 1.2rem;
  margin: 0 auto 2.2rem;
  max-width: 50ch;
  position: relative;
  line-height: 1.7;
}
.cta-box .btn-primary { background: var(--ink); color: var(--yellow); border-color: var(--paper); }
.cta-box .btn-primary:hover { background: var(--yellow); color: var(--ink); border-color: var(--ink); }

/* ── Footer ────────────────────────────────────────── */
.footer {
  background: linear-gradient(180deg, rgba(17,32,74,.55), rgba(7,12,33,.85));
  border-top: 4px solid var(--spider-red);
  padding: 3rem 0 1.5rem;
  margin-top: 4rem;
  position: relative;
}
.footer::before {
  content: ''; position: absolute; inset: 0;
  background: var(--benday-blue); opacity: .9; pointer-events: none;
  mix-blend-mode: screen;
}
.footer-grid {
  display: grid; grid-template-columns: 1fr; gap: 2.4rem;
  position: relative;
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}
.footer-brand h3 {
  font-family: var(--font-display);
  font-size: 1.6rem;
  letter-spacing: .08em;
  color: var(--paper);
  margin-bottom: 0.8rem;
  text-shadow: 3px 3px 0 var(--pink);
}
.footer-brand p { color: var(--text-muted); font-style: italic; font-size: 1.05rem; font-weight: 600; }
.footer-links h4, .footer-social h4 {
  font-family: var(--font-display);
  letter-spacing: .14em;
  color: var(--yellow);
  margin-bottom: 1rem;
}
.footer-links ul, .footer-social ul { list-style: none; padding: 0; margin: 0; }
.footer-links li, .footer-social li { margin-bottom: 0.65rem; }
.footer-links a, .footer-social a {
  color: var(--text-dim); font-size: 1.1rem; font-weight: 600;
  border-bottom: 1px dashed transparent;
  transition: color .15s, border-color .15s;
}
.footer-links a:hover, .footer-social a:hover {
  color: var(--cyan); border-bottom-color: var(--cyan);
}
.footer-bottom {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--ink-3);
  text-align: center; color: var(--text-muted); font-size: 1rem; position: relative;
}
@media (max-width: 760px) {
  .footer-grid { gap: 1.6rem; }
}

/* ── Generic content (bio, gallery, socials, etc.) ── */
.section p { color: var(--text-dim); font-size: 1.2rem; font-weight: 600; line-height: 1.8; margin-bottom: 1.4em; }
.section h2 { color: var(--text); }
.section h2 + p, .section h3 + p { margin-top: 1.2em; }
.section p + p { margin-top: 0.4em; }
.section ul, .section ol { margin-bottom: 1.4em; font-size: 1.15rem; font-weight: 600; }
.section li { margin-bottom: 0.5em; line-height: 1.75; }
.section blockquote { margin: 1.6em 0; padding-left: 1.2rem; border-left: 4px solid var(--pink); }

/* Gallery — single-column vertical for mobile-first comic-page flow */
.gallery-grid {
  display: grid; grid-template-columns: 1fr;
  gap: 1.4rem;
  max-width: 720px;
  margin: 0 auto;
}
.gallery-item {
  border: 3px solid var(--ink);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--hard-shadow);
  background: var(--paper);
  transition: transform .15s, box-shadow .15s;
}
.gallery-item:hover { transform: translate(-2px, -2px) rotate(-0.5deg); box-shadow: var(--hard-shadow-lg); }
.gallery-item img { display: block; width: 100%; max-height: 80vh; object-fit: cover; }

.gallery-placeholder {
  text-align: center; padding: 4rem 1rem; color: var(--text-muted);
  border: 3px dashed var(--ink-3); border-radius: var(--radius);
}

/* ── Scroll-reveal ──────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity: 1; transform: translateY(0); }

/* ── Reduced motion ─────────────────────────────────── */
@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;
  }
}

/* ════════════════════════════════════════════════════════
   PER-PAGE THEMES
   Each page redefines --spider-bg + --benday-red/blue so the
   shared body bg-image rule picks up new colors automatically.
   Plus per-page section-title gradient + accent borders.
   ════════════════════════════════════════════════════════ */

/* ── page-bio: ORIGIN STORY (orange / yellow / crimson) ── */
body.page-bio {
  --spider-bg:     #150509;
  --spider-red:    #ff8a1e;
  --spider-red-2:  #ffb04a;
  --spider-blue:   #f5c518;
  --title-shadow:  #2a0807;
  --benday-red:
    radial-gradient(circle, rgba(255,138,30,.32) 2.4px, transparent 4.6px) 0 0 / 16px 16px;
  --benday-red-strong:
    radial-gradient(circle, rgba(255,80,30,.46) 2.6px, transparent 4.8px) 0 0 / 16px 16px;
  --benday-blue:
    radial-gradient(circle, rgba(245,197,24,.28) 2.8px, transparent 5px) 8px 8px / 22px 22px;
  background:
    radial-gradient(ellipse at 8% 6%,   rgba(255,138,30,.32), transparent 42%),
    radial-gradient(ellipse at 92% 96%, rgba(245,197,24,.26), transparent 44%),
    radial-gradient(ellipse at 60% 40%, rgba(255,60,40,.10),  transparent 38%),
    var(--benday-blue),
    var(--benday-red) var(--spider-bg);
  background-attachment: fixed;
}
body.page-bio .hero {
  background:
    radial-gradient(ellipse at 30% 30%, rgba(255,138,30,.50), transparent 55%),
    radial-gradient(ellipse at 70% 70%, rgba(245,197,24,.40), transparent 55%),
    radial-gradient(ellipse at center,   rgba(40,12,8,.30),    transparent 70%);
}
body.page-bio .section-title {
  background: linear-gradient(90deg, #ff8a1e, #f5c518, #ff3c28, #ff8a1e);
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
body.page-bio .navbar { border-bottom-color: #ff8a1e; }
body.page-bio .footer { border-top-color: #ff8a1e; }

/* ── page-gallery: LICHTENSTEIN POP (magenta / cyan / yellow) ── */
body.page-gallery {
  --spider-bg:     #140725;
  --spider-red:    #ff2dd7;
  --spider-red-2:  #ff5fe3;
  --spider-blue:   #00d8ff;
  --title-shadow:  #1a0530;
  --benday-red:
    radial-gradient(circle, rgba(255,45,215,.34) 2.4px, transparent 5px) 0 0 / 18px 18px;
  --benday-red-strong:
    radial-gradient(circle, rgba(255,45,215,.50) 2.6px, transparent 5.2px) 0 0 / 18px 18px;
  --benday-blue:
    radial-gradient(circle, rgba(0,216,255,.30) 3.2px, transparent 5.4px) 10px 10px / 24px 24px;
  background:
    radial-gradient(ellipse at 6% 8%,   rgba(255,45,215,.32), transparent 42%),
    radial-gradient(ellipse at 94% 92%, rgba(0,216,255,.28),  transparent 44%),
    radial-gradient(ellipse at 50% 50%, rgba(245,197,24,.10), transparent 40%),
    var(--benday-blue),
    var(--benday-red) var(--spider-bg);
  background-attachment: fixed;
}
body.page-gallery .hero {
  background:
    radial-gradient(ellipse at 30% 30%, rgba(255,45,215,.50), transparent 55%),
    radial-gradient(ellipse at 70% 70%, rgba(0,216,255,.45),  transparent 55%),
    radial-gradient(ellipse at center,   rgba(28,10,50,.30),  transparent 70%);
}
body.page-gallery .section-title {
  background: linear-gradient(90deg, #ff2dd7, #00d8ff, #f5c518, #ff2dd7);
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
body.page-gallery .navbar { border-bottom-color: #ff2dd7; }
body.page-gallery .footer { border-top-color: #ff2dd7; }

/* ── page-cumberland-con: COSMIC EVENT (purple / teal / magenta) ── */
body.page-cumberland-con {
  --spider-bg:     #0c0427;
  --spider-red:    #a81eff;
  --spider-red-2:  #c956ff;
  --spider-blue:   #00ddc9;
  --title-shadow:  #100425;
  --benday-red:
    radial-gradient(circle, rgba(168,30,255,.34) 2.4px, transparent 4.8px) 0 0 / 16px 16px;
  --benday-red-strong:
    radial-gradient(circle, rgba(255,42,204,.48) 2.6px, transparent 5px) 0 0 / 16px 16px;
  --benday-blue:
    radial-gradient(circle, rgba(0,221,201,.28) 2.8px, transparent 5px) 9px 9px / 22px 22px;
  background:
    radial-gradient(ellipse at 12% 6%,  rgba(168,30,255,.34), transparent 42%),
    radial-gradient(ellipse at 88% 94%, rgba(0,221,201,.28),  transparent 44%),
    radial-gradient(ellipse at 70% 30%, rgba(255,42,204,.12), transparent 36%),
    var(--benday-blue),
    var(--benday-red) var(--spider-bg);
  background-attachment: fixed;
}
body.page-cumberland-con .hero {
  background:
    radial-gradient(ellipse at 30% 30%, rgba(168,30,255,.50), transparent 55%),
    radial-gradient(ellipse at 70% 70%, rgba(0,221,201,.45),  transparent 55%),
    radial-gradient(ellipse at center,   rgba(17,6,54,.30),    transparent 70%);
}
body.page-cumberland-con .section-title {
  background: linear-gradient(90deg, #a81eff, #00ddc9, #ff2acc, #a81eff);
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
body.page-cumberland-con .navbar { border-bottom-color: #a81eff; }
body.page-cumberland-con .footer { border-top-color: #a81eff; }

/* ── page-socials: SUNSET INSTAGRAM (pink / tangerine / yellow) ── */
body.page-socials {
  --spider-bg:     #1b061d;
  --spider-red:    #ff5188;
  --spider-red-2:  #ff84a9;
  --spider-blue:   #ff9f4a;
  --title-shadow:  #210420;
  --benday-red:
    radial-gradient(circle, rgba(255,81,136,.34) 2.4px, transparent 4.8px) 0 0 / 16px 16px;
  --benday-red-strong:
    radial-gradient(circle, rgba(255,81,136,.50) 2.6px, transparent 5px) 0 0 / 16px 16px;
  --benday-blue:
    radial-gradient(circle, rgba(255,159,74,.30) 2.8px, transparent 5px) 8px 8px / 22px 22px;
  background:
    radial-gradient(ellipse at 8% 8%,   rgba(255,81,136,.32), transparent 42%),
    radial-gradient(ellipse at 92% 92%, rgba(255,159,74,.30), transparent 44%),
    radial-gradient(ellipse at 50% 60%, rgba(245,197,24,.10), transparent 40%),
    var(--benday-blue),
    var(--benday-red) var(--spider-bg);
  background-attachment: fixed;
}
body.page-socials .hero {
  background:
    radial-gradient(ellipse at 30% 30%, rgba(255,81,136,.50), transparent 55%),
    radial-gradient(ellipse at 70% 70%, rgba(255,159,74,.45), transparent 55%),
    radial-gradient(ellipse at center,   rgba(36,10,38,.30),   transparent 70%);
}
body.page-socials .section-title {
  background: linear-gradient(90deg, #ff5188, #ff9f4a, #f5c518, #ff5188);
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
body.page-socials .navbar { border-bottom-color: #ff5188; }
body.page-socials .footer { border-top-color: #ff5188; }

/* ════════════════════════════════════════════════════════
   Utility classes — replace inline styles for html-validate cleanliness.
   ════════════════════════════════════════════════════════ */
.section--flush-top { padding-top: 0; }

.founder-credit {
  margin-top: 8px;
  color: var(--text-dim);
  font-size: 0.85rem;
}

.cta-spacer-top { margin-top: 15px; }

/* Brand-coloured social CTA buttons (replace per-platform inline styles). */
.btn-brand-instagram { background: #e1306c; border-color: #e1306c; }
.btn-brand-tiktok    { background: #00f2ea; border-color: #00f2ea; color: #000; }
.btn-brand-facebook  { background: #1877f2; border-color: #1877f2; }
.btn-brand-youtube   { background: #ff0000; border-color: #ff0000; }
.btn-brand-twitter   { background: #1da1f2; border-color: #1da1f2; }
.btn-brand-twitch    { background: #9146ff; border-color: #9146ff; }
.btn-brand-linkedin  { background: #0a66c2; border-color: #0a66c2; }
.btn-brand-github    { background: #333333; border-color: #333333; }
.btn-brand-website   { background: #e94560; border-color: #e94560; }
