/*
 * PanditJi — 2026 Premium Design System
 *
 * Design language:
 *  - Inter (UI text) + Cormorant Garamond (editorial headings) via Google Fonts
 *  - Dark cosmic zodiac section with glassmorphism cards
 *  - Gold gradient text accents on section headings
 *  - Clean white content area — not flat newspaper, not SaaS-card-heavy
 *  - Micro-interactions: intentional, not decorative
 *  - Glassmorphism: subtle (blur 6-8px, low opacity) — 2026 spec
 */

/* =========================================================================
   DESIGN TOKENS
   ========================================================================= */
:root {
  /* Brand */
  --pj-red:          #e2001a;
  --pj-red-dark:     #b80015;
  --pj-gold:         #c8972a;
  --pj-gold-light:   #f0b429;
  --pj-gold-bright:  #ffd060;

  /* Cosmic (dark sections) */
  --pj-cosmic-0:     #080a14;
  --pj-cosmic-1:     #0d0f1e;
  --pj-cosmic-2:     #141630;
  --pj-cosmic-3:     #1e2048;

  /* Content (light sections) */
  --pj-bg:           #ffffff;
  --pj-bg-warm:      #faf8f4;
  --pj-bg-subtle:    #f5f3ef;
  --pj-border:       #ebebeb;
  --pj-border-mid:   #d8d8d8;

  /* Text */
  --pj-text:         #1a1a1a;
  --pj-text-mid:     #3d3d3d;
  --pj-text-light:   #888888;

  /* Element colours (zodiac) */
  --pj-fire:         #ff5533;
  --pj-earth:        #52a84b;
  --pj-air:          #4488ff;
  --pj-water:        #22a8c4;

  /* Elevation */
  --pj-shadow-xs:    0 1px 3px rgba(0,0,0,.05);
  --pj-shadow-sm:    0 2px 10px rgba(0,0,0,.08);
  --pj-shadow-md:    0 4px 24px rgba(0,0,0,.11);
  --pj-shadow-gold:  0 4px 24px rgba(200,151,42,.25);

  /* Layout */
  --pj-container:    1200px;
  --pj-radius:       10px;
  --pj-radius-sm:    6px;
  --pj-radius-lg:    16px;
  --pj-radius-full:  9999px;

  /* Typography */
  --pj-sans:   'Inter', system-ui, -apple-system, sans-serif;
  --pj-serif:  'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --pj-symbol: 'Segoe UI Symbol', 'Apple Symbols', 'Noto Sans Symbols', sans-serif;

  /* Motion */
  --pj-ease:  cubic-bezier(.4, 0, .2, 1);
  --pj-dur:   200ms;
}

/* =========================================================================
   BASE RESET
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; }

.pj-body {
  font-family: var(--pj-sans);
  color: var(--pj-text);
  background: var(--pj-bg-warm);
  font-size: 15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.pj-body .site { padding-top: 0 !important; }
.pj-page-wrap  { min-height: 60vh; background: #fff; }

/* =========================================================================
   HEADER
   White, clean. 3px red top line is the only red in the header.
   Typography uses the new Google Fonts.
   ========================================================================= */
.pj-site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: #fff;
  border-top: 3px solid var(--pj-red);
  border-bottom: 1px solid var(--pj-border);
  box-shadow: var(--pj-shadow-xs);
}

/* Top bar: logo + date + search */
.pj-header-top {
  background: #fff;
  padding: 12px 0;
  border-bottom: 1px solid var(--pj-border);
}

.pj-header-top__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.pj-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}

.pj-logo__icon {
  font-size: 1.8rem;
  line-height: 1;
}

.pj-logo__text {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}

.pj-logo__name {
  font-family: var(--pj-serif);
  font-size: 1.65rem;
  font-weight: 700;
  color: var(--pj-text);
  letter-spacing: -0.5px;
  /* Subtle gold shimmer on the name */
  background: linear-gradient(135deg, #1a1a1a 30%, var(--pj-gold) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.pj-logo__tagline {
  font-family: var(--pj-sans);
  font-size: 0.62rem;
  font-weight: 500;
  color: var(--pj-text-light);
  letter-spacing: 0.9px;
  text-transform: uppercase;
}

.pj-logo img { max-height: 50px; width: auto; }

/* Header right: date + search */
.pj-header-top__right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.pj-header-date {
  font-size: 0.75rem;
  color: var(--pj-text-light);
  font-weight: 500;
  white-space: nowrap;
}

.pj-search-form {
  display: flex;
  align-items: stretch;
  border: 1.5px solid var(--pj-border-mid);
  border-radius: var(--pj-radius-sm);
  overflow: hidden;
  background: var(--pj-bg-subtle);
  transition: border-color var(--pj-dur);
}

.pj-search-form:focus-within {
  border-color: var(--pj-gold);
  background: #fff;
}

.pj-search-form__input {
  border: none;
  background: transparent;
  padding: 7px 12px;
  font-size: 0.82rem;
  font-family: var(--pj-sans);
  color: var(--pj-text);
  width: 200px;
  outline: none;
}

.pj-search-form__input::placeholder { color: var(--pj-text-light); }

.pj-search-form__btn {
  background: transparent;
  border: none;
  border-left: 1.5px solid var(--pj-border-mid);
  padding: 0 11px;
  color: var(--pj-gold);
  cursor: pointer;
  display: flex;
  align-items: center;
  transition: background var(--pj-dur), color var(--pj-dur);
}

.pj-search-form__btn:hover {
  background: var(--pj-gold);
  color: #fff;
}

/* Navigation bar */
.pj-header-nav { background: #fff; }

.pj-nav__inner {
  display: flex;
  align-items: stretch;
}

.pj-nav__menu {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-wrap: wrap;
}

.pj-nav__menu > li { position: relative; }

.pj-nav__menu > li > a {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 12px 15px;
  font-size: 0.82rem;
  font-weight: 600;
  font-family: var(--pj-sans);
  color: var(--pj-text-mid);
  text-decoration: none;
  letter-spacing: 0.15px;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color var(--pj-dur), border-color var(--pj-dur);
}

.pj-nav__menu > li > a:hover,
.pj-nav__menu > li > a.pj-nav__link--active {
  color: var(--pj-red);
  border-bottom-color: var(--pj-red);
}

.pj-nav__caret {
  font-size: 0.5rem;
  opacity: 0.5;
  transition: transform var(--pj-dur);
}

.pj-nav__item--has-sub:hover .pj-nav__caret { transform: rotate(180deg); }

/* Dropdown */
.pj-nav__submenu {
  display: none;
  position: absolute;
  top: calc(100% + 1px);
  left: 0;
  background: #fff;
  border: 1px solid var(--pj-border);
  border-top: 2px solid var(--pj-red);
  border-radius: 0 0 var(--pj-radius-sm) var(--pj-radius-sm);
  list-style: none;
  padding: 6px 0;
  margin: 0;
  min-width: 155px;
  z-index: 200;
  box-shadow: var(--pj-shadow-md);
}

.pj-nav__item--has-sub:hover .pj-nav__submenu { display: block; }

.pj-nav__submenu li a {
  display: block;
  padding: 8px 16px;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--pj-text-mid);
  text-decoration: none;
  transition: background var(--pj-dur), color var(--pj-dur);
}

.pj-nav__submenu li a:hover {
  background: #fff8f0;
  color: var(--pj-red);
}

.pj-nav__hamburger { display: none; }

/* =========================================================================
   MOBILE NAV
   ========================================================================= */
@media (max-width: 768px) {
  .pj-header-date       { display: none; }
  .pj-search-form__input { width: 130px; }

  .pj-nav__hamburger {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    padding: 10px 16px;
    background: none;
    border: none;
    cursor: pointer;
    margin-left: auto;
  }

  .pj-hamburger__bar {
    display: block;
    width: 20px;
    height: 2px;
    background: var(--pj-text);
    border-radius: 1px;
    transition: transform .18s, opacity .18s;
  }

  .pj-nav__hamburger[aria-expanded="true"] .pj-hamburger__bar:nth-child(1)
    { transform: translateY(7px) rotate(45deg); }
  .pj-nav__hamburger[aria-expanded="true"] .pj-hamburger__bar:nth-child(2)
    { opacity: 0; }
  .pj-nav__hamburger[aria-expanded="true"] .pj-hamburger__bar:nth-child(3)
    { transform: translateY(-7px) rotate(-45deg); }

  .pj-nav__menu {
    display: none;
    flex-direction: column;
    width: 100%;
    border-top: 1px solid var(--pj-border);
    padding: 4px 0;
  }

  .pj-nav__menu.pj-nav__menu--open { display: flex; }

  .pj-nav__menu > li > a {
    padding: 11px 18px;
    border-bottom: 1px solid var(--pj-border);
    border-left: 2px solid transparent;
  }

  .pj-nav__menu > li > a:hover {
    border-left-color: var(--pj-red);
    background: var(--pj-bg-subtle);
  }

  .pj-nav__submenu {
    position: static;
    display: none;
    box-shadow: none;
    border: none;
    background: var(--pj-bg-subtle);
  }

  .pj-nav__item--has-sub.pj-nav__item--open .pj-nav__submenu { display: block; }
  .pj-nav__submenu li a { padding-left: 32px; }
}

/* =========================================================================
   LAYOUT UTILITIES
   ========================================================================= */
.pj-container {
  max-width: var(--pj-container);
  margin: 0 auto;
  padding: 0 24px;
}

.pj-homepage { background: var(--pj-bg-warm); }
.pj-section  { padding: 40px 0; }

/* Section header — gold gradient title + plain view-all link */
.pj-section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--pj-border);
  position: relative;
}

