/*
Theme Name:     Kalpana Makeovers Child
Theme URI:      https://kalpanamakeovers.com
Description:    Custom Kadence child theme for Kalpana Makeovers, Visakhapatnam. Bridal makeup studio and academy.
Author:         Flashcloud
Author URI:     https://flashcloud.com
Template:       kadence
Version:        1.0.0
Text Domain:    kalpana-child
*/

/* ============================================================
   1. TOKENS — locked palette + type + scale + spacing + radius
   ============================================================ */
:root {
  /* Palette */
  --km-coral: #F06F40;
  --km-coral-deep: #C9531E;
  --km-coral-soft: #FBE3D6;
  --km-gold: #C9A14F;
  --km-gold-deep: #A07F35;
  --km-paper: #FBF6EE;
  --km-paper-2: #F3EBDA;
  --km-paper-3: #ECE1CB;
  --km-ink: #3D2918;
  --km-ink-soft: #6B523E;
  --km-mute: #A28D7C;
  --km-line: rgba(61,41,24,0.12);
  --km-line-strong: rgba(61,41,24,0.22);
  --km-shadow-card: 0 10px 28px -16px rgba(61,41,24,0.18), 0 2px 6px -2px rgba(61,41,24,0.08);
  --km-shadow-photo: 0 40px 80px -30px rgba(61,41,24,0.30), 0 0 0 1px rgba(61,41,24,0.04);

  /* Type pair: Fraunces (display) + Inter (body) */
  --km-serif: "Fraunces", "Georgia", serif;
  --km-sans: "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;

  /* Scale */
  --km-h1: clamp(2.8rem, 5.4vw, 4.4rem);
  --km-h2: clamp(2.0rem, 3.6vw, 3.0rem);
  --km-h3: clamp(1.35rem, 2.2vw, 1.7rem);
  --km-h4: 1.15rem;
  --km-body: clamp(1rem, 1.2vw, 1.125rem);
  --km-small: 0.875rem;
  --km-eyebrow: 0.78rem;
  --km-lh-tight: 1.1;
  --km-lh-normal: 1.6;

  /* Spacing */
  --km-s-1: 0.5rem;
  --km-s-2: 1rem;
  --km-s-3: 1.5rem;
  --km-s-4: 2.5rem;
  --km-s-5: 4rem;
  --km-s-6: 6rem;
  --km-section-y: clamp(3rem, 5vw, 4.5rem);
  --km-gutter: clamp(1.25rem, 3vw, 2.5rem);

  /* Radius */
  --km-r-sm: 6px;
  --km-r-md: 12px;
  --km-r-lg: 20px;
  --km-r-pill: 999px;

  /* Container */
  --km-max: 1240px;
  --km-max-wide: 1360px;

  /* Sticky band (Flashcloud sticky pattern) */
  --km-band-h: 0px;
}

/* ============================================================
   2. RESET + base layer
   ============================================================ */
html { scroll-behavior: smooth; }
body, body.wp-singular, body.home, body.archive, body.search, body.blog, body.error404 {
  background: var(--km-paper) !important;
  color: var(--km-ink) !important;
  font-family: var(--km-sans);
  font-size: var(--km-body);
  line-height: var(--km-lh-normal);
  -webkit-font-smoothing: antialiased;
}

/* Kill Kadence's white content frame + boxed wrapper */
.wp-site-blocks, .entry-content, .content-container, .site-container,
.content-area, .site-content, #primary, #main {
  background: transparent !important;
}
.content-area { margin: 0 !important; }
.entry-hero.page-hero-section { display: none !important; }

/* Hide page titles on pages (NOT bare .entry-title — that breaks blog loop) */
.page .entry-title, .single-page .entry-title { display: none !important; }
body.page .entry-header { display: none !important; }

/* Headings */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--km-serif);
  font-weight: 600;
  color: var(--km-ink);
  line-height: var(--km-lh-tight);
  letter-spacing: -0.005em;
}
h1 { font-size: var(--km-h1); font-weight: 700; letter-spacing: -0.015em; }
h2 { font-size: var(--km-h2); font-weight: 700; letter-spacing: -0.01em; }
h3 { font-size: var(--km-h3); }
h4 { font-size: var(--km-h4); font-family: var(--km-sans); font-weight: 600; }

