/**
Theme Name: Astra Child
Author: Brainstorm Force
Author URI: http://wpastra.com/about/
Description: Astra is the fastest, fully customizable & beautiful theme suitable for blogs, personal portfolios and business websites. It is very lightweight (less than 50KB on frontend) and offers unparalleled speed. Built with SEO in mind, Astra comes with schema.org code integrated so search engines will love your site. Astra offers plenty of sidebar options and widget areas giving you a full control for customizations. Furthermore, we have included special features and templates so feel free to choose any of your favorite page builder plugin to create pages flexibly. Some of the other features: # WooCommerce Ready # Responsive # Compatible with major plugins # Translation Ready # Extendible with premium addons # Regularly updated # Designed, Developed, Maintained & Supported by Brainstorm Force. Looking for a perfect base theme? Look no further. Astra is fast, fully customizable and beautiful theme!
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: astra-child
Template: astra
*/

/* =========================================================
   LOGOS MECHANICS — CORE BRAND SYSTEM
Added by Roger Wamba on 4/15/2026
   For Astra Child Theme
   ========================================================= */

/* -----------------------------
   1. BRAND TOKENS
----------------------------- */
:root {
  /* Core brand colors */
  --lm-color-navy: #0B1F3B;
  --lm-color-gold: #D4AF37;
  --lm-color-charcoal: #0C0C0E;
  --lm-color-soft-white: #F5F7FA;
  --lm-color-blue-gray: #8A9BB5;

  /* Extended neutrals */
  --lm-color-white: #FFFFFF;
  --lm-color-light: #EEF2F7;
  --lm-color-light-2: #E4EAF2;
  --lm-color-border: rgba(11, 31, 59, 0.10);
  --lm-color-border-dark: rgba(245, 247, 250, 0.14);

  /* Text colors on light backgrounds */
  --lm-text-primary: #11233F;
  --lm-text-secondary: #4E607A;
  --lm-text-muted: #73839A;

  /* Text colors on dark backgrounds */
  --lm-text-on-dark: #F5F7FA;
  --lm-text-on-dark-muted: #B8C3D3;

  /* Accent usage */
  --lm-accent: var(--lm-color-gold);
  --lm-accent-hover: #C29C22;

  /* Background system */
  --lm-bg-page: #FFFFFF;
  --lm-bg-soft: #F8FAFC;
  --lm-bg-dark: var(--lm-color-charcoal);
  --lm-bg-deep: var(--lm-color-navy);

  /* Typography */
  --lm-font-heading: "Playfair Display", Georgia, "Times New Roman", serif;
  --lm-font-body: "Inter", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* Font sizes */
  --lm-text-xs: 0.8125rem;
  --lm-text-sm: 0.9375rem;
  --lm-text-base: 1rem;
  --lm-text-md: 1.0625rem;
  --lm-text-lg: 1.125rem;
  --lm-text-xl: 1.25rem;
  --lm-text-2xl: 1.75rem;
  --lm-text-3xl: 2.375rem;
  --lm-text-4xl: 3.25rem;

  /* Line height */
  --lm-line-tight: 1.15;
  --lm-line-heading: 1.2;
  --lm-line-body: 1.72;

  /* Spacing / structure */
  --lm-radius-sm: 6px;
  --lm-radius-md: 12px;
  --lm-radius-lg: 20px;
  --lm-radius-xl: 28px;

  --lm-shadow-soft: 0 12px 32px rgba(8, 20, 40, 0.08);
  --lm-shadow-card: 0 18px 46px rgba(8, 20, 40, 0.10);
  --lm-transition: 220ms ease;
}

