/* ============================================
   CRAIC & THE CARRIAGE — Custom CSS
   Palette: Black, Warm Walnut, Bronze
   Vibe: Sophisticated + Personality
   
   HOW TO INSTALL:
   1. Log into WordPress admin
   2. Go to Appearance → Customize → Additional CSS
   3. Paste this entire file
   4. Click "Publish"
   ============================================ */

/* ---------- CSS Variables ---------- */
:root {
  --black: #0f0f0f;
  --black-soft: #1a1a1a;
  --walnut: #5c4033;
  --walnut-light: #7a5c4f;
  --walnut-glow: #6b4a3a;
  --bronze: #c49a6c;
  --bronze-light: #d4ad7d;
  --bronze-bright: #dbb98f;
  --cream: #f5efe6;
  --cream-soft: #ebe3d7;
  --text-light: #f0ebe4;
  --text-muted: #a89a8c;
  --text-dark: #2c2420;
}

/* ---------- Global Foundation ---------- */
body {
  background-color: var(--black) !important;
  color: var(--text-light) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ---------- Typography ---------- */
/* Import premium fonts */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Raleway:wght@300;400;500;600;700&display=swap');

body,
.elementor-widget-text-editor,
.elementor-text-editor p,
p {
  font-family: 'Raleway', sans-serif !important;
  font-weight: 300 !important;
  letter-spacing: 0.02em !important;
  line-height: 1.75 !important;
  font-size: 16px !important;
  color: var(--text-light) !important;
}

h1, h2, h3, h4, h5, h6,
.elementor-heading-title,
.elementor-widget-heading .elementor-heading-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-weight: 500 !important;
  letter-spacing: 0.03em !important;
  line-height: 1.2 !important;
  color: var(--cream) !important;
}

h1, .elementor-widget-heading .elementor-heading-title.elementor-size-xxl {
  font-size: clamp(2.2rem, 5vw, 3.5rem) !important;
  font-weight: 600 !important;
}

h2, .elementor-widget-heading .elementor-heading-title.elementor-size-xl {
  font-size: clamp(1.8rem, 4vw, 2.8rem) !important;
}

h3, .elementor-widget-heading .elementor-heading-title.elementor-size-large {
  font-size: clamp(1.4rem, 3vw, 2rem) !important;
}

/* Bronze accent for key headings */
h2::after {
  content: '';
  display: block;
  width: 60px;
  height: 2px;
  background: linear-gradient(90deg, var(--bronze), transparent);
  margin-top: 12px;
}

/* Center the underline when text is centered */
.elementor-widget-heading[style*="text-align: center"] h2::after,
.has-text-align-center h2::after,
.elementor-align-center h2::after {
  margin-left: auto;
  margin-right: auto;
}

/* ---------- Links ---------- */
a {
  color: var(--bronze) !important;
  text-decoration: none !important;
  transition: color 0.3s ease !important;
}

a:hover {
  color: var(--bronze-bright) !important;
}

/* ---------- Navigation ---------- */
.elementor-nav-menu a,
nav a,
.menu-item a {
  font-family: 'Raleway', sans-serif !important;
  font-weight: 400 !important;
  font-size: 14px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--cream-soft) !important;
  transition: color 0.3s ease, border-bottom 0.3s ease !important;
  padding-bottom: 4px !important;
  border-bottom: 1.5px solid transparent !important;
}

.elementor-nav-menu a:hover,
nav a:hover,
.menu-item a:hover,
.elementor-nav-menu .current-menu-item a {
  color: var(--bronze) !important;
  border-bottom-color: var(--bronze) !important;
}

/* ---------- Buttons ---------- */
.elementor-button,
.elementor-widget-button a,
button,
input[type="submit"],
.wp-block-button__link,
.e-form__buttons__wrapper button {
  font-family: 'Raleway', sans-serif !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  background: linear-gradient(135deg, var(--bronze), var(--walnut)) !important;
  color: var(--cream) !important;
  border: none !important;
  border-radius: 2px !important;
  padding: 14px 36px !important;
  transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
  cursor: pointer !important;
  box-shadow: 0 2px 12px rgba(196, 154, 108, 0.15) !important;
}

.elementor-button:hover,
.elementor-widget-button a:hover,
button:hover,
input[type="submit"]:hover {
  background: linear-gradient(135deg, var(--bronze-bright), var(--walnut-light)) !important;
  box-shadow: 0 4px 20px rgba(196, 154, 108, 0.3) !important;
  transform: translateY(-1px) !important;
}

/* ---------- Sections & Backgrounds ---------- */
.elementor-section,
.elementor-top-section {
  background-color: var(--black) !important;
}

/* Add subtle walnut-tinted sections for visual rhythm */
.elementor-section:nth-child(even) {
  background-color: var(--black-soft) !important;
}

/* Section padding - more breathing room */
.elementor-section > .elementor-container {
  padding-top: 60px !important;
  padding-bottom: 60px !important;
}