p { color: var(--km-ink); }
a { color: var(--km-coral-deep); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
a:hover { color: var(--km-coral); }

/* ============================================================
   3. Section system
   ============================================================ */
.km-section {
  position: relative;
  padding: var(--km-section-y) var(--km-gutter);
  overflow: hidden;
}
.km-section--paper { background: var(--km-paper); }
.km-section--paper-2 { background: var(--km-paper-2); }
.km-section--coral { background: var(--km-coral); color: var(--km-paper); }
.km-section--coral h1, .km-section--coral h2, .km-section--coral h3 { color: var(--km-paper); }
.km-section--coral p { color: rgba(251,246,238,0.92); }

/* Sibling spacing: when two same-bg paper sections sit next to each other,
   don't double-pad. The second one keeps only half its top padding.
   Coral / paper-2 transitions retain full padding so the colour break reads. */
.km-section--paper + .km-section--paper { padding-top: calc(var(--km-section-y) * 0.4); }
.km-section--paper-2 + .km-section--paper-2 { padding-top: calc(var(--km-section-y) * 0.4); }

/* The first hero section keeps a bit more top air (under the sticky header)
   but a noticeably tighter bottom so it reads as the lead-in to whatever follows. */
.km-page > .km-section:first-child { padding-bottom: calc(var(--km-section-y) * 0.6); }

.km-container { max-width: var(--km-max); margin: 0 auto; }
.km-container--wide { max-width: var(--km-max-wide); margin: 0 auto; }

/* Gold zari hairline ornament */
.km-zari-top::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0, var(--km-gold) 20%, var(--km-gold) 80%, transparent 100%);
  opacity: 0.7;
}

/* ============================================================
   4. Typography components
   ============================================================ */
.km-eyebrow {
  font-family: var(--km-sans);
  font-size: var(--km-eyebrow);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--km-coral);
  margin: 0 0 var(--km-s-2);
}
.km-section--coral .km-eyebrow { color: var(--km-paper); opacity: 0.85; }

.km-lead {
  font-family: var(--km-serif);
  font-size: clamp(1.15rem, 1.6vw, 1.35rem);
  font-weight: 400;
  font-style: italic;
  color: var(--km-ink-soft);
  line-height: 1.5;
}

.km-display { font-family: var(--km-serif); }

/* ============================================================
   5. Buttons
   ============================================================ */
.km-btn,
.km-btn:visited,
.wp-block-button.is-style-km-primary .wp-block-button__link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1.6rem;
  font-family: var(--km-sans);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  border-radius: var(--km-r-pill);
  background: var(--km-coral);
  color: var(--km-paper) !important;
  border: 1.5px solid var(--km-coral);
  text-decoration: none !important;
  transition: background 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}
.km-btn:hover { background: var(--km-coral-deep); border-color: var(--km-coral-deep); transform: translateY(-1px); box-shadow: 0 8px 20px -10px rgba(240,111,64,0.5); }

.km-btn--ghost,
.km-btn--ghost:visited {
  background: transparent;
  color: var(--km-coral-deep) !important;
  border-color: var(--km-coral);
}
.km-btn--ghost:hover { background: var(--km-coral); color: var(--km-paper) !important; }

.km-section--coral .km-btn--ghost { color: var(--km-paper) !important; border-color: var(--km-paper); }
.km-section--coral .km-btn--ghost:hover { background: var(--km-paper); color: var(--km-coral) !important; }

.km-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--km-coral-deep);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid var(--km-coral);
  padding-bottom: 2px;
}
.km-link::after { content: "→"; transition: transform 0.18s ease; }
.km-link:hover::after { transform: translateX(3px); }

/* ============================================================
   6. Hero
   ============================================================ */
.km-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--km-s-5);
  align-items: center;
  min-height: clamp(520px, 70vh, 720px);
}
.km-hero__media {
  border-radius: var(--km-r-lg);
  overflow: hidden;
  box-shadow: var(--km-shadow-photo);
  aspect-ratio: 5/6;
  background: var(--km-paper-2);
}
.km-hero__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.km-hero__body { max-width: 540px; }
.km-hero__title { margin: 0 0 var(--km-s-3); }
.km-hero__sub { margin: 0 0 var(--km-s-4); color: var(--km-ink-soft); font-size: clamp(1.05rem,1.4vw,1.2rem); }
.km-hero__ctas { display: flex; gap: var(--km-s-2); flex-wrap: wrap; }

