/* ═══════════════════════════════════════════════════════════════
   PLATFORM.CSS v5 — Premium Light Design System
   Iteration 11-30: Classic View + In-Game Blog Reader
   Font: Plus Jakarta Sans · Accent: #6366F1 Indigo
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,opsz,wght@0,6..15,300;0,6..15,400;0,6..15,500;0,6..15,600;0,6..15,700;0,6..15,800;0,6..15,900;1,6..15,400&display=swap');

/* ── Design Tokens ── */
:root {
  --p-bg:            #F5F6F8;
  --p-bg-2:          #EDEEF2;
  --p-surface:       #FFFFFF;
  --p-surface-2:     #F9FAFB;
  --p-border:        rgba(0,0,0,0.065);
  --p-border-md:     rgba(0,0,0,0.11);
  --p-border-acc:    rgba(99,102,241,0.22);

  --p-ink:           #0C1222;
  --p-ink-2:         #1B2537;
  --p-ink-muted:     #52637A;
  --p-ink-faint:     #8796A9;

  --p-indigo:        #6366F1;
  --p-indigo-d:      #4F46E5;
  --p-indigo-dd:     #3730A3;
  --p-indigo-l:      #EEF2FF;
  --p-indigo-m:      #C7D2FE;
  --p-sky:           #0EA5E9;
  --p-sky-l:         #E0F2FE;
  --p-green:         #10B981;
  --p-green-l:       #ECFDF5;
  --p-rose:          #F43F5E;
  --p-rose-l:        #FFF1F2;
  --p-amber:         #F59E0B;
  --p-amber-l:       #FFFBEB;
  --p-purple:        #A855F7;

  --p-shadow-xs:  0 1px 2px rgba(0,0,0,0.04);
  --p-shadow-sm:  0 1px 3px rgba(0,0,0,0.06), 0 2px 8px rgba(0,0,0,0.03);
  --p-shadow:     0 2px 8px rgba(0,0,0,0.07), 0 8px 24px rgba(0,0,0,0.04);
  --p-shadow-md:  0 4px 16px rgba(0,0,0,0.09), 0 16px 48px rgba(0,0,0,0.05);
  --p-shadow-lg:  0 8px 32px rgba(0,0,0,0.10), 0 32px 80px rgba(0,0,0,0.07);
  --p-shadow-xl:  -20px 0 60px rgba(0,0,0,0.09), 0 0 0 1px rgba(0,0,0,0.04);

  --p-r-xs:   4px;
  --p-r-sm:   8px;
  --p-r:      12px;
  --p-r-lg:   16px;
  --p-r-xl:   20px;
  --p-r-2xl:  28px;
  --p-r-pill: 9999px;

  --p-font:  'Plus Jakarta Sans', -apple-system, system-ui, sans-serif;
  --p-ease:  cubic-bezier(0.16, 1, 0.3, 1);
  --p-ease2: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ════════════════════════════════════════════════════════════
   ITERATION 11 — CLASSIC MODE BASE
   ════════════════════════════════════════════════════════════ */

body.classic-mode {
  background: var(--p-bg) !important;
  color: var(--p-ink) !important;
  overflow-x: hidden !important;
  font-family: var(--p-font) !important;
  -webkit-font-smoothing: antialiased !important;
}
body.classic-mode::before,
body.classic-mode::after { display: none !important; }
body.classic-mode canvas { opacity: 0.12 !important; }

.classic-view {
  max-width: 900px !important;
  margin: 0 auto !important;
  padding: 0 1.5rem 4rem !important;
  animation: p-fade-up 0.55s var(--p-ease) both !important;
}

@keyframes p-fade-up {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ════════════════════════════════════════════════════════════
   ITERATION 12 — CLASSIC HEADER
   ════════════════════════════════════════════════════════════ */

.classic-hdr {
  position: sticky !important;
  top: 0 !important;
  z-index: 100 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 0 !important;
  height: 60px !important;
  margin: 0 -1.5rem !important;
  padding: 0 1.5rem !important;
  background: rgba(245,246,248,0.92) !important;
  border-bottom: 1px solid var(--p-border) !important;
  backdrop-filter: blur(32px) saturate(2) !important;
  -webkit-backdrop-filter: blur(32px) saturate(2) !important;
  box-shadow: 0 1px 0 var(--p-border), 0 4px 20px rgba(0,0,0,0.03) !important;
}

.classic-hdr__logo {
  font-family: var(--p-font) !important;
  font-size: 1.2rem !important;
  font-weight: 900 !important;
  letter-spacing: -0.035em !important;
  color: var(--p-ink) !important;
  text-decoration: none !important;
  text-shadow: none !important;
}
.classic-hdr__logo span {
  color: var(--p-indigo) !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  -webkit-text-fill-color: var(--p-indigo) !important;
  background-clip: unset !important;
}

.classic-hdr__btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.4rem !important;
  padding: 7px 18px !important;
  background: var(--p-indigo) !important;
  border: none !important;
  border-radius: var(--p-r-pill) !important;
  color: #fff !important;
  font-family: var(--p-font) !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  text-transform: none !important;
  box-shadow: 0 2px 10px rgba(99,102,241,0.3) !important;
  transition: all 0.18s var(--p-ease) !important;
  text-decoration: none !important;
  cursor: pointer !important;
}
.classic-hdr__btn:hover {
  background: var(--p-indigo-d) !important;
  color: #fff !important;
  box-shadow: 0 4px 20px rgba(99,102,241,0.45) !important;
  transform: translateY(-1px) !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 13 — CLASSIC HERO
   ════════════════════════════════════════════════════════════ */

.classic-hero {
  padding: 3.5rem 0 2.5rem !important;
  text-align: center !important;
  position: relative !important;
}

.classic-hero__photo {
  width: 110px !important;
  height: 110px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  border: 3px solid var(--p-surface) !important;
  box-shadow:
    0 0 0 4px var(--p-indigo-l),
    0 0 0 6px var(--p-indigo-m),
    var(--p-shadow-md) !important;
  margin-bottom: 1.25rem !important;
  transition: transform 0.4s var(--p-ease) !important;
}
.classic-hero__photo:hover { transform: scale(1.04) rotate(-2deg) !important; }

.classic-hero__name {
  font-family: var(--p-font) !important;
  font-size: 2.25rem !important;
  font-weight: 900 !important;
  letter-spacing: -0.045em !important;
  color: var(--p-ink) !important;
  text-shadow: none !important;
  margin-bottom: 0.35rem !important;
  line-height: 1.1 !important;
}

.classic-hero__role {
  font-family: var(--p-font) !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--p-indigo) !important;
  margin-bottom: 1.5rem !important;
}

.classic-hero::after {
  content: '' !important;
  display: block !important;
  width: 60px !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--p-indigo), var(--p-sky)) !important;
  border-radius: 3px !important;
  margin: 0.5rem auto 0 !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 14 — SECTION CARDS
   ════════════════════════════════════════════════════════════ */