/* Red left accent strip */
.pj-section-header::before {
  content: '';
  position: absolute;
  left: -24px;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--pj-red);
}

.pj-section-title {
  font-family: var(--pj-serif);
  font-size: 1.45rem;
  font-weight: 700;
  margin: 0;
  letter-spacing: -0.2px;
  /* Gold gradient text — the key accent */
  background: linear-gradient(135deg, var(--pj-text) 0%, var(--pj-gold) 120%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.pj-section-title__icon {
  font-style: normal;
  /* Can't gradient-text an inline element easily — just keep it plain */
  -webkit-text-fill-color: var(--pj-gold);
}

.pj-section-viewall {
  font-size: 0.72rem;
  font-weight: 700;
  font-family: var(--pj-sans);
  color: var(--pj-red);
  text-decoration: none;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  border: none;
  padding: 0;
  white-space: nowrap;
  transition: opacity var(--pj-dur);
}

.pj-section-viewall:hover { opacity: 0.7; text-decoration: underline; }

.pj-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 20px;
  font-family: var(--pj-sans);
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: var(--pj-radius-sm);
  transition: all var(--pj-dur) var(--pj-ease);
  cursor: pointer;
}

.pj-btn--outline {
  border: 1.5px solid rgba(255,255,255,.4);
  color: #fff;
  background: rgba(255,255,255,.08);
}

.pj-btn--outline:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.7);
}

/* =========================================================================
   FEATURED VIDEO  — dark, rich
   ========================================================================= */
.pj-featured-video {
  background: linear-gradient(160deg, #0a0b14 0%, #13102a 55%, #0d0a1e 100%);
  padding: 40px 0;
  position: relative;
  overflow: hidden;
}

/* Subtle radial glow */
.pj-featured-video::after {
  content: '';
  position: absolute;
  top: -80px;
  right: 15%;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(200,151,42,.12) 0%, transparent 70%);
  pointer-events: none;
}

.pj-featured-video .pj-section-header { border-bottom-color: rgba(255,255,255,.1); }

.pj-featured-video .pj-section-title {
  background: linear-gradient(135deg, #fff 20%, var(--pj-gold-bright) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.pj-featured-video .pj-section-header::before { background: var(--pj-gold); }

.pj-featured-video__layout {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 32px;
  align-items: start;
}

.pj-video-embed {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  background: #000;
  border-radius: var(--pj-radius-lg);
  overflow: hidden;
  box-shadow: 0 8px 48px rgba(0,0,0,.6);
}

.pj-video-embed iframe,
.pj-video-embed video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

.pj-video-thumbnail-link {
  display: block;
  position: relative;
  border-radius: var(--pj-radius-lg);
  overflow: hidden;
  box-shadow: 0 8px 48px rgba(0,0,0,.6);
}

.pj-video-thumbnail {
  width: 100%;
  display: block;
  aspect-ratio: 16/9;
  object-fit: cover;
}

.pj-video-play-btn {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.3);
  transition: background var(--pj-dur);
}

.pj-video-play-btn::after {
  content: '';
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--pj-red);
  box-shadow: 0 0 0 8px rgba(226,0,26,.2);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpolygon points='5,3 19,12 5,21'/%3E%3C/svg%3E");
  background-size: 34%;
  background-repeat: no-repeat;
  background-position: 56% 50%;
  transition: transform var(--pj-dur), box-shadow var(--pj-dur);
}

.pj-video-thumbnail-link:hover .pj-video-play-btn { background: rgba(0,0,0,.45); }
.pj-video-thumbnail-link:hover .pj-video-play-btn::after {
  transform: scale(1.1);
  box-shadow: 0 0 0 12px rgba(226,0,26,.15);
}

.pj-featured-video__info { padding: 6px 0; }

.pj-featured-video__label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--pj-red);
  color: #fff;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 3px;
  margin-bottom: 12px;
}

.pj-featured-video__title {
  font-family: var(--pj-serif);
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.3;
  margin: 0 0 12px;
  color: #fff;
}

.pj-featured-video__title a { color: inherit; text-decoration: none; }
.pj-featured-video__title a:hover { color: var(--pj-gold-bright); }

.pj-featured-video__excerpt {
  font-size: 0.88rem;
  color: rgba(255,255,255,.6);
  line-height: 1.65;
  margin: 0 0 20px;
}

/* =========================================================================
   ZODIAC SECTION — THE STAR OF THE PAGE
   Dark cosmic background. 12 glassmorphism cards.
   ========================================================================= */
.pj-zodiac-section {
  /* Rich dark cosmic gradient */
  background:
    radial-gradient(ellipse at 20% 50%, rgba(108,61,224,.15) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(200,151,42,.08) 0%, transparent 50%),
    linear-gradient(160deg, var(--pj-cosmic-0) 0%, var(--pj-cosmic-2) 50%, var(--pj-cosmic-1) 100%);
  padding: 40px 0;
  position: relative;
  overflow: hidden;
}

/* Star field — tiny CSS dots */
.pj-zodiac-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1px 1px at 10% 15%, rgba(255,255,255,.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 30% 60%, rgba(255,255,255,.3) 0%, transparent 100%),
    radial-gradient(1px 1px at 50% 25%, rgba(255,255,255,.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 70% 80%, rgba(255,255,255,.3) 0%, transparent 100%),
    radial-gradient(1px 1px at 90% 40%, rgba(255,255,255,.4) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 20% 90%, rgba(255,255,255,.25) 0%, transparent 100%),
    radial-gradient(1px 1px at 60% 5%, rgba(255,255,255,.35) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 85% 70%, rgba(255,255,255,.2) 0%, transparent 100%);
  pointer-events: none;
}

.pj-zodiac-section .pj-section-header { border-bottom-color: rgba(255,255,255,.1); }

.pj-zodiac-section .pj-section-header::before { background: var(--pj-gold); }

.pj-zodiac-section .pj-section-title {
  background: linear-gradient(135deg, #fff 0%, var(--pj-gold-bright) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Tabs on dark bg */
.pj-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 24px;
  /* Glassmorphism pill container */
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--pj-radius-full);
  padding: 4px;
  width: fit-content;
}

.pj-tab {
  padding: 7px 20px;
  background: none;
  border: none;
  border-radius: var(--pj-radius-full);
  font-size: 0.82rem;
  font-weight: 600;
  font-family: var(--pj-sans);
  color: rgba(255,255,255,.55);
  cursor: pointer;
  letter-spacing: 0.2px;
  transition: background var(--pj-dur), color var(--pj-dur);
  white-space: nowrap;
}

.pj-tab:hover { color: rgba(255,255,255,.9); }

/* Active tab: solid white pill */
.pj-tab--active,
.pj-tab[aria-selected="true"] {
  background: rgba(255,255,255,.14);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.2);
}

/* Tab panels */
.pj-tab-panel { display: none; }
.pj-tab-panel--active,
.pj-tab-panel:not([hidden]) { display: grid; }

/* =========================================================================
   ZODIAC GRID — GLASSMORPHISM CARDS
   ========================================================================= */
.pj-zodiac-grid {
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}

