@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Plus+Jakarta+Sans:wght@600;700;800&display=swap');

/*
 * Bolne Ki Practice by Parul Arya, editorial blog edition.
 * This file ports the supplied Tailwind v4 design system into WordPress-ready CSS.
 * Color values intentionally use OKLCH tokens to stay consistent with the source system.
 */

:root {
  --radius: 0.625rem;
  --radius-sm: calc(var(--radius) - 4px);
  --radius-md: calc(var(--radius) - 2px);
  --radius-lg: var(--radius);
  --radius-xl: calc(var(--radius) + 4px);
  --radius-2xl: calc(var(--radius) + 8px);
  --radius-3xl: calc(var(--radius) + 12px);
  --radius-4xl: calc(var(--radius) + 16px);

  --background: oklch(0.16 0.03 260);
  --foreground: oklch(0.98 0.005 250);
  --card: oklch(0.21 0.035 260);
  --card-foreground: oklch(0.98 0.005 250);
  --popover: oklch(0.21 0.035 260);
  --popover-foreground: oklch(0.98 0.005 250);
  --primary: oklch(0.72 0.18 50);
  --primary-foreground: oklch(0.16 0.03 260);
  --secondary: oklch(0.26 0.035 260);
  --secondary-foreground: oklch(0.98 0.005 250);
  --muted: oklch(0.24 0.03 260);
  --muted-foreground: oklch(0.72 0.02 255);
  --accent: oklch(0.72 0.18 50);
  --accent-foreground: oklch(0.16 0.03 260);
  --destructive: oklch(0.577 0.245 27.325);
  --destructive-foreground: oklch(0.984 0.003 247.858);
  --border: oklch(0.3 0.03 260);
  --input: oklch(0.3 0.03 260);
  --ring: oklch(0.72 0.18 50);
  --chart-1: oklch(0.646 0.222 41.116);
  --chart-2: oklch(0.6 0.118 184.704);
  --chart-3: oklch(0.398 0.07 227.392);
  --chart-4: oklch(0.828 0.189 84.429);
  --chart-5: oklch(0.769 0.188 70.08);
  --brand-orange: oklch(0.72 0.18 50);
  --brand-orange-glow: oklch(0.78 0.18 55);
  --hero-bg: oklch(0.16 0.03 260);
  --grid-line: oklch(1 0 0 / 4%);
  --gradient-primary: linear-gradient(135deg, oklch(0.72 0.18 50), oklch(0.66 0.2 35));
  --shadow-glow: 0 0 60px oklch(0.72 0.18 50 / 35%);
  --shadow-card: 0 20px 60px -20px oklch(0 0 0 / 60%);
  --sidebar: oklch(0.984 0.003 247.858);
  --sidebar-foreground: oklch(0.129 0.042 264.695);
  --sidebar-primary: oklch(0.208 0.042 265.755);
  --sidebar-primary-foreground: oklch(0.984 0.003 247.858);
  --sidebar-accent: oklch(0.968 0.007 247.896);
  --sidebar-accent-foreground: oklch(0.208 0.042 265.755);
  --sidebar-border: oklch(0.929 0.013 255.508);
  --sidebar-ring: oklch(0.704 0.04 256.788);

  --surface-raised: oklch(0.24 0.036 260);
  --surface-glass: oklch(0.21 0.035 260 / 82%);
  --surface-deep: oklch(0.13 0.035 260);
  --surface-soft: oklch(0.26 0.035 260);
  --line-soft: oklch(1 0 0 / 8%);
  --line-strong: oklch(0.72 0.18 50 / 35%);
  --orange-soft: oklch(0.72 0.18 50 / 12%);
  --orange-ring: oklch(0.72 0.18 50 / 25%);
  --text-soft: oklch(0.86 0.012 255);
  --text-faint: oklch(0.72 0.02 255);
  --max: 1160px;
  --reading: 760px;
  --font-body: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-display: 'Plus Jakarta Sans', 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.dark {
  --background: oklch(0.129 0.042 264.695);
  --foreground: oklch(0.984 0.003 247.858);
  --card: oklch(0.208 0.042 265.755);
  --card-foreground: oklch(0.984 0.003 247.858);
  --popover: oklch(0.208 0.042 265.755);
  --popover-foreground: oklch(0.984 0.003 247.858);
  --primary: oklch(0.929 0.013 255.508);
  --primary-foreground: oklch(0.208 0.042 265.755);
  --secondary: oklch(0.279 0.041 260.031);
  --secondary-foreground: oklch(0.984 0.003 247.858);
  --muted: oklch(0.279 0.041 260.031);
  --muted-foreground: oklch(0.704 0.04 256.788);
  --accent: oklch(0.279 0.041 260.031);
  --accent-foreground: oklch(0.984 0.003 247.858);
  --destructive: oklch(0.704 0.191 22.216);
  --destructive-foreground: oklch(0.984 0.003 247.858);
  --border: oklch(1 0 0 / 10%);
  --input: oklch(1 0 0 / 15%);
  --ring: oklch(0.551 0.027 264.364);
  --chart-1: oklch(0.488 0.243 264.376);
  --chart-2: oklch(0.696 0.17 162.48);
  --chart-3: oklch(0.769 0.188 70.08);
  --chart-4: oklch(0.627 0.265 303.9);
  --chart-5: oklch(0.645 0.246 16.439);
  --sidebar: oklch(0.208 0.042 265.755);
  --sidebar-foreground: oklch(0.984 0.003 247.858);
  --sidebar-primary: oklch(0.488 0.243 264.376);
  --sidebar-primary-foreground: oklch(0.984 0.003 247.858);
  --sidebar-accent: oklch(0.279 0.041 260.031);
  --sidebar-accent-foreground: oklch(0.984 0.003 247.858);
  --sidebar-border: oklch(1 0 0 / 10%);
  --sidebar-ring: oklch(0.551 0.027 264.364);
}

* { box-sizing: border-box; border-color: var(--border); }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background-color: var(--background);
  color: var(--foreground);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(circle at 18% -8%, oklch(0.72 0.18 50 / 24%), oklch(0 0 0 / 0) 32%),
    radial-gradient(circle at 92% 4%, oklch(0.66 0.20 35 / 18%), oklch(0 0 0 / 0) 28%),
    radial-gradient(circle at 50% 120%, oklch(0.72 0.18 50 / 9%), oklch(0 0 0 / 0) 34%),
    var(--hero-bg);
}
body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-image:
    linear-gradient(var(--grid-line) 1px, oklch(0 0 0 / 0) 1px),
    linear-gradient(90deg, var(--grid-line) 1px, oklch(0 0 0 / 0) 1px);
  background-size: 60px 60px;
  mask-image: linear-gradient(180deg, oklch(0 0 0 / 100%), oklch(0 0 0 / 0%) 74%);
}
a { color: inherit; text-decoration: none; transition: color .18s ease, opacity .18s ease, transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease; }
a:hover { color: var(--brand-orange-glow); }
img { max-width: 100%; height: auto; display: block; }
button, input, select, textarea { font: inherit; }
ul, ol { padding-left: 1.35em; }
li { margin: .35em 0; }
p { margin: 0 0 1em; }
p:last-child { margin-bottom: 0; }
::selection { background: oklch(0.72 0.18 50 / 28%); color: var(--foreground); }