.classic-sec {
  background: var(--p-surface) !important;
  border: 1px solid var(--p-border) !important;
  border-radius: var(--p-r-2xl) !important;
  padding: 2rem !important;
  margin-bottom: 1.25rem !important;
  box-shadow: var(--p-shadow-sm) !important;
  transition: box-shadow 0.25s var(--p-ease), transform 0.25s var(--p-ease) !important;
  position: relative !important;
  overflow: hidden !important;
}
.classic-sec::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--p-indigo) 0%, var(--p-sky) 50%, var(--p-purple) 100%) !important;
  opacity: 0 !important;
  transition: opacity 0.25s !important;
}
.classic-sec:hover { box-shadow: var(--p-shadow-md) !important; }
.classic-sec:hover::before { opacity: 1 !important; }

.classic-sec__title {
  font-family: var(--p-font) !important;
  font-size: 0.62rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--p-indigo) !important;
  margin-bottom: 1.5rem !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  -webkit-text-fill-color: var(--p-indigo) !important;
  background-clip: unset !important;
}
.classic-sec__title::before {
  content: '' !important;
  display: inline-block !important;
  width: 18px !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--p-indigo), var(--p-sky)) !important;
  border-radius: 3px !important;
  flex-shrink: 0 !important;
}

.classic-sec__content h3 {
  font-family: var(--p-font) !important;
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  color: var(--p-ink) !important;
  margin-bottom: 0.5rem !important;
}
.classic-sec__content p {
  font-size: 0.9rem !important;
  color: var(--p-ink-muted) !important;
  line-height: 1.78 !important;
  font-family: var(--p-font) !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 15 — ABOUT PROFILE
   ════════════════════════════════════════════════════════════ */

.tpl-about__hero {
  display: flex !important;
  align-items: center !important;
  gap: 1.25rem !important;
  background: linear-gradient(135deg, var(--p-indigo-l) 0%, var(--p-sky-l) 100%) !important;
  border: 1px solid var(--p-indigo-m) !important;
  border-radius: var(--p-r-xl) !important;
  padding: 1.25rem !important;
  margin-bottom: 1.5rem !important;
  overflow: hidden !important;
  position: relative !important;
}
.tpl-about__photo img {
  width: 80px !important;
  height: 80px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  border: 2.5px solid var(--p-surface) !important;
  box-shadow: 0 0 0 3px var(--p-indigo-m), var(--p-shadow-sm) !important;
}
.tpl-about__name {
  font-family: var(--p-font) !important;
  font-size: 1.05rem !important;
  font-weight: 800 !important;
  letter-spacing: -0.025em !important;
  color: var(--p-ink) !important;
  text-transform: none !important;
  margin-bottom: 0.15rem !important;
}
.tpl-about__role {
  font-family: var(--p-font) !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  color: var(--p-indigo-d) !important;
  margin-bottom: 0.5rem !important;
  text-transform: none !important;
  letter-spacing: -0.01em !important;
}
.tpl-about__badge {
  display: inline-block !important;
  padding: 3px 11px !important;
  background: var(--p-surface) !important;
  border: 1px solid var(--p-indigo-m) !important;
  border-radius: var(--p-r-pill) !important;
  color: var(--p-indigo-d) !important;
  font-family: var(--p-font) !important;
  font-size: 0.58rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 16 — STAT CARDS (animated numbers)
   ════════════════════════════════════════════════════════════ */

.tpl-stats {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 0.75rem !important;
  margin-top: 1.25rem !important;
}

.tpl-stat {
  background: var(--p-surface) !important;
  border: 1px solid var(--p-border) !important;
  border-radius: var(--p-r-xl) !important;
  padding: 1.25rem 1rem !important;
  box-shadow: var(--p-shadow-xs) !important;
  transition: all 0.25s var(--p-ease) !important;
  position: relative !important;
  overflow: hidden !important;
  cursor: default !important;
}
.tpl-stat::before {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important; left: 0 !important; right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, var(--p-indigo), var(--p-sky)) !important;
  transform: scaleX(0) !important;
  transition: transform 0.3s var(--p-ease) !important;
}
.tpl-stat:hover {
  border-color: var(--p-border-acc) !important;
  box-shadow: var(--p-shadow-md) !important;
  transform: translateY(-4px) !important;
}
.tpl-stat:hover::before { transform: scaleX(1) !important; }

.tpl-stat__num {
  display: block !important;
  font-family: var(--p-font) !important;
  font-size: 2rem !important;
  font-weight: 900 !important;
  background: linear-gradient(135deg, var(--p-indigo) 0%, var(--p-sky) 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  line-height: 1.1 !important;
  margin-bottom: 0.25rem !important;
  letter-spacing: -0.04em !important;
}
.tpl-stat__label {
  font-family: var(--p-font) !important;
  font-size: 0.62rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  color: var(--p-ink-faint) !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 17 — EXPERIENCE TIMELINE
   ════════════════════════════════════════════════════════════ */

.tpl-experience { display: flex !important; flex-direction: column !important; }

.tpl-job {
  position: relative !important;
  border-left: 2px solid var(--p-border-md) !important;
  padding: 0.5rem 0 1.25rem 1.75rem !important;
  transition: border-left-color 0.2s !important;
}
.tpl-job:hover { border-left-color: var(--p-indigo) !important; }
.tpl-job:last-child { padding-bottom: 0 !important; }

.tpl-job::before {
  content: '' !important;
  position: absolute !important;
  left: -5px !important; top: 0.6rem !important;
  width: 8px !important; height: 8px !important;
  border-radius: 50% !important;
  background: var(--p-surface) !important;
  border: 2.5px solid var(--p-indigo) !important;
  box-shadow: 0 0 0 3px var(--p-indigo-l) !important;
  transition: all 0.25s var(--p-ease) !important;
}
.tpl-job:hover::before {
  background: var(--p-indigo) !important;
  box-shadow: 0 0 0 5px var(--p-indigo-l) !important;
}

.tpl-job__company {
  font-family: var(--p-font) !important;
  font-size: 0.95rem !important;
  font-weight: 800 !important;
  color: var(--p-ink) !important;
  letter-spacing: -0.02em !important;
  text-transform: none !important;
  margin-bottom: 0.1rem !important;
}
.tpl-job__role {
  font-family: var(--p-font) !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  color: var(--p-indigo) !important;
  margin-bottom: 0.1rem !important;
}
.tpl-job__period {
  font-family: var(--p-font) !important;
  font-size: 0.66rem !important;
  font-weight: 500 !important;
  color: var(--p-ink-faint) !important;
  margin-bottom: 0.5rem !important;
}
.tpl-job__list { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.tpl-job__list li {
  position: relative !important;
  padding-left: 1rem !important;
  font-family: var(--p-font) !important;
  font-size: 0.82rem !important;
  color: var(--p-ink-muted) !important;
  line-height: 1.65 !important;
  margin-bottom: 0.2rem !important;
}
.tpl-job__list li::before {
  content: '–' !important;
  position: absolute !important;
  left: 0 !important;
  color: var(--p-indigo) !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 18 — BLOG CARDS (classic view)
   ════════════════════════════════════════════════════════════ */

.tpl-blog__header { border-bottom: 1px solid var(--p-border) !important; margin-bottom: 1rem !important; padding-bottom: 0.75rem !important; }
.tpl-blog__header-title {
  font-family: var(--p-font) !important;
  font-size: 0.6rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--p-green) !important;
  text-shadow: none !important;
}
.tpl-blog__grid { display: flex !important; flex-direction: column !important; gap: 0.65rem !important; }

.tpl-blog__card {
  background: var(--p-surface) !important;
  border: 1px solid var(--p-border) !important;
  border-radius: var(--p-r-xl) !important;
  box-shadow: var(--p-shadow-xs) !important;
  padding: 1.1rem !important;
  transition: all 0.25s var(--p-ease) !important;
  cursor: pointer !important;
  text-decoration: none !important;
  display: block !important;
  position: relative !important;
  overflow: hidden !important;
}
.tpl-blog__card::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important; top: 0 !important; bottom: 0 !important;
  width: 0 !important;
  background: linear-gradient(to bottom, var(--p-indigo), var(--p-sky)) !important;
  border-radius: 0 !important;
  transition: width 0.25s var(--p-ease) !important;
}
.tpl-blog__card:hover {
  border-color: var(--p-border-acc) !important;
  box-shadow: var(--p-shadow-md) !important;
  transform: translateY(-2px) translateX(4px) !important;
}
.tpl-blog__card:hover::before { width: 3px !important; }

.tpl-blog__card-cat {
  display: inline-block !important;
  padding: 2px 9px !important;
  background: var(--p-indigo-l) !important;
  color: var(--p-indigo-d) !important;
  border-radius: var(--p-r-pill) !important;
  font-family: var(--p-font) !important;
  font-size: 0.56rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  margin-bottom: 0.4rem !important;
  border: 1px solid var(--p-indigo-m) !important;
}
.tpl-blog__card-title {
  font-family: var(--p-font) !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  color: var(--p-ink) !important;
  line-height: 1.4 !important;
  letter-spacing: -0.015em !important;
  margin-bottom: 0.3rem !important;
}
.tpl-blog__card-excerpt {
  font-size: 0.75rem !important;
  color: var(--p-ink-muted) !important;
  line-height: 1.6 !important;
  font-family: var(--p-font) !important;
}
.tpl-blog__card-meta {
  font-family: var(--p-font) !important;
  font-size: 0.6rem !important;
  color: var(--p-ink-faint) !important;
  font-weight: 500 !important;
  margin-top: 0.5rem !important;
}
.tpl-blog__card-link {
  font-family: var(--p-font) !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  color: var(--p-indigo) !important;
  text-decoration: none !important;
  text-shadow: none !important;
  letter-spacing: 0 !important;
}
.tpl-blog__loading {
  color: var(--p-ink-faint) !important;
  font-family: var(--p-font) !important;
  font-size: 0.82rem !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 19 — TOOLS CARDS (classic view)
   ════════════════════════════════════════════════════════════ */

.tpl-tools__intro {
  color: var(--p-ink-muted) !important;
  border-left: 3px solid var(--p-indigo) !important;
  background: var(--p-indigo-l) !important;
  border-radius: 0 var(--p-r-sm) var(--p-r-sm) 0 !important;
  padding: 0.75rem 1rem !important;
  font-size: 0.84rem !important;
  line-height: 1.7 !important;
  margin-bottom: 1rem !important;
  font-family: var(--p-font) !important;
}

.tpl-tools__grid { display: flex !important; flex-direction: column !important; gap: 0.6rem !important; }

.tpl-tools__card {
  background: var(--p-surface) !important;
  border: 1px solid var(--p-border) !important;
  border-radius: var(--p-r-xl) !important;
  box-shadow: var(--p-shadow-xs) !important;
  padding: 1rem !important;
  transition: all 0.25s var(--p-ease) !important;
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.9rem !important;
}
.tpl-tools__card::after {
  content: '' !important;
  position: absolute !important;
  right: 0 !important; top: 0 !important; bottom: 0 !important;
  width: 0 !important;
  background: linear-gradient(to bottom, var(--p-indigo), var(--p-sky)) !important;
  transition: width 0.25s var(--p-ease) !important;
}
.tpl-tools__card:hover {
  border-color: var(--p-border-acc) !important;
  box-shadow: var(--p-shadow-md) !important;
  transform: translateY(-2px) !important;
}
.tpl-tools__card:hover::after { width: 3px !important; }

.tpl-tools__card-icon {
  font-size: 1.5rem !important;
  flex-shrink: 0 !important;
  width: 44px !important;
  height: 44px !important;
  background: var(--p-indigo-l) !important;
  border-radius: var(--p-r-sm) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid var(--p-indigo-m) !important;
}

.tpl-tools__card-name {
  font-family: var(--p-font) !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  color: var(--p-ink) !important;
  letter-spacing: -0.015em !important;
  margin-bottom: 0.15rem !important;
  text-transform: none !important;
}
.tpl-tools__card-desc {
  font-size: 0.75rem !important;
  color: var(--p-ink-muted) !important;
  line-height: 1.55 !important;
  font-family: var(--p-font) !important;
}
.tpl-tools__card-link {
  font-family: var(--p-font) !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  color: var(--p-indigo) !important;
  text-decoration: none !important;
  text-shadow: none !important;
  letter-spacing: 0 !important;
}
.tpl-tools__loading {
  color: var(--p-ink-faint) !important;
  font-family: var(--p-font) !important;
  font-size: 0.82rem !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 20 — CONTACT TEMPLATE
   ════════════════════════════════════════════════════════════ */

.tpl-contact > p {
  background: linear-gradient(135deg, var(--p-indigo-l), var(--p-sky-l)) !important;
  border-left: 3px solid var(--p-indigo) !important;
  border-radius: 0 var(--p-r-sm) var(--p-r-sm) 0 !important;
  color: var(--p-ink-muted) !important;
  font-family: var(--p-font) !important;
  font-size: 0.86rem !important;
  line-height: 1.72 !important;
  padding: 0.9rem 1.1rem !important;
  margin-bottom: 1.1rem !important;
}
.tpl-contact__links { display: flex !important; flex-wrap: wrap !important; gap: 0.5rem !important; margin-bottom: 1.25rem !important; }

.tpl-contact__link {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.4rem !important;
  background: var(--p-surface) !important;
  border: 1.5px solid var(--p-border-md) !important;
  border-radius: var(--p-r) !important;
  color: var(--p-ink-2) !important;
  font-family: var(--p-font) !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  box-shadow: var(--p-shadow-xs) !important;
  padding: 7px 14px !important;
  transition: all 0.2s var(--p-ease) !important;
  text-decoration: none !important;
}
.tpl-contact__link:hover {
  background: var(--p-indigo) !important;
  border-color: var(--p-indigo) !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(99,102,241,0.35) !important;
  transform: translateY(-2px) !important;
}

.tpl-form__label {
  font-family: var(--p-font) !important;
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  color: var(--p-ink-muted) !important;
  text-transform: uppercase !important;
  display: block !important;
  margin-bottom: 0.4rem !important;
}
.tpl-form__input, .tpl-form__textarea {
  width: 100% !important;
  background: var(--p-surface) !important;
  border: 1.5px solid var(--p-border-md) !important;
  border-radius: var(--p-r-sm) !important;
  color: var(--p-ink) !important;
  font-family: var(--p-font) !important;
  font-size: 0.88rem !important;
  padding: 10px 14px !important;
  transition: border-color 0.15s, box-shadow 0.15s !important;
  outline: none !important;
}
.tpl-form__input:focus, .tpl-form__textarea:focus {
  border-color: var(--p-indigo) !important;
  box-shadow: 0 0 0 3px rgba(99,102,241,0.12) !important;
}
.tpl-form__submit {
  background: linear-gradient(135deg, var(--p-indigo) 0%, var(--p-indigo-d) 100%) !important;
  border: none !important;
  border-radius: var(--p-r-sm) !important;
  color: #fff !important;
  font-family: var(--p-font) !important;
  font-size: 0.88rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  padding: 11px 24px !important;
  cursor: pointer !important;
  box-shadow: 0 2px 10px rgba(99,102,241,0.4) !important;
  transition: all 0.2s var(--p-ease) !important;
  text-transform: none !important;
}
.tpl-form__submit:hover {
  box-shadow: 0 4px 20px rgba(99,102,241,0.5) !important;
  transform: translateY(-2px) !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 21 — PANEL (Slide-in overlay)
   ════════════════════════════════════════════════════════════ */

.panel__inner {
  background: rgba(249,250,251,0.97) !important;
  backdrop-filter: blur(48px) saturate(2) !important;
  -webkit-backdrop-filter: blur(48px) saturate(2) !important;
  border-left: 1px solid var(--p-border) !important;
  box-shadow: var(--p-shadow-xl) !important;
  font-family: var(--p-font) !important;
}
.panel__inner::before,
.panel__inner::after { display: none !important; }

.panel__header {
  background: rgba(255,255,255,0.98) !important;
  border-bottom: 1px solid var(--p-border) !important;
  padding: 1.1rem 1.4rem !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 10 !important;
}
.panel__header::before { display: none !important; }

.panel__title-prefix {
  font-family: var(--p-font) !important;
  font-size: 0.55rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  color: var(--p-indigo) !important;
  text-transform: uppercase !important;
  margin-bottom: 0.15rem !important;
  display: block !important;
}
.panel__title {
  font-family: var(--p-font) !important;
  font-size: 1.05rem !important;
  font-weight: 800 !important;
  letter-spacing: -0.025em !important;
  color: var(--p-ink) !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  -webkit-text-fill-color: var(--p-ink) !important;
  background-clip: unset !important;
  filter: none !important;
  text-transform: none !important;
}
.panel__close {
  background: var(--p-rose-l) !important;
  border: 1px solid rgba(244,63,94,0.15) !important;
  border-radius: var(--p-r-xs) !important;
  color: var(--p-rose) !important;
  font-family: var(--p-font) !important;
  font-size: 0.62rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.05em !important;
  padding: 5px 10px !important;
  cursor: pointer !important;
  transition: all 0.16s !important;
}
.panel__close:hover {
  background: var(--p-rose) !important;
  border-color: var(--p-rose) !important;
  color: #fff !important;
  box-shadow: 0 3px 12px rgba(244,63,94,0.3) !important;
}
.panel__body {
  background: var(--p-bg) !important;
  padding: 1.25rem !important;
  scrollbar-color: var(--p-border-md) transparent !important;
  scrollbar-width: thin !important;
}
.panel__body::-webkit-scrollbar { width: 4px !important; }
.panel__body::-webkit-scrollbar-thumb { background: var(--p-border-md) !important; border-radius: 4px !important; }
.panel__body h3 {
  font-family: var(--p-font) !important;
  font-size: 0.62rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--p-indigo) !important;
  margin-bottom: 0.75rem !important;
}
.panel__body p {
  font-family: var(--p-font) !important;
  font-size: 0.86rem !important;
  color: var(--p-ink-muted) !important;
  line-height: 1.72 !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 22 — CLASSIC FOOTER
   ════════════════════════════════════════════════════════════ */

.classic-ftr {
  border-top: 1px solid var(--p-border) !important;
  background: none !important;
  padding: 2.5rem 0 0 !important;
  margin-top: 2rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 1rem !important;
}
.classic-ftr__logo {
  font-family: var(--p-font) !important;
  font-size: 1.2rem !important;
  font-weight: 900 !important;
  letter-spacing: -0.035em !important;
  color: var(--p-ink) !important;
}
.classic-ftr__logo span {
  color: var(--p-indigo) !important;
  background: none !important;
  -webkit-text-fill-color: var(--p-indigo) !important;
}
.classic-ftr__copy {
  font-family: var(--p-font) !important;
  font-size: 0.78rem !important;
  color: var(--p-ink-faint) !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 23 — VALO SIDEBAR
   ════════════════════════════════════════════════════════════ */

.valo-sidebar {
  background: rgba(255,255,255,0.98) !important;
  border-right: 1px solid var(--p-border) !important;
  box-shadow: 1px 0 0 var(--p-border) !important;
  display: flex !important;
  flex-direction: column !important;
  font-family: var(--p-font) !important;
}
.valo-sidebar::before {
  content: '' !important;
  display: block !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--p-indigo), var(--p-sky), var(--p-purple)) !important;
  box-shadow: none !important;
  flex-shrink: 0 !important;
}

.valo-sidebar__header {
  padding: 1.1rem 1.25rem 0.9rem !important;
  border-bottom: 1px solid var(--p-border) !important;
  flex-shrink: 0 !important;
}
.valo-sidebar__logo {
  font-family: var(--p-font) !important;
  font-size: 1.2rem !important;
  font-weight: 900 !important;
  letter-spacing: -0.035em !important;
  color: var(--p-ink) !important;
  margin-bottom: 0.1rem !important;
}
.valo-sidebar__logo span { color: var(--p-indigo) !important; text-shadow: none !important; }
.valo-sidebar__label {
  font-family: var(--p-font) !important;
  font-size: 0.56rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  color: var(--p-ink-faint) !important;
  text-transform: uppercase !important;
}

.valo-sidebar__posts {
  flex: 1 !important;
  overflow-y: auto !important;
  padding: 0.5rem 0 !important;
  scrollbar-width: thin !important;
  scrollbar-color: var(--p-border-md) transparent !important;
}
.valo-sidebar__posts::-webkit-scrollbar { width: 4px !important; }
.valo-sidebar__posts::-webkit-scrollbar-thumb { background: var(--p-border-md) !important; border-radius: 4px !important; }

.valo-sidebar__post {
  padding: 0.75rem 1.25rem !important;
  border-left: 3px solid transparent !important;
  cursor: pointer !important;
  transition: all 0.18s !important;
  display: block !important;
  text-decoration: none !important;
}
.valo-sidebar__post:hover {
  background: var(--p-indigo-l) !important;
  border-left-color: var(--p-indigo-m) !important;
}
.valo-sidebar__post--active {
  background: rgba(99,102,241,0.07) !important;
  border-left-color: var(--p-indigo) !important;
}
.valo-sidebar__post-cat {
  font-family: var(--p-font) !important;
  font-size: 0.5rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--p-indigo) !important;
  margin-bottom: 0.2rem !important;
}
.valo-sidebar__post-title {
  font-family: var(--p-font) !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  color: var(--p-ink) !important;
  line-height: 1.4 !important;
  letter-spacing: -0.01em !important;
  margin-bottom: 0.2rem !important;
}
.valo-sidebar__post--active .valo-sidebar__post-title,
.valo-sidebar__post:hover .valo-sidebar__post-title { color: var(--p-indigo-d) !important; }
.valo-sidebar__post-meta {
  font-family: var(--p-font) !important;
  font-size: 0.55rem !important;
  color: var(--p-ink-faint) !important;
}

.valo-sidebar__back {
  border-top: 1px solid var(--p-border) !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  padding: 0.9rem 1.25rem !important;
  font-family: var(--p-font) !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  color: var(--p-ink-muted) !important;
  cursor: pointer !important;
  text-decoration: none !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  transition: all 0.15s !important;
  flex-shrink: 0 !important;
}
.valo-sidebar__back:hover { color: var(--p-indigo) !important; background: var(--p-indigo-l) !important; }

/* ════════════════════════════════════════════════════════════
   ITERATION 24 — VALO TOPBAR
   ════════════════════════════════════════════════════════════ */

.valo-content { background: var(--p-bg) !important; display: flex !important; flex-direction: column !important; }

.valo-topbar {
  background: rgba(255,255,255,0.98) !important;
  border-bottom: 1px solid var(--p-border) !important;
  height: 54px !important;
  padding: 0 1.5rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-shrink: 0 !important;
  gap: 1rem !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 10 !important;
  box-shadow: 0 1px 0 var(--p-border), 0 2px 10px rgba(0,0,0,0.03) !important;
}

.valo-topbar__left {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  min-width: 0 !important;
  overflow: hidden !important;
  flex: 1 !important;
}
.valo-topbar__cat {
  font-family: var(--p-font) !important;
  font-size: 0.58rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--p-indigo-d) !important;
  background: var(--p-indigo-l) !important;
  padding: 3px 10px !important;
  border-radius: var(--p-r-pill) !important;
  border: 1px solid var(--p-indigo-m) !important;
  flex-shrink: 0 !important;
}
.valo-topbar__sep { color: var(--p-border-md) !important; flex-shrink: 0 !important; }
.valo-topbar__title-short {
  font-family: var(--p-font) !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  color: var(--p-ink-muted) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  min-width: 0 !important;
}

.valo-topbar__right {
  display: flex !important;
  align-items: center !important;
  gap: 0.4rem !important;
  flex-shrink: 0 !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 25 — VALO TOPBAR BUTTONS
   ════════════════════════════════════════════════════════════ */

.valo-topbar__share {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.35rem !important;
  padding: 6px 15px !important;
  background: var(--p-indigo) !important;
  border: none !important;
  border-radius: var(--p-r-pill) !important;
  font-family: var(--p-font) !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  cursor: pointer !important;
  transition: all 0.18s var(--p-ease) !important;
  box-shadow: 0 2px 10px rgba(99,102,241,0.3) !important;
  letter-spacing: -0.01em !important;
  text-transform: none !important;
}
.valo-topbar__share:hover {
  background: var(--p-indigo-d) !important;
  box-shadow: 0 4px 18px rgba(99,102,241,0.45) !important;
  transform: translateY(-1px) !important;
  color: #fff !important;
}

.valo-topbar__open {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.35rem !important;
  padding: 5px 13px !important;
  background: var(--p-surface) !important;
  border: 1.5px solid var(--p-border-md) !important;
  border-radius: var(--p-r-pill) !important;
  font-family: var(--p-font) !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  color: var(--p-ink-2) !important;
  text-decoration: none !important;
  transition: all 0.18s var(--p-ease) !important;
  letter-spacing: -0.01em !important;
  text-transform: none !important;
}
.valo-topbar__open:hover {
  background: var(--p-ink) !important;
  border-color: var(--p-ink) !important;
  color: #fff !important;
  box-shadow: 0 3px 12px rgba(12,18,34,0.2) !important;
  transform: translateY(-1px) !important;
}

.valo-topbar__close {
  display: inline-flex !important;
  align-items: center !important;
  padding: 5px 10px !important;
  background: var(--p-rose-l) !important;
  border: 1px solid rgba(244,63,94,0.15) !important;
  border-radius: var(--p-r-xs) !important;
  font-family: var(--p-font) !important;
  font-size: 0.65rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.04em !important;
  color: var(--p-rose) !important;
  cursor: pointer !important;
  transition: all 0.16s !important;
  text-transform: none !important;
}
.valo-topbar__close:hover {
  background: var(--p-rose) !important;
  border-color: var(--p-rose) !important;
  color: #fff !important;
  box-shadow: 0 3px 10px rgba(244,63,94,0.3) !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 26 — VALO HERO (no dark overlay!)
   ════════════════════════════════════════════════════════════ */

.valo-hero {
  background: var(--p-surface) !important;
  border-bottom: 1px solid var(--p-border) !important;
  min-height: auto !important;
  flex-shrink: 0 !important;
  position: relative !important;
  overflow: hidden !important;
}
.valo-hero__img-wrap { display: none !important; }
.valo-hero__img-overlay { display: none !important; }

.valo-hero__meta {
  position: relative !important;
  z-index: 1 !important;
  padding: 1.75rem 2rem 1.5rem !important;
  background: var(--p-surface) !important;
}

.valo-hero__cat-badge {
  display: inline-flex !important;
  align-items: center !important;
  padding: 3px 11px !important;
  background: var(--p-indigo-l) !important;
  color: var(--p-indigo-d) !important;
  border: 1px solid var(--p-indigo-m) !important;
  font-family: var(--p-font) !important;
  font-size: 0.58rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.09em !important;
  border-radius: var(--p-r-pill) !important;
  text-transform: uppercase !important;
  margin-bottom: 0.85rem !important;
  clip-path: none !important;
  background-color: var(--p-indigo-l) !important;
}

.valo-hero__title {
  font-family: var(--p-font) !important;
  font-size: clamp(1.25rem, 2.8vw, 1.95rem) !important;
  font-weight: 900 !important;
  letter-spacing: -0.035em !important;
  color: var(--p-ink) !important;
  line-height: 1.15 !important;
  margin-bottom: 0.75rem !important;
  text-shadow: none !important;
}

.valo-hero__info {
  display: flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
  flex-wrap: wrap !important;
}
.valo-hero__date, .valo-hero__read {
  font-family: var(--p-font) !important;
  font-size: 0.75rem !important;
  font-weight: 500 !important;
  color: var(--p-ink-faint) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}
.valo-hero__dot {
  color: var(--p-border-md) !important;
  font-size: 0.5rem !important;
}

.valo-hero__accent-line {
  position: absolute !important;
  bottom: 0 !important; left: 0 !important; right: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--p-indigo) 0%, var(--p-sky) 50%, var(--p-purple) 100%) !important;
  box-shadow: none !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 27 — VALO ARTICLE BODY
   ════════════════════════════════════════════════════════════ */

.valo-article {
  flex: 1 !important;
  overflow-y: auto !important;
  background: var(--p-bg) !important;
  scrollbar-width: thin !important;
  scrollbar-color: rgba(99,102,241,0.15) transparent !important;
}
.valo-article::-webkit-scrollbar { width: 5px !important; }
.valo-article::-webkit-scrollbar-thumb { background: rgba(99,102,241,0.15) !important; border-radius: 5px !important; }
.valo-article::-webkit-scrollbar-thumb:hover { background: rgba(99,102,241,0.3) !important; }

.valo-article__body {
  padding: 2rem 2.5rem 3rem !important;
  color: var(--p-ink-2) !important;
  font-family: var(--p-font) !important;
  font-size: 0.97rem !important;
  line-height: 1.8 !important;
  max-width: 680px !important;
}

.valo-article__body p { color: var(--p-ink-2) !important; margin-bottom: 1.15rem !important; }

.valo-article__body h2 {
  font-size: 1.25rem !important;
  font-weight: 800 !important;
  color: var(--p-ink) !important;
  letter-spacing: -0.025em !important;
  margin: 2rem 0 0.65rem !important;
  line-height: 1.2 !important;
  font-family: var(--p-font) !important;
  position: relative !important;
  padding-top: 1.25rem !important;
}
.valo-article__body h2::before {
  content: '' !important;
  display: block !important;
  width: 30px !important; height: 3px !important;
  background: linear-gradient(90deg, var(--p-indigo), var(--p-sky)) !important;
  border-radius: 2px !important;
  margin-bottom: 0.75rem !important;
}

.valo-article__body h3 {
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--p-ink) !important;
  letter-spacing: -0.015em !important;
  margin: 1.5rem 0 0.5rem !important;
  font-family: var(--p-font) !important;
}

.valo-article__body ul, .valo-article__body ol {
  padding-left: 1.5rem !important;
  margin-bottom: 1.15rem !important;
}
.valo-article__body li {
  color: var(--p-ink-2) !important;
  line-height: 1.72 !important;
  margin-bottom: 0.35rem !important;
}
.valo-article__body li::marker { color: var(--p-indigo) !important; }
.valo-article__body strong { color: var(--p-ink) !important; font-weight: 700 !important; }
.valo-article__body em { color: var(--p-ink-muted) !important; }

.valo-article__body a {
  color: var(--p-indigo) !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
  text-decoration-color: rgba(99,102,241,0.35) !important;
  transition: text-decoration-color 0.15s !important;
}
.valo-article__body a:hover {
  color: var(--p-indigo-d) !important;
  text-decoration-color: var(--p-indigo) !important;
}

.valo-article__body pre {
  background: var(--p-ink) !important;
  color: #CBD5E1 !important;
  border-radius: var(--p-r-xl) !important;
  padding: 1.25rem 1.5rem !important;
  overflow-x: auto !important;
  font-size: 0.82rem !important;
  line-height: 1.62 !important;
  margin: 1.5rem 0 !important;
  box-shadow: var(--p-shadow-md) !important;
  position: relative !important;
}
.valo-article__body pre::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, var(--p-indigo), var(--p-sky)) !important;
  border-radius: var(--p-r-xl) var(--p-r-xl) 0 0 !important;
}

.valo-article__body code {
  background: var(--p-indigo-l) !important;
  color: var(--p-indigo-d) !important;
  padding: 2px 6px !important;
  border-radius: 5px !important;
  font-size: 0.875em !important;
  border: 1px solid var(--p-indigo-m) !important;
}
.valo-article__body pre code {
  background: transparent !important;
  color: inherit !important;
  padding: 0 !important;
  border: none !important;
  font-size: inherit !important;
}

.valo-article__body blockquote {
  border-left: none !important;
  background: linear-gradient(135deg, var(--p-indigo-l), var(--p-sky-l)) !important;
  margin: 1.5rem 0 !important;
  padding: 1.25rem 1.5rem 1.25rem 1.75rem !important;
  border-radius: var(--p-r-lg) !important;
  color: var(--p-indigo-dd) !important;
  font-style: italic !important;
  border: 1px solid var(--p-indigo-m) !important;
  position: relative !important;
}
.valo-article__body blockquote::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important; top: 0 !important; bottom: 0 !important;
  width: 3px !important;
  background: linear-gradient(to bottom, var(--p-indigo), var(--p-sky)) !important;
  border-radius: 3px 0 0 3px !important;
}

