/* ============================================================
   MAHRAJ INDUSTRIES — CUSTOM THEME OVERRIDE
   Version: 2.0 | February 2026
   Scope: UI only — Colors, Typography, Responsive Layout
   No content or URL changes.
   ============================================================ */

/* ── GOOGLE FONTS IMPORT ─────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@300;400;500;600;700&family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

/* ── CSS CUSTOM PROPERTIES (DESIGN TOKENS) ───────────────── */
:root {
  /* Brand Colors */
  --mi-primary:          #D64E02;   /* Refined deep orange */
  --mi-primary-dark:     #B84000;   /* Hover / pressed */
  --mi-primary-light:    #FF6B2B;   /* Accent / highlights */
  --mi-primary-pale:     #FFF0E8;   /* Tinted backgrounds */
  --mi-primary-border:   #F0C4A8;   /* Light border tint */

  /* Neutrals */
  --mi-dark:             #0F1923;   /* Headings */
  --mi-dark-2:           #1E2A36;   /* Sub-headings, nav bg */
  --mi-text:             #374151;   /* Body text */
  --mi-text-muted:       #6B7280;   /* Muted / secondary text */
  --mi-border:           #E5E7EB;   /* Default border */
  --mi-bg-light:         #F9FAFB;   /* Section backgrounds */
  --mi-bg-card:          #FFFFFF;   /* Card background */
  --mi-white:            #FFFFFF;

  /* Typography */
  --mi-font-body:        'Inter', 'Poppins', sans-serif;
  --mi-font-heading:     'Space Grotesk', 'Poppins', sans-serif;
  --mi-font-accent:      'Poppins', sans-serif;

  /* Font Sizes — Fluid Scale */
  --mi-fs-xs:            0.75rem;    /* 12px */
  --mi-fs-sm:            0.875rem;   /* 14px */
  --mi-fs-base:          1rem;       /* 16px */
  --mi-fs-md:            1.0625rem;  /* 17px */
  --mi-fs-lg:            1.125rem;   /* 18px */
  --mi-fs-xl:            1.25rem;    /* 20px */
  --mi-fs-2xl:           1.5rem;     /* 24px */
  --mi-fs-3xl:           1.875rem;   /* 30px */
  --mi-fs-4xl:           2.25rem;    /* 36px */
  --mi-fs-5xl:           3rem;       /* 48px */

  /* Spacing */
  --mi-radius:           8px;
  --mi-radius-md:        12px;
  --mi-radius-lg:        16px;
  --mi-radius-xl:        24px;
  --mi-shadow:           0 4px 16px rgba(0,0,0,0.08);
  --mi-shadow-md:        0 8px 32px rgba(0,0,0,0.12);
  --mi-shadow-hover:     0 12px 40px rgba(214,78,2,0.18);

  /* Transitions */
  --mi-transition:       all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

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

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body,
body.home,
body.page,
body.single {
  font-family: var(--mi-font-body) !important;
  font-size: var(--mi-fs-base) !important;
  line-height: 1.7 !important;
  color: var(--mi-text) !important;
  background-color: var(--mi-white) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── HEADINGS ─────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6,
.elementor-heading-title,
.title,
.rs-split-text-disable {
  font-family: var(--mi-font-heading) !important;
  color: var(--mi-dark) !important;
  line-height: 1.25 !important;
  letter-spacing: -0.02em;
  font-weight: 700 !important;
}

h1, .elementor-heading-title.elementor-size-xxl {
  font-size: clamp(2rem, 4.5vw, 3.5rem) !important;
  line-height: 1.15 !important;
}

h2, .elementor-heading-title.elementor-size-xl {
  font-size: clamp(1.6rem, 3.5vw, 2.5rem) !important;
}

h3, .elementor-heading-title.elementor-size-large {
  font-size: clamp(1.25rem, 2.5vw, 1.875rem) !important;
}

h4, .elementor-heading-title.elementor-size-medium {
  font-size: clamp(1.1rem, 2vw, 1.375rem) !important;
}

h5 { font-size: var(--mi-fs-xl) !important; }
h6 { font-size: var(--mi-fs-lg) !important; }

/* ── LINKS ────────────────────────────────────────────────── */
a {
  color: var(--mi-primary) !important;
  text-decoration: none !important;
  transition: var(--mi-transition) !important;
}
a:hover {
  color: var(--mi-primary-dark) !important;
}

/* ── BODY TEXT ────────────────────────────────────────────── */
p,
.desc-text,
.description,
.elementor-text-editor p {
  font-family: var(--mi-font-body) !important;
  font-size: var(--mi-fs-md) !important;
  line-height: 1.75 !important;
  color: var(--mi-text) !important;
}

/* ── NAVBAR ───────────────────────────────────────────────── */
#masthead,
.site-header,
header,
.elementor-nav-menu,
nav,
.elementor-location-header {
  background-color: var(--mi-dark-2) !important;
}

/* Nav links */
.elementor-nav-menu .elementor-item,
.elementor-nav-menu a,
nav a,
.elementor-sub-item {
  font-family: var(--mi-font-body) !important;
  font-size: var(--mi-fs-sm) !important;
  font-weight: 500 !important;
  letter-spacing: 0.03em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.88) !important;
  transition: var(--mi-transition) !important;
}

.elementor-nav-menu .elementor-item:hover,
.elementor-nav-menu .elementor-item.elementor-item-active,
nav a:hover {
  color: var(--mi-primary-light) !important;
}

/* Dropdown menu */
.sub-menu,
.elementor-nav-menu--dropdown,
.sub-menu.elementor-nav-menu--dropdown {
  background-color: var(--mi-dark) !important;
  border-top: 2px solid var(--mi-primary) !important;
  border-radius: 0 0 var(--mi-radius-md) var(--mi-radius-md) !important;
  box-shadow: var(--mi-shadow-md) !important;
}

.sub-menu .elementor-sub-item,
.elementor-nav-menu--dropdown a {
  font-size: var(--mi-fs-xs) !important;
  padding: 0.55rem 1.25rem !important;
  color: rgba(255,255,255,0.8) !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
}

.sub-menu .elementor-sub-item:hover,
.elementor-nav-menu--dropdown a:hover {
  color: var(--mi-primary-light) !important;
  background-color: rgba(255,255,255,0.05) !important;
}

/* ── HERO / BANNER SECTIONS ───────────────────────────────── */
.e-con[style*="background"],
section[style*="background-image"],
.hero-section,
[class*="hero"],
[class*="banner"] {
  position: relative;
}

/* ── SECTION BACKGROUNDS ──────────────────────────────────── */
.e-con,
.elementor-section,
section {
  background-color: inherit;
}

/* Alternating light sections */
.e-con > .e-con-inner,
.elementor-section-boxed > .elementor-container {
  max-width: 1280px !important;
}

/* ── BUTTONS ──────────────────────────────────────────────── */
.rs-btn,
.rs-button .rs-btn,
.elementor-button,
button,
input[type="submit"],
.wpcf7-submit,
.btn,
.button {
  font-family: var(--mi-font-body) !important;
  font-size: var(--mi-fs-sm) !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  border-radius: var(--mi-radius) !important;
  transition: var(--mi-transition) !important;
  cursor: pointer !important;
}

/* Primary filled button */
.elementor-button.elementor-button-link,
a.elementor-button,
.rs-btn {
  background-color: var(--mi-primary) !important;
  color: var(--mi-white) !important;
  border: 2px solid var(--mi-primary) !important;
  padding: 0.75rem 1.75rem !important;
  box-shadow: 0 4px 14px rgba(214,78,2,0.3) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
}

.elementor-button.elementor-button-link:hover,
a.elementor-button:hover,
.rs-btn:hover {
  background-color: var(--mi-primary-dark) !important;
  border-color: var(--mi-primary-dark) !important;
  color: var(--mi-white) !important;
  box-shadow: var(--mi-shadow-hover) !important;
  transform: translateY(-2px) !important;
}

/* ── SERVICE CARDS ────────────────────────────────────────── */
.rs-addon-services.style1 .services-inner,
.services-inner {
  background-color: var(--mi-bg-light) !important;
  border: 1px solid var(--mi-border) !important;
  border-radius: var(--mi-radius-md) !important;
  padding: 2rem 1.75rem !important;
  transition: var(--mi-transition) !important;
  box-shadow: var(--mi-shadow) !important;
}

.rs-addon-services.style1 .services-inner:hover {
  background-color: var(--mi-primary) !important;
  border-color: var(--mi-primary) !important;
  box-shadow: var(--mi-shadow-hover) !important;
  transform: translateY(-4px) !important;
}

.rs-addon-services.style1 .services-inner .services-title .title {
  font-family: var(--mi-font-heading) !important;
  font-size: var(--mi-fs-xl) !important;
  font-weight: 700 !important;
  color: var(--mi-dark) !important;
  margin-top: 1.25rem !important;
  margin-bottom: 0.75rem !important;
}

.rs-addon-services.style1 .services-inner:hover .services-title .title,
.rs-addon-services.style1 .services-inner:hover .desc-text {
  color: var(--mi-white) !important;
}

/* ── SECTION HEADINGS (Sub-text label) ────────────────────── */
.prelements-heading .title-inner span.sub-text,
.sub-text {
  font-family: var(--mi-font-body) !important;
  font-size: var(--mi-fs-xs) !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--mi-primary) !important;
  background-color: var(--mi-primary-pale) !important;
  padding: 0.3rem 0.85rem !important;
  border-radius: 50px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.35rem !important;
}