h1, h2, h3, h4 {
  font-family: var(--font-display);
  letter-spacing: -0.02em;
  color: var(--foreground);
}
.container { max-width: var(--max); margin: 0 auto; padding: 0 22px; }
.reading { max-width: var(--reading); margin: 0 auto; }
.bg-grid {
  background-image:
    linear-gradient(var(--grid-line) 1px, oklch(0 0 0 / 0) 1px),
    linear-gradient(90deg, var(--grid-line) 1px, oklch(0 0 0 / 0) 1px);
  background-size: 60px 60px;
}
.text-brand { color: var(--brand-orange); }
.bg-brand { background-color: var(--brand-orange); }
.gradient-brand { background: var(--gradient-primary); }
.gradient-text {
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  background-clip: text;
  color: oklch(0 0 0 / 0);
}
.shadow-glow { box-shadow: var(--shadow-glow); }
.shadow-card-soft { box-shadow: var(--shadow-card); }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid var(--line-soft);
  background: oklch(0.16 0.03 260 / 76%);
  backdrop-filter: saturate(160%) blur(16px);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 13px 0; }
.brand { display: inline-flex; align-items: center; gap: 12px; font-weight: 900; color: var(--foreground); letter-spacing: -.035em; line-height: 1.1; }
.brand:hover { color: var(--foreground); }
.brand-mark {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-2xl);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  color: var(--primary-foreground);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 22px;
  background: var(--gradient-primary);
  box-shadow: 0 0 34px oklch(0.72 0.18 50 / 24%);
}
.brand-copy { display: flex; flex-direction: column; gap: 1px; }
.brand-copy small { font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--muted-foreground); }
.brand-copy span { font-size: 16px; }
.custom-logo-link { display: flex; align-items: center; line-height: 0; }
.custom-logo { max-height: 58px; width: auto; border-radius: 0; }
.nav { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.nav ul { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.nav li { margin: 0; padding: 0; }
.nav a, .nav li a { font-size: 14px; font-weight: 800; color: var(--muted-foreground); }
.nav a:hover, .nav li a:hover { color: var(--foreground); }
.header-actions { display: flex; align-items: center; gap: 10px; }
.btn, .cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  padding: 10px 15px;
  border-radius: 999px;
  border: 1px solid var(--line-soft);
  background: oklch(0.26 0.035 260 / 72%);
  color: var(--foreground);
  font-size: 14px;
  font-weight: 900;
  line-height: 1.15;
  box-shadow: 0 12px 28px -18px oklch(0 0 0 / 80%);
  cursor: pointer;
  text-align: center;
}
.btn:hover, .cta:hover { background: oklch(0.3 0.035 260 / 92%); color: var(--foreground); border-color: var(--orange-ring); }
.btn-primary, .cta-primary, .nav .cta, .form-submit input {
  border: 0;
  color: var(--primary-foreground);
  background: var(--gradient-primary);
  box-shadow: 0 0 36px oklch(0.72 0.18 50 / 24%);
}
.btn-primary:hover, .cta-primary:hover, .nav .cta:hover, .form-submit input:hover { color: var(--primary-foreground); filter: saturate(1.06) brightness(1.04); transform: translateY(-1px); }
.btn-ghost { background: oklch(0.21 0.035 260 / 52%); box-shadow: none; }
.mobile-toggle { display: none; width: 44px; height: 44px; border: 1px solid var(--line-soft); background: var(--card); border-radius: var(--radius-2xl); padding: 0; align-items: center; justify-content: center; color: var(--foreground); }
.hamburger { display: flex; flex-direction: column; gap: 4px; }
.hamburger span { display: block; width: 19px; height: 2px; border-radius: 3px; background: var(--foreground); transition: transform .18s ease, opacity .18s ease; }
.mobile-toggle.is-open .hamburger span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.mobile-toggle.is-open .hamburger span:nth-child(2) { opacity: 0; }
.mobile-toggle.is-open .hamburger span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.site-main { padding: 0 0 68px; }
.blog-hero { position: relative; padding: 54px 0 34px; overflow: hidden; }
.blog-hero::before {
  content: "";
  position: absolute;
  inset: 42px auto auto 54%;
  width: min(560px, 70vw);
  height: min(560px, 70vw);
  transform: translateX(-12%);
  background: radial-gradient(circle, oklch(0.72 0.18 50 / 19%), oklch(0 0 0 / 0) 64%);
  filter: blur(2px);
  pointer-events: none;
}
.hero-grid { position: relative; display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(280px, .88fr); gap: 28px; align-items: center; }
.hero-card {
  padding: 28px;
  border-radius: var(--radius-4xl);
  border: 1px solid var(--line-soft);
  background: linear-gradient(180deg, oklch(0.21 0.035 260 / 88%), oklch(0.18 0.03 260 / 76%));
  box-shadow: var(--shadow-card);
  backdrop-filter: blur(10px);
  position: relative;
  overflow: hidden;
}
.hero-card::after {
  content: "";
  position: absolute;
  inset: -1px;
  pointer-events: none;
  border-radius: inherit;
  background: linear-gradient(135deg, oklch(0.72 0.18 50 / 24%), oklch(0 0 0 / 0) 42%, oklch(1 0 0 / 6%));
  mask: linear-gradient(oklch(0 0 0), oklch(0 0 0)) content-box, linear-gradient(oklch(0 0 0), oklch(0 0 0));
  mask-composite: exclude;
  padding: 1px;
}
.kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--brand-orange-glow);
  background: var(--orange-soft);
  border: 1px solid var(--orange-ring);
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  box-shadow: 0 0 32px oklch(0.72 0.18 50 / 12%);
}
.kicker::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--brand-orange); box-shadow: 0 0 18px oklch(0.72 0.18 50 / 62%); }
.hero-title, .single-title, .page-title { font-family: var(--font-display); font-weight: 800; color: var(--foreground); letter-spacing: -.025em; line-height: 1.08; margin: 14px 0 14px; }
.hero-title { font-size: clamp(40px, 5.75vw, 70px); max-width: 10.5ch; }
.hero-copy { font-size: 19px; color: var(--muted-foreground); max-width: 60ch; margin-bottom: 22px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 20px; }
.hero-actions .btn { min-height: 48px; padding: 12px 18px; }
.hero-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 24px; }
.stat-pill { padding: 14px; border-radius: var(--radius-3xl); background: oklch(0.24 0.036 260 / 80%); border: 1px solid var(--line-soft); box-shadow: 0 14px 30px -24px oklch(0 0 0 / 90%); }
.stat-pill strong { display: block; font-family: var(--font-display); font-size: 25px; line-height: 1; color: var(--foreground); }
.stat-pill span { display: block; color: var(--muted-foreground); font-size: 12px; font-weight: 800; margin-top: 4px; }
.hero-visual { position: relative; display: grid; gap: 14px; align-content: start; }
.hero-media-card {
  position: relative;
  min-height: 430px;
  border-radius: var(--radius-4xl);
  overflow: hidden;
  background: var(--surface-deep);
  border: 1px solid var(--line-soft);
  box-shadow: var(--shadow-card), var(--shadow-glow);
  isolation: isolate;
}
.hero-media-card::after { content: ""; position: absolute; inset: 16px; border: 1px solid oklch(1 0 0 / 16%); border-radius: calc(var(--radius-4xl) - 3px); pointer-events: none; z-index: 2; }
.hero-media { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 50% 32%; opacity: .92; filter: saturate(1.05) contrast(1.02); }
.hero-media-shade { position: absolute; inset: 0; background: linear-gradient(180deg, oklch(0.13 0.035 260 / 4%) 0%, oklch(0.13 0.035 260 / 18%) 38%, oklch(0.13 0.035 260 / 82%) 100%), radial-gradient(circle at 80% 0%, oklch(0.72 0.18 50 / 28%), oklch(0 0 0 / 0) 48%); z-index: 1; }
.hero-media-content { position: absolute; left: 28px; right: 28px; bottom: 28px; z-index: 3; padding: 18px; border-radius: var(--radius-3xl); background: oklch(0.16 0.03 260 / 70%); border: 1px solid oklch(1 0 0 / 14%); backdrop-filter: blur(10px); }
.hero-media-content .label { display: inline-flex; border-radius: 999px; padding: 6px 10px; color: var(--brand-orange-glow); background: var(--orange-soft); border: 1px solid var(--orange-ring); font-weight: 900; font-size: 12px; }
.hero-media-content h2 { font-family: var(--font-display); letter-spacing: -.04em; font-size: clamp(26px, 3vw, 36px); line-height: 1.05; margin: 12px 0 8px; color: var(--foreground); }
.hero-media-content p { color: var(--text-soft); margin: 0; }
.hero-media-content h2, .hero-media-content p { overflow-wrap: anywhere; }
.hero-proof-strip { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.visual-proof { padding: 14px 16px; background: oklch(0.21 0.035 260 / 86%); border: 1px solid var(--line-soft); border-radius: var(--radius-3xl); box-shadow: 0 16px 34px -24px oklch(0 0 0 / 90%); color: var(--foreground); font-weight: 900; min-width: 0; }
.visual-proof strong { display: block; font-family: var(--font-display); font-size: 17px; line-height: 1.1; letter-spacing: -.03em; }
.visual-proof span { display: block; color: var(--muted-foreground); font-size: 12px; font-weight: 800; margin-top: 4px; overflow-wrap: anywhere; }

.section { padding: 38px 0; }
.section-head { display: flex; align-items: end; justify-content: space-between; gap: 18px; margin-bottom: 20px; }
.section-head h2 { font-family: var(--font-display); font-size: clamp(28px, 3vw, 42px); letter-spacing: -.04em; line-height: 1.1; color: var(--foreground); margin: 10px 0 0; }
.section-head p { margin: 8px 0 0; color: var(--muted-foreground); max-width: 62ch; }
.grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 18px; }
.classroom-section { padding-top: 26px; }
.classroom-grid { display: grid; grid-template-columns: minmax(0, .86fr) minmax(360px, 1.14fr); gap: 26px; align-items: center; }
.classroom-copy { padding: 26px; border-radius: var(--radius-4xl); background: linear-gradient(180deg, oklch(0.23 0.036 260 / 92%), oklch(0.18 0.03 260 / 82%)); border: 1px solid var(--line-soft); box-shadow: var(--shadow-card); }
.classroom-copy h2 { font-family: var(--font-display); font-size: clamp(30px, 3.8vw, 48px); line-height: 1.05; letter-spacing: -.045em; margin: 14px 0 14px; }
.classroom-copy p { color: var(--muted-foreground); font-size: 17px; }
.inline-proof-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 20px; }
.inline-proof { padding: 14px; border-radius: var(--radius-3xl); border: 1px solid var(--line-soft); background: oklch(0.24 0.036 260 / 80%); }
.inline-proof strong { display: block; color: var(--foreground); font-family: var(--font-display); letter-spacing: -.03em; }
.inline-proof span { display: block; color: var(--muted-foreground); font-size: 12px; font-weight: 800; margin-top: 3px; }
.classroom-gallery { display: grid; grid-template-columns: repeat(8, 1fr); grid-auto-rows: 92px; gap: 12px; align-items: stretch; }
.classroom-photo { margin: 0; border-radius: var(--radius-3xl); overflow: hidden; border: 1px solid var(--line-soft); background: var(--card); box-shadow: var(--shadow-card); }
.classroom-photo img { width: 100%; height: 100%; object-fit: cover; }
.classroom-photo.large { grid-column: span 5; grid-row: span 3; }
.classroom-photo.tall { grid-column: span 3; grid-row: span 4; }
.classroom-photo:not(.large):not(.tall) { grid-column: span 3; grid-row: span 2; }
.classroom-photo.portrait { grid-column: span 3; grid-row: span 2; }
.classroom-photo.large img { object-position: 50% 42%; }
.classroom-photo.tall img { object-position: 50% 48%; }
.classroom-photo.portrait img { object-position: 50% 18%; }
.card { background: var(--surface-glass); border: 1px solid var(--line-soft); border-radius: var(--radius-3xl); box-shadow: var(--shadow-card); overflow: hidden; backdrop-filter: blur(10px); }
.card.pad { padding: 20px; }
.card:hover { border-color: var(--orange-ring); }
.path-card { grid-column: span 4; padding: 24px; background: linear-gradient(180deg, oklch(0.23 0.036 260 / 92%), oklch(0.18 0.03 260 / 84%)); border: 1px solid var(--line-soft); border-radius: var(--radius-4xl); box-shadow: var(--shadow-card); position: relative; overflow: hidden; }
.path-card::after { content: ""; position: absolute; inset: auto -18% -42% auto; width: 180px; height: 180px; background: radial-gradient(circle, oklch(0.72 0.18 50 / 18%), oklch(0 0 0 / 0) 68%); }
.path-card .icon { width: 46px; height: 46px; border-radius: var(--radius-2xl); display: grid; place-items: center; background: var(--gradient-primary); color: var(--primary-foreground); font-family: var(--font-display); font-weight: 900; box-shadow: 0 0 30px oklch(0.72 0.18 50 / 24%); }
.path-card h3 { font-family: var(--font-display); font-size: 22px; letter-spacing: -.03em; margin: 16px 0 8px; color: var(--foreground); }
.path-card p { color: var(--muted-foreground); }
.path-card a { display: inline-flex; margin-top: 10px; color: var(--brand-orange-glow); font-weight: 900; }
.path-card a:hover { color: var(--foreground); }