/* Inverted hero variant: image LEFT, text RIGHT */
.km-hero--inverted .km-hero__media { order: 1; }
.km-hero--inverted .km-hero__body { order: 2; }

@media (max-width: 860px) {
  .km-hero { grid-template-columns: 1fr; gap: var(--km-s-4); min-height: auto; }
  .km-hero__media { aspect-ratio: 16/10; }
  .km-hero--inverted .km-hero__media { order: 0; }
}

/* ============================================================
   7. Intro band (stacked centre)
   ============================================================ */
.km-intro { text-align: center; max-width: 780px; margin: 0 auto; }
.km-intro h2 { margin: 0 0 var(--km-s-3); line-height: 1.12; }
.km-intro__h2-italic {
  font-style: italic;
  font-weight: 500;
  color: var(--km-coral-deep);
  font-size: 0.86em;
  letter-spacing: 0.005em;
}
.km-intro p { color: var(--km-ink-soft); margin: 0 0 var(--km-s-3); max-width: 620px; margin-left: auto; margin-right: auto; }
.km-intro__pillars { display: inline-flex; gap: 0; margin-top: var(--km-s-2); flex-wrap: wrap; justify-content: center; align-items: center; }
.km-intro__pillars > * {
  font-family: var(--km-sans);
  font-size: 0.84rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--km-gold-deep);
  padding: 0 var(--km-s-3);
  text-decoration: none;
  border: 0;
  position: relative;
  transition: color 0.18s ease;
}
.km-intro__pillars a:hover { color: var(--km-coral-deep); }
.km-intro__pillars a:hover span { border-bottom-color: var(--km-coral); }
.km-intro__pillars a span { border-bottom: 1px solid transparent; padding-bottom: 2px; transition: border-bottom-color 0.18s ease; }
.km-intro__pillars > * + *::before {
  content: "·";
  color: var(--km-gold);
  position: absolute;
  left: -3px;
  font-weight: 400;
  letter-spacing: 0;
}

/* Tight section variant — pulls the following section closer */
.km-section--tight-bottom { padding-bottom: clamp(2.5rem, 5vw, 4rem); }

/* ============================================================
   8. Teaser split (2-up cards)
   ============================================================ */
.km-split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--km-s-4); }
@media (max-width: 860px) { .km-split { grid-template-columns: 1fr; } }
.km-teaser {
  background: var(--km-paper);
  border: 1px solid var(--km-line);
  border-radius: var(--km-r-md);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.km-teaser:hover { transform: translateY(-3px); box-shadow: var(--km-shadow-card); }
.km-teaser__media { aspect-ratio: 16/10; overflow: hidden; }
.km-teaser__media img { width: 100%; height: 100%; object-fit: cover; }
.km-teaser__body { padding: var(--km-s-4); display: flex; flex-direction: column; gap: var(--km-s-2); flex: 1; }
.km-teaser__body h3 { margin: 0; }
.km-teaser__body p { color: var(--km-ink-soft); margin: 0; }
.km-teaser__body .km-link { margin-top: auto; }
.km-teaser__rule { width: 36px; height: 1px; background: var(--km-gold); margin-bottom: var(--km-s-1); }

/* ============================================================
   9. Quote band
   ============================================================ */
.km-quote { text-align: center; max-width: 820px; margin: 0 auto; }
.km-quote blockquote {
  font-family: var(--km-serif);
  font-style: italic;
  font-size: clamp(1.4rem, 2.6vw, 2.2rem);
  font-weight: 400;
  line-height: 1.4;
  color: var(--km-ink);
  margin: 0 0 var(--km-s-3);
  border: 0; padding: 0;
}
.km-quote__attr { font-family: var(--km-sans); font-size: var(--km-small); color: var(--km-mute); letter-spacing: 0.04em; }
.km-quote__ornament { display: block; width: 8px; height: 8px; border-radius: 50%; background: var(--km-coral); margin: var(--km-s-3) auto; }

/* ============================================================
   10. Prefooter CTA
   ============================================================ */
.km-prefooter { text-align: center; max-width: 720px; margin: 0 auto; }
.km-prefooter h2 { margin: 0 0 var(--km-s-2); }
.km-prefooter p { margin: 0 0 var(--km-s-4); font-size: 1.1rem; }

/* ============================================================
   11. Course / service cards (3-up grid)
   ============================================================ */
.km-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--km-s-4); }
@media (max-width: 1024px) { .km-grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .km-grid-3 { grid-template-columns: 1fr; } }