.pj-zodiac-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
  padding: 22px 10px 18px;
  text-decoration: none;
  color: rgba(255,255,255,.85);
  position: relative;

  /* Glassmorphism */
  background: rgba(255,255,255,.05);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--pj-radius-lg);

  transition:
    background var(--pj-dur) var(--pj-ease),
    border-color var(--pj-dur) var(--pj-ease),
    transform var(--pj-dur) var(--pj-ease),
    box-shadow var(--pj-dur) var(--pj-ease);
}

/* Remove the coloured top bar — no longer needed */
.pj-zodiac-card::before { display: none; }

.pj-zodiac-card:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(var(--pj-sign-rgb, 255,85,51), .5);
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,0,0,.3), 0 0 0 1px rgba(var(--pj-sign-rgb, 255,85,51), .2);
  color: #fff;
}

/* Element RGB values for rgba() glow on hover */
.pj-zodiac-card--aries,
.pj-zodiac-card--leo,
.pj-zodiac-card--sagittarius  {
  --pj-sign-color: var(--pj-fire);
  --pj-sign-rgb: 255,85,51;
}

.pj-zodiac-card--taurus,
.pj-zodiac-card--virgo,
.pj-zodiac-card--capricorn    {
  --pj-sign-color: var(--pj-earth);
  --pj-sign-rgb: 82,168,75;
}

.pj-zodiac-card--gemini,
.pj-zodiac-card--libra,
.pj-zodiac-card--aquarius     {
  --pj-sign-color: var(--pj-air);
  --pj-sign-rgb: 68,136,255;
}

.pj-zodiac-card--cancer,
.pj-zodiac-card--scorpio,
.pj-zodiac-card--pisces       {
  --pj-sign-color: var(--pj-water);
  --pj-sign-rgb: 34,168,196;
}

/* Zodiac symbol */
.pj-zodiac-card__symbol {
  font-family: var(--pj-symbol);
  font-size: 1.65rem;
  line-height: 1;
  color: var(--pj-sign-color, var(--pj-gold-light));
  display: block;
  transition: transform var(--pj-dur) var(--pj-ease);
  text-rendering: optimizeLegibility;
}

.pj-zodiac-card:hover .pj-zodiac-card__symbol {
  transform: scale(1.15);
}

.pj-zodiac-card__name {
  font-size: 0.8rem;
  font-weight: 700;
  font-family: var(--pj-sans);
  color: inherit;
  letter-spacing: 0.1px;
  line-height: 1;
}

.pj-zodiac-card__hindi {
  font-size: 0.68rem;
  font-family: var(--pj-serif);
  font-style: italic;
  color: rgba(255,255,255,.5);
  line-height: 1;
}

.pj-zodiac-card__dates {
  font-size: 0.6rem;
  color: rgba(255,255,255,.35);
  line-height: 1;
}

/* =========================================================================
   CONTENT + SIDEBAR LAYOUT
   ========================================================================= */
.pj-content-sidebar-wrap {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 32px;
  padding: 36px 0 52px;
  align-items: start;
}

.pj-main-content .pj-section { padding: 0 0 32px; }
.pj-main-content .pj-section + .pj-section {
  padding-top: 32px;
  border-top: 1px solid var(--pj-border);
}

/* =========================================================================
   ARTICLE CARDS
   Clean white cards. Serif title. Subtle hover border-glow.
   ========================================================================= */
.pj-card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.pj-card {
  background: var(--pj-bg);
  border-radius: var(--pj-radius);
  overflow: hidden;
  border: 1px solid var(--pj-border);
  display: flex;
  flex-direction: column;
  transition:
    border-color var(--pj-dur),
    box-shadow var(--pj-dur),
    transform var(--pj-dur) var(--pj-ease);
}

.pj-card:hover {
  border-color: var(--pj-gold);
  box-shadow: var(--pj-shadow-gold);
  transform: translateY(-2px);
}

.pj-card__thumb-link {
  display: block;
  overflow: hidden;
  height: 160px;
  border-radius: 8px 8px 0 0;
}

.pj-card__thumb {
  width: 100%;
  height: 160px;
  object-fit: cover;
  display: block;
  transition: transform 0.4s var(--pj-ease);
}

.pj-card:hover .pj-card__thumb { transform: scale(1.05); }

.pj-card__body {
  padding: 14px 16px 16px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.pj-card__meta { display: flex; gap: 6px; flex-wrap: wrap; }

.pj-badge {
  font-size: 0.6rem;
  font-weight: 700;
  font-family: var(--pj-sans);
  padding: 2px 8px;
  border-radius: var(--pj-radius-full);
  letter-spacing: 0.6px;
  text-transform: uppercase;
}

.pj-badge--sign  { background: #fef0f0; color: #c0001a; border: 1px solid #f8c8cc; }
.pj-badge--type  { background: #fdf7e8; color: #8a5e00; border: 1px solid #e8d090; }
.pj-badge--event { background: #eef2fd; color: #1a40b0; border: 1px solid #b8c8f0; }

.pj-card__title {
  font-family: var(--pj-serif);
  font-size: 1.02rem;
  font-weight: 700;
  line-height: 1.35;
  margin: 0;
  flex: 1;
}

.pj-card__title a { color: var(--pj-text); text-decoration: none; transition: color var(--pj-dur); }
.pj-card__title a:hover { color: var(--pj-red); }

.pj-card__excerpt {
  font-size: 0.8rem;
  color: var(--pj-text-light);
  line-height: 1.55;
  margin: 0;
}

.pj-card__date {
  font-size: 0.7rem;
  font-family: var(--pj-sans);
  color: var(--pj-text-light);
  margin-top: auto;
}

/* =========================================================================
   ASTRO EVENTS LIST
   ========================================================================= */
.pj-events-list { display: flex; flex-direction: column; gap: 12px; }

.pj-event-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: var(--pj-bg);
  border-radius: var(--pj-radius);
  padding: 14px 16px;
  border: 1px solid var(--pj-border);
  border-left: 3px solid var(--pj-gold);
  transition: box-shadow var(--pj-dur), transform var(--pj-dur);
}

.pj-event-item:hover {
  box-shadow: var(--pj-shadow-sm);
  transform: translateX(3px);
}

.pj-event-item__date-block {
  flex-shrink: 0;
  width: 50px;
  text-align: center;
  background: var(--pj-cosmic-1);
  color: #fff;
  border-radius: var(--pj-radius-sm);
  padding: 8px 4px;
  line-height: 1;
}

.pj-event-item__day {
  display: block;
  font-family: var(--pj-serif);
  font-size: 1.55rem;
  font-weight: 700;
  line-height: 1;
}

.pj-event-item__month {
  display: block;
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--pj-gold-light);
  margin-top: 3px;
}

.pj-event-item__content { flex: 1; padding-top: 2px; }

.pj-event-item__title {
  font-family: var(--pj-serif);
  font-size: 0.97rem;
  font-weight: 700;
  margin: 4px 0 4px;
  line-height: 1.3;
}

.pj-event-item__title a { color: var(--pj-text); text-decoration: none; }
.pj-event-item__title a:hover { color: var(--pj-red); }

.pj-event-item__excerpt {
  font-size: 0.8rem;
  color: var(--pj-text-light);
  margin: 0;
  line-height: 1.5;
}

/* =========================================================================
   SIDEBAR WIDGETS
   ========================================================================= */
.pj-sidebar {
  position: sticky;
  top: calc(var(--pj-header-h, 110px) + 20px);
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.pj-widget {
  background: var(--pj-bg);
  border-radius: var(--pj-radius);
  overflow: hidden;
  border: 1px solid var(--pj-border);
  box-shadow: var(--pj-shadow-xs);
}

.pj-widget__title {
  font-family: var(--pj-sans);
  font-size: 0.68rem;
  font-weight: 800;
  color: #fff;
  background: var(--pj-cosmic-1);
  margin: 0;
  padding: 9px 14px;
  letter-spacing: 1px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 7px;
}

/* Lucky numbers */
.pj-lucky-numbers {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 16px 14px;
}

.pj-lucky-number {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--pj-red) 0%, #8b0010 100%);
  color: #fff;
  font-family: var(--pj-serif);
  font-size: 1.1rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 10px rgba(226,0,26,.3);
  transition: transform var(--pj-dur);
}

.pj-lucky-number:hover { transform: scale(1.08); }

/* Trending */
.pj-trending-list { list-style: none; padding: 0; margin: 0; }

.pj-trending-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 10px 14px;
  border-bottom: 1px solid var(--pj-border);
  transition: background var(--pj-dur);
}

.pj-trending-item:last-child { border-bottom: none; }
.pj-trending-item:hover { background: var(--pj-bg-subtle); }

.pj-trending-item__num {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  font-size: 0.65rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
  border-radius: 3px;
  background: var(--pj-border);
  color: var(--pj-text-light);
}

.pj-trending-item:nth-child(-n+3) .pj-trending-item__num {
  background: var(--pj-gold);
  color: #fff;
}

.pj-trending-item__link {
  font-family: var(--pj-serif);
  font-size: 0.87rem;
  font-weight: 600;
  color: var(--pj-text);
  text-decoration: none;
  line-height: 1.4;
  transition: color var(--pj-dur);
}

.pj-trending-item__link:hover { color: var(--pj-red); }

/* Sign quick links */
.pj-sign-links { list-style: none; padding: 0; margin: 0; columns: 2; }
.pj-sign-links li { break-inside: avoid; }

.pj-sign-links a {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  font-family: var(--pj-sans);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--pj-text-mid);
  text-decoration: none;
  border-bottom: 1px solid var(--pj-border);
  transition: background var(--pj-dur), color var(--pj-dur);
}