.post-grid { row-gap: 22px; }
.post-grid .post-card-wrap { grid-column: span 6; }
.post-card { height: 100%; background: linear-gradient(180deg, oklch(0.22 0.035 260 / 92%), oklch(0.18 0.03 260 / 90%)); border: 1px solid var(--line-soft); border-radius: var(--radius-4xl); box-shadow: var(--shadow-card); overflow: hidden; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.post-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card), var(--shadow-glow); border-color: var(--orange-ring); }
.post-card .thumb { display: block; overflow: hidden; background: radial-gradient(circle at 22% 0%, oklch(0.72 0.18 50 / 20%), var(--surface-soft)); border-bottom: 1px solid var(--line-soft); }
.post-card .thumb img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; transition: transform .24s ease, opacity .24s ease; opacity: .94; }
.post-card:hover .thumb img { transform: scale(1.02); opacity: 1; }
.post-card .post-pad { padding: 18px 20px 22px; }
.meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; color: var(--muted-foreground); font-size: 13px; }
.badge { display: inline-flex; align-items: center; gap: 7px; border-radius: 999px; padding: 6px 10px; background: var(--orange-soft); border: 1px solid var(--orange-ring); color: var(--brand-orange-glow); font-size: 12px; font-weight: 900; }
.badge.pink { background: oklch(0.26 0.035 260 / 80%); border-color: var(--line-soft); color: var(--text-soft); }
.post-card h2 { font-family: var(--font-display); font-size: 23px; line-height: 1.15; letter-spacing: -.035em; color: var(--foreground); margin: 12px 0 9px; }
.post-card h2 a:hover { color: var(--brand-orange-glow); }
.post-card p { color: var(--muted-foreground); margin: 0; }
.read-more { display: inline-flex; margin-top: 14px; font-weight: 900; color: var(--brand-orange-glow); }