.valo-article__body hr {
  border: none !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, var(--p-border-md), transparent) !important;
  margin: 2rem 0 !important;
}

.valo-article__body table {
  width: 100% !important;
  border-collapse: collapse !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  box-shadow: var(--p-shadow-sm) !important;
  margin: 1.5rem 0 !important;
  font-size: 0.87rem !important;
}
.valo-article__body th {
  background: var(--p-ink) !important;
  color: #fff !important;
  padding: 0.7rem 1rem !important;
  text-align: left !important;
  font-weight: 700 !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.02em !important;
}
.valo-article__body td {
  padding: 0.6rem 1rem !important;
  border-bottom: 1px solid var(--p-border) !important;
  color: var(--p-ink-2) !important;
  background: var(--p-surface) !important;
}
.valo-article__body tr:last-child td { border-bottom: none !important; }
.valo-article__body tr:nth-child(even) td { background: var(--p-surface-2) !important; }

/* ════════════════════════════════════════════════════════════
   ITERATION 28 — VALO ACCENT RAIL
   ════════════════════════════════════════════════════════════ */

.valo-accent-rail {
  background: var(--p-surface) !important;
  border-left: 1px solid var(--p-border) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  padding-top: 2rem !important;
  gap: 0 !important;
}
.valo-accent-rail__line {
  flex: 1 !important;
  width: 1px !important;
  background: var(--p-border-md) !important;
  border-radius: 1px !important;
}
.valo-accent-rail__dot {
  width: 8px !important; height: 8px !important;
  border-radius: 50% !important;
  background: var(--p-indigo) !important;
  box-shadow: 0 0 12px rgba(99,102,241,0.5) !important;
  flex-shrink: 0 !important;
  margin: 0.5rem 0 !important;
}