.pj-sign-links a:hover {
  color: var(--pj-red);
  background: var(--pj-bg-subtle);
}

.pj-sign-symbol {
  font-family: var(--pj-symbol);
  font-size: 1rem;
  color: var(--pj-sign-color, var(--pj-gold));
  flex-shrink: 0;
}

/* Apply sign colours in sidebar links too */
.pj-sign-links li:has(a[href*="aries"])       .pj-sign-symbol,
.pj-sign-links li:has(a[href*="leo"])          .pj-sign-symbol,
.pj-sign-links li:has(a[href*="sagittarius"]) .pj-sign-symbol
  { color: var(--pj-fire); }

.pj-sign-links li:has(a[href*="taurus"])      .pj-sign-symbol,
.pj-sign-links li:has(a[href*="virgo"])        .pj-sign-symbol,
.pj-sign-links li:has(a[href*="capricorn"])   .pj-sign-symbol
  { color: var(--pj-earth); }

.pj-sign-links li:has(a[href*="gemini"])      .pj-sign-symbol,
.pj-sign-links li:has(a[href*="libra"])        .pj-sign-symbol,
.pj-sign-links li:has(a[href*="aquarius"])    .pj-sign-symbol
  { color: var(--pj-air); }

.pj-sign-links li:has(a[href*="cancer"])      .pj-sign-symbol,
.pj-sign-links li:has(a[href*="scorpio"])      .pj-sign-symbol,
.pj-sign-links li:has(a[href*="pisces"])       .pj-sign-symbol
  { color: var(--pj-water); }

.pj-sign-links small {
  font-size: 0.62rem;
  color: var(--pj-text-light);
  font-style: italic;
  margin-left: auto;
}

/* =========================================================================
   SINGLE HOROSCOPE
   ========================================================================= */
.pj-single-horoscope-wrap { padding: 32px 0 48px; }
.pj-single-horoscope__header { margin-bottom: 24px; }

.pj-single-horoscope__sign-badge {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

.pj-single-horoscope__symbol {
  font-family: var(--pj-symbol);
  font-size: 2.2rem;
  color: var(--pj-gold);
  line-height: 1;
}

.pj-single-horoscope__title {
  font-family: var(--pj-serif);
  font-size: 1.85rem;
  font-weight: 700;
  color: var(--pj-text);
  line-height: 1.2;
  margin: 0 0 8px;
}

.pj-single-horoscope__date {
  font-family: var(--pj-sans);
  font-size: 0.78rem;
  color: var(--pj-text-light);
  margin: 0;
}

.pj-single-horoscope__thumb { overflow: hidden; border-radius: var(--pj-radius); margin-bottom: 24px; }
.pj-single-horoscope__thumb img { width: 100%; height: auto; display: block; }

.pj-single-horoscope__content {
  font-family: var(--pj-serif);
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--pj-text-mid);
  margin-bottom: 32px;
}

/* Lucky panel — dark cosmic panel */
.pj-lucky-panel {
  background: linear-gradient(135deg, var(--pj-cosmic-1), var(--pj-cosmic-3));
  border-radius: var(--pj-radius-lg);
  padding: 24px;
  color: #fff;
  border: 1px solid rgba(255,255,255,.07);
  position: relative;
  overflow: hidden;
}

.pj-lucky-panel::before {
  content: '';
  position: absolute;
  top: -40px;
  right: -40px;
  width: 180px;
  height: 180px;
  background: radial-gradient(circle, rgba(200,151,42,.15) 0%, transparent 70%);
  pointer-events: none;
}

.pj-lucky-panel__title {
  font-family: var(--pj-sans);
  font-size: 0.65rem;
  font-weight: 800;
  margin: 0 0 18px;
  color: var(--pj-gold-light);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  border-bottom: 1px solid rgba(255,255,255,.1);
  padding-bottom: 12px;
}

.pj-lucky-panel__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }

.pj-lucky-panel__item { display: flex; flex-direction: column; gap: 4px; }

.pj-lucky-panel__label {
  font-family: var(--pj-sans);
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  color: rgba(255,255,255,.4);
}

.pj-lucky-panel__item strong {
  font-family: var(--pj-serif);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--pj-gold-bright);
}

/* =========================================================================
   ARCHIVE
   ========================================================================= */
.pj-archive-wrap { padding: 28px 0 48px; }
.pj-archive-header { margin-bottom: 20px; }

/* =========================================================================
   FOOTER
   ========================================================================= */
.pj-site-footer {
  background: var(--pj-cosmic-0);
  border-top: 2px solid var(--pj-cosmic-2);
  color: rgba(255,255,255,.55);
}

.pj-footer__top { padding: 48px 0 32px; border-bottom: 1px solid rgba(255,255,255,.06); }

.pj-footer__top-inner {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
}

.pj-footer__logo {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--pj-serif);
  font-size: 1.4rem;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  margin-bottom: 10px;
}

.pj-footer__tagline { font-size: 0.82rem; color: rgba(255,255,255,.35); margin: 0; line-height: 1.55; }

.pj-footer__links h4 {
  font-family: var(--pj-sans);
  font-size: 0.65rem;
  font-weight: 800;
  color: rgba(255,255,255,.8);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin: 0 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}

.pj-footer__links ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }

.pj-footer__links a {
  font-size: 0.82rem;
  color: rgba(255,255,255,.45);
  text-decoration: none;
  transition: color var(--pj-dur);
}

.pj-footer__links a:hover { color: var(--pj-gold-light); }

.pj-footer__bottom { padding: 14px 0; }

.pj-footer__bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 6px;
}

.pj-footer__bottom p { font-size: 0.72rem; color: rgba(255,255,255,.25); margin: 0; }

/* =========================================================================
   UTILITIES
   ========================================================================= */
.pj-empty-state {
  text-align: center;
  padding: 28px 24px;
  color: var(--pj-text-light);
  font-style: italic;
  background: var(--pj-bg-subtle);
  border-radius: var(--pj-radius);
  border: 1.5px dashed var(--pj-border-mid);
  font-size: 0.88rem;
  font-family: var(--pj-serif);
}

.pj-empty-state--small { padding: 12px; font-size: 0.8rem; margin: 0 14px 14px; }

.screen-reader-text { clip: rect(1px,1px,1px,1px); height: 1px; overflow: hidden; position: absolute; width: 1px; }

/* =========================================================================
   PAGINATION
   ========================================================================= */
.navigation.pagination {
  margin: 40px 0 12px;
}

.navigation.pagination .nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex-wrap: wrap;
}

.navigation.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 38px;
  padding: 0 10px;
  border-radius: 6px;
  border: 1px solid var(--pj-border-mid);
  background: var(--pj-bg);
  color: var(--pj-text-mid);
  font-family: var(--pj-sans);
  font-size: 0.82rem;
  font-weight: 500;
  text-decoration: none;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  line-height: 1;
}

.navigation.pagination .page-numbers:hover {
  background: var(--pj-bg-subtle);
  border-color: var(--pj-gold);
  color: var(--pj-text);
}

.navigation.pagination .page-numbers.current {
  background: var(--pj-red);
  border-color: var(--pj-red);
  color: #fff;
  font-weight: 600;
  cursor: default;
}