.layout { margin-top: 24px; }
.layout-main { min-width: 0; }
.layout-aside .subscribe-card, .layout-aside .lead-card { margin: 0 0 16px; max-width: none; }
.sidebar-float { position: static; }
.layout-three { display: block; }

.single-wrap { padding-top: 30px; }
.single-floating-layout { max-width: 1320px; margin: 0 auto; padding: 0 22px; display: block; }
.single-main-col { min-width: 0; }
.single-rail { display: none; }
.single-rail-sticky { position: sticky; top: 92px; }
.single-header { padding: 10px 0 12px; }
.single-title { font-size: clamp(38px, 5vw, 62px); }
.single-meta { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; color: var(--muted-foreground); font-size: 14px; font-weight: 700; }
.single-thumb { margin: 20px auto 0; overflow: hidden; border-radius: var(--radius-4xl); box-shadow: var(--shadow-card); border: 1px solid var(--line-soft); background: var(--card); }
.single-thumb img { width: 100%; height: auto; border-radius: 0; }
.content { margin-top: 24px; font-size: 18px; color: var(--text-soft); }
.content h2, .content h3, .content h4 { font-family: var(--font-display); color: var(--foreground); letter-spacing: -.035em; line-height: 1.15; }
.content h2 { font-size: 32px; margin: 34px 0 12px; }
.content h3 { font-size: 24px; margin: 28px 0 10px; }
.content p { margin: 16px 0; }
.content a { color: var(--brand-orange-glow); font-weight: 800; text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.content blockquote { margin: 24px 0; padding: 18px 20px; border: 1px solid var(--orange-ring); border-left: 5px solid var(--brand-orange); border-radius: var(--radius-3xl); background: linear-gradient(180deg, oklch(0.22 0.035 260 / 92%), oklch(0.18 0.03 260 / 84%)); color: var(--foreground); font-weight: 700; }
.content img, .content figure { border-radius: var(--radius-3xl); margin-left: auto; margin-right: auto; }
.content figure { margin-top: 24px; margin-bottom: 24px; }
.content table { width: 100%; border-collapse: separate; border-spacing: 0; margin: 24px 0; border: 1px solid var(--line-soft); border-radius: var(--radius-3xl); overflow: hidden; background: var(--card); }
.content th, .content td { padding: 12px 14px; border-bottom: 1px solid var(--line-soft); vertical-align: top; }
.content th { text-align: left; background: var(--surface-soft); color: var(--foreground); font-weight: 900; }
.content tr:last-child td { border-bottom: none; }
.content code { background: var(--surface-soft); padding: 2px 7px; border-radius: var(--radius-lg); color: var(--brand-orange-glow); }
.content pre { background: var(--surface-deep); color: var(--foreground); padding: 16px; border-radius: var(--radius-2xl); overflow: auto; border: 1px solid var(--line-soft); }
.pager { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 28px; }
.pager a { display: block; padding: 14px 16px; border-radius: var(--radius-2xl); background: var(--card); border: 1px solid var(--line-soft); font-weight: 900; color: var(--foreground); box-shadow: 0 12px 30px -20px oklch(0 0 0 / 80%); }
.pager a:hover { background: var(--surface-soft); border-color: var(--orange-ring); color: var(--brand-orange-glow); }

.lead-card, .subscribe-card { max-width: var(--reading); margin: 22px auto 0; padding: 20px; border-radius: var(--radius-4xl); border: 1px solid var(--line-soft); box-shadow: var(--shadow-card); background: linear-gradient(180deg, oklch(0.23 0.036 260 / 92%), oklch(0.18 0.03 260 / 86%)); }
.lead-card .top, .subscribe-card .top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 12px; }
.lead-card h3, .subscribe-card h3 { font-family: var(--font-display); font-size: 21px; line-height: 1.15; color: var(--foreground); letter-spacing: -.035em; margin: 0; }
.lead-card p, .subscribe-card p { color: var(--muted-foreground); margin: 6px 0 0; }
.lead-form { display: grid; grid-template-columns: repeat(12, 1fr); gap: 12px; margin-top: 12px; }
.field { grid-column: span 6; }
.field.full { grid-column: span 12; }
label { display: block; font-size: 12px; font-weight: 900; letter-spacing: .01em; color: var(--muted-foreground); margin-bottom: 6px; }
input, select, textarea { width: 100%; padding: 12px 13px; border-radius: var(--radius-2xl); border: 1px solid var(--input); background: oklch(0.16 0.03 260 / 84%); color: var(--foreground); outline: none; }
textarea { min-height: 96px; resize: vertical; }
input::placeholder, textarea::placeholder { color: oklch(0.72 0.02 255 / 72%); }
input:focus, select:focus, textarea:focus { border-color: var(--ring); box-shadow: 0 0 0 4px oklch(0.72 0.18 50 / 14%); }
.submit { grid-column: span 12; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.status { font-size: 13px; color: var(--muted-foreground); font-weight: 800; }
.subscribe-form { margin-top: 12px; }
.subscribe-form .row { display: flex; gap: 12px; flex-wrap: wrap; }
.subscribe-form .field { flex: 1; min-width: 150px; }
.subscribe-form .row + .row { margin-top: 12px; }
.consent { display: flex; gap: 10px; align-items: flex-start; margin-top: 10px; font-size: 12px; color: var(--muted-foreground); font-weight: 700; }
.consent input { width: auto; margin-top: 3px; accent-color: var(--brand-orange); }
.search-form { display: flex; gap: 10px; margin-top: 16px; }
.search-form input { min-height: 46px; }
.search-form button { flex: 0 0 auto; }

.mobile-actionbar { display: none; position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 60; gap: 10px; padding: 10px; border: 1px solid var(--line-soft); background: oklch(0.16 0.03 260 / 92%); backdrop-filter: blur(12px); border-radius: var(--radius-3xl); box-shadow: var(--shadow-card); }
.mobile-actionbar a { flex: 1; }

.comments-area { margin-top: 28px; }
.comments-card { padding: 20px; border-radius: var(--radius-4xl); background: var(--card); border: 1px solid var(--line-soft); box-shadow: var(--shadow-card); }
.comments-title, .comment-reply-title { font-family: var(--font-display); font-size: 22px; letter-spacing: -.035em; color: var(--foreground); margin: 0 0 14px; }
.comment-list, .comment-list .children { list-style: none; margin: 0; padding: 0; }
.comment-list > li { margin-top: 14px; }
.comment-body { border: 1px solid var(--line-soft); border-radius: var(--radius-2xl); padding: 14px 16px; background: var(--surface-raised); }
.comment-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; flex-wrap: wrap; }
.comment-author { display: flex; align-items: center; gap: 10px; font-weight: 900; color: var(--foreground); }
.comment-author .avatar { border-radius: 999px; }
.comment-metadata { margin-left: auto; font-size: 12px; color: var(--muted-foreground); }
.reply a { display: inline-flex; padding: 8px 11px; border: 1px solid var(--line-soft); border-radius: 999px; font-size: 13px; font-weight: 900; color: var(--muted-foreground); }
.comment-form { display: grid; grid-template-columns: repeat(12, 1fr); gap: 12px; margin-top: 14px; }
.comment-form .comment-notes, .comment-form .logged-in-as { grid-column: span 12; color: var(--muted-foreground); }
.comment-form-comment, .comment-form-author, .comment-form-email, .comment-form-url { margin: 0; }
.comment-form-comment { grid-column: span 12; }
.comment-form-author, .comment-form-email, .comment-form-url { grid-column: span 4; }
.form-submit { grid-column: span 12; margin: 0; }
.form-submit input { display: inline-flex; min-height: 42px; padding: 10px 16px; border-radius: 999px; font-weight: 900; cursor: pointer; width: auto; }

