/*
 Theme Name:   pbrar-child
 Theme URI:    https://pbrar.org
 Description:  Astra Child Theme for pbrar.org — Parminder Brar
 Author:       Parminder Brar
 Template:     astra
 Version:      1.0.0
 Text Domain:  pbrar-child
*/

/* ============================================================
   GOOGLE FONTS — loaded here, no Customizer step needed
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,500;0,600;1,400&family=Nunito+Sans:wght@300;400;600;700&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ============================================================
   COLOUR TOKENS
   ============================================================ */
:root {
  --pbr-slate:      #1B2A4A;
  --pbr-gold:       #B8972A;
  --pbr-bg:         #F9F7F4;
  --pbr-white:      #FFFFFF;
  --pbr-text:       #2a2a2a;
  --pbr-muted:      #555555;
  --pbr-rule:       #D9CBA3;
  --pbr-callout-bg: #F5EDD6;
}

/* ============================================================
   BASE — override Astra defaults completely
   ============================================================ */
html,
body,
.ast-single-post,
.woocommerce div.product {
  background-color: var(--pbr-bg) !important;
  color: var(--pbr-text) !important;
}

body,
body *,
p,
li,
td,
.entry-content,
.entry-summary {
  font-family: 'Lora', Georgia, serif !important;
  font-size: 17px;
  line-height: 1.75;
  color: var(--pbr-text);
}

/* ============================================================
   HEADINGS — force Playfair Display, override Astra completely
   ============================================================ */
h1, h2, h3, h4, h5, h6,
.entry-title,
.entry-title a,
.page-title,
.ast-archive-title,
.widget-title,
.wp-block-heading {
  font-family: 'Playfair Display', Georgia, serif !important;
  color: var(--pbr-slate) !important;
  font-weight: 600 !important;
  line-height: 1.25 !important;
}

h1 { font-size: 2.4rem !important; }
h2 { font-size: 1.8rem !important; }
h3 { font-size: 1.35rem !important; }
h4 { font-size: 1.1rem !important; }

/* ============================================================
   LINKS
   ============================================================ */
a, a:visited {
  color: var(--pbr-gold) !important;
  text-decoration: none !important;
}
a:hover, a:focus {
  color: var(--pbr-slate) !important;
  text-decoration: underline !important;
}

/* ============================================================
   HEADER & NAVIGATION
   ============================================================ */
.site-header,
.main-header-bar,
#masthead,
.ast-primary-header-bar,
#ast-desktop-header {
  background-color: var(--pbr-white) !important;
  border-bottom: 1px solid var(--pbr-rule) !important;
  box-shadow: none !important;
}

/* Site title */
.site-title,
.site-title a,
.ast-site-title,
.ast-site-title a {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 1.35rem !important;
  font-weight: 600 !important;
  color: var(--pbr-slate) !important;
  letter-spacing: 0.01em !important;
  text-decoration: none !important;
}

/* Nav items */
.main-navigation a,
.ast-primary-nav a,
.main-header-menu a,
#site-navigation a,
.ast-nav-menu a,
.ast-nav-menu li a,
.menu-toggle {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 13px !important;
  letter-spacing: 0.08em !important;
  font-weight: 600 !important;
  color: var(--pbr-slate) !important;
  text-decoration: none !important;
}

.main-navigation a:hover,
.ast-primary-nav a:hover,
.ast-nav-menu a:hover {
  color: var(--pbr-gold) !important;
}

/* No dropdowns */
.main-navigation .sub-menu,
.ast-nav-menu .sub-menu {
  display: none !important;
}

/* ============================================================
   CONTENT WIDTH — 820px max
   ============================================================ */
.ast-container,
.entry-content,
.ast-article-single,
.single .entry-content,
.page .entry-content,
.ast-page-builder-template .entry-content {
  max-width: 820px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 20px !important;
  padding-right: 20px !important;
}

/* Let Elementor full-width sections break out */
.elementor-section-full_width {
  max-width: 100% !important;
}
.elementor-section-boxed .elementor-container,
.elementor-section-full_width .elementor-container {
  max-width: 820px !important;
}

/* ============================================================
   HORIZONTAL RULES — gold
   ============================================================ */
hr {
  border: none !important;
  border-top: 1px solid var(--pbr-gold) !important;
  opacity: 0.5 !important;
  margin: 2.5rem 0 !important;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer,
#colophon,
.ast-small-footer,
.footer-widget-area,
.ast-footer-copyright {
  background-color: var(--pbr-slate) !important;
  color: #a0aec0 !important;
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 13px !important;
}

.site-footer a,
.ast-small-footer a,
.ast-footer-copyright a {
  color: var(--pbr-gold) !important;
}
.site-footer a:hover,
.ast-small-footer a:hover {
  color: var(--pbr-white) !important;
  text-decoration: none !important;
}

/* ============================================================
   ELEMENTOR WIDGETS — keep consistent
   ============================================================ */
.elementor-widget-heading .elementor-heading-title {
  font-family: 'Playfair Display', Georgia, serif !important;
  color: var(--pbr-slate) !important;
}

.elementor-widget-text-editor,
.elementor-widget-text-editor p {
  font-family: 'Lora', Georgia, serif !important;
  font-size: 17px !important;
  line-height: 1.75 !important;
  color: var(--pbr-text) !important;
}

.elementor-divider-separator {
  border-top-color: var(--pbr-gold) !important;
}

.elementor-button,
.elementor-button-wrapper .elementor-button {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 13px !important;
  letter-spacing: 0.08em !important;
  font-weight: 700 !important;
  background-color: var(--pbr-gold) !important;
  color: var(--pbr-white) !important;
  border-radius: 2px !important;
  border: none !important;
}
.elementor-button:hover {
  background-color: var(--pbr-slate) !important;
}

/* ============================================================
   PBRAR UTILITY CLASSES
   Used when building pages in Elementor custom HTML widgets
   ============================================================ */

/* Kicker / label — small uppercase gold above headlines */
.pbr-kicker, .pbr-label {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--pbr-gold) !important;
  display: block;
  margin-bottom: 0.5rem;
}