/* ---------- Images ---------- */
.elementor-widget-image img,
.elementor-image img {
  border-radius: 3px !important;
  transition: transform 0.5s ease, box-shadow 0.5s ease !important;
}

.elementor-widget-image:hover img,
.elementor-image:hover img {
  transform: scale(1.02) !important;
  box-shadow: 0 8px 40px rgba(92, 64, 51, 0.2) !important;
}

/* ---------- Gallery ---------- */
.elementor-image-gallery img,
.gallery-item img,
.e-gallery-item img {
  border-radius: 3px !important;
  transition: all 0.4s ease !important;
  filter: brightness(0.92) !important;
}

.elementor-image-gallery img:hover,
.gallery-item img:hover,
.e-gallery-item img:hover {
  filter: brightness(1) !important;
  transform: scale(1.03) !important;
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.4) !important;
}

/* ---------- Social Icons ---------- */
.elementor-social-icon,
.elementor-icon {
  background-color: transparent !important;
  border: 1.5px solid var(--walnut-light) !important;
  border-radius: 50% !important;
  transition: all 0.3s ease !important;
  color: var(--bronze) !important;
}

.elementor-social-icon:hover,
.elementor-icon:hover {
  background-color: var(--bronze) !important;
  border-color: var(--bronze) !important;
  color: var(--black) !important;
  transform: translateY(-2px) !important;
}

.elementor-social-icon i,
.elementor-icon i {
  color: inherit !important;
}

/* ---------- Dividers / Separators ---------- */
.elementor-divider-separator {
  border-color: var(--walnut) !important;
  opacity: 0.4 !important;
}

/* ---------- FAQ / Accordion ---------- */
.elementor-accordion .elementor-accordion-item {
  border-color: var(--walnut) !important;
  background-color: var(--black-soft) !important;
  margin-bottom: 8px !important;
  border-radius: 3px !important;
}

.elementor-accordion .elementor-tab-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-weight: 500 !important;
  font-size: 1.15rem !important;
  color: var(--cream) !important;
  padding: 18px 24px !important;
  transition: background-color 0.3s ease !important;
}

.elementor-accordion .elementor-tab-title:hover {
  background-color: rgba(92, 64, 51, 0.15) !important;
}

.elementor-accordion .elementor-tab-title a {
  color: var(--cream) !important;
}

.elementor-accordion .elementor-tab-title .elementor-accordion-icon {
  color: var(--bronze) !important;
}

.elementor-accordion .elementor-tab-content {
  font-family: 'Raleway', sans-serif !important;
  color: var(--text-muted) !important;
  padding: 16px 24px 24px !important;
  line-height: 1.8 !important;
  background-color: var(--black-soft) !important;
}

/* ---------- Footer ---------- */
footer,
.elementor-location-footer,
footer .elementor-section {
  background-color: var(--black) !important;
  border-top: 1px solid rgba(92, 64, 51, 0.3) !important;
}

footer h6,
footer p,
footer a {
  color: var(--text-muted) !important;
}

footer a:hover {
  color: var(--bronze) !important;
}

/* ---------- Phone & Email Links ---------- */
a[href^="tel:"],
a[href^="mailto:"] {
  font-family: 'Cormorant Garamond', serif !important;
  font-weight: 500 !important;
  color: var(--bronze) !important;
  font-size: 1.1em !important;
}

/* ---------- Forms ---------- */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
textarea,
select,
.elementor-field-textual {
  background-color: var(--black-soft) !important;
  border: 1px solid var(--walnut) !important;
  border-radius: 2px !important;
  color: var(--text-light) !important;
  font-family: 'Raleway', sans-serif !important;
  font-size: 15px !important;
  padding: 12px 16px !important;
  transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
}

input:focus,
textarea:focus,
select:focus,
.elementor-field-textual:focus {
  border-color: var(--bronze) !important;
  box-shadow: 0 0 0 2px rgba(196, 154, 108, 0.15) !important;
  outline: none !important;
}

::placeholder {
  color: var(--text-muted) !important;
  font-weight: 300 !important;
}

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: var(--black);
}

::-webkit-scrollbar-thumb {
  background: var(--walnut);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--bronze);
}

/* ---------- Selection highlight ---------- */
::selection {
  background-color: var(--bronze);
  color: var(--black);
}

