/*
 Theme Name:   ABC's Clothing Line
 Theme URI:    https://www.facebook.com/abcsclothingline
 Description:  Child theme for ABC's Clothing Line — built on Astra
 Author:       ABC's Clothing Line
 Template:     astra
 Version:      1.0.0
 Text Domain:  abcs-child
*/

/* ─────────────────────────────────────────
   GOOGLE FONTS
───────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Open+Sans:wght@300;400;500;600&display=swap');

/* ─────────────────────────────────────────
   CSS VARIABLES
───────────────────────────────────────── */
:root {
  --cream:       #f8f5f0;
  --white:       #ffffff;
  --dark:        #18181a;
  --charcoal:    #2e2e30;
  --mid:         #666666;
  --muted:       #999999;
  --teal:        #1a6b5e;
  --teal-2:      #22897a;
  --teal-light:  #e6f2ef;
  --gold:        #c8a96e;
  --border:      #e2ddd8;
  --serif:       'Cormorant Garamond', serif;
  --sans:        'Open Sans', sans-serif;
}

/* ─────────────────────────────────────────
   GLOBAL BASE
───────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.75;
  color: var(--mid);
  background-color: var(--cream);
  -webkit-font-smoothing: antialiased;
}

/* ─────────────────────────────────────────
   TYPOGRAPHY
───────────────────────────────────────── */
h1, h2, h3, h4, h5, h6,
.entry-title,
.page-title {
  font-family: var(--serif);
  font-weight: 500;
  color: var(--dark);
  line-height: 1.05;
  letter-spacing: -0.3px;
}

h1 { font-size: clamp(2.8rem, 5vw, 4.8rem); letter-spacing: -0.5px; }
h2 { font-size: clamp(2rem, 3.5vw, 3rem); }
h3 { font-size: clamp(1.4rem, 2.5vw, 1.8rem); }
h4 { font-size: 1.2rem; }

p {
  font-family: var(--sans);
  font-size: 0.95rem;
  line-height: 1.8;
  color: var(--mid);
  font-weight: 300;
}

a {
  color: var(--teal);
  text-decoration: none;
  transition: color 0.2s ease;
}

a:hover {
  color: var(--teal-2);
}

h1 em, h2 em {
  font-style: italic;
  color: var(--teal);
}

/* ─────────────────────────────────────────
   ASTRA HEADER OVERRIDES
───────────────────────────────────────── */

/* Main header background */
.site-header,
#masthead,
.ast-header-break-point .site-header {
  background: rgba(248, 245, 240, 0.96) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border) !important;
  box-shadow: none !important;
}

/* Sticky header */
.ast-sticky-active #masthead,
.ast-header-sticked #masthead {
  background: rgba(248, 245, 240, 0.97) !important;
  box-shadow: 0 1px 0 var(--border) !important;
}

/* Site title / logo text */
.site-title,
.site-title a,
.ast-site-identity .site-title a {
  font-family: var(--serif) !important;
  font-size: 1.15rem !important;
  font-weight: 600 !important;
  color: var(--dark) !important;
  letter-spacing: 0.3px !important;
}

.site-title a:hover {
  color: var(--teal) !important;
}

/* Nav menu links */
.main-navigation .menu > li > a,
.ast-nav-menu > li > a,
#site-navigation .menu > li > a,
.main-header-menu > li > a {
  font-family: var(--sans) !important;
  font-size: 0.8rem !important;
  font-weight: 400 !important;
  color: var(--mid) !important;
  letter-spacing: 0.5px !important;
  text-transform: none !important;
  padding: 0 1.2rem !important;
  line-height: 60px !important;
}

.main-navigation .menu > li > a:hover,
.ast-nav-menu > li > a:hover,
#site-navigation .menu > li > a:hover {
  color: var(--teal) !important;
  background: transparent !important;
}