.navigation.pagination .page-numbers.dots {
  border-color: transparent;
  background: transparent;
  color: var(--pj-text-light);
  pointer-events: none;
}

.navigation.pagination .prev.page-numbers,
.navigation.pagination .next.page-numbers {
  padding: 0 14px;
  gap: 4px;
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 1024px) {
  .pj-zodiac-grid       { grid-template-columns: repeat(6, 1fr); }
  .pj-card-grid         { grid-template-columns: repeat(2, 1fr); }
  .pj-footer__top-inner { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 900px) {
  .pj-content-sidebar-wrap      { grid-template-columns: 1fr; }
  .pj-sidebar                   { position: static; display: grid; grid-template-columns: repeat(2, 1fr); }
  .pj-featured-video__layout    { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .pj-zodiac-grid         { grid-template-columns: repeat(4, 1fr); gap: 8px; }
  .pj-card-grid           { grid-template-columns: 1fr; }
  .pj-sidebar             { grid-template-columns: 1fr; }
  .pj-footer__top-inner   { grid-template-columns: 1fr; gap: 24px; }
  .pj-lucky-panel__grid   { grid-template-columns: 1fr; }
  .pj-sign-links          { columns: 1; }
  .pj-tabs                { border-radius: var(--pj-radius); }
  .pj-search-form__input  { width: 120px; }
  .pj-logo__name          { font-size: 1.35rem; }
  .pj-section-header::before { display: none; }
  .pj-container           { padding: 0 16px; }
}

@media (max-width: 420px) {
  .pj-zodiac-grid { grid-template-columns: repeat(3, 1fr); }
}

/* =========================================================================
   TOI HOROSCOPE PAGE DESIGN SYSTEM
   Clean newspaper layout inspired by Times of India horoscope page.
   Uses toi- prefix to avoid conflicts with existing pj- styles.
   ========================================================================= */

:root {
  --toi-red:        #d32f2f;
  --toi-red-dark:   #b71c1c;
  --toi-text:       #222222;
  --toi-text-mid:   #444444;
  --toi-text-light: #777777;
  --toi-bg:         #ffffff;
  --toi-bg-gray:    #f4f4f4;
  --toi-bg-section: #fafafa;
  --toi-border:     #e0e0e0;
  --toi-border-mid: #cccccc;
  --toi-container:  1200px;
  --toi-fire:       #e53935;
  --toi-earth:      #43a047;
  --toi-air:        #1e88e5;
  --toi-water:      #00897b;
  --toi-sans: 'Inter', system-ui, sans-serif;
  --toi-serif: 'Cormorant Garamond', Georgia, serif;
}

/* ─── LAYOUT ─── */
.toi-page { background: var(--toi-bg); font-family: var(--toi-sans); color: var(--toi-text); padding-top: 20px; padding-bottom: 20px; }

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

.toi-two-col {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 28px;
  padding: 24px 0 48px;
  align-items: start;
}

.toi-main { min-width: 0; }

/* ─── BREADCRUMB ─── */
.toi-breadcrumb {
  font-size: 0.72rem;
  color: var(--toi-text-light);
  padding: 10px 0 4px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.toi-breadcrumb a { color: var(--toi-text-light); text-decoration: none; }
.toi-breadcrumb a:hover { color: var(--toi-red); text-decoration: underline; }
.toi-breadcrumb span[aria-current] { color: var(--toi-red); font-weight: 600; }

/* ─── PAGE TITLE ─── */
.toi-page-title {
  font-family: var(--toi-serif);
  font-size: 2rem;
  font-weight: 700;
  margin: 0 0 24px;
  color: var(--toi-text);
}

/* ─── ZODIAC SECTION ─── */
.toi-zodiac-section {
  background: var(--toi-bg);
  border-bottom: 1px solid var(--toi-border);
  padding: 20px 0 0;
  margin-bottom: 8px;
}

/* Carousel wrapper with scroll */
.toi-carousel-wrap {
  overflow: hidden;
  position: relative;
}
.toi-carousel-wrap::after {
  content: '';
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 40px;
  background: linear-gradient(to right, transparent, rgba(255,255,255,.95));
  pointer-events: none;
}

.toi-carousel {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding-bottom: 12px;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.toi-carousel::-webkit-scrollbar { display: none; }

/* Sign button */
.toi-sign-btn {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 12px 10px 10px;
  width: 88px;
  background: var(--toi-bg-gray);
  border: 2px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  text-align: center;
  transition: border-color .15s, background .15s, transform .15s;
  font-family: var(--toi-sans);
}
.toi-sign-btn:hover {
  border-color: var(--toi-border-mid);
  background: #fff;
}
.toi-sign-btn--active {
  background: #fff;
  border-color: var(--toi-red) !important;
  box-shadow: 0 2px 8px rgba(211,47,47,.15);
}

/* Sign glyph — colored circle */
.toi-sign-btn__glyph {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  font-family: 'Segoe UI Symbol', 'Apple Symbols', 'Noto Sans Symbols', sans-serif;
  color: #fff;
  background: var(--toi-red);
  flex-shrink: 0;
  margin: 0 auto;
  transition: transform .15s;
}
.toi-sign-btn--active .toi-sign-btn__glyph,
.toi-sign-btn:hover .toi-sign-btn__glyph { transform: scale(1.08); }

/* Element colors for sign glyphs */
.toi-elem--fire .toi-sign-btn__glyph  { background: var(--toi-fire); }
.toi-elem--earth .toi-sign-btn__glyph { background: var(--toi-earth); }
.toi-elem--air .toi-sign-btn__glyph   { background: var(--toi-air); }
.toi-elem--water .toi-sign-btn__glyph { background: var(--toi-water); }

/* Also applied to panel icon */
.toi-panel-icon.toi-elem--fire  { background: var(--toi-fire); }
.toi-panel-icon.toi-elem--earth { background: var(--toi-earth); }
.toi-panel-icon.toi-elem--air   { background: var(--toi-air); }
.toi-panel-icon.toi-elem--water { background: var(--toi-water); }

.toi-sign-btn__name {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--toi-text);
  line-height: 1.2;
}
.toi-sign-btn__dates {
  font-size: 0.6rem;
  color: var(--toi-text-light);
  line-height: 1.2;
}

/* ─── TYPE TABS ─── */
.toi-type-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--toi-border);
  margin-top: 16px;
  overflow-x: auto;
  scrollbar-width: none;
}
.toi-type-tabs::-webkit-scrollbar { display: none; }

.toi-type-tab {
  padding: 10px 18px;
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  font-size: 0.82rem;
  font-weight: 600;
  font-family: var(--toi-sans);
  color: var(--toi-text-light);
  cursor: pointer;
  white-space: nowrap;
  transition: color .15s, border-color .15s;
  letter-spacing: 0.1px;
}
.toi-type-tab:hover { color: var(--toi-text); }
.toi-type-tab--active {
  color: var(--toi-red);
  border-bottom-color: var(--toi-red);
}

/* ─── HOROSCOPE PANEL ─── */
.toi-horoscope-panel {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 22px 0 24px;
  border-bottom: 1px solid var(--toi-border);
}

.toi-panel-icon {
  flex-shrink: 0;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--toi-red);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.2rem;
  font-family: 'Segoe UI Symbol', 'Apple Symbols', 'Noto Sans Symbols', sans-serif;
  color: #fff;
  transition: background .2s;
}

.toi-panel-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}
.toi-panel-img--hidden  { display: none; }
.toi-panel-symbol--hidden { display: none; }
.toi-panel-icon--has-img { background: transparent; font-size: 0; }

.toi-panel-body { flex: 1; min-width: 0; }

.toi-panel-title {
  font-family: var(--toi-serif);
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0 0 4px;
  color: var(--toi-text);
  line-height: 1.3;
}

.toi-panel-dates {
  font-size: 0.78rem;
  color: var(--toi-text-light);
  margin: 0 0 10px;
}

.toi-panel-traits {
  font-size: 0.78rem;
  font-style: italic;
  color: var(--toi-text-light);
  margin: 0 0 10px;
  line-height: 1.5;
}

.toi-panel-excerpt {
  font-size: 0.9rem;
  color: var(--toi-text-mid);
  line-height: 1.65;
  margin: 0 0 14px;
}