/* Loading states */
.valo-loading-bar { background: var(--p-bg-2) !important; }
.valo-loading-bar::after {
  background: linear-gradient(90deg, transparent, var(--p-indigo), transparent) !important;
}
.valo-loading-text {
  font-family: var(--p-font) !important;
  color: var(--p-indigo) !important;
  font-size: 0.68rem !important;
  letter-spacing: 0.1em !important;
  font-weight: 700 !important;
  text-transform: none !important;
}

/* ════════════════════════════════════════════════════════════
   ITERATION 29 — STANDALONE BLOG / BODY OVERRIDES
   ════════════════════════════════════════════════════════════ */

body:not(.game-mode) {
  background: var(--p-bg) !important;
  color: var(--p-ink) !important;
  overflow: auto !important;
  height: auto !important;
  width: auto !important;
  font-family: var(--p-font) !important;
}
body:not(.game-mode)::before,
body:not(.game-mode)::after { display: none !important; }

/* ════════════════════════════════════════════════════════════
   ITERATION 30 — GLOBAL SELECTION + FOCUS + SCROLLBARS
   ════════════════════════════════════════════════════════════ */

body.classic-mode ::selection,
body:not(.game-mode) ::selection,
.valo-reader ::selection {
  background: rgba(99,102,241,0.18) !important;
}