.km-card {
  position: relative;
  background: var(--km-paper);
  border: 1px solid var(--km-line);
  border-top: 1px solid var(--km-gold);
  border-radius: var(--km-r-md);
  padding: var(--km-s-4);
  display: flex; flex-direction: column;
  gap: var(--km-s-2);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.km-card::before {
  /* gold corner ornament top-right */
  content: "";
  position: absolute;
  top: var(--km-s-2); right: var(--km-s-2);
  width: 14px; height: 14px;
  background:
    linear-gradient(45deg, transparent 47%, var(--km-gold) 48%, var(--km-gold) 52%, transparent 53%),
    linear-gradient(-45deg, transparent 47%, var(--km-gold) 48%, var(--km-gold) 52%, transparent 53%);
  opacity: 0.55;
}
.km-card:hover { transform: translateY(-3px); box-shadow: var(--km-shadow-card); }
.km-card__meta { font-family: var(--km-sans); font-size: var(--km-eyebrow); font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--km-coral); }
.km-card__title { font-family: var(--km-serif); font-weight: 600; font-size: 1.4rem; margin: 0; }
.km-card__desc { color: var(--km-ink-soft); font-size: 0.97rem; margin: 0; }
.km-card__list { list-style: none; padding: 0; margin: var(--km-s-1) 0 var(--km-s-2); }
.km-card__list li { position: relative; padding-left: 1.1rem; margin-bottom: 0.35rem; font-size: 0.95rem; color: var(--km-ink); }
.km-card__list li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 6px; height: 6px; border-radius: 50%; background: var(--km-coral); }
.km-card__cta { margin-top: auto; padding-top: var(--km-s-2); }

/* ============================================================
   12. Service table (bridal tiers)
   ============================================================ */
.km-tier-table { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--km-gold); border-bottom: 1px solid var(--km-gold); }
@media (max-width: 860px) { .km-tier-table { grid-template-columns: 1fr; } }
.km-tier {
  padding: var(--km-s-4) var(--km-s-3);
  background: var(--km-paper);
  border-right: 1px solid var(--km-line);
}
.km-tier:last-child { border-right: 0; }
.km-tier:nth-child(2) { background: var(--km-paper-2); }
.km-tier__icon { width: 28px; height: 28px; color: var(--km-gold-deep); margin-bottom: var(--km-s-2); }
.km-tier__name { font-family: var(--km-serif); font-weight: 600; font-size: 1.35rem; margin: 0 0 0.25rem; }
.km-tier__price { font-family: var(--km-sans); font-size: 0.95rem; font-weight: 600; color: var(--km-coral); letter-spacing: 0.04em; margin: 0 0 var(--km-s-2); }
.km-tier__list { list-style: none; padding: 0; margin: 0; }
.km-tier__list li { position: relative; padding-left: 1rem; margin-bottom: 0.4rem; font-size: 0.92rem; color: var(--km-ink); }
.km-tier__list li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 5px; height: 5px; border-radius: 50%; background: var(--km-coral); }

/* ============================================================
   13. Comparison table
   ============================================================ */
.km-compare { width: 100%; border-collapse: collapse; margin-top: var(--km-s-3); }
.km-compare th, .km-compare td { padding: var(--km-s-2) var(--km-s-3); text-align: left; vertical-align: top; font-size: 0.95rem; }
.km-compare thead th { font-family: var(--km-serif); font-weight: 600; font-size: 1.05rem; color: var(--km-ink); border-bottom: 2px solid var(--km-gold); }
.km-compare tbody tr:nth-child(odd) { background: var(--km-paper-2); }
.km-compare tbody th { font-family: var(--km-sans); font-weight: 600; font-size: var(--km-eyebrow); letter-spacing: 0.1em; text-transform: uppercase; color: var(--km-ink-soft); }
.km-compare td.km-price { color: var(--km-coral); font-weight: 600; }

/* ============================================================
   14. Portfolio gallery
   ============================================================ */