/* Hero headline */
.pbr-headline-hero {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: clamp(2.2rem, 5vw, 3.4rem) !important;
  line-height: 1.15 !important;
  color: var(--pbr-slate) !important;
  font-weight: 600 !important;
}

/* Opening statement */
.pbr-opening {
  font-family: 'Lora', Georgia, serif !important;
  font-size: 1.15rem !important;
  line-height: 1.65 !important;
  color: var(--pbr-muted) !important;
  max-width: 600px;
}

/* H.E.L.P. Hillary callout box */
.pbr-hillary-box {
  background-color: var(--pbr-callout-bg);
  border: 1px solid var(--pbr-gold);
  border-left: 6px solid var(--pbr-gold);
  padding: 2rem 2rem 2rem 1.75rem;
  margin: 2.5rem 0;
}
.pbr-hillary-box p {
  font-family: 'Lora', Georgia, serif !important;
  font-size: 1rem !important;
  color: var(--pbr-text) !important;
  line-height: 1.7 !important;
}

/* Writing page cards */
.pbr-writing-card {
  border-top: 2px solid var(--pbr-gold);
  padding: 1.5rem 0;
}
.pbr-writing-tag {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--pbr-gold) !important;
  display: block;
  margin-bottom: 0.4rem;
}
.pbr-writing-title {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 1.2rem !important;
  color: var(--pbr-slate) !important;
  font-weight: 600 !important;
  margin-bottom: 0.4rem;
}
.pbr-writing-title a {
  color: var(--pbr-slate) !important;
}
.pbr-writing-title a:hover {
  color: var(--pbr-gold) !important;
}
.pbr-writing-desc {
  font-family: 'Lora', Georgia, serif !important;
  font-size: 0.97rem !important;
  color: var(--pbr-muted) !important;
}

/* About page period labels */
.pbr-period-label {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--pbr-gold) !important;
  display: block;
  margin-bottom: 0.3rem;
}
.pbr-act-title {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 1.6rem !important;
  color: var(--pbr-slate) !important;
  font-weight: 600 !important;
  margin-top: 0;
}

/* Roles / timeline table */
.pbr-roles-table { width: 100%; border-collapse: collapse; }
.pbr-roles-table td {
  padding: 0.5rem 0.75rem 0.5rem 0;
  border-bottom: 1px solid var(--pbr-rule);
  font-family: 'Lora', Georgia, serif !important;
  font-size: 0.97rem !important;
  vertical-align: top;
}
.pbr-roles-table td:first-child {
  width: 110px;
  color: var(--pbr-gold) !important;
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  white-space: nowrap;
  padding-right: 1.5rem;
}

/* Mountain entries */
.pbr-mountain-entry { border-top: 1px solid var(--pbr-rule); padding: 2rem 0 1.5rem; }
.pbr-mountain-name {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 1.4rem !important;
  color: var(--pbr-slate) !important;
  font-weight: 600 !important;
}
.pbr-mountain-meta {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 12px !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--pbr-gold) !important;
  font-weight: 600 !important;
}

/* Photo caption */
.pbr-photo-frame img { border: 1px solid var(--pbr-gold); display: block; width: 100%; }
.pbr-photo-caption {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 12px !important;
  color: #888 !important;
  margin-top: 0.5rem;
}
.pbr-photo-portrait { max-width: 60%; margin: 1.5rem auto; display: block; }

/* ============================================================
   WPFORMS
   ============================================================ */
.wpforms-container .wpforms-field input,
.wpforms-container .wpforms-field textarea {
  font-family: 'Lora', Georgia, serif !important;
  font-size: 16px !important;
  border: 1px solid var(--pbr-rule) !important;
  border-radius: 2px !important;
  background-color: var(--pbr-white) !important;
  color: var(--pbr-text) !important;
}
.wpforms-container .wpforms-field input:focus,
.wpforms-container .wpforms-field textarea:focus {
  border-color: var(--pbr-gold) !important;
  outline: none !important;
}
.wpforms-container label {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--pbr-slate) !important;
}
.wpforms-submit,
.wpforms-container .wpforms-submit-container button {
  font-family: 'Nunito Sans', sans-serif !important;
  font-weight: 700 !important;
  background-color: var(--pbr-gold) !important;
  color: var(--pbr-white) !important;
  border: none !important;
  border-radius: 2px !important;
  padding: 0.8rem 2rem !important;
  font-size: 13px !important;
  cursor: pointer !important;
}
.wpforms-submit:hover { background-color: var(--pbr-slate) !important; }

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width: 768px) {
  body, body * { font-size: 16px !important; }
  h1, .pbr-headline-hero { font-size: 1.9rem !important; }
  h2 { font-size: 1.45rem !important; }
  .pbr-photo-portrait { max-width: 100% !important; }
  .pbr-opening { font-size: 1.05rem !important; }
}