.pagination, .nav-links { display: flex; gap: 8px; align-items: center; justify-content: center; flex-wrap: wrap; margin-top: 24px; }
.page-numbers { display: inline-flex; min-width: 40px; height: 40px; align-items: center; justify-content: center; border-radius: 999px; border: 1px solid var(--line-soft); background: var(--card); font-weight: 900; color: var(--muted-foreground); }
.page-numbers.current { background: var(--gradient-primary); color: var(--primary-foreground); border: 0; }
.page-numbers:hover { background: var(--surface-soft); color: var(--foreground); border-color: var(--orange-ring); }

.site-footer { border-top: 1px solid var(--line-soft); padding: 34px 0; color: var(--muted-foreground); font-size: 14px; background: oklch(0.13 0.035 260 / 72%); }
.footer-inner { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; align-items: center; }
.footer-brand { font-weight: 900; color: var(--foreground); letter-spacing: -.03em; }
.footer-links { display: flex; gap: 14px; flex-wrap: wrap; list-style: none; margin: 0; padding: 0; }
.footer-links li { margin: 0; }
.footer-links a { font-weight: 900; color: var(--muted-foreground); }
.footer-links a:hover { color: var(--brand-orange-glow); }

.page-wrap { padding: 34px 0; }
.page-card { padding: 28px; border-radius: var(--radius-4xl); background: var(--card); border: 1px solid var(--line-soft); box-shadow: var(--shadow-card); }
.not-found { text-align: center; padding: 70px 0; }
.not-found h1 { font-family: var(--font-display); font-size: clamp(42px, 7vw, 80px); color: var(--foreground); letter-spacing: -.05em; margin: 0 0 10px; }
.screen-reader-text { position: absolute!important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

@media (min-width: 1180px) {
  .layout-three { display: grid; grid-template-columns: 260px minmax(0, 1fr) 300px; gap: 24px; align-items: start; }
  .sidebar-float { position: sticky; top: 92px; }
  .single-floating-layout { display: grid; grid-template-columns: minmax(0, var(--reading)) 320px; gap: 38px; align-items: start; justify-content: center; }
  .single-rail { display: block; }
  .single-mobile-cards { display: none; }
  .after-comments-lead { display: none; }
}
@media (max-width: 1179px) {
  .single-mobile-cards { display: block; margin-top: 22px; }
  .pager { grid-template-columns: 1fr; }
  .mobile-actionbar { display: flex; }
  body { padding-bottom: 86px; }
}
@media (max-width: 940px) {
  .nav { display: none; }
  .mobile-toggle { display: inline-flex; }
  .header-inner { align-items: flex-start; }
  .nav.is-open { display: flex; flex-direction: column; align-items: flex-start; width: 100%; position: absolute; left: 0; right: 0; top: 70px; padding: 16px 22px 20px; background: oklch(0.16 0.03 260 / 96%); border-bottom: 1px solid var(--line-soft); box-shadow: var(--shadow-card); }
  .nav.is-open ul { flex-direction: column; align-items: flex-start; }
  .header-actions { width: 100%; flex-direction: column; align-items: stretch; }
  .nav.is-open .cta, .nav.is-open .btn { width: 100%; }
}
@media (max-width: 880px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-visual { min-height: auto; }
  .hero-media-card { min-height: 390px; }
  .hero-stats { grid-template-columns: 1fr 1fr; }
  .stat-pill:last-child { grid-column: span 2; }
  .classroom-grid { grid-template-columns: 1fr; }
  .classroom-gallery { grid-auto-rows: 82px; }
  .path-card { grid-column: span 12; }
  .post-grid .post-card-wrap { grid-column: span 12; }
}
@media (max-width: 760px) {
  .comment-form-author, .comment-form-email, .comment-form-url { grid-column: span 12; }
  .comment-metadata { margin-left: 0; }
}
@media (max-width: 680px) {
  .field { grid-column: span 12; }
  .submit .btn { width: 100%; }
  .search-form { flex-direction: column; }
  .search-form button { width: 100%; }
}
@media (max-width: 560px) {
  .blog-hero { padding-top: 34px; }
  .hero-card { padding: 20px; border-radius: var(--radius-4xl); }
  .hero-title { font-size: 40px; }
  .hero-copy { font-size: 16px; }
  .hero-stats { grid-template-columns: 1fr; }
  .stat-pill:last-child { grid-column: auto; }
  .section-head { display: block; }
  .hero-proof-strip, .inline-proof-grid { grid-template-columns: 1fr; }
  .hero-media-card { min-height: 360px; }
  .hero-media-content { left: 18px; right: 18px; bottom: 18px; padding: 15px; }
  .classroom-gallery { grid-template-columns: 1fr; grid-auto-rows: auto; }
  .classroom-photo, .classroom-photo.large, .classroom-photo.tall, .classroom-photo.portrait, .classroom-photo:not(.large):not(.tall) { grid-column: auto; grid-row: auto; }
  .classroom-photo img { aspect-ratio: 4 / 3; }
}

/* v1.3 editorial identity: Bolne Ki Practice */
.journal-hero .hero-grid { align-items: stretch; }
.journal-card { display: flex; flex-direction: column; justify-content: center; }
.journal-masthead {
  display: inline-flex;
  width: fit-content;
  margin-top: 18px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid oklch(1 0 0 / 10%);
  background: oklch(0.98 0.005 250 / 6%);
  color: var(--foreground);
  font-family: var(--font-display);
  font-weight: 900;
  letter-spacing: -.03em;
}
.hero-note {
  margin: -7px 0 0;
  max-width: 58ch;
  color: var(--text-soft);
  font-size: 16px;
  font-weight: 700;
}
.editorial-card .hero-media-content { max-width: 92%; }
.form-consent { grid-column: span 12; }
.consent {
  padding: 10px 12px;
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-2xl);
  background: oklch(0.16 0.03 260 / 52%);
}
.consent span { line-height: 1.45; }
.comment-consent { grid-column: span 12; margin: 0; }
.comment-consent label { display: flex; gap: 10px; align-items: flex-start; margin: 0; color: var(--muted-foreground); }
.comment-consent input { flex: 0 0 auto; margin-top: 4px; width: auto; accent-color: var(--brand-orange); }


