/*
Theme Name: Kelly DeMarco — Private Letter
Theme URI: https://kellydemarco.com/
Description: Hestia child theme for kellydemarco.com. Dark + gold art-deco editorial identity for a premium strategy & high-end entertainment-space publication. Custom header, footer, and favicon. Forces full pre-<!--more--> content on the blog index for SEO link-juice strategy.
Author: kellydemarco.com
Template: hestia
Version: 1.0.5
Text Domain: kellydemarco-child
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --kd-ink: #14110f;          /* near-black warm ink */
  --kd-ink-2: #1c1917;
  --kd-paper: #fafaf9;        /* editorial paper */
  --kd-paper-2: #f3f1ec;
  --kd-gold: #d4af37;
  --kd-gold-soft: #e8d28a;
  --kd-gold-deep: #9c7c1f;
  --kd-muted: #a8a29e;
  --kd-line: rgba(212,175,55,0.28);
  --kd-serif: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --kd-sans: 'Helvetica Neue', Arial, sans-serif;
}

/* ============================================================
   HEADER — dark bar, gold monogram, art-deco rule
   ============================================================ */
.navbar.navbar-default.navbar-not-transparent,
.navbar.navbar-default {
  background-color: var(--kd-ink) !important;
  border-bottom: 1px solid var(--kd-line);
  box-shadow: 0 2px 18px rgba(0,0,0,0.35);
}

.navbar .navbar-brand,
.navbar .navbar-brand p {
  color: var(--kd-paper) !important;
  font-family: var(--kd-serif);
  font-weight: 700;
  letter-spacing: 0.5px;
  display: flex;
  align-items: center;
  gap: 12px;
}

/* gold monogram chip injected via functions.php */
.kd-monogram {
  display: inline-flex;
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
}
.kd-monogram svg { width: 100%; height: 100%; display: block; }

.kd-brand-text { display: inline-flex; flex-direction: column; line-height: 1; }
.kd-brand-name {
  font-family: var(--kd-serif);
  font-size: 20px;
  color: var(--kd-paper);
}
.kd-brand-tag {
  font-family: var(--kd-sans);
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--kd-gold);
  margin-top: 4px;
}

.navbar .navbar-nav > li > a {
  color: var(--kd-paper) !important;
  font-family: var(--kd-sans);
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.navbar .navbar-nav > li > a:hover,
.navbar .navbar-nav > li.on-section > a {
  color: var(--kd-gold) !important;
}

/* Keep the whole navbar on ONE row (desktop). The menu was wrapping to a
   second line because the labels were long; we shorten labels via JS and
   compress spacing here so everything fits in a single row. */
@media (min-width: 769px) {
  .navbar .container {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
  }
  #main-navigation.navbar-collapse {
    flex: 1 1 auto;
    display: flex !important;
    justify-content: flex-end;
  }
  #main-navigation .navbar-nav {
    display: flex;
    flex-wrap: nowrap;
    margin: 0;
    float: none;
  }
  #main-navigation .navbar-nav > li { white-space: nowrap; }
  #main-navigation .navbar-nav > li > a {
    padding-left: 12px;
    padding-right: 12px;
    font-size: 11px;
    letter-spacing: 1px;
  }
}

/* thin gold deco line under the fixed header */
.navbar.navbar-fixed-top::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--kd-gold), transparent);
  opacity: 0.6;
}

/* ============================================================
   PAGE HEADER / HERO — replace pink gradient with ink+gold
   ============================================================ */
.header-filter.header-filter-gradient,
.page-header .header-filter-gradient {
  background: linear-gradient(135deg, #14110f 0%, #2a2118 55%, #14110f 100%) !important;
}
#primary.page-header::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(90deg, transparent 0 38px, var(--kd-line) 38px 39px);
  opacity: 0.10;
  pointer-events: none;
  z-index: 1;
}
.page-header .hestia-title { color: var(--kd-gold-soft); font-family: var(--kd-serif); }

/* ============================================================
   BLOG INDEX cards — editorial restraint
   ============================================================ */