.toi-read-more {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--toi-red);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 700;
  font-family: var(--toi-sans);
  padding: 7px 18px;
  border-radius: 4px;
  text-decoration: none;
  letter-spacing: 0.2px;
  transition: background .15s;
}
.toi-read-more:hover { background: var(--toi-red-dark); color: #fff; }

/* ─── SECTION HEADERS ─── */
.toi-section { margin-bottom: 28px; }

.toi-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--toi-red);
  margin-bottom: 16px;
}

.toi-section-title {
  font-family: var(--toi-sans);
  font-size: 0.85rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin: 0;
  color: var(--toi-text);
}

.toi-viewall {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--toi-red);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  white-space: nowrap;
  transition: opacity .15s;
}
.toi-viewall:hover { opacity: 0.75; text-decoration: underline; }

.toi-meta {
  font-size: 0.7rem;
  color: var(--toi-text-light);
  display: block;
  margin-top: 4px;
}

.toi-badge {
  display: inline-block;
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: #fdecea;
  color: var(--toi-red);
  border: 1px solid #f5c6c6;
  padding: 2px 8px;
  border-radius: 3px;
  margin-bottom: 6px;
}

/* ─── HERO GRID ─── */
.toi-hero-grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 20px;
}

.toi-hero-lead { display: flex; flex-direction: column; }

.toi-hero-lead__img-wrap { display: block; overflow: hidden; }
.toi-hero-lead__img {
  width: 100%;
  height: 240px;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}
.toi-hero-lead__img-wrap:hover .toi-hero-lead__img { transform: scale(1.03); }

.toi-hero-lead__body { padding: 12px 0 0; }

.toi-hero-lead__title {
  font-family: var(--toi-serif);
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.35;
  margin: 0 0 8px;
}
.toi-hero-lead__title a { color: var(--toi-text); text-decoration: none; }
.toi-hero-lead__title a:hover { color: var(--toi-red); }

.toi-hero-lead__excerpt {
  font-size: 0.85rem;
  color: var(--toi-text-mid);
  line-height: 1.6;
  margin: 0;
}

.toi-hero-aside {
  display: flex;
  flex-direction: column;
  gap: 14px;
  border-left: 1px solid var(--toi-border);
  padding-left: 20px;
}

.toi-side-card { display: flex; gap: 10px; align-items: flex-start; }
.toi-side-card__img-wrap { flex-shrink: 0; overflow: hidden; width: 90px; }
.toi-side-card__img { width: 90px; height: 64px; object-fit: cover; display: block; transition: transform .3s; }
.toi-side-card__img-wrap:hover .toi-side-card__img { transform: scale(1.04); }
.toi-side-card__body { flex: 1; min-width: 0; }
.toi-side-card__title { font-size: 0.82rem; font-weight: 600; line-height: 1.4; margin: 0; }
.toi-side-card__title a { color: var(--toi-text); text-decoration: none; }
.toi-side-card__title a:hover { color: var(--toi-red); }

/* ─── ARTICLE GRID ─── */
.toi-article-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.toi-grid-card {
  border-bottom: 1px solid var(--toi-border);
  padding-bottom: 14px;
}
.toi-grid-card__img-wrap { display: block; overflow: hidden; }
.toi-grid-card__img { width: 100%; height: 140px; object-fit: cover; display: block; transition: transform .3s; }
.toi-grid-card__img-wrap:hover .toi-grid-card__img { transform: scale(1.03); }
.toi-grid-card__body { padding-top: 8px; }
.toi-grid-card__title { font-size: 0.82rem; font-weight: 600; line-height: 1.4; margin: 0; }
.toi-grid-card__title a { color: var(--toi-text); text-decoration: none; }
.toi-grid-card__title a:hover { color: var(--toi-red); }

/* ─── TRENDING TOPICS ─── */
.toi-tags-scroll {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 6px;
  scrollbar-width: none;
}
.toi-tags-scroll::-webkit-scrollbar { display: none; }

.toi-tag {
  flex: 0 0 auto;
  display: inline-block;
  padding: 5px 14px;
  background: var(--toi-bg-gray);
  border: 1px solid var(--toi-border);
  border-radius: 20px;
  font-size: 0.74rem;
  font-weight: 500;
  color: var(--toi-text-mid);
  text-decoration: none;
  white-space: nowrap;
  transition: background .15s, color .15s, border-color .15s;
}
.toi-tag:hover {
  background: var(--toi-red);
  color: #fff;
  border-color: var(--toi-red);
}

/* ─── TYPE SECTIONS (Monthly / Yearly) ─── */
.toi-type-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.toi-type-lead__img { width: 100%; height: 200px; object-fit: cover; display: block; }
.toi-type-lead__title { font-family: var(--toi-serif); font-size: 1rem; font-weight: 700; margin: 10px 0 0; line-height: 1.4; }
.toi-type-lead__title a { color: var(--toi-text); text-decoration: none; }
.toi-type-lead__title a:hover { color: var(--toi-red); }

.toi-type-list { display: flex; flex-direction: column; gap: 0; border-left: 1px solid var(--toi-border); padding-left: 16px; }
.toi-type-list__item { padding: 10px 0; border-bottom: 1px solid var(--toi-border); }
.toi-type-list__item:last-child { border-bottom: none; }
.toi-type-list__title { font-size: 0.82rem; font-weight: 600; margin: 0 0 3px; line-height: 1.4; }
.toi-type-list__title a { color: var(--toi-text); text-decoration: none; }
.toi-type-list__title a:hover { color: var(--toi-red); }

/* ─── MORE STORIES ─── */
.toi-more-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--toi-border);
}
.toi-more-item {
  padding: 12px 14px;
  border-right: 1px solid var(--toi-border);
  border-bottom: 1px solid var(--toi-border);
}
.toi-more-item:nth-child(3n) { border-right: none; }
.toi-more-item:nth-last-child(-n+3) { border-bottom: none; }
.toi-more-item a { font-size: 0.8rem; font-weight: 500; color: var(--toi-text-mid); text-decoration: none; line-height: 1.45; display: block; }
.toi-more-item a:hover { color: var(--toi-red); }