.km-gallery {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 180px;
  gap: var(--km-s-2);
}
.km-gallery__lead { grid-column: span 3; grid-row: span 2; }
.km-gallery__cell { grid-column: span 2; }
.km-gallery img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--km-r-md); display: block; }
@media (max-width: 860px) {
  .km-gallery { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 140px; }
  .km-gallery__lead { grid-column: span 2; grid-row: span 2; }
  .km-gallery__cell { grid-column: span 1; }
}

/* ============================================================
   15. About + stats
   ============================================================ */
.km-about { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: var(--km-s-5); align-items: center; }
@media (max-width: 860px) { .km-about { grid-template-columns: 1fr; } }
.km-about__media { border-radius: var(--km-r-lg); overflow: hidden; aspect-ratio: 4/5; box-shadow: var(--km-shadow-photo); }
.km-about__media img { width: 100%; height: 100%; object-fit: cover; }
.km-about__founder { font-family: var(--km-serif); font-style: italic; color: var(--km-coral); margin: var(--km-s-3) 0; }
.km-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--km-s-3); margin-top: var(--km-s-4); padding-top: var(--km-s-4); border-top: 1px solid var(--km-line); }
.km-stats__num { font-family: var(--km-serif); font-weight: 700; font-size: clamp(2rem, 3vw, 2.6rem); color: var(--km-coral); line-height: 1; }
.km-stats__label { font-family: var(--km-sans); font-size: var(--km-eyebrow); letter-spacing: 0.14em; text-transform: uppercase; color: var(--km-ink-soft); margin-top: 0.4rem; }

/* ============================================================
   16. Contact
   ============================================================ */
.km-contact { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: var(--km-s-5); align-items: start; }
@media (max-width: 860px) { .km-contact { grid-template-columns: 1fr; } }
.km-contact__form-wrap {
  background: var(--km-paper);
  border: 1px solid var(--km-line);
  border-radius: var(--km-r-lg);
  padding: var(--km-s-4);
  box-shadow: var(--km-shadow-card);
}
.km-contact__details > * + * { margin-top: var(--km-s-3); }
.km-contact__details h3 { margin: 0; }
.km-contact__details .km-eyebrow { margin: 0 0 var(--km-s-2); }
.km-contact__details a { color: var(--km-ink); text-decoration: none; border-bottom: 1px dashed var(--km-line-strong); }
.km-contact__details a:hover { border-bottom-color: var(--km-coral); color: var(--km-coral-deep); }
.km-contact__map { aspect-ratio: 16/10; border-radius: var(--km-r-md); overflow: hidden; border: 1px solid var(--km-line); margin-top: var(--km-s-3); }
.km-contact__map iframe { width: 100%; height: 100%; border: 0; display: block; }

/* WPForms dark-on-ivory styling */
.km-contact__form-wrap .wpforms-form input[type=text],
.km-contact__form-wrap .wpforms-form input[type=email],
.km-contact__form-wrap .wpforms-form input[type=tel],
.km-contact__form-wrap .wpforms-form input[type=date],
.km-contact__form-wrap .wpforms-form select,
.km-contact__form-wrap .wpforms-form textarea {
  background: #fff !important;
  border: 1px solid var(--km-line-strong) !important;
  border-radius: var(--km-r-sm) !important;
  color: var(--km-ink) !important;
  font-family: var(--km-sans) !important;
  font-size: 0.97rem !important;
  padding: 0.75rem 0.85rem !important;
  min-height: 44px !important;
}
.km-contact__form-wrap .wpforms-form input:focus,
.km-contact__form-wrap .wpforms-form select:focus,
.km-contact__form-wrap .wpforms-form textarea:focus {
  outline: 0 !important;
  border-color: var(--km-coral) !important;
  box-shadow: 0 0 0 3px rgba(240,111,64,0.18) !important;
}
.km-contact__form-wrap .wpforms-form label {
  font-family: var(--km-sans) !important;
  font-size: var(--km-eyebrow) !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--km-ink-soft) !important;
}
.km-contact__form-wrap .wpforms-form button[type=submit] {
  background: var(--km-coral) !important;
  color: var(--km-paper) !important;
  border: 1.5px solid var(--km-coral) !important;
  border-radius: var(--km-r-pill) !important;
  font-family: var(--km-sans) !important;
  font-weight: 600 !important;
  font-size: 0.95rem !important;
  letter-spacing: 0.02em;
  padding: 0.85rem 1.6rem !important;
  cursor: pointer;
  transition: background 0.18s ease;
}
.km-contact__form-wrap .wpforms-form button[type=submit]:hover { background: var(--km-coral-deep) !important; border-color: var(--km-coral-deep) !important; }