/* -----------------------------
   2. GLOBAL BASE
----------------------------- */
html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body,
button,
input,
select,
textarea {
  font-family: var(--lm-font-body);
  color: var(--lm-text-primary);
  background-color: var(--lm-bg-page);
  font-size: var(--lm-text-base);
  line-height: var(--lm-line-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Helps reduce Astra font inheritance issues */
body,
.site,
.ast-site-identity,
.entry-content,
.entry-content p,
.widget,
.menu-item a,
.ast-builder-menu .menu-link,
.site-footer,
.site-header {
  font-family: var(--lm-font-body);
}

/* -----------------------------
   3. HEADINGS
----------------------------- */
h1, h2, h3, h4, h5, h6,
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
  font-family: var(--lm-font-heading);
  color: var(--lm-color-navy);
  line-height: var(--lm-line-heading);
  letter-spacing: -0.015em;
  font-weight: 700;
  margin-top: 0;
  margin-bottom: 0.75em;
}

h1,
.entry-content h1 {
  font-size: clamp(2.5rem, 5vw, 4.25rem);
  line-height: 1.06;
  letter-spacing: -0.03em;
  font-weight: 700;
}

h2,
.entry-content h2 {
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.12;
}

h3,
.entry-content h3 {
  font-size: clamp(1.5rem, 2.8vw, 2.125rem);
  line-height: 1.18;
}

h4,
.entry-content h4 {
  font-size: clamp(1.25rem, 2.2vw, 1.5rem);
}

h5,
.entry-content h5 {
  font-size: 1.125rem;
}

h6,
.entry-content h6 {
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* -----------------------------
   4. PARAGRAPHS / BODY COPY
----------------------------- */
p,
.entry-content p,
.editor-styles-wrapper p {
  font-family: var(--lm-font-body);
  font-size: var(--lm-text-md);
  line-height: var(--lm-line-body);
  color: var(--lm-text-primary);
  margin-top: 0;
  margin-bottom: 1.25em;
}

.entry-content p.has-large-font-size {
  font-size: 1.25rem;
  line-height: 1.7;
}

small,
figcaption,
.wp-caption-text {
  font-size: var(--lm-text-sm);
  color: var(--lm-text-muted);
}

/* -----------------------------
   5. LINKS
----------------------------- */
a,
.entry-content a,
.site a {
  color: var(--lm-color-navy);
  text-decoration: none;
  transition:
    color var(--lm-transition),
    opacity var(--lm-transition),
    border-color var(--lm-transition);
}

a:hover,
a:focus,
.entry-content a:hover,
.entry-content a:focus {
  color: var(--lm-accent-hover);
}

.entry-content p a,
.entry-content li a {
  border-bottom: 1px solid rgba(212, 175, 55, 0.35);
}

.entry-content p a:hover,
.entry-content li a:hover {
  border-bottom-color: rgba(212, 175, 55, 0.75);
}

/* -----------------------------
   6. STRONG / EMPHASIS / QUOTES
----------------------------- */
strong,
b {
  color: var(--lm-color-navy);
  font-weight: 700;
}

em,
i {
  font-style: italic;
}

blockquote,
.wp-block-quote {
  margin: 2rem 0;
  padding: 1.5rem 1.5rem 1.5rem 1.25rem;
  border-left: 3px solid var(--lm-color-gold);
  background: linear-gradient(
    180deg,
    rgba(212, 175, 55, 0.05) 0%,
    rgba(11, 31, 59, 0.02) 100%
  );
  border-radius: 0 var(--lm-radius-md) var(--lm-radius-md) 0;
}

blockquote p,
.wp-block-quote p {
  font-family: var(--lm-font-heading);
  font-size: clamp(1.2rem, 2vw, 1.45rem);
  line-height: 1.55;
  color: var(--lm-color-navy);
  margin-bottom: 0.5rem;
}

blockquote cite,
.wp-block-quote cite {
  display: block;
  font-family: var(--lm-font-body);
  font-size: var(--lm-text-sm);
  color: var(--lm-text-secondary);
  margin-top: 0.75rem;
}

/* -----------------------------
   7. LISTS
----------------------------- */
ul,
ol,
.entry-content ul,
.entry-content ol {
  margin: 0 0 1.5rem 1.25rem;
  padding: 0;
  color: var(--lm-text-primary);
}

li,
.entry-content li {
  margin-bottom: 0.5rem;
  line-height: 1.7;
}

/* -----------------------------
   8. HEADER / NAVIGATION
----------------------------- */
.site-title,
.site-title a,
.ast-site-title-wrap .site-title,
.ast-site-title-wrap .site-title a {
  font-family: var(--lm-font-heading);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--lm-color-navy);
}

.site-description,
.ast-site-identity p.site-description {
  font-family: var(--lm-font-body);
  color: var(--lm-text-secondary);
  font-size: var(--lm-text-sm);
  letter-spacing: 0.02em;
}

.main-header-menu > .menu-item > .menu-link,
.ast-builder-menu .main-header-menu > .menu-item > .menu-link,
.ast-builder-menu-1 .menu-link {
  font-family: var(--lm-font-body);
  font-size: 0.96rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--lm-color-navy);
}