body.classic-mode :focus-visible,
body:not(.game-mode) :focus-visible {
  outline: 2.5px solid var(--p-indigo) !important;
  outline-offset: 3px !important;
  border-radius: 4px !important;
}

/* Responsive */
@media (max-width: 768px) {
  .valo-sidebar { display: none !important; }
  .valo-accent-rail { display: none !important; }
  .valo-article__body { padding: 1.5rem 1.25rem 2.5rem !important; }
  .valo-hero__meta { padding: 1.25rem !important; }
  .valo-topbar { padding: 0 1rem !important; }
  .classic-view { padding: 0 1rem 3rem !important; }
}

/* ════════════════════════════════════════════════════════════
   BATCH UX — Blog card upgrades & hero action buttons
   ════════════════════════════════════════════════════════════ */

/* ── Category filter pills ── */
.blog-filter-bar {
  display: flex !important;
  gap: .4rem !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  padding-bottom: .5rem !important;
  margin-bottom: 1rem !important;
  scrollbar-width: none !important;
  -ms-overflow-style: none !important;
}
.blog-filter-bar::-webkit-scrollbar { display: none !important; }
.blog-filter-pill {
  flex-shrink: 0 !important;
  padding: .3rem .9rem !important;
  border-radius: 9999px !important;
  border: 1.5px solid var(--p-border-md) !important;
  background: var(--p-surface) !important;
  font-family: var(--p-font) !important;
  font-size: .68rem !important;
  font-weight: 700 !important;
  letter-spacing: .04em !important;
  cursor: pointer !important;
  transition: all .2s !important;
  white-space: nowrap !important;
  color: var(--p-ink-muted) !important;
}
.blog-filter-pill:hover,
.blog-filter-pill--active {
  border-color: var(--p-indigo) !important;
  background: var(--p-indigo) !important;
  color: #fff !important;
}