/* ── TESTIMONIAL CARDS ────────────────────────────────────── */
.rs-testimonial-slider.style1 .testimonial-inner {
  background-color: var(--mi-bg-card) !important;
  border: 1px solid var(--mi-border) !important;
  border-radius: var(--mi-radius-lg) !important;
  padding: 1.75rem !important;
  box-shadow: var(--mi-shadow) !important;
  transition: var(--mi-transition) !important;
}

.rs-testimonial-slider.style1 .testimonial-inner:hover {
  box-shadow: var(--mi-shadow-md) !important;
  border-color: var(--mi-primary-border) !important;
  transform: translateY(-3px) !important;
}

/* Star ratings */
.rs-testimonial-slider .ratings i,
.ri-star-fill {
  color: #F59E0B !important;
  font-size: 1rem !important;
}

/* ── ICON BOX ─────────────────────────────────────────────── */
.rs-iconbox-area .box-inner {
  border-radius: var(--mi-radius-md) !important;
  transition: var(--mi-transition) !important;
  padding: 1.25rem !important;
}

.rs-iconbox-area .box-inner .text-area .iconbox-title .title {
  font-family: var(--mi-font-heading) !important;
  font-size: var(--mi-fs-lg) !important;
  font-weight: 600 !important;
  color: var(--mi-dark) !important;
}