/* Active nav item */
.main-navigation .menu > .current-menu-item > a,
.ast-nav-menu > .current-menu-item > a,
.main-navigation .menu > .current_page_item > a {
  color: var(--teal) !important;
  border-bottom: 2px solid var(--teal) !important;
  font-weight: 500 !important;
}

/* Nav CTA button — last menu item styled as button */
.main-navigation .menu > li.menu-item-button > a,
.ast-nav-menu > li.menu-item-button > a {
  background: var(--teal) !important;
  color: #fff !important;
  border-radius: 4px !important;
  padding: 0.55rem 1.4rem !important;
  line-height: normal !important;
  font-size: 0.78rem !important;
  font-weight: 500 !important;
  border-bottom: none !important;
  margin-left: 0.75rem;
  align-self: center;
}

.main-navigation .menu > li.menu-item-button > a:hover,
.ast-nav-menu > li.menu-item-button > a:hover {
  background: var(--teal-2) !important;
  color: #fff !important;
}

/* ─────────────────────────────────────────
   ASTRA FOOTER OVERRIDES
───────────────────────────────────────── */
.site-footer,
#colophon,
.ast-footer-widget-area,
.ast-footer-copyright {
  background: #111113 !important;
  color: rgba(255, 255, 255, 0.35) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
}

.site-footer a,
#colophon a,
.ast-footer-copyright a {
  color: rgba(255, 255, 255, 0.35) !important;
  font-size: 0.75rem !important;
  transition: color 0.2s !important;
  text-decoration: none !important;
}

.site-footer a:hover,
#colophon a:hover {
  color: var(--gold) !important;
}

.ast-footer-copyright .ast-copyright-text,
.site-info {
  font-size: 0.7rem !important;
  color: rgba(255, 255, 255, 0.2) !important;
  font-family: var(--sans) !important;
}

/* Footer widgets */
.ast-footer-widget-area .widget-title,
.footer-widget-area .widget-title {
  font-family: var(--serif) !important;
  color: rgba(255, 255, 255, 0.7) !important;
  font-size: 1rem !important;
}

/* ─────────────────────────────────────────
   ASTRA PAGE / CONTENT AREA
───────────────────────────────────────── */

/* Remove default Astra page padding when using Elementor */
.elementor-page .entry-content,
.ast-page-builder-template .entry-content {
  padding: 0 !important;
  margin: 0 !important;
}

/* Full-width layout */
.ast-page-builder-template #primary,
.elementor-page #primary {
  padding: 0 !important;
  margin: 0 !important;
}

/* Remove Astra's default content max-width when Elementor handles it */
.ast-container,
.ast-page-builder-template .ast-container {
  max-width: 100% !important;
  padding: 0 !important;
}

/* ─────────────────────────────────────────
   LAYOUT UTILITIES
───────────────────────────────────────── */
.abcs-inner {
  max-width: 1040px;
  margin: 0 auto;
  padding: 0 3rem;
}

@media (max-width: 768px) {
  .abcs-inner { padding: 0 1.5rem; }
}

/* ─────────────────────────────────────────
   SECTION STYLES
───────────────────────────────────────── */
.abcs-section         { padding: 80px 0; }
.abcs-section--white  { background: var(--white); }
.abcs-section--cream  { background: var(--cream); }
.abcs-section--dark   { background: var(--dark); }
.abcs-section--teal   { background: var(--teal); }

.abcs-section--dark h1,
.abcs-section--dark h2,
.abcs-section--dark h3 { color: var(--cream); }
.abcs-section--dark p  { color: rgba(248,245,240,0.55); }
.abcs-section--teal h1,
.abcs-section--teal h2,
.abcs-section--teal p  { color: #fff; }

/* ─────────────────────────────────────────
   EYEBROW LABEL
───────────────────────────────────────── */
.abcs-eyebrow {
  font-family: var(--sans);
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--teal);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}

.abcs-eyebrow::before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 1px;
  background: var(--teal);
  flex-shrink: 0;
}