/* v1.4 brand logo + audio lesson support */
.audio-badge { background: oklch(0.72 0.18 50 / 14%); border-color: var(--orange-ring); color: var(--brand-orange-glow); }

.brand-logo-wrap {
  width: 52px;
  height: 52px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  background: oklch(0 0 0 / 45%);
  border: 1px solid oklch(1 0 0 / 14%);
  box-shadow: 0 0 34px oklch(0.72 0.18 50 / 22%);
  overflow: hidden;
}
.brand-logo-img {
  width: 48px;
  height: 48px;
  object-fit: contain;
}
.custom-brand { gap: 10px; }
.custom-brand .custom-logo-link {
  width: 52px;
  height: 52px;
  border-radius: 999px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: oklch(0 0 0 / 45%);
  border: 1px solid oklch(1 0 0 / 14%);
  box-shadow: 0 0 34px oklch(0.72 0.18 50 / 22%);
}
.custom-logo {
  max-height: 50px;
  max-width: 50px;
  width: auto;
  height: auto;
  border-radius: 999px;
}
.journal-masthead {
  align-items: center;
  gap: 10px;
}
.journal-masthead img {
  width: 34px;
  height: 34px;
  object-fit: contain;
  border-radius: 999px;
  flex: 0 0 auto;
}
.journal-masthead span {
  display: inline-flex;
}
.footer-brand-line {
  display: flex;
  align-items: center;
  gap: 12px;
  max-width: 650px;
}
.footer-brand-line img {
  width: 46px;
  height: 46px;
  object-fit: contain;
  border-radius: 999px;
  flex: 0 0 auto;
  box-shadow: 0 0 26px oklch(0.72 0.18 50 / 18%);
}
.audio-lesson-card {
  margin: 28px 0;
  padding: 18px;
  border-radius: var(--radius-4xl);
  border: 1px solid var(--orange-ring);
  background:
    radial-gradient(circle at 8% 0%, oklch(0.72 0.18 50 / 18%), oklch(0 0 0 / 0) 34%),
    linear-gradient(180deg, oklch(0.23 0.036 260 / 94%), oklch(0.17 0.03 260 / 90%));
  box-shadow: var(--shadow-card), 0 0 44px oklch(0.72 0.18 50 / 12%);
}
.audio-lesson-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}
.audio-kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border-radius: 999px;
  padding: 6px 10px;
  background: var(--orange-soft);
  border: 1px solid var(--orange-ring);
  color: var(--brand-orange-glow);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.audio-kicker::before {
  content: "▶";
  font-size: 10px;
}
.audio-lesson-card h3 {
  margin: 11px 0 7px;
  font-family: var(--font-display);
  letter-spacing: -.035em;
  font-size: clamp(22px, 2.6vw, 30px);
}
.audio-lesson-card p {
  margin: 0;
  color: var(--muted-foreground);
  font-weight: 700;
}
.audio-lesson-player {
  display: block;
  width: 100%;
  min-height: 42px;
  border-radius: 999px;
  background: oklch(0.98 0.005 250);
}
.content .audio-lesson-card,
.reading .audio-lesson-card {
  max-width: 100%;
}
@media (max-width: 560px) {
  .brand-copy small { font-size: 9px; }
  .brand-copy span { font-size: 14px; }
  .brand-logo-wrap,
  .custom-brand .custom-logo-link {
    width: 44px;
    height: 44px;
  }
  .brand-logo-img,
  .custom-logo {
    width: 40px;
    height: 40px;
  }
  .footer-brand-line {
    align-items: flex-start;
  }
  .audio-lesson-card {
    padding: 15px;
  }
}