/* ── TABS ─────────────────────────────────────────────────── */
.content--teb-area .tab-button-area a {
  font-family: var(--mi-font-body) !important;
  font-size: var(--mi-fs-sm) !important;
  font-weight: 600 !important;
  color: var(--mi-text-muted) !important;
  transition: var(--mi-transition) !important;
  padding: 0.5rem 0 !important;
  border-bottom: 2px solid transparent !important;
}

.content--teb-area .tab-button-area a:hover,
.content--teb-area .tab-button-area a.active {
  color: var(--mi-primary) !important;
  border-bottom-color: var(--mi-primary) !important;
}

/* ── FAQ SECTION ──────────────────────────────────────────── */
.faq-section,
.accordion-item,
.accordion-headerd {
  border: 1px solid var(--mi-border) !important;
  border-radius: var(--mi-radius-md) !important;
  margin-bottom: 0.75rem !important;
  overflow: hidden !important;
}

.accordion-button,
.nav-link.accordion-button {
  font-family: var(--mi-font-heading) !important;
  font-size: var(--mi-fs-md) !important;
  font-weight: 600 !important;
  color: var(--mi-dark) !important;
  background-color: var(--mi-bg-light) !important;
  padding: 1rem 1.25rem !important;
}

.accordion-button:not(.collapsed),
.nav-link.accordion-button:not(.collapsed) {
  color: var(--mi-primary) !important;
  background-color: var(--mi-primary-pale) !important;
}

.answer,
.rstab-main .tab-content p {
  font-size: var(--mi-fs-base) !important;
  line-height: 1.75 !important;
  color: var(--mi-text) !important;
  padding: 1rem 1.25rem !important;
}

/* ── LOGO GRID ────────────────────────────────────────────── */
.rs-addon-slider.rsl_logo_style2 .rs-grid-figure {
  background-color: var(--mi-bg-light) !important;
  border-radius: var(--mi-radius-md) !important;
  border: 1px solid var(--mi-border) !important;
  transition: var(--mi-transition) !important;
}

.rs-addon-slider.rsl_logo_style2 .rs-grid-figure:hover {
  border-color: var(--mi-primary-border) !important;
  box-shadow: var(--mi-shadow-hover) !important;
}