.abcs-eyebrow--gold { color: var(--gold); }
.abcs-eyebrow--gold::before { background: var(--gold); }

/* ─────────────────────────────────────────
   BUTTONS
───────────────────────────────────────── */
.elementor-button,
.wp-block-button__link,
.abcs-btn {
  font-family: var(--sans) !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.5px !important;
  border-radius: 4px !important;
  padding: 14px 32px !important;
  transition: background 0.2s ease, transform 0.15s ease !important;
  text-decoration: none !important;
  cursor: pointer !important;
  border: none !important;
  display: inline-block !important;
}

.abcs-btn-primary,
.elementor-button.abcs-btn-primary {
  background: var(--teal) !important;
  color: #fff !important;
}
.abcs-btn-primary:hover { background: var(--teal-2) !important; transform: translateY(-2px); }

.abcs-btn-white { background: #fff !important; color: var(--teal) !important; }
.abcs-btn-white:hover { opacity: 0.9; color: var(--teal) !important; }

.abcs-btn-gold { background: var(--gold) !important; color: var(--dark) !important; font-weight: 600 !important; }

.abcs-btn-ghost {
  background: transparent !important;
  color: var(--mid) !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: 0 !important;
  padding: 0 0 2px 0 !important;
}
.abcs-btn-ghost:hover { color: var(--teal) !important; border-color: var(--teal) !important; }

/* ─────────────────────────────────────────
   CARDS
───────────────────────────────────────── */
.abcs-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 2.5rem 2rem;
  transition: box-shadow 0.25s, transform 0.25s;
}
.abcs-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.07);
  transform: translateY(-4px);
}

.abcs-card-num {
  font-family: var(--serif);
  font-size: 0.75rem;
  color: var(--gold);
  letter-spacing: 2px;
  font-weight: 500;
  margin-bottom: 1.5rem;
  display: block;
}

.abcs-icon-box {
  width: 48px;
  height: 48px;
  background: var(--teal-light);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
}

.abcs-tag {
  display: inline-block;
  margin-top: 1.25rem;
  font-size: 0.65rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--teal);
  font-weight: 500;
  border-bottom: 1px solid var(--teal);
  padding-bottom: 2px;
  font-family: var(--sans);
}

/* ─────────────────────────────────────────
   GRIDS
───────────────────────────────────────── */
.abcs-grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.5rem; }
.abcs-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.abcs-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; }

.abcs-grid-bordered {
  display: grid;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}
.abcs-grid-bordered > * { background: var(--cream); }