/* ── Card cover image / placeholder ── */
.tpl-blog__card-cover {
  width: calc(100% + 2.2rem) !important;
  height: 140px !important;
  margin: -1.1rem -1.1rem .85rem !important;
  border-radius: var(--p-r-xl) var(--p-r-xl) 0 0 !important;
  overflow: hidden !important;
  position: relative !important;
  flex-shrink: 0 !important;
}
.tpl-blog__card-cover img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  opacity: 1 !important;
  transition: transform .4s ease !important;
  filter: none !important;
}
.tpl-blog__card:hover .tpl-blog__card-cover img { transform: scale(1.04) !important; }
.tpl-blog__card-cover--placeholder {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 100% !important;
  font-family: var(--p-font) !important;
  font-size: .62rem !important;
  font-weight: 800 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.8) !important;
}

/* ── Card footer layout ── */
.tpl-blog__card-footer {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-top: .5rem !important;
}

/* ── Reaction chips on cards ── */
.tpl-blog__card-reactions {
  display: flex !important;
  gap: .25rem !important;
  margin-top: .35rem !important;
}
.tpl-blog__card-reaction {
  font-size: .68rem !important;
  color: var(--p-ink-faint) !important;
  background: var(--p-bg) !important;
  border: 1px solid var(--p-border) !important;
  padding: .1rem .4rem !important;
  border-radius: 9999px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: .1rem !important;
}