/* ── CONTACT FORM ─────────────────────────────────────────── */
.wpcf7 input:not([type="submit"]),
.wpcf7 textarea,
.wpcf7 select,
input[type="text"],
input[type="email"],
input[type="tel"],
textarea,
select {
  font-family: var(--mi-font-body) !important;
  font-size: var(--mi-fs-base) !important;
  color: var(--mi-text) !important;
  background-color: var(--mi-bg-light) !important;
  border: 1.5px solid var(--mi-border) !important;
  border-radius: var(--mi-radius) !important;
  padding: 0.75rem 1rem !important;
  width: 100% !important;
  transition: var(--mi-transition) !important;
  outline: none !important;
}

.wpcf7 input:not([type="submit"]):focus,
.wpcf7 textarea:focus,
input[type="text"]:focus,
input[type="email"]:focus,
textarea:focus {
  border-color: var(--mi-primary) !important;
  background-color: var(--mi-white) !important;
  box-shadow: 0 0 0 3px rgba(214,78,2,0.12) !important;
}

/* ── FOOTER ───────────────────────────────────────────────── */
footer,
#colophon,
.site-footer,
.elementor-location-footer > .e-con {
  background-color: var(--mi-dark) !important;
  color: rgba(255,255,255,0.75) !important;
}

footer h2, footer h3, footer h4, footer h5, footer h6,
.site-footer h2, .site-footer h3, .site-footer h4,
.elementor-location-footer h2,
.elementor-location-footer h3,
.elementor-location-footer h4 {
  color: var(--mi-white) !important;
  font-family: var(--mi-font-heading) !important;
  font-size: var(--mi-fs-xl) !important;
  font-weight: 700 !important;
}

footer p,
footer a,
.site-footer p,
.site-footer a {
  font-size: var(--mi-fs-sm) !important;
  color: rgba(255,255,255,0.7) !important;
  line-height: 1.8 !important;
}

footer a:hover,
.site-footer a:hover {
  color: var(--mi-primary-light) !important;
}

footer .elementor-icon-list-text,
.site-footer .elementor-icon-list-text {
  font-size: var(--mi-fs-sm) !important;
  color: rgba(255,255,255,0.72) !important;
}

/* Footer icon list icons */
footer .elementor-icon-list-icon,
.site-footer .elementor-icon-list-icon {
  color: var(--mi-primary-light) !important;
}

/* ── BREADCRUMBS ──────────────────────────────────────────── */
.breadcrumbs,
.rank-math-breadcrumb,
nav.woocommerce-breadcrumb {
  font-size: var(--mi-fs-xs) !important;
  color: var(--mi-text-muted) !important;
}

/* ── WHATSAPP CHAT BUTTON ─────────────────────────────────── */
.ht-ctc-chat {
  filter: drop-shadow(0 4px 12px rgba(37,211,102,0.4)) !important;
}

/* ── IMAGE STYLING ────────────────────────────────────────── */
img {
  max-width: 100% !important;
  height: auto !important;
}

.rs-image img,
.elementor-image img {
  border-radius: var(--mi-radius) !important;
}

/* ── GENERAL SECTION SPACING ──────────────────────────────── */
.e-con,
.elementor-section {
  padding-top: clamp(2.5rem, 5vw, 5rem) !important;
  padding-bottom: clamp(2.5rem, 5vw, 5rem) !important;
}

/* ── CLIP PATH OVERRIDES ──────────────────────────────────── */
.services-inner.clip-path-enable {
  clip-path: polygon(0 0, 85% 0, 100% 15%, 100% 100%, 0 100%) !important;
}

/* ── ELEMENTOR OVERRIDES ──────────────────────────────────── */
.elementor-widget-heading .elementor-heading-title {
  font-family: var(--mi-font-heading) !important;
}

.elementor-widget-text-editor {
  font-family: var(--mi-font-body) !important;
  font-size: var(--mi-fs-md) !important;
  line-height: 1.75 !important;
}

/* ── SMOOTH REVEAL (non-blocking) ─────────────────────────── */
@media (prefers-reduced-motion: no-preference) {
  .e-con,
  .services-inner,
  .testimonial-inner {
    will-change: transform;
  }
}

/* ─────────────────────────────────────────────────────────── */
/* RESPONSIVE OVERRIDES                                        */
/* ─────────────────────────────────────────────────────────── */