/* ---------- Mobile Responsive Refinements ---------- */
@media (max-width: 767px) {
  .elementor-section > .elementor-container {
    padding-top: 36px !important;
    padding-bottom: 36px !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  h1, .elementor-widget-heading .elementor-heading-title.elementor-size-xxl {
    font-size: 2rem !important;
  }

  h2, .elementor-widget-heading .elementor-heading-title.elementor-size-xl {
    font-size: 1.6rem !important;
  }

  .elementor-button,
  .elementor-widget-button a {
    padding: 12px 28px !important;
    font-size: 12px !important;
  }
}

/* ---------- Subtle page load animation ---------- */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.elementor-widget {
  animation: fadeInUp 0.6s ease forwards;
}

/* Stagger the animations slightly */
.elementor-widget:nth-child(1) { animation-delay: 0.05s; }
.elementor-widget:nth-child(2) { animation-delay: 0.1s; }
.elementor-widget:nth-child(3) { animation-delay: 0.15s; }
.elementor-widget:nth-child(4) { animation-delay: 0.2s; }
.elementor-widget:nth-child(5) { animation-delay: 0.25s; }

/* ---------- Custom "Irish" accent details ---------- */
/* Subtle bronze line at very top of page */
body::before {
  content: '';
  display: block;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--bronze), var(--walnut), var(--bronze), transparent);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
}
/* ============================================
   FIX: Override stubborn Elementor backgrounds
   ADD this to the BOTTOM of your existing CSS
   in Appearance → Customize → Additional CSS
   ============================================ */

/* Force dark backgrounds on ALL sections */
.elementor-section,
.elementor-top-section,
.elementor-inner-section,
.elementor-section-wrap > .elementor-section,
.elementor-element,
.elementor-column-wrap,
.elementor-widget-wrap,
.elementor-container,
section.elementor-section,
div.elementor-section,
.elementor-section[data-element_type="section"],
.elementor-section .elementor-container,
.elementor-section-boxed .elementor-container,
.e-con,
.e-con-inner,
.e-child {
  background-color: var(--black) !important;
  background-image: none !important;
}

/* Alternating darker sections for visual rhythm */
.elementor-top-section:nth-child(even),
.e-con:nth-child(even) {
  background-color: var(--black-soft) !important;
}

/* Force dark on page body and wrapper */
.elementor-page,
.page,
#content,
#primary,
.site-main,
.entry-content,
.page-content,
.elementor,
.elementor-inner,
.elementor-section-wrap,
main,
article {
  background-color: var(--black) !important;
}

/* Fix header/nav area background */
header,
.elementor-location-header,
.site-header,
.elementor-section.elementor-section-height-min-height,
#masthead {
  background-color: var(--black) !important;
}

/* Fix the logo white box - make background transparent */
.elementor-widget-image img[src*="SVG"],
.elementor-widget-image img[src*="cropped"],
.custom-logo,
.site-branding img,
header img {
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
}

/* Force all text to light on dark */
.elementor-widget-text-editor,
.elementor-text-editor,
.elementor-text-editor p,
.elementor-widget-text-editor p,
.elementor-heading-title,
.elementor-widget-heading .elementor-heading-title,
.elementor-tab-title,
.elementor-tab-content,
label,
span {
  color: var(--text-light) !important;
}

/* Fix heading colors specifically */
.elementor-widget-heading .elementor-heading-title {
  color: var(--cream) !important;
}

/* Fix form fields on Contact page */
.elementor-form .elementor-field,
.elementor-field-group input,
.elementor-field-group textarea,
.elementor-field-group select,
.wpcf7-form input,
.wpcf7-form textarea,
.wpcf7-form select,
input,
textarea,
select {
  background-color: var(--black-soft) !important;
  color: var(--text-light) !important;
  border: 1px solid var(--walnut) !important;
}

/* Fix form labels */
.elementor-field-label,
.wpcf7-form label,
label {
  color: var(--text-muted) !important;
}

/* Fix any white overlay sections */
.elementor-background-overlay {
  background-color: transparent !important;
  background-image: none !important;
}

/* Gallery page - ensure dark background behind images */
.elementor-image-gallery,
.elementor-widget-image-gallery,
.gallery,
.e-gallery,
.elementor-widget-gallery {
  background-color: var(--black) !important;
}

/* Fix FAQ/Accordion text visibility */
.elementor-accordion .elementor-tab-content p,
.elementor-accordion .elementor-tab-content {
  color: var(--text-muted) !important;
  background-color: var(--black-soft) !important;
}

.elementor-accordion .elementor-tab-title,
.elementor-accordion .elementor-tab-title a,
.elementor-accordion-title {
  color: var(--cream) !important;
  background-color: var(--black-soft) !important;
}

/* Fix any remaining white sections with inline styles */
[style*="background-color: #ffffff"],
[style*="background-color: #fff"],
[style*="background-color: white"],
[style*="background-color:#ffffff"],
[style*="background-color:#fff"],
[style*="background: #ffffff"],
[style*="background: #fff"],
[style*="background: white"],
[style*="background-color: rgb(255"],
[style*="background-color: rgba(255"] {
  background-color: var(--black) !important;
  background: var(--black) !important;
}

/* Fix light gray backgrounds */
[style*="background-color: #f"],
[style*="background-color: #e"],
[style*="background-color: #d"],
[style*="background-color: #c"] {
  background-color: var(--black-soft) !important;
  background: var(--black-soft) !important;
}body 
{ padding-top: 72px; }