/* ============================================================
   17. Blog
   ============================================================ */
.km-blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--km-s-4); }
@media (max-width: 1024px) { .km-blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .km-blog-grid { grid-template-columns: 1fr; } }

.km-post-card {
  background: var(--km-paper);
  border: 1px solid var(--km-line);
  border-radius: var(--km-r-md);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.km-post-card:hover { transform: translateY(-3px); box-shadow: var(--km-shadow-card); }
.km-post-card__media { aspect-ratio: 16/10; overflow: hidden; }
.km-post-card__media img { width: 100%; height: 100%; object-fit: cover; }
.km-post-card__body { padding: var(--km-s-3); display: flex; flex-direction: column; gap: var(--km-s-1); flex: 1; }
.km-post-card__date { font-family: var(--km-sans); font-size: var(--km-eyebrow); font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--km-coral); border-bottom: 1px solid var(--km-gold); padding-bottom: 0.4rem; margin-bottom: 0.4rem; }
.km-post-card__title { font-family: var(--km-serif); font-weight: 600; font-size: 1.3rem; margin: 0; line-height: 1.25; }
.km-post-card__title a { color: var(--km-ink); text-decoration: none; border: 0; }
.km-post-card__title a:hover { color: var(--km-coral-deep); }
.km-post-card__excerpt { color: var(--km-ink-soft); font-size: 0.95rem; margin: 0; flex: 1; }
.km-post-card__link { margin-top: var(--km-s-2); }

/* Blog hero */
.km-blog-hero { text-align: center; max-width: 720px; margin: 0 auto var(--km-s-5); }
.km-blog-hero .km-eyebrow { color: var(--km-coral); }

/* Loop entry overrides (Kadence default blog) */
.loop-entry .entry-taxonomies, .loop-entry .posted-by, .loop-entry .meta-author { display: none !important; }

/* Single post layout — custom template */
.km-single { background: var(--km-paper); }
.km-single__title {
  font-family: var(--km-serif);
  font-weight: 700;
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  letter-spacing: -0.015em;
  line-height: 1.1;
  color: var(--km-ink);
}
.km-single__deck {
  font-family: var(--km-serif);
  font-style: italic;
  font-size: clamp(1.1rem, 1.6vw, 1.3rem);
  color: var(--km-ink-soft);
  line-height: 1.5;
  margin: 0;
}
.km-single__media {
  border-radius: var(--km-r-lg);
  overflow: hidden;
  margin: 0;
  box-shadow: var(--km-shadow-photo);
  aspect-ratio: 16 / 9;
}
.km-single__media .km-single__hero-img,
.km-single__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.km-single__content { font-family: var(--km-sans); font-size: var(--km-body); color: var(--km-ink); line-height: var(--km-lh-normal); }
.km-single__content > * + * { margin-top: var(--km-s-3); }
.km-single__content h2 { font-family: var(--km-serif); font-weight: 700; font-size: clamp(1.5rem, 2.4vw, 2rem); margin-top: var(--km-s-5); }
.km-single__content h3 { font-family: var(--km-serif); font-weight: 600; font-size: 1.3rem; margin-top: var(--km-s-4); }
.km-single__content p { color: var(--km-ink); }
.km-single__content ul, .km-single__content ol { padding-left: 1.5rem; }
.km-single__content ul li, .km-single__content ol li { margin-bottom: 0.4rem; }
.km-single__content strong { color: var(--km-ink); font-weight: 600; }
.km-single__content a { color: var(--km-coral-deep); }
.km-single__content blockquote {
  font-family: var(--km-serif);
  font-style: italic;
  font-size: 1.25rem;
  color: var(--km-ink-soft);
  border-left: 3px solid var(--km-gold);
  padding-left: var(--km-s-3);
  margin: var(--km-s-4) 0;
}

/* Hide Kadence single-post meta cruft */
.single-post .entry-header,
.single-post .post-meta-wrap,
.single-post .entry-meta,
.single-post .entry-categories,
.single-post .entry-taxonomies,
.single-post .posted-by,
.single-post .meta-author,
.single-post .post-navigation,
.single-post .nav-links,
.single-post .post-navigation-sub,
.single-post .comments-area,
.single-post .entry-hero,
.single-post .breadcrumbs,
.single-post .entry-content-wrap > .entry-meta { display: none !important; }