/* ── TABLET (max-width: 1024px) ──────────────────────────── */
@media screen and (max-width: 1024px) {
  :root {
    --mi-fs-base: 0.9375rem;
  }

  .e-con,
  .elementor-section {
    padding-top: clamp(2rem, 4vw, 3.5rem) !important;
    padding-bottom: clamp(2rem, 4vw, 3.5rem) !important;
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }

  h1, .elementor-heading-title.elementor-size-xxl {
    font-size: clamp(1.75rem, 4vw, 2.5rem) !important;
  }

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

/* ── MOBILE (max-width: 768px) ───────────────────────────── */
@media screen and (max-width: 768px) {
  :root {
    --mi-fs-base: 0.9375rem;
    --mi-fs-md:   1rem;
  }

  body {
    font-size: var(--mi-fs-base) !important;
  }

  /* Layout */
  .e-con,
  .elementor-section {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
  }

  /* Headings fluid scale */
  h1 {
    font-size: clamp(1.6rem, 7vw, 2.25rem) !important;
    line-height: 1.2 !important;
  }

  h2 {
    font-size: clamp(1.35rem, 6vw, 1.75rem) !important;
  }

  h3 {
    font-size: clamp(1.1rem, 5vw, 1.375rem) !important;
  }

  h4, h5, h6 {
    font-size: var(--mi-fs-xl) !important;
  }

  p, .desc-text, .description {
    font-size: var(--mi-fs-base) !important;
    line-height: 1.7 !important;
  }

  /* Service cards stack on mobile */
  .rs-addon-services.style1 .services-inner {
    padding: 1.5rem 1.25rem !important;
    margin-bottom: 1rem !important;
  }

  .rs-addon-services.style1 .services-inner .services-title .title {
    font-size: var(--mi-fs-lg) !important;
    margin-top: 0.875rem !important;
  }

  /* Buttons full-width on small screens */
  .elementor-button.elementor-button-link,
  a.elementor-button,
  .rs-btn {
    padding: 0.65rem 1.25rem !important;
    font-size: var(--mi-fs-xs) !important;
  }

  /* Tab button spacing */
  .content--teb-area .tab-button-area a {
    font-size: var(--mi-fs-xs) !important;
    padding: 0.4rem 0.75rem !important;
  }

  /* Testimonial card padding */
  .rs-testimonial-slider.style1 .testimonial-inner {
    padding: 1.25rem !important;
  }

  /* FAQ */
  .accordion-button,
  .nav-link.accordion-button {
    font-size: var(--mi-fs-base) !important;
    padding: 0.875rem 1rem !important;
  }

  .answer {
    font-size: var(--mi-fs-sm) !important;
    padding: 0.875rem 1rem !important;
  }

  /* Icon box text */
  .rs-iconbox-area .box-inner .text-area .iconbox-title .title {
    font-size: var(--mi-fs-md) !important;
  }

  /* Footer */
  footer h3, footer h4, .site-footer h3, .site-footer h4 {
    font-size: var(--mi-fs-lg) !important;
  }

  footer p, footer a, .site-footer p, .site-footer a {
    font-size: var(--mi-fs-xs) !important;
  }

  /* Sub-text badge smaller */
  .prelements-heading .title-inner span.sub-text,
  .sub-text {
    font-size: 0.65rem !important;
    padding: 0.25rem 0.65rem !important;
  }
}

/* ── SMALL MOBILE (max-width: 480px) ─────────────────────── */
@media screen and (max-width: 480px) {
  .e-con,
  .elementor-section {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  h1 {
    font-size: 1.5rem !important;
    line-height: 1.3 !important;
  }

  h2 {
    font-size: 1.3rem !important;
  }

  h3 {
    font-size: 1.1rem !important;
  }

  .services-inner {
    padding: 1.25rem 1rem !important;
  }

  img.rs-image,
  .rs-image img {
    border-radius: var(--mi-radius) !important;
  }
}

/* ── PRINT STYLES ─────────────────────────────────────────── */
@media print {
  body {
    font-size: 12pt !important;
    color: #000 !important;
    background: #fff !important;
  }

  h1, h2, h3 {
    page-break-after: avoid;
  }

  .ht-ctc-chat,
  nav,
  footer {
    display: none !important;
  }
}

/* ── HIGH CONTRAST OVERRIDE ───────────────────────────────── */
@media (prefers-contrast: high) {
  :root {
    --mi-primary: #C04000;
    --mi-text: #000;
    --mi-dark: #000;
    --mi-border: #444;
  }
}