.main-header-menu > .menu-item > .menu-link:hover,
.ast-builder-menu .menu-link:hover,
.ast-builder-menu .current-menu-item > .menu-link,
.ast-builder-menu .current-menu-ancestor > .menu-link {
  color: var(--lm-color-gold);
}

/* -----------------------------
   9. BUTTONS
----------------------------- */
button,
input[type="button"],
input[type="submit"],
.ast-button,
.ast-custom-button,
.wp-block-button__link,
a.wp-block-button__link,
a.button,
a.ast-button {
  font-family: var(--lm-font-body);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  border-radius: 999px;
  padding: 0.9rem 1.4rem;
  border: 1px solid var(--lm-color-navy);
  background: var(--lm-color-navy);
  color: var(--lm-color-soft-white);
  transition:
    background-color var(--lm-transition),
    color var(--lm-transition),
    border-color var(--lm-transition),
    transform var(--lm-transition),
    box-shadow var(--lm-transition);
  box-shadow: var(--lm-shadow-soft);
}

button:hover,
input[type="button"]:hover,
input[type="submit"]:hover,
.ast-button:hover,
.ast-custom-button:hover,
.wp-block-button__link:hover,
a.wp-block-button__link:hover,
a.button:hover,
a.ast-button:hover {
  background: var(--lm-color-gold);
  border-color: var(--lm-color-gold);
  color: var(--lm-color-charcoal);
  transform: translateY(-1px);
}

/* Secondary / ghost button utility */
.lm-button-secondary,
.lm-button-secondary .wp-block-button__link,
a.lm-button-secondary {
  background: transparent !important;
  color: var(--lm-color-navy) !important;
  border: 1px solid rgba(11, 31, 59, 0.18) !important;
  box-shadow: none !important;
}

.lm-button-secondary:hover,
.lm-button-secondary .wp-block-button__link:hover,
a.lm-button-secondary:hover {
  border-color: var(--lm-color-gold) !important;
  color: var(--lm-color-gold) !important;
  background: rgba(212, 175, 55, 0.05) !important;
}

/* -----------------------------
   10. FORM ELEMENTS
----------------------------- */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
textarea,
select {
  width: 100%;
  font-family: var(--lm-font-body);
  font-size: var(--lm-text-base);
  color: var(--lm-text-primary);
  background: #ffffff;
  border: 1px solid rgba(11, 31, 59, 0.14);
  border-radius: var(--lm-radius-md);
  padding: 0.85rem 1rem;
  transition:
    border-color var(--lm-transition),
    box-shadow var(--lm-transition),
    background-color var(--lm-transition);
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: rgba(212, 175, 55, 0.85);
  box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.14);
}

/* -----------------------------
   11. ARTICLE / CONTENT AREA
----------------------------- */
.entry-content {
  color: var(--lm-text-primary);
}

.entry-content > * {
  max-width: 760px;
}

.entry-content > .alignwide {
  max-width: 1100px;
}

.entry-content > .alignfull {
  max-width: 100%;
}

.entry-title,
.ast-article-single .entry-title,
.blog .entry-title,
.archive .entry-title {
  font-family: var(--lm-font-heading);
  color: var(--lm-color-navy);
  letter-spacing: -0.025em;
}

.entry-meta,
.entry-meta * {
  font-family: var(--lm-font-body);
  font-size: var(--lm-text-sm);
  color: var(--lm-text-muted);
}

/* -----------------------------
   12. CARDS / SURFACES
----------------------------- */
.lm-card {
  background: #ffffff;
  border: 1px solid rgba(11, 31, 59, 0.08);
  border-radius: var(--lm-radius-lg);
  box-shadow: var(--lm-shadow-card);
  padding: 1.5rem;
}