.card-blog .category a,
.card-blog .category .text-info,
.card.card-blog .category a {
  color: var(--kd-gold-deep) !important;
  font-family: var(--kd-sans);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.card-blog .card-title a {
  font-family: var(--kd-serif);
  color: var(--kd-ink-2);
}
.card-blog .card-title a:hover { color: var(--kd-gold-deep); }
.card-blog a.moretag,
.card-blog a.more-link {
  color: var(--kd-gold-deep) !important;
  font-family: var(--kd-sans);
  font-size: 12px;
  letter-spacing: 1px;
  border-bottom: 1px solid var(--kd-line);
}

/* ============================================================
   SIDEBAR widget headings
   ============================================================ */
.blog-sidebar .widget h5.wp-block-heading {
  font-family: var(--kd-serif);
  color: var(--kd-ink-2);
  border-bottom: 1px solid var(--kd-line);
  padding-bottom: 8px;
  letter-spacing: 0.5px;
}
.blog-sidebar a { color: var(--kd-ink-2); }
.blog-sidebar a:hover { color: var(--kd-gold-deep); }

/* ============================================================
   FOOTER — dark with gold deco, custom columns
   ============================================================ */
footer.footer.footer-black,
footer.footer.footer-black.footer-big {
  background: var(--kd-ink) !important;
  border-top: 1px solid var(--kd-line);
}
/* Override Hestia's faint footer text color so our columns are readable. */
footer.footer .kd-footer,
footer.footer .kd-footer p,
footer.footer .kd-footer span { color: var(--kd-muted) !important; }
footer.footer .kd-footer .kd-foot-brand-name { color: var(--kd-paper) !important; }
footer.footer .kd-footer .kd-foot-tag,
footer.footer .kd-footer h6 { color: var(--kd-gold) !important; }
footer.footer .kd-footer a { color: var(--kd-muted) !important; }
footer.footer .kd-footer a:hover { color: var(--kd-gold-soft) !important; }
.kd-footer {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 40px;
  padding: 56px 0 28px;
  color: var(--kd-muted);
  font-family: var(--kd-sans);
}
.kd-footer .kd-foot-brand-name {
  font-family: var(--kd-serif);
  font-size: 22px;
  color: var(--kd-paper);
  margin: 0 0 10px;
}
.kd-footer .kd-foot-tag {
  font-size: 10px; letter-spacing: 3px; text-transform: uppercase;
  color: var(--kd-gold);
}
.kd-footer h6 {
  font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--kd-gold); margin: 0 0 16px;
}
.kd-footer ul { list-style: none; padding: 0; margin: 0; }
.kd-footer ul li { margin-bottom: 9px; }
.kd-footer a { color: var(--kd-muted); font-size: 13px; }
.kd-footer a:hover { color: var(--kd-gold-soft); }
.kd-footer p { font-size: 12.5px; line-height: 1.8; margin: 0 0 14px; }

.kd-footer-rule {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--kd-gold), transparent);
  opacity: 0.5;
  margin: 8px 0 0;
}
.kd-foot-bottom {
  padding: 18px 0 28px;
  font-family: var(--kd-sans);
  font-size: 11px;
  letter-spacing: 0.5px;
  color: #6f6a64;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}
.kd-foot-bottom a { color: #8c857c; }
.kd-foot-bottom a:hover { color: var(--kd-gold-soft); }
.kd-disclaimer { font-size: 11px; color: #6f6a64; line-height: 1.7; }

/* hide the default ThemeIsle credit row visually-balanced layout */
footer.footer .hestia-bottom-footer-content .copyright.pull-right { display: none; }

/* Hide the theme's original (near-empty) footer; show only our PHP footer.
   Our footer is marked with .kd-footer-wrap. */
footer.footer.footer-black:not(.kd-footer-wrap) { display: none !important; }
footer.footer.kd-footer-wrap { display: block !important; }

@media (max-width: 768px) {
  .kd-footer { grid-template-columns: 1fr; gap: 28px; padding: 40px 0 18px; }
  .kd-foot-bottom { flex-direction: column; }
}

/* ============================================================
   HERO — intro section directly under the header
   ============================================================ */
.kd-hero {
  background: linear-gradient(135deg, #14110f 0%, #2a2118 55%, #14110f 100%);
  position: relative;
  overflow: hidden;
  margin-top: 0;
  padding: 96px 0 72px;
}
.kd-hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(90deg, transparent 0 46px, var(--kd-line) 46px 47px);
  opacity: 0.08;
  pointer-events: none;
}
.kd-hero::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--kd-gold), transparent);
  opacity: 0.55;
}
.kd-hero-inner {
  position: relative;
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
  padding: 0 20px;
}
.kd-hero-kicker {
  display: inline-block;
  font-family: var(--kd-sans);
  font-size: 11px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--kd-gold);
  margin-bottom: 22px;
}
.kd-hero-title {
  font-family: var(--kd-serif);
  font-size: 46px;
  line-height: 1.2;
  color: var(--kd-paper);
  margin: 0 0 20px;
  font-weight: 700;
}
.kd-hero-title em {
  font-style: italic;
  color: var(--kd-gold-soft);
}
.kd-hero-sub {
  font-family: var(--kd-serif);
  font-size: 17px;
  line-height: 1.8;
  color: #cfc6ba;
  margin: 0 auto 26px;
  max-width: 620px;
}
.kd-hero-rule {
  width: 64px; height: 2px;
  background: linear-gradient(90deg, var(--kd-gold-deep), var(--kd-gold-soft));
  margin: 0 auto 26px;
}
.kd-hero-tags { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; }
.kd-hero-tags a {
  font-family: var(--kd-sans);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--kd-gold-soft);
  border: 1px solid var(--kd-line);
  border-radius: 2px;
  padding: 7px 16px;
  transition: all .2s ease;
}
.kd-hero-tags a:hover {
  color: var(--kd-ink);
  background: var(--kd-gold);
  border-color: var(--kd-gold);
}