/* ============================================================
   18. Sticky Kadence header (per feedback_sticky_kadence_header)
   ============================================================ */
html body #main-header,
html body #mobile-header,
html body .site-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  background: rgba(251,246,238,0.92) !important;
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--km-line);
}
html body #wrapper,
html body #page,
html body .site,
html body .site-content { overflow: visible !important; }

/* Header nav styling */
html body .main-navigation .menu-item a {
  font-family: var(--km-sans) !important;
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  color: var(--km-ink) !important;
  letter-spacing: 0.01em;
  text-transform: none !important;
}
html body .main-navigation .menu-item a:hover { color: var(--km-coral-deep) !important; }
html body .main-navigation .current-menu-item > a { color: var(--km-coral-deep) !important; }
html body .header-navigation-style-standard .header-menu-container ul li.menu-item > a:hover::before { background: var(--km-coral) !important; }

/* Hide the duplicated site title text — the logo lockup already contains the wordmark */
.site-branding .site-title-wrap,
.site-branding .site-title,
.site-branding .site-description { display: none !important; }

/* Logo sizing: keep proportions, cap height so it stays trim */
.site-branding .custom-logo { max-height: 52px; width: auto !important; }
@media (max-width: 1024px) { .site-branding .custom-logo { max-height: 44px; } }
@media (max-width: 640px)  { .site-branding .custom-logo { max-height: 38px; } }

/* ============================================================
   19. Footer (paper + gold rules)
   ============================================================ */
html body .site-footer { background: var(--km-paper-3) !important; color: var(--km-ink) !important; }
html body .site-footer .widget-title, html body .site-footer h2.widget-title {
  font-family: var(--km-serif) !important;
  font-weight: 600 !important;
  font-size: 1.05rem !important;
  color: var(--km-ink) !important;
  margin-bottom: var(--km-s-2) !important;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--km-gold);
}
html body .site-footer p, html body .site-footer li, html body .site-footer a {
  font-family: var(--km-sans) !important;
  font-size: 0.92rem !important;
  color: var(--km-ink-soft) !important;
  line-height: 1.7 !important;
}
html body .site-footer a { text-decoration: none; border-bottom: 1px dashed var(--km-line-strong); }
html body .site-footer a:hover { color: var(--km-coral-deep) !important; border-bottom-color: var(--km-coral); }
html body .site-footer ul { list-style: none; padding: 0; margin: 0; }
html body .site-footer ul li { padding: 0.2rem 0; }
html body .site-footer .site-bottom-footer-wrap .site-footer-row-container-inner {
  padding: 1.25rem 0 !important;
  border-top: 1px solid var(--km-line);
  font-size: 0.85rem !important;
  color: var(--km-mute) !important;
}
.km-footer-attribution { color: var(--km-mute); }
.km-footer-attribution a { color: var(--km-ink-soft) !important; text-decoration: none; border-bottom: 1px solid var(--km-line-strong); }
.km-footer-attribution a:hover { color: var(--km-coral-deep) !important; border-bottom-color: var(--km-coral); }

/* Social SVG icon row */
.km-social { display: flex; gap: 0.75rem; margin-top: var(--km-s-2); }
.km-social a { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border: 1px solid var(--km-line); border-radius: 50%; color: var(--km-ink-soft); transition: all 0.18s ease; background: transparent; }
.km-social a:hover { background: var(--km-coral); color: var(--km-paper); border-color: var(--km-coral); }
.km-social svg { width: 16px; height: 16px; fill: currentColor; }

/* ============================================================
   20. Decorative + utility
   ============================================================ */
.km-divider-gold { width: 60px; height: 1px; background: var(--km-gold); margin: var(--km-s-2) auto; }
.km-center { text-align: center; }
.km-mt-3 { margin-top: var(--km-s-3) !important; }
.km-mt-4 { margin-top: var(--km-s-4) !important; }
.km-mb-3 { margin-bottom: var(--km-s-3) !important; }
.km-mb-4 { margin-bottom: var(--km-s-4) !important; }

/* Don't stretch main */
.wp-site-blocks > main { flex: 0 0 auto !important; }