.lm-card-dark {
  background: linear-gradient(
    180deg,
    rgba(11, 31, 59, 0.96) 0%,
    rgba(12, 12, 14, 1) 100%
  );
  color: var(--lm-text-on-dark);
  border: 1px solid var(--lm-color-border-dark);
  border-radius: var(--lm-radius-lg);
  box-shadow: var(--lm-shadow-card);
  padding: 1.5rem;
}

.lm-card-dark h1,
.lm-card-dark h2,
.lm-card-dark h3,
.lm-card-dark h4,
.lm-card-dark h5,
.lm-card-dark h6,
.lm-card-dark p,
.lm-card-dark li,
.lm-card-dark a {
  color: var(--lm-text-on-dark);
}

.lm-card-dark a:hover {
  color: var(--lm-color-gold);
}

/* -----------------------------
   13. SECTION UTILITIES
----------------------------- */
.lm-section-light {
  background: var(--lm-bg-page);
  color: var(--lm-text-primary);
}

.lm-section-soft {
  background: var(--lm-bg-soft);
  color: var(--lm-text-primary);
}

.lm-section-deep {
  background: var(--lm-bg-deep);
  color: var(--lm-text-on-dark);
}

.lm-section-dark {
  background: var(--lm-bg-dark);
  color: var(--lm-text-on-dark);
}

.lm-section-deep h1,
.lm-section-deep h2,
.lm-section-deep h3,
.lm-section-deep h4,
.lm-section-deep h5,
.lm-section-deep h6,
.lm-section-dark h1,
.lm-section-dark h2,
.lm-section-dark h3,
.lm-section-dark h4,
.lm-section-dark h5,
.lm-section-dark h6 {
  color: var(--lm-text-on-dark);
}

.lm-section-deep p,
.lm-section-dark p,
.lm-section-deep li,
.lm-section-dark li {
  color: var(--lm-text-on-dark-muted);
}

/* -----------------------------
   14. GOLD ACCENT UTILITIES
----------------------------- */
.lm-accent {
  color: var(--lm-color-gold) !important;
}

.lm-rule {
  width: 72px;
  height: 2px;
  background: var(--lm-color-gold);
  border: 0;
  margin: 1rem 0 1.5rem;
}

.lm-kicker {
  display: inline-block;
  font-family: var(--lm-font-body);
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--lm-color-gold);
  margin-bottom: 1rem;
}

/* -----------------------------
   15. FOOTER
----------------------------- */
.site-footer,
.ast-footer-wrap {
  background: var(--lm-color-charcoal);
  color: var(--lm-text-on-dark-muted);
}

.site-footer a,
.ast-footer-wrap a {
  color: var(--lm-text-on-dark);
}

.site-footer a:hover,
.ast-footer-wrap a:hover {
  color: var(--lm-color-gold);
}

.site-footer h1,
.site-footer h2,
.site-footer h3,
.site-footer h4,
.site-footer h5,
.site-footer h6,
.ast-footer-wrap h1,
.ast-footer-wrap h2,
.ast-footer-wrap h3,
.ast-footer-wrap h4,
.ast-footer-wrap h5,
.ast-footer-wrap h6 {
  color: var(--lm-text-on-dark);
  font-family: var(--lm-font-heading);
}

/* -----------------------------
   16. SELECTION / HIGHLIGHT
----------------------------- */
::selection {
  background: rgba(212, 175, 55, 0.22);
  color: var(--lm-color-navy);
}

/* -----------------------------
   17. RESPONSIVE TUNING
----------------------------- */
@media (max-width: 921px) {
  p,
  .entry-content p {
    font-size: 1rem;
  }

  .main-header-menu > .menu-item > .menu-link,
  .ast-builder-menu .main-header-menu > .menu-item > .menu-link {
    font-size: 0.95rem;
  }

  .lm-card,
  .lm-card-dark {
    padding: 1.25rem;
  }
}

@media (max-width: 544px) {
  h1,
  .entry-content h1 {
    font-size: clamp(2.2rem, 8vw, 3rem);
  }

  h2,
  .entry-content h2 {
    font-size: clamp(1.7rem, 6.2vw, 2.3rem);
  }

  h3,
  .entry-content h3 {
    font-size: clamp(1.35rem, 5vw, 1.8rem);
  }

  p,
  .entry-content p {
    font-size: 1rem;
    line-height: 1.72;
  }
}