/* Hestia adds 24px top margins to top-level blocks; the hero should sit flush. */
.kd-hero { margin-block-start: 0 !important; }

/* If any empty page-header slips through on the index, collapse it. */
.home #primary.page-header:empty,
.blog #primary.page-header:empty { display: none; }

/* Belt-and-suspenders: never show the pink gradient hero on the index
   even if the empty page-header is not removed for some reason. */
.home #primary.page-header .header-filter-gradient,
.blog #primary.page-header .header-filter-gradient {
  background: linear-gradient(135deg, #14110f 0%, #2a2118 55%, #14110f 100%) !important;
}

@media (max-width: 768px) {
  .kd-hero { padding: 64px 0 48px; }
  .kd-hero-title { font-size: 32px; }
}

/* ============================================================
   SIDEBAR — give the widgets a distinct editorial identity
   (instead of the stock WordPress block look)
   ============================================================ */
.blog-sidebar .widget {
  background: #ffffff;
  border: 1px solid #ece9e2;
  border-top: 2px solid var(--kd-gold);
  border-radius: 4px;
  padding: 22px 22px 20px;
  margin-bottom: 26px;
  box-shadow: 0 8px 26px -18px rgba(20,17,15,0.4);
}
.blog-sidebar .widget h5.wp-block-heading {
  font-family: var(--kd-serif);
  font-size: 13px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--kd-ink-2);
  border-bottom: none;
  padding: 0 0 0 14px;
  margin: 0 0 16px;
  position: relative;
}
.blog-sidebar .widget h5.wp-block-heading::before {
  content: "";
  position: absolute; left: 0; top: 2px; bottom: 2px;
  width: 3px;
  background: linear-gradient(180deg, var(--kd-gold-soft), var(--kd-gold-deep));
  border-radius: 2px;
}
/* recent posts / archives / categories list items */
.blog-sidebar .wp-block-latest-posts__list li,
.blog-sidebar .wp-block-archives li,
.blog-sidebar .wp-block-categories li {
  list-style: none;
  border-bottom: 1px dashed #ece9e2;
  padding: 9px 0;
  margin: 0;
}
.blog-sidebar .wp-block-latest-posts__list li:last-child,
.blog-sidebar .wp-block-archives li:last-child,
.blog-sidebar .wp-block-categories li:last-child { border-bottom: none; }
.blog-sidebar .wp-block-latest-posts__list,
.blog-sidebar .wp-block-archives,
.blog-sidebar .wp-block-categories { padding-left: 0; margin: 0; }
.blog-sidebar .widget a {
  font-family: var(--kd-sans);
  font-size: 13.5px;
  line-height: 1.5;
  color: #3f3a34;
}
.blog-sidebar .widget a:hover { color: var(--kd-gold-deep); }
/* search box */
.blog-sidebar .wp-block-search__input {
  border: 1px solid #ddd7cc;
  border-radius: 3px;
}
.blog-sidebar .wp-block-search__button {
  background: var(--kd-ink) !important;
  color: var(--kd-gold-soft) !important;
  border: none !important;
  border-radius: 3px;
  letter-spacing: 1px;
}
.blog-sidebar .wp-block-search__button:hover { background: var(--kd-gold-deep) !important; color:#fff !important; }

/* Hide the Archives and Recent Comments widgets.
   Identify them by their inner block (no reliance on widget id). */
.blog-sidebar .widget:has(.wp-block-archives),
.blog-sidebar .widget:has(.wp-block-latest-comments),
.blog-sidebar .widget:has(.no-comments),
.blog-sidebar .widget.kd-hide-widget { display: none !important; }

/* ============================================================
   OVERRIDE residual Hestia pink (#e91e63) accents
   ============================================================ */
a { color: var(--kd-gold-deep); }
a:hover { color: var(--kd-ink-2); }
.card-blog a.moretag:hover,
.card-blog a.more-link:hover,
.widget a:hover { color: var(--kd-ink-2) !important; }

/* ============================================================
   FOOTER visibility — ensure injected columns render even if
   Hestia leaves the footer container otherwise empty
   ============================================================ */
footer.footer.footer-black .container { width: 100%; }
footer.footer.footer-black .kd-footer a,
footer.footer.footer-black .kd-foot-bottom a { text-decoration: none; }

/* ============================================================
   Google font import (deco serif)
   ============================================================ */