@media (max-width: 768px) {
  .abcs-grid-2,
  .abcs-grid-3,
  .abcs-grid-4 { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────
   MARQUEE
───────────────────────────────────────── */
.abcs-marquee-wrap {
  overflow: hidden;
  background: var(--teal);
  padding: 0.6rem 0;
}
.abcs-marquee-track {
  display: flex;
  gap: 3rem;
  white-space: nowrap;
  animation: abcs-marquee 24s linear infinite;
}
.abcs-marquee-track span {
  font-family: var(--sans);
  font-size: 0.67rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  flex-shrink: 0;
}
.abcs-marquee-track strong {
  color: rgba(255,255,255,0.85);
  font-weight: 500;
}
@keyframes abcs-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ─────────────────────────────────────────
   PROCESS STEPS (dark bg)
───────────────────────────────────────── */
.abcs-step {
  padding: 2.5rem 2rem;
  border-right: 1px solid rgba(255,255,255,0.07);
}
.abcs-step:last-child { border-right: none; }
.abcs-step-num {
  font-family: var(--serif);
  font-size: 2.5rem;
  font-weight: 600;
  color: rgba(255,255,255,0.06);
  line-height: 1;
  margin-bottom: 1.25rem;
}
.abcs-step-tag {
  font-size: 0.65rem;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 500;
  margin-bottom: 0.6rem;
  font-family: var(--sans);
  display: block;
}
.abcs-step-title {
  font-family: var(--serif);
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--cream);
  margin-bottom: 0.6rem;
}
.abcs-step-desc {
  font-size: 0.82rem;
  line-height: 1.75;
  color: rgba(248,245,240,0.45);
  font-weight: 300;
}

/* ─────────────────────────────────────────
   TESTIMONIALS
───────────────────────────────────────── */
.abcs-testi { background: var(--white); padding: 2.25rem 2rem; }
.abcs-testi-stars { display: flex; gap: 3px; margin-bottom: 1rem; }
.abcs-testi-star { width: 10px; height: 10px; background: var(--gold); border-radius: 50%; }
.abcs-testi-quote {
  font-family: var(--serif);
  font-size: 1rem;
  font-style: italic;
  line-height: 1.75;
  color: var(--charcoal);
  margin-bottom: 1.5rem;
  font-weight: 400;
}
.abcs-testi-author {
  font-size: 0.72rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 500;
  font-family: var(--sans);
}

/* ─────────────────────────────────────────
   FAQ ACCORDION
───────────────────────────────────────── */
.abcs-faq-list { border-top: 1px solid var(--border); }
.abcs-faq-item { border-bottom: 1px solid var(--border); }
.abcs-faq-btn {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.2rem 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  gap: 1rem;
}
.abcs-faq-q {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--dark);
  font-family: var(--sans);
}
.abcs-faq-icon {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  color: var(--muted);
  flex-shrink: 0;
  transition: all 0.2s;
  line-height: 1;
}
.abcs-faq-item.open .abcs-faq-icon {
  background: var(--teal);
  border-color: var(--teal);
  color: #fff;
  transform: rotate(45deg);
}
.abcs-faq-answer {
  font-size: 0.85rem;
  line-height: 1.8;
  color: var(--mid);
  padding-bottom: 1.25rem;
  display: none;
  font-weight: 300;
  font-family: var(--sans);
}
.abcs-faq-item.open .abcs-faq-answer { display: block; }

/* ─────────────────────────────────────────
   NOTICE / CALLOUT
───────────────────────────────────────── */
.abcs-notice {
  padding: 1.25rem 1.5rem;
  border-left: 3px solid var(--teal);
  background: var(--teal-light);
  font-size: 0.82rem;
  color: var(--charcoal);
  line-height: 1.65;
  font-family: var(--sans);
}
.abcs-notice strong { color: var(--teal); }

/* ─────────────────────────────────────────
   WOOCOMMERCE OVERRIDES
───────────────────────────────────────── */
.woocommerce .button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button {
  font-family: var(--sans) !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  background: var(--teal) !important;
  color: #fff !important;
  border-radius: 4px !important;
  padding: 12px 28px !important;
  letter-spacing: 0.5px !important;
  border: none !important;
  transition: background 0.2s !important;
}
.woocommerce .button:hover,
.woocommerce button.button:hover,
.woocommerce a.button:hover {
  background: var(--teal-2) !important;
  color: #fff !important;
}
.woocommerce .button.alt,
.woocommerce button.button.alt {
  background: var(--teal) !important;
}

.woocommerce-Price-amount,
.woocommerce .price {
  font-family: var(--serif) !important;
  color: var(--teal) !important;
  font-weight: 600 !important;
  font-size: 1.1rem !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--serif) !important;
  font-size: 1.1rem !important;
  font-weight: 500 !important;
  color: var(--dark) !important;
}

.woocommerce ul.products li.product {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  border-radius: 4px !important;
  overflow: hidden !important;
  transition: box-shadow 0.25s, transform 0.2s !important;
}
.woocommerce ul.products li.product:hover {
  box-shadow: 0 6px 28px rgba(0,0,0,0.07) !important;
  transform: translateY(-3px) !important;
}