/* v1.5 final polish: official logo frame, Hindi readability, lead dashboard controls */
.brand-copy span em,
.journal-masthead span em {
  display: block;
  margin-top: 2px;
  font-style: normal;
  font-family: 'Inter', sans-serif;
  font-size: .72em;
  font-weight: 900;
  letter-spacing: 0;
  color: var(--brand-orange-glow);
}
.header-inner { padding: 10px 0; }
.brand { gap: 13px; letter-spacing: -.02em; }
.brand-copy { min-width: 0; }
.brand-copy small { line-height: 1.05; }
.brand-copy span { line-height: 1.05; }
.brand-logo-wrap,
.custom-brand .custom-logo-link,
.footer-logo-frame {
  background: oklch(0.98 0.005 250);
  border: 3px solid oklch(0.98 0.005 250);
  outline: 1px solid oklch(0.72 0.18 50 / 36%);
}
.brand-logo-img,
.custom-logo {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: cover;
  border-radius: 999px;
}
.custom-logo-link img { border-radius: 999px; }
.journal-masthead {
  gap: 11px;
  padding: 9px 15px 9px 10px;
  align-items: center;
}
.journal-masthead img {
  width: 42px;
  height: 42px;
  object-fit: cover;
  background: oklch(0.98 0.005 250);
  border: 2px solid oklch(0.98 0.005 250);
  box-shadow: 0 0 24px oklch(0.72 0.18 50 / 18%);
}
.journal-masthead span {
  display: block;
  line-height: 1.05;
}
.hero-title,
.classroom-copy h2,
.section-head h2,
.single-title,
.page-title {
  word-spacing: .04em;
}
.classroom-grid { align-items: stretch; }
.classroom-copy { display: flex; flex-direction: column; justify-content: center; }
.classroom-gallery { min-height: 420px; }
.classroom-photo { transform: translateZ(0); }
.footer-brand-line img {
  background: oklch(0.98 0.005 250);
  border: 3px solid oklch(0.98 0.005 250);
  outline: 1px solid oklch(0.72 0.18 50 / 34%);
  object-fit: cover;
}
.wp-list-table .column-lead_message,
.wp-list-table .column-lead_page_url,
.wp-list-table .column-subscriber_page_url {
  max-width: 190px;
}
@media (max-width: 560px) {
  .hero-title { max-width: none; }
  .journal-masthead { width: 100%; }
  .journal-masthead img { width: 38px; height: 38px; }
  .brand-copy span em { display: none; }
}