/* ── Skeleton shimmer ── */
.card-skeleton {
  background: var(--p-surface) !important;
  border-radius: var(--p-r-xl) !important;
  padding: 1.1rem !important;
  border: 1px solid var(--p-border) !important;
  overflow: hidden !important;
  position: relative !important;
}
.card-skeleton::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.7) 50%, transparent 100%) !important;
  animation: p-shimmer 1.4s ease-in-out infinite !important;
}
@keyframes p-shimmer {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}
.card-skeleton__img {
  width: 100% !important;
  height: 120px !important;
  background: var(--p-border-md) !important;
  border-radius: var(--p-r-sm) !important;
  margin-bottom: .75rem !important;
}
.card-skeleton__line {
  height: 12px !important;
  background: var(--p-border-md) !important;
  border-radius: 6px !important;
  margin-bottom: .6rem !important;
}
.card-skeleton__line--sm    { width: 35% !important; height: 9px !important; }
.card-skeleton__line--title { width: 85% !important; height: 18px !important; }
.card-skeleton__line--full  { width: 100% !important; }
.card-skeleton__line--md    { width: 65% !important; }

/* ── Hero unified action buttons ── */
.classic-hero__actions {
  display: flex !important;
  gap: .5rem !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  margin-top: 1.25rem !important;
}
.classic-hero__action {
  display: inline-flex !important;
  align-items: center !important;
  gap: .4rem !important;
  padding: .55rem 1.15rem !important;
  border-radius: 9999px !important;
  font-family: var(--p-font) !important;
  font-size: .8rem !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: all .22s var(--p-ease) !important;
  border: 1.5px solid transparent !important;
  cursor: pointer !important;
  white-space: nowrap !important;
}
.classic-hero__action--dark {
  background: #1a1a2e !important;
  color: #fff !important;
  border-color: #1a1a2e !important;
}
.classic-hero__action--dark:hover {
  background: #0d0d1a !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,.25) !important;
}
.classic-hero__action--green {
  background: #10b981 !important;
  color: #fff !important;
  border-color: #10b981 !important;
}
.classic-hero__action--green:hover {
  background: #059669 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 16px rgba(16,185,129,.3) !important;
}
.classic-hero__action--indigo {
  background: linear-gradient(135deg, var(--p-indigo), #8b5cf6) !important;
  color: #fff !important;
  border-color: transparent !important;
  box-shadow: 0 3px 14px rgba(99,102,241,.3) !important;
}
.classic-hero__action--indigo:hover {
  transform: translateY(-2px) scale(1.03) !important;
  box-shadow: 0 6px 24px rgba(99,102,241,.4) !important;
}
.classic-hero__action--ghost {
  background: transparent !important;
  color: var(--p-indigo) !important;
  border-color: var(--p-indigo) !important;
}
.classic-hero__action--ghost:hover {
  background: var(--p-indigo) !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
}