/* ─── SIDEBAR ─── */
.toi-sidebar {
  position: sticky;
  top: calc(var(--pj-header-h, 110px) + 16px);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.toi-widget {
  background: var(--toi-bg);
  border: 1px solid var(--toi-border);
  overflow: hidden;
}
.toi-widget__title {
  font-family: var(--toi-sans);
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #fff;
  background: var(--toi-red);
  margin: 0;
  padding: 8px 14px;
}

.toi-lucky-wrap { display: flex; flex-wrap: wrap; gap: 10px; padding: 14px; }
.toi-lucky-ball {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--toi-red);
  color: #fff;
  font-family: var(--toi-serif);
  font-size: 1rem;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

.toi-trending-list { list-style: none; margin: 0; padding: 0; }
.toi-trending-item { display: flex; align-items: flex-start; gap: 10px; padding: 9px 14px; border-bottom: 1px solid var(--toi-border); }
.toi-trending-item:last-child { border-bottom: none; }
.toi-trending-num {
  flex-shrink: 0;
  width: 20px; height: 20px;
  border-radius: 3px;
  background: var(--toi-bg-gray);
  color: var(--toi-text-light);
  font-size: 0.65rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  margin-top: 1px;
}
.toi-trending-item:nth-child(-n+3) .toi-trending-num { background: var(--toi-red); color: #fff; }
.toi-trending-link { font-size: 0.8rem; color: var(--toi-text); text-decoration: none; line-height: 1.4; }
.toi-trending-link:hover { color: var(--toi-red); }

.toi-sign-links { list-style: none; padding: 0; margin: 0; columns: 2; }
.toi-sign-links li { break-inside: avoid; }
.toi-sign-links a {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 12px;
  font-size: 0.78rem; font-weight: 500;
  color: var(--toi-text-mid); text-decoration: none;
  border-bottom: 1px solid var(--toi-border);
  transition: background .12s, color .12s;
}
.toi-sign-links a:hover { background: var(--toi-bg-gray); color: var(--toi-red); }
.toi-sign-links__glyph { font-family: 'Segoe UI Symbol','Apple Symbols','Noto Sans Symbols',sans-serif; font-size: 1rem; color: var(--toi-red); }

.toi-empty { padding: 14px; font-size: 0.8rem; color: var(--toi-text-light); font-style: italic; margin: 0; }

/* ─── FEATURED BADGE ─── */
.toi-badge--featured { background: #f0c000; color: #333; border: none; font-weight: 700; }

/* ─── CALENDAR WIDGET (sidebar) ─── */
.toi-cal-widget { padding: 0; overflow: hidden; }
.toi-cal-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px 10px; }
.toi-cal-viewall { font-size: 0.72rem; color: var(--toi-red); text-decoration: none; font-weight: 600; }
.toi-cal-viewall:hover { text-decoration: underline; }

.toi-cal { width: 100%; border-collapse: collapse; font-size: 0.78rem; }
.toi-cal thead th { text-align: center; padding: 4px 2px; color: var(--toi-text-light); font-weight: 600; font-size: 0.7rem; }
.toi-cal td { text-align: center; padding: 3px 2px; }
.toi-cal__empty { background: transparent; }
.toi-cal__day { color: var(--toi-text-mid); }
.toi-cal__day a { color: inherit; text-decoration: none; display: block; border-radius: 50%; width: 24px; height: 24px; line-height: 24px; margin: 0 auto; }
.toi-cal__day--today { font-weight: 700; }
.toi-cal__day--today a, .toi-cal__day--today { color: var(--pj-gold); }
.toi-cal__day--event a { background: var(--toi-red); color: #fff !important; font-weight: 600; }
.toi-cal__day--event a:hover { background: #b30000; }

.toi-cal-events { list-style: none; padding: 10px 16px 14px; margin: 0; border-top: 1px solid var(--toi-border); }
.toi-cal-events__item { display: flex; align-items: baseline; gap: 8px; padding: 5px 0; border-bottom: 1px solid var(--toi-border); font-size: 0.78rem; }
.toi-cal-events__item:last-child { border-bottom: none; }
.toi-cal-events__date { flex-shrink: 0; color: var(--toi-red); font-weight: 600; min-width: 38px; }
.toi-cal-events__item a { color: var(--toi-text-dark); text-decoration: none; }
.toi-cal-events__item a:hover { color: var(--toi-red); }

/* ─── EVENTS ARCHIVE PAGE ─── */
.pj-events-archive { padding: 32px 0 56px; }
.pj-year-nav { display: flex; align-items: center; gap: 16px; margin-top: 10px; }
.pj-year-nav__btn { color: var(--toi-red); text-decoration: none; font-weight: 600; font-size: 0.9rem; }
.pj-year-nav__btn:hover { text-decoration: underline; }
.pj-year-nav__current { font-weight: 700; font-size: 1.1rem; }

.pj-month-jumps { display: flex; flex-wrap: wrap; gap: 6px; margin: 20px 0 28px; }
.pj-month-jump { padding: 4px 10px; border-radius: 4px; border: 1px solid var(--toi-border); font-size: 0.78rem; font-weight: 600; color: var(--toi-text-mid); text-decoration: none; }
.pj-month-jump:hover, .pj-month-jump--has-events { border-color: var(--toi-red); color: var(--toi-red); background: #fff5f5; }

.pj-events-month { margin-bottom: 36px; }
.pj-events-month__heading { display: flex; align-items: center; gap: 12px; font-size: 1.15rem; font-weight: 700; color: var(--toi-text-dark); padding-bottom: 10px; border-bottom: 2px solid var(--toi-red); margin-bottom: 16px; }
.pj-events-month__count { font-size: 0.75rem; font-weight: 500; color: var(--toi-text-light); }

.pj-events-list { display: flex; flex-direction: column; gap: 12px; }
.pj-event-card { display: flex; gap: 16px; padding: 14px; border: 1px solid var(--toi-border); border-radius: var(--pj-radius, 8px); background: #fff; }
.pj-event-card:hover { border-color: #e0c0c0; box-shadow: 0 2px 8px rgba(0,0,0,.06); }
.pj-event-card__date-badge { flex-shrink: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; width: 52px; height: 52px; background: var(--toi-red); border-radius: 8px; color: #fff; }
.pj-event-card__day { font-size: 1.3rem; font-weight: 700; line-height: 1; }
.pj-event-card__mon { font-size: 0.65rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.pj-event-card__body { flex: 1; }
.pj-event-card__title { margin: 4px 0 6px; font-size: 0.95rem; font-weight: 600; }
.pj-event-card__title a { color: var(--toi-text-dark); text-decoration: none; }
.pj-event-card__title a:hover { color: var(--toi-red); }
.pj-event-card__excerpt { font-size: 0.8rem; color: var(--toi-text-mid); margin: 0; }
.pj-badge--event { background: #fff3e0; color: #e65100; border: 1px solid #ffcc80; }

.pj-single-event { max-width: 860px; }
.pj-single-event__footer { margin-top: 28px; }
.pj-back-link { color: var(--toi-red); text-decoration: none; font-size: 0.9rem; font-weight: 600; }
.pj-back-link:hover { text-decoration: underline; }

/* ─── YOUTUBE EMBEDS ─── */
.toi-featured-video { margin: 0 0 28px; }
.toi-video-embed { position: relative; aspect-ratio: 16/9; max-width: 640px; margin: 0 auto; border-radius: 10px; overflow: hidden; background: #000; }
.toi-video-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

.pj-horoscope-short { margin: 0 auto 28px; max-width: 360px; }
.pj-horoscope-short iframe { display: block; width: 100%; aspect-ratio: 9/16; border: 0; border-radius: 12px; }

/* ─── RESPONSIVE ─── */
@media (max-width: 1024px) {
  .toi-two-col { grid-template-columns: 1fr 240px; gap: 20px; }
  .toi-article-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  .toi-two-col { grid-template-columns: 1fr; }
  .toi-sidebar { position: static; display: grid; grid-template-columns: repeat(2, 1fr); }
  .toi-hero-grid { grid-template-columns: 1fr; }
  .toi-hero-aside { border-left: none; border-top: 1px solid var(--toi-border); padding-left: 0; padding-top: 14px; flex-direction: row; flex-wrap: wrap; }
  .toi-side-card { flex: 0 0 calc(50% - 7px); }
  .toi-type-layout { grid-template-columns: 1fr; }
  .toi-type-list { border-left: none; border-top: 1px solid var(--toi-border); padding-left: 0; padding-top: 12px; }
}

@media (max-width: 640px) {
  .toi-article-grid { grid-template-columns: 1fr; }
  .toi-more-grid    { grid-template-columns: repeat(2, 1fr); }
  .toi-more-item:nth-child(2n) { border-right: none; }
  .toi-more-item:nth-child(3n) { border-right: 1px solid var(--toi-border); }
  .toi-sidebar { grid-template-columns: 1fr; }
  .toi-sign-links { columns: 1; }
  .toi-hero-aside { flex-direction: column; }
  .toi-side-card  { flex: 0 0 auto; width: 100%; }
  .toi-page-title { font-size: 1.5rem; }
  .toi-panel-icon { width: 56px; height: 56px; font-size: 1.7rem; }
}

@media (max-width: 420px) {
  .toi-more-grid { grid-template-columns: 1fr; }
  .toi-more-item { border-right: none !important; }
}


/* =========================================================================
   NUMEROLOGY PAGE
   ========================================================================= */

.pj-numerology-page { padding-top: 0; }
.pj-num-hero { text-align: center; padding: 3rem 1rem 2rem; background: linear-gradient(135deg, #0d0620 0%, #1a0535 60%, #2c0b4a 100%); color: #fff; border-radius: 0 0 1.5rem 1.5rem; margin-bottom: 2.5rem; }
.pj-num-hero__title { font-family: var(--pj-font-serif); font-size: 3rem; color: var(--pj-gold); margin: 0 0 .75rem; }
.pj-num-hero__sub { font-size: 1.1rem; opacity: .85; max-width: 560px; margin: 0 auto; line-height: 1.6; }
.pj-num-calc { margin-bottom: 2.5rem; }
.pj-num-calc__card { background: #fff; border: 1px solid #e8e0f0; border-radius: 1rem; padding: 2rem; box-shadow: 0 2px 12px rgba(0,0,0,.07); }
.pj-num-calc__title { font-family: var(--pj-font-serif); font-size: 1.6rem; color: #1a0535; margin: 0 0 .5rem; }
.pj-num-calc__desc { color: #555; margin: 0 0 1.25rem; line-height: 1.6; }
.pj-num-calc__row { display: flex; gap: .75rem; flex-wrap: wrap; }
.pj-num-calc__input { flex: 1 1 200px; padding: .75rem 1rem; font-size: 1.1rem; border: 2px solid #d0c0e8; border-radius: .6rem; outline: none; transition: border-color .2s; }
.pj-num-calc__input:focus { border-color: var(--pj-gold); }
.pj-num-calc__btn { padding: .75rem 1.75rem; background: linear-gradient(135deg, #1a0535, #3b1260); color: #fff; font-size: 1rem; font-weight: 600; border: none; border-radius: .6rem; cursor: pointer; transition: opacity .2s; white-space: nowrap; }
.pj-num-calc__btn:hover { opacity: .88; }
.pj-num-calc__result { margin-top: 1.25rem; }
.pj-calc-error { color: var(--pj-red); font-size: .95rem; }
.pj-calc-success { display: flex; align-items: center; gap: 1.25rem; background: linear-gradient(135deg, #fdf7e3, #fff9ed); border: 1px solid var(--pj-gold); border-radius: .75rem; padding: 1.25rem 1.5rem; flex-wrap: wrap; }
.pj-calc-num { width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg, #1a0535, #3b1260); color: var(--pj-gold); font-family: var(--pj-font-serif); font-size: 2.25rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pj-calc-info { font-size: 1.05rem; color: #1a0535; line-height: 1.5; }
.pj-calc-cta { display: inline-block; margin-top: .5rem; padding: .45rem 1rem; background: var(--pj-gold); color: #1a0535; font-weight: 600; border-radius: .4rem; font-size: .9rem; text-decoration: none; }
.pj-calc-cta:hover { background: #b8831e; color: #fff; }
.pj-num-calc__how { margin-top: 1rem; }
.pj-num-calc__how summary { cursor: pointer; color: #6b4aa0; font-weight: 600; font-size: .9rem; }
.pj-num-calc__how-body { padding: .75rem 0 0; color: #444; font-size: .9rem; line-height: 1.7; }
.pj-num-calc__how-body ol { padding-left: 1.25rem; }
.pj-num-calc__how-body li { margin-bottom: .3rem; }
.pj-num-picker { margin-bottom: 2.5rem; }
.pj-num-picker__title { font-family: var(--pj-font-serif); font-size: 1.5rem; color: #1a0535; margin: 0 0 1rem; text-align: center; }
.pj-num-picker__grid { display: grid; grid-template-columns: repeat(9, 1fr); gap: .75rem; }
.pj-num-picker__btn { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 1rem .5rem; background: #fff; border: 2px solid #e0d6f0; border-radius: .75rem; text-decoration: none; color: #1a0535; transition: all .2s; gap: .3rem; }
.pj-num-picker__btn:hover { border-color: var(--pj-gold); background: #fdf7e3; transform: translateY(-2px); }
.pj-num-picker__btn--active { border-color: var(--pj-gold); background: linear-gradient(135deg, #1a0535, #3b1260); color: #fff; }
.pj-num-picker__btn--active .pj-num-picker__num { color: var(--pj-gold); }
.pj-num-picker__btn--active .pj-num-picker__tag { color: rgba(255,255,255,.8); }
.pj-num-picker__num { font-family: var(--pj-font-serif); font-size: 2rem; font-weight: 700; line-height: 1; }
.pj-num-picker__tag { font-size: .7rem; text-align: center; opacity: .75; }
.pj-num-overview__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-bottom: 2.5rem; }
.pj-num-overview__card { display: flex; align-items: center; gap: 1rem; padding: 1.25rem; background: #fff; border: 1px solid #e8e0f0; border-radius: .75rem; text-decoration: none; color: #1a0535; transition: all .2s; }
.pj-num-overview__card:hover { border-color: var(--pj-gold); box-shadow: 0 4px 16px rgba(0,0,0,.08); transform: translateY(-2px); }
.pj-num-overview__num { width: 52px; height: 52px; background: linear-gradient(135deg, #1a0535, #3b1260); color: var(--pj-gold); font-family: var(--pj-font-serif); font-size: 1.5rem; font-weight: 700; border-radius: .5rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pj-num-overview__info { display: flex; flex-direction: column; gap: .2rem; }
.pj-num-overview__info strong { font-size: 1rem; }
.pj-num-overview__info span { font-size: .8rem; color: #777; }
.pj-num-detail { background: #fff; border: 1px solid #e8e0f0; border-radius: 1rem; padding: 2rem; margin-bottom: 2.5rem; }
.pj-num-detail__header { display: flex; gap: 1.5rem; align-items: flex-start; margin-bottom: 1.5rem; flex-wrap: wrap; }
.pj-num-detail__badge { width: 80px; height: 80px; background: linear-gradient(135deg, #1a0535, #3b1260); color: var(--pj-gold); font-family: var(--pj-font-serif); font-size: 2.75rem; font-weight: 700; border-radius: 1rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pj-num-detail__name { font-family: var(--pj-font-serif); font-size: 1.75rem; color: #1a0535; margin: 0 0 .5rem; }
.pj-num-detail__meta { display: flex; flex-wrap: wrap; gap: .5rem 1.5rem; font-size: .9rem; color: #555; }
.pj-num-detail__meta strong { color: #1a0535; }
.pj-num-detail__desc { font-size: 1.05rem; line-height: 1.75; color: #333; margin-bottom: 1.25rem; }
.pj-num-detail__traits { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.75rem; }
.pj-num-detail__trait { background: #f0e8ff; color: #3b1260; padding: .3rem .85rem; border-radius: 2rem; font-size: .85rem; font-weight: 600; }
.pj-num-detail__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; margin-bottom: 2rem; }
.pj-num-detail__block { background: #f8f5ff; border-radius: .75rem; padding: 1.25rem; }
.pj-num-detail__block h3 { font-family: var(--pj-font-serif); font-size: 1.1rem; color: #1a0535; margin: 0 0 .5rem; }
.pj-num-detail__block p { font-size: .92rem; line-height: 1.65; color: #444; margin: 0; }
.pj-num-detail__famous { list-style: none; padding: 0; margin: 0; }
.pj-num-detail__famous li { font-size: .92rem; color: #444; padding: .2rem 0; border-bottom: 1px dashed #ddd; }
.pj-num-detail__famous li:last-child { border-bottom: none; }
.pj-num-compat { margin-bottom: 2rem; }
.pj-num-compat__title { font-family: var(--pj-font-serif); font-size: 1.25rem; color: #1a0535; margin: 0 0 1rem; }
.pj-num-compat__grid { display: grid; grid-template-columns: repeat(9, 1fr); gap: .5rem; }
.pj-num-compat__cell { display: flex; flex-direction: column; align-items: center; padding: .75rem .25rem; border-radius: .5rem; font-size: .8rem; gap: .25rem; }
.pj-num-compat__cell--excellent { background: #d4edda; color: #155724; }
.pj-num-compat__cell--good { background: #fff3cd; color: #856404; }
.pj-num-compat__cell--fair { background: #f8d7da; color: #721c24; }
.pj-num-compat__num { font-size: 1.25rem; font-weight: 700; }
.pj-num-compat__lvl { font-size: .7rem; font-weight: 600; }
.pj-num-others { border-top: 1px solid #e8e0f0; padding-top: 1.5rem; }
.pj-num-others__title { font-size: 1rem; color: #555; margin: 0 0 .75rem; }
.pj-num-others__row { display: flex; gap: .5rem; flex-wrap: wrap; }
.pj-num-others__btn { width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; background: #f0e8ff; color: #3b1260; font-weight: 700; font-size: 1.1rem; border-radius: .5rem; text-decoration: none; transition: all .2s; }
.pj-num-others__btn:hover { background: #3b1260; color: var(--pj-gold); }
.pj-num-others__btn--active { background: var(--pj-gold); color: #1a0535; }
@media (max-width: 900px) {
  .pj-num-picker__grid { grid-template-columns: repeat(5, 1fr); }
  .pj-num-overview__grid { grid-template-columns: repeat(2, 1fr); }
  .pj-num-compat__grid { grid-template-columns: repeat(5, 1fr); }
}
@media (max-width: 640px) {
  .pj-num-hero__title { font-size: 2rem; }
  .pj-num-picker__grid { grid-template-columns: repeat(3, 1fr); }
  .pj-num-overview__grid { grid-template-columns: 1fr; }
  .pj-num-detail__grid { grid-template-columns: 1fr; }
  .pj-num-compat__grid { grid-template-columns: repeat(3, 1fr); }
  .pj-calc-success { flex-direction: column; text-align: center; }
}
@media (max-width: 400px) {
  .pj-num-picker__grid { grid-template-columns: repeat(3, 1fr); }
  .pj-num-picker__tag { display: none; }
}