.woocommerce-breadcrumb {
  font-family: var(--sans) !important;
  font-size: 0.78rem !important;
  color: var(--muted) !important;
}

.woocommerce-tabs .tabs li a {
  font-family: var(--sans) !important;
  font-size: 0.82rem !important;
  color: var(--mid) !important;
}
.woocommerce-tabs .tabs li.active a {
  color: var(--teal) !important;
}

.woocommerce .woocommerce-ordering select,
.woocommerce-page .woocommerce-ordering select {
  font-family: var(--sans) !important;
  font-size: 0.82rem !important;
  border: 1px solid var(--border) !important;
  border-radius: 4px !important;
  color: var(--mid) !important;
}

/* Cart & Checkout */
.woocommerce table.shop_table th {
  font-family: var(--sans) !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  color: var(--dark) !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  border-bottom: 1px solid var(--border) !important;
}
.woocommerce table.shop_table td {
  font-family: var(--sans) !important;
  font-size: 0.88rem !important;
  color: var(--mid) !important;
  border-bottom: 1px solid var(--border) !important;
}

/* Order form inputs */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
  font-family: var(--sans) !important;
  font-size: 0.88rem !important;
  border: 1px solid var(--border) !important;
  border-radius: 4px !important;
  padding: 10px 14px !important;
  color: var(--dark) !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--teal) !important;
  outline: none !important;
}

/* Form labels */
.woocommerce form .form-row label {
  font-family: var(--sans) !important;
  font-size: 0.78rem !important;
  font-weight: 500 !important;
  color: var(--dark) !important;
  letter-spacing: 0.3px !important;
}

/* ─────────────────────────────────────────
   ELEMENTOR OVERRIDES
───────────────────────────────────────── */
.elementor-widget-heading .elementor-heading-title {
  font-family: var(--serif) !important;
}
.elementor-widget-text-editor p {
  font-family: var(--sans) !important;
  font-size: 0.95rem !important;
  color: var(--mid) !important;
  font-weight: 300 !important;
  line-height: 1.8 !important;
}
.elementor-widget-divider .elementor-divider-separator {
  border-color: var(--border) !important;
}

/* ─────────────────────────────────────────
   UTILITIES
───────────────────────────────────────── */
.text-teal   { color: var(--teal)     !important; }
.text-gold   { color: var(--gold)     !important; }
.text-dark   { color: var(--dark)     !important; }
.text-mid    { color: var(--mid)      !important; }
.text-muted  { color: var(--muted)    !important; }
.text-cream  { color: var(--cream)    !important; }
.text-white  { color: #fff            !important; }

.bg-cream    { background: var(--cream)       !important; }
.bg-white    { background: var(--white)       !important; }
.bg-dark     { background: var(--dark)        !important; }
.bg-teal     { background: var(--teal)        !important; }
.bg-teal-lt  { background: var(--teal-light)  !important; }
.bg-gold     { background: var(--gold)        !important; }

.font-serif  { font-family: var(--serif) !important; }
.font-sans   { font-family: var(--sans)  !important; }
.font-300    { font-weight: 300 !important; }
.font-400    { font-weight: 400 !important; }
.font-500    { font-weight: 500 !important; }
.font-600    { font-weight: 600 !important; }

.uppercase     { text-transform: uppercase !important; }
.italic        { font-style: italic        !important; }
.tracking-wide { letter-spacing: 2px       !important; }
.tracking-xl   { letter-spacing: 3px       !important; }

.border-t { border-top:    1px solid var(--border) !important; }
.border-b { border-bottom: 1px solid var(--border) !important; }
.border-r { border-right:  1px solid var(--border) !important; }
.border-l { border-left:   1px solid var(--border) !important; }

.rounded     { border-radius: 4px  !important; }
.rounded-sm  { border-radius: 2px  !important; }
.rounded-full{ border-radius: 50%  !important; }

@keyframes abcs-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}
.abcs-pulse { animation: abcs-pulse 2s infinite; }