/* v1.6 WhatsApp access + audio dashboard polish */
.whatsapp-cta,
.whatsapp-btn,
.whatsapp-link,
.footer-whatsapp,
.whatsapp-float {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.whatsapp-cta svg,
.whatsapp-btn svg,
.whatsapp-link svg,
.footer-whatsapp svg,
.whatsapp-float svg {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  fill: currentColor;
}
.whatsapp-cta {
  min-height: 42px;
  padding: 9px 14px;
  border-radius: 999px;
  border: 1px solid oklch(0.72 0.18 145 / 32%);
  background: oklch(0.62 0.16 145 / 14%);
  color: oklch(0.82 0.17 145);
  font-size: 14px;
  font-weight: 900;
}
.whatsapp-cta:hover,
.whatsapp-btn:hover,
.whatsapp-link:hover,
.footer-whatsapp:hover,
.whatsapp-float:hover {
  color: oklch(0.88 0.17 145);
  border-color: oklch(0.82 0.17 145 / 48%);
}
.whatsapp-btn {
  border-color: oklch(0.72 0.18 145 / 32%);
  background: oklch(0.62 0.16 145 / 14%);
  color: oklch(0.82 0.17 145);
}
.direct-chat {
  grid-column: span 12;
  margin-top: -4px;
}
.whatsapp-link {
  width: fit-content;
  border: 1px solid oklch(0.72 0.18 145 / 30%);
  border-radius: 999px;
  padding: 9px 12px;
  background: oklch(0.62 0.16 145 / 10%);
  color: oklch(0.82 0.17 145);
  font-size: 13px;
  font-weight: 900;
}
.footer-whatsapp svg { width: 16px; height: 16px; }
.whatsapp-float {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 60;
  min-height: 48px;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid oklch(0.72 0.18 145 / 34%);
  background: oklch(0.22 0.08 145 / 94%);
  color: oklch(0.96 0.04 145);
  font-weight: 900;
  box-shadow: 0 16px 46px -16px oklch(0 0 0 / 84%), 0 0 34px oklch(0.72 0.18 145 / 18%);
  backdrop-filter: blur(12px);
}
.whatsapp-float svg { width: 21px; height: 21px; }
@media (max-width: 760px) {
  .whatsapp-float span { display: none; }
  .whatsapp-float { width: 52px; height: 52px; padding: 0; }
  .header-actions .whatsapp-cta span { display: none; }
}


/* v1.7 gallery alignment + roman Hindi copy cleanup */
.classroom-grid {
  grid-template-columns: minmax(0, .88fr) minmax(420px, 1.12fr);
  align-items: center;
}
.classroom-gallery {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-template-rows: repeat(5, 86px);
  grid-auto-rows: 86px;
  gap: 12px;
  min-height: auto;
  align-items: stretch;
}
.classroom-photo.large {
  grid-column: 1 / 9;
  grid-row: 1 / 4;
}
.classroom-photo.tall {
  grid-column: 9 / 13;
  grid-row: 1 / 5;
}
.classroom-photo:not(.large):not(.tall):not(.portrait) {
  grid-column: 1 / 5;
  grid-row: 4 / 6;
}
.classroom-photo.portrait {
  grid-column: 5 / 9;
  grid-row: 4 / 6;
}
.classroom-photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.classroom-photo.large img { object-position: 50% 44%; }
.classroom-photo.tall img { object-position: 50% 45%; }
.classroom-photo:not(.large):not(.tall):not(.portrait) img { object-position: 50% 52%; }
.classroom-photo.portrait img { object-position: 50% 18%; }
.brand-copy span em,
.journal-masthead span em { display: none; }
@media (max-width: 980px) {
  .classroom-grid { grid-template-columns: 1fr; }
  .classroom-gallery { grid-template-rows: repeat(5, 76px); grid-auto-rows: 76px; }
}
@media (max-width: 560px) {
  .classroom-gallery { grid-template-columns: 1fr; grid-template-rows: none; grid-auto-rows: auto; }
  .classroom-photo,
  .classroom-photo.large,
  .classroom-photo.tall,
  .classroom-photo.portrait,
  .classroom-photo:not(.large):not(.tall):not(.portrait) {
    grid-column: auto;
    grid-row: auto;
  }
  .classroom-photo img { aspect-ratio: 4 / 3; height: auto; }
  .classroom-photo.tall img,
  .classroom-photo.portrait img { aspect-ratio: 4 / 3; }
}

/* v1.8 logo visibility + standalone blog lead-gen cleanup */
.brand-logo-wrap,
.custom-brand .custom-logo-link {
  width: 56px;
  height: 56px;
  background: oklch(0.98 0.005 250);
  border: 1px solid oklch(0.98 0.005 250);
  outline: 1px solid oklch(0.72 0.18 50 / 42%);
  box-shadow: 0 0 30px oklch(0.72 0.18 50 / 18%);
}
.brand-logo-img,
.custom-logo {
  width: 108%;
  height: 108%;
  max-width: none;
  max-height: none;
  object-fit: cover;
  border-radius: 999px;
}
.journal-masthead img,
.footer-brand-line img {
  object-fit: cover;
  transform: scale(1.08);
  border-width: 1px;
}
.footer-full-site-note {
  margin: 14px 0 0;
  max-width: 720px;
  color: var(--muted-foreground);
  font-weight: 700;
  line-height: 1.55;
}
.footer-full-site-note a {
  color: var(--brand-orange-glow);
  font-weight: 950;
  text-decoration: none;
}
.footer-full-site-note a:hover { text-decoration: underline; }
.compact-section-head { max-width: 780px; }
.utility-grid .path-card.no-link { min-height: 100%; }
.utility-grid .path-card.no-link p { margin-bottom: 0; }
#demo-form { scroll-margin-top: 110px; }
#latest-posts { scroll-margin-top: 110px; }
@media (max-width: 560px) {
  .brand-logo-wrap,
  .custom-brand .custom-logo-link { width: 46px; height: 46px; }
  .brand-logo-img,
  .custom-logo { width: 110%; height: 110%; }
}
