﻿/* ================================================================
   PARAKRAM INTERNATIONAL — Industrial Green Theme CSS
   Dark Green · Forest Green · White · Light Grey
================================================================ */

/* ----------------------------------------------------------------
   CSS VARIABLES
---------------------------------------------------------------- */
:root {
    --primary:       #1a4731;   /* dark forest green */
    --primary-mid:   #2d6a4f;   /* mid forest green */
    --primary-light: #40916c;   /* medium green */
    --accent:        #52b788;   /* bright accent green */
    --accent-dark:   #2d6a4f;   /* dark accent green */
    --accent-hover:  #74c69d;   /* hover light green */
    --steel:         #607d8b;   /* steel grey */
    --steel-light:   #90a4ae;   /* light steel */
    --dark:          #0a1f13;   /* near-black green */
    --white:         #ffffff;
    --light:         #f4faf7;   /* light green-tinted bg */
    --light-2:       #e8f3ed;   /* slightly greener bg */
    --text:          #1e3a2b;   /* dark green-tinted text */
    --text-muted:    #6b7280;
    --border:        #c8ddd2;   /* green-tinted border */
    --shadow-sm:     0 2px 10px rgba(0,0,0,.08);
    --shadow:        0 4px 24px rgba(0,0,0,.12);
    --shadow-lg:     0 12px 48px rgba(0,0,0,.18);
    --radius:        12px;
    --radius-sm:     8px;
    --transition:    all .3s ease;
}

/* ----------------------------------------------------------------
   RESET & BASE
---------------------------------------------------------------- */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: 'Inter', 'Segoe UI', Tahoma, sans-serif;
    color: var(--text);
    line-height: 1.7;
    overflow-x: hidden;
    background: var(--white);
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; height: auto; display: block; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; }

.container {
    /* max-width: 1200px; */
    margin: 0 auto;
    padding: 0 1.5rem;
}
.text-center { text-align: center; }

/* ----------------------------------------------------------------
   TYPOGRAPHY HELPERS
---------------------------------------------------------------- */
.section-badge {
    display: inline-block;
    background: rgba(82,183,136,.12);
    color: var(--accent);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: .35rem 1.1rem;
    border-radius: 50px;
    border: 1px solid rgba(82,183,136,.3);
    margin-bottom: .85rem;
}
.section-badge-light {
    background: rgba(255,255,255,.1);
    color: var(--accent);
    border-color: rgba(82,183,136,.3);
}
.section-title {
    font-family: 'Rajdhani', 'Inter', sans-serif;
    font-size: clamp(1.8rem, 4vw, 2.6rem);
    font-weight: 700;
    color: var(--primary);
    line-height: 1.2;
    margin-bottom: 1rem;
}
.section-title span { color: var(--accent); }
.section-subtitle {
    font-size: 1rem;
    color: var(--text-muted);
    max-width: 620px;
    margin: 0 auto 3rem;
}

/* ----------------------------------------------------------------
   BUTTONS
---------------------------------------------------------------- */
.btn-primary-custom {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: var(--primary);
    color: var(--white);
    border: 2px solid var(--primary);
    padding: .75rem 1.8rem;
    border-radius: 6px;
    font-weight: 700;
    font-size: .95rem;
    transition: var(--transition);
}
.btn-primary-custom:hover {
    background: var(--primary-mid);
    border-color: var(--primary-mid);
    color: var(--white);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(26,71,49,.3);
}
.btn-lg { padding: .9rem 2.4rem; font-size: 1rem; }


/* ================================================================
   NAVBAR
================================================================ */
.navbar-custom {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1000;
    transition: var(--transition);
    background: rgba(82, 183, 136, 0.12);
}
.navbar-custom.scrolled {
    background: var(--white);
    box-shadow: 0 2px 20px rgba(0,0,0,.12);
}
.navbar-custom.scrolled .nav-link-item {
    color: var(--primary);
}
.navbar-custom.scrolled .nav-link-item:hover,
.navbar-custom.scrolled .nav-link-item.active {
    color: var(--accent);
    background: rgba(82,183,136,.08);
}
.navbar-custom.scrolled .nav-call-btn {
    color: var(--primary);
    border-color: rgba(0,0,0,.15);
}
.navbar-custom.scrolled .nav-call-btn:hover {
    color: var(--accent);
    border-color: var(--accent);
}
.navbar-custom.scrolled .hamburger span {
    background: var(--primary);
}

.nav-container {
    max-width: 1260px;
    margin: 0 auto;
    padding: 0 1.5rem;
    display: flex;
    align-items: center;
    /* background-color: rgba(82, 183, 136, 0.12); */
    justify-content: space-between;
    height: 100px;
}

/* Brand / Logo */
.navbar-brand-wrap,
.footer-logo-wrap {
    display: flex;
    align-items: center;
    gap: .75rem;
    text-decoration: none;
}
.brand-logo-img {
    height: 100px;
    width: auto;
    object-fit: contain;
    display: block;
}
.logo-dark { display: none; }
.logo-white { display: block; }
.navbar-custom.scrolled .logo-white { display: none; }
.navbar-custom.scrolled .logo-dark { display: block; }
.brand-logo {
    width: 44px; height: 44px;
    background: var(--accent);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.brand-logo-sm { width: 36px; height: 36px; }
.brand-logo-p {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.5rem;
    font-weight: 900;
    color: var(--primary);
    line-height: 1;
}
.brand-logo-sm .brand-logo-p { font-size: 1.25rem; }
.brand-text-block {
    display: flex;
    flex-direction: column;
    line-height: 1;
}
.brand-name {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--white);
    letter-spacing: 1.5px;
}
.brand-tagline {
    font-size: .62rem;
    font-weight: 600;
    color: var(--accent);
    letter-spacing: 2px;
    text-transform: uppercase;
}

/* Nav Menu */
.nav-menu {
    display: flex;
    align-items: center;
    gap: .1rem;
}
.nav-link-item {
    display: block;
    color: rgba(255,255,255,.85);
    font-weight: 500;
    font-size: 1.1rem;
    padding: .6rem 1rem;
    border-radius: var(--radius-sm);
    transition: var(--transition);
    position: relative;
}
.nav-link-item:hover,
.nav-link-item.active {
    color: var(--accent);
    background: rgba(82,183,136,.08);
}
.nav-arrow { font-size: .7rem; margin-left: .25rem; }

/* Dropdown */
.nav-dropdown { position: relative; }
.dropdown-menu-custom {
    position: absolute;
    top: calc(100% + .5rem);
    left: 0;
    background: var(--primary);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--radius-sm);
    padding: .5rem 0;
    min-width: 210px;
    box-shadow: var(--shadow-lg);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: var(--transition);
    z-index: 200;
}
.nav-dropdown:hover .dropdown-menu-custom {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.dropdown-menu-custom li a {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .6rem 1.2rem;
    color: rgba(255,255,255,.75);
    font-size: .88rem;
    font-weight: 500;
    transition: var(--transition);
}
.dropdown-menu-custom li a:hover {
    color: var(--accent);
    background: rgba(82,183,136,.08);
    padding-left: 1.5rem;
}
.dropdown-menu-custom li a i { color: var(--accent); font-size: .65rem; }

/* Nav Actions */
.nav-actions {
    display: flex;
    align-items: center;
    gap: .75rem;
}
.nav-call-btn {
    display: flex;
    align-items: center;
    gap: .4rem;
    color: rgba(255,255,255,.85);
    font-size: .85rem;
    font-weight: 600;
    padding: .4rem .75rem;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,.2);
    transition: var(--transition);
}
.nav-call-btn:hover { color: var(--accent); border-color: var(--accent); }
.nav-call-btn i { color: var(--accent); }

.nav-cta-btn {
    display: flex;
    align-items: center;
    gap: .4rem;
    background: var(--accent);
    color: var(--primary);
    font-weight: 700;
    font-size: .88rem;
    padding: .5rem 1.2rem;
    border-radius: 6px;
    transition: var(--transition);
    border: 2px solid var(--accent);
}
.nav-cta-btn:hover {
    background: var(--white);
    color: var(--primary);
    border-color: var(--white);
    transform: translateY(-1px);
}

/* Hamburger */
.hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: .5rem;
}
.hamburger span {
    display: block;
    width: 24px; height: 2px;
    background: var(--white);
    border-radius: 2px;
    transition: var(--transition);
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile Menu */
.mobile-menu {
    display: none;
    background: var(--primary);
    border-top: 1px solid rgba(255,255,255,.1);
    padding: 1rem 0;
    position: absolute;
    top: 72px; left: 0; right: 0;
    box-shadow: 0 8px 30px rgba(0,0,0,.3);
    z-index: 999;
    transform: translateY(-10px);
    opacity: 0;
    transition: var(--transition);
    pointer-events: none;
}
.mobile-menu.open {
    display: block;
    transform: translateY(0);
    opacity: 1;
    pointer-events: all;
}
.mobile-menu ul { padding: 0 1.5rem; }
.mobile-menu ul li { border-bottom: 1px solid rgba(255,255,255,.06); }
.mobile-menu ul li a {
    display: flex;
    align-items: center;
    gap: .75rem;
    color: rgba(255,255,255,.85);
    padding: .85rem 0;
    font-weight: 500;
    font-size: .95rem;
    transition: var(--transition);
}
.mobile-menu ul li a:hover { color: var(--accent); }
.mobile-menu ul li a i { width: 18px; color: var(--accent); }
.mobile-cta-row {
    display: flex !important;
    gap: .75rem;
    padding: 1rem 0 !important;
    border-bottom: none !important;
}
.mob-call, .mob-login {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    padding: .6rem 1rem;
    border-radius: 6px;
    font-weight: 600;
    font-size: .88rem;
}
.mob-call {
    background: rgba(82,183,136,.15);
    color: var(--accent) !important;
    border: 1px solid rgba(82,183,136,.3);
}
.mob-login {
    background: var(--accent);
    color: var(--primary) !important;
}


/* ================================================================
   HERO SECTION
================================================================ */
.hero-section {
    min-height: 100vh;
    /* position: relative; */
    display: flex;
    align-items: center;
    overflow: hidden;
    padding: 6rem 0 3rem;
}
.hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.hero-slider {
    position: absolute;
    inset: 0;
}
.hero-slide {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0;
    transition: opacity 1.2s ease-in-out;
}
.hero-slide.active {
    opacity: 1;
}
.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(10,31,19,.72) 0%,
        rgba(26,71,49,.62) 50%,
        rgba(10,31,19,.52) 100%
    );
}
.hero-particles {
    position: absolute;
    inset: 0;
    overflow: hidden;
}
.hero-content-wrap {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.5rem;
    display: flex;
    justify-content: center;
    align-items: center;
}
.hero-content {
    text-align: center;
    max-width: 800px;
    width: 100%;
    transition: opacity .3s ease, transform .3s ease;
}
.hero-text-fade {
    opacity: 0;
    transform: translateY(10px);
}

/* Eyebrow */
.hero-eyebrow {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: 1.2rem;
    justify-content: center;
}
.eyebrow-line {
    flex: 1;
    max-width: 40px;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent));
    border-radius: 2px;
}
.eyebrow-line:last-child {
    background: linear-gradient(90deg, var(--accent), transparent);
}
.eyebrow-text {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--accent);
    white-space: nowrap;
}

/* Heading glow accent */
.hero-accent-glow {
    background: linear-gradient(135deg, #52b788 0%, #74c69d 40%, #b7e4c7 70%, #52b788 100%);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: heroAccentShimmer 3s linear infinite;
    text-shadow: none;
    filter: drop-shadow(0 0 18px rgba(82,183,136,.55));
}
@keyframes heroAccentShimmer {
    0%   { background-position: 0% center; }
    100% { background-position: 200% center; }
}
.hero-heading-sub {
    display: inline-block;
    font-weight: 800;
    font-size: 95%;
    color: #ffd700;
    text-shadow: 0 0 24px rgba(255,215,0,.5), 0 2px 8px rgba(0,0,0,.4);
    position: relative;
}
.hero-heading-sub::after {
    content: '';
    position: absolute;
    left: 0; bottom: -3px;
    width: 100%; height: 2px;
    background: linear-gradient(to right, #ffd700, transparent);
    border-radius: 2px;
}

/* Grade tags */
.hero-grade-tag {
    display: inline-block;
    background: rgba(82,183,136,.18);
    border: 1px solid rgba(82,183,136,.4);
    color: var(--accent);
    font-size: .75rem;
    font-weight: 700;
    padding: .1rem .5rem;
    border-radius: 4px;
    letter-spacing: .5px;
    vertical-align: middle;
}

/* Micro stats */
.hero-micro-stats {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 0 auto 2rem;
    padding: .9rem 1.4rem;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 10px;
    backdrop-filter: blur(8px);
    width: fit-content;
}
.micro-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .15rem;
}
.micro-num {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--accent);
    line-height: 1;
}
.micro-lbl {
    font-size: .65rem;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: rgba(255,255,255,.6);
}
.micro-divider {
    width: 1px;
    height: 32px;
    background: rgba(255,255,255,.15);
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    background: rgba(82,183,136,.15);
    border: 1px solid rgba(82,183,136,.35);
    color: var(--accent);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: .4rem 1.1rem;
    border-radius: 50px;
    margin-bottom: 1.5rem;
}
.badge-dot {
    width: 7px; height: 7px;
    background: var(--accent);
    border-radius: 50%;
    animation: pulse-dot 1.6s ease infinite;
}
@keyframes pulse-dot {
    0%,100% { opacity: 1; transform: scale(1); }
    50% { opacity: .4; transform: scale(1.5); }
}

.hero-heading {
    font-family: 'Rajdhani', 'Inter', sans-serif;
    font-size: clamp(2.2rem, 5vw, 4rem);
    font-weight: 900;
    color: var(--white);
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin-bottom: 1.25rem;
    text-shadow: 0 2px 24px rgba(0,0,0,.35);
}
.hero-accent { color: var(--accent); }

.hero-subtext {
    font-size: 1.05rem;
    color: rgba(255,255,255,.8);
    max-width: 680px;
    margin: 0 auto 2rem;
    line-height: 1.8;
}
.hero-subtext strong { color: var(--accent); font-weight: 600; }

.hero-actions {
    display: flex;
    gap: .85rem;
    flex-wrap: wrap;
    margin-bottom: 1.75rem;
    justify-content: center;
}
.btn-hero-primary {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: var(--primary);
    color: var(--white);
    font-weight: 700;
    font-size: .95rem;
    padding: .85rem 1.8rem;
    border-radius: 6px;
    transition: var(--transition);
    border: 2px solid var(--primary);
}
.btn-hero-primary:hover {
    background: var(--primary-mid);
    border-color: var(--primary-mid);
    color: var(--white);
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(26,71,49,.35);
}
.btn-hero-secondary {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: rgba(255,255,255,.1);
    color: var(--white);
    font-weight: 700;
    font-size: .95rem;
    padding: .85rem 1.8rem;
    border-radius: 6px;
    border: 2px solid rgba(255,255,255,.3);
    transition: var(--transition);
    backdrop-filter: blur(8px);
}
.btn-hero-secondary:hover {
    background: var(--white);
    color: var(--primary);
    border-color: var(--white);
    transform: translateY(-2px);
}
.btn-whatsapp {
    background: #25D366;
    color: #fff;
    border-color: #25D366;
}
.btn-whatsapp:hover {
    background: #1ebe5a;
    color: #fff;
    border-color: #1ebe5a;
    transform: translateY(-2px);
}
.btn-hero-outline {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: transparent;
    color: rgba(255,255,255,.75);
    font-weight: 600;
    font-size: .88rem;
    padding: .85rem 1.4rem;
    border-radius: 6px;
    border: 2px solid rgba(255,255,255,.2);
    transition: var(--transition);
}
.btn-hero-outline:hover {
    border-color: var(--accent);
    color: var(--accent);
}

.hero-contact-strip {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
    justify-content: center;
}
.hero-strip-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-size: .88rem;
    font-weight: 600;
    padding: .55rem 1.1rem;
    border-radius: 50px;
    transition: var(--transition);
}
.hero-strip-call {
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.85);
    border: 1px solid rgba(255,255,255,.2);
}
.hero-strip-call:hover { background: rgba(255,255,255,.15); color: var(--white); }
.hero-strip-wa {
    background: rgba(37,211,102,.15);
    color: #25d366;
    border: 1px solid rgba(37,211,102,.3);
}
.hero-strip-wa:hover { background: #25d366; color: var(--white); }

/* Hero Info Card */
.hero-info-card {
    background: rgba(26,71,49,.85);
    border: 1px solid rgba(82,183,136,.25);
    border-radius: var(--radius);
    overflow: hidden;
    backdrop-filter: blur(12px);
    box-shadow: 0 16px 48px rgba(0,0,0,.3);
}
.hero-card-header {
    background: var(--primary);
    color: var(--white);
    font-weight: 700;
    font-size: .9rem;
    padding: .85rem 1.25rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.hero-rate-list { padding: .75rem 0; }
.rate-row {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .7rem 1.25rem;
    border-bottom: 1px solid rgba(255,255,255,.06);
    transition: var(--transition);
}
.rate-row:last-child { border-bottom: none; }
.rate-row:hover { background: rgba(255,255,255,.04); }
.rate-grade {
    flex: 1;
    color: var(--white);
    font-weight: 600;
    font-size: .9rem;
}
.rate-val {
    color: rgba(255,255,255,.6);
    font-size: .82rem;
}
.rate-tag {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .72rem;
    font-weight: 700;
    padding: .2rem .55rem;
    border-radius: 50px;
}
.rate-up { background: rgba(52,211,153,.15); color: #34d399; }
.rate-high { background: rgba(82,183,136,.15); color: var(--accent); }
.hero-card-note {
    padding: .75rem 1.25rem;
    font-size: .78rem;
    color: rgba(255,255,255,.45);
    border-top: 1px solid rgba(255,255,255,.08);
    display: flex;
    align-items: center;
    gap: .4rem;
}
.hero-card-cta {
    display: block;
    text-align: center;
    background: var(--accent);
    color: var(--primary);
    font-weight: 700;
    font-size: .9rem;
    padding: .85rem;
    transition: var(--transition);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
}
.hero-card-cta:hover { background: var(--accent-hover); color: var(--primary); }

/* Hero Scroll Hint */
.hero-scroll-hint {
    position: absolute;
    bottom: 2.5rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    color: rgba(255,255,255,.4);
    font-size: .72rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}
.scroll-line-anim {
    width: 1px; height: 48px;
    background: linear-gradient(to bottom, rgba(82,183,136,.8), transparent);
    animation: scroll-line 1.5s ease-in-out infinite;
}
@keyframes scroll-line {
    0% { transform: scaleY(0); transform-origin: top; opacity: 1; }
    50% { transform: scaleY(1); transform-origin: top; opacity: 1; }
    51% { transform: scaleY(1); transform-origin: bottom; opacity: 1; }
    100% { transform: scaleY(0); transform-origin: bottom; opacity: 0; }
}

/* Reveal animations */
.reveal-hero { animation: fadeSlideUp .9s .2s both; }
.reveal-hero-delay { animation: fadeSlideUp .9s .5s both; }
@keyframes fadeSlideUp {
    from { opacity: 0; transform: translateY(30px); }
    to   { opacity: 1; transform: translateY(0); }
}


/* ================================================================
   GUARANTEE BANNER
================================================================ */
.guarantee-banner {
    position: relative;
    background: linear-gradient(100deg, #0a1f13 0%, #1a4731 45%, #0f2d1e 100%);
    padding: 2rem 0;
    overflow: hidden;
    border-top: 1px solid rgba(82,183,136,.15);
    border-bottom: 1px solid rgba(82,183,136,.15);
}
.guarantee-glow-left {
    position: absolute;
    top: -60px; left: -60px;
    width: 320px; height: 320px;
    background: radial-gradient(circle, rgba(82,183,136,.18) 0%, transparent 70%);
    pointer-events: none;
}
.guarantee-glow-right {
    position: absolute;
    bottom: -80px; right: -60px;
    width: 380px; height: 380px;
    background: radial-gradient(circle, rgba(82,183,136,.12) 0%, transparent 70%);
    pointer-events: none;
}
.guarantee-inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 2.5rem;
}
.guarantee-icon-col { display: flex; justify-content: center; }
.guarantee-medal {
    position: relative;
    width: 90px; height: 90px;
    background: linear-gradient(135deg, rgba(82,183,136,.2), rgba(82,183,136,.05));
    border: 2px solid rgba(82,183,136,.4);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.guarantee-medal i {
    font-size: 2.4rem;
    color: var(--accent);
    position: relative; z-index: 1;
}
.guarantee-pulse {
    position: absolute;
    inset: -8px;
    border-radius: 50%;
    border: 2px solid rgba(82,183,136,.35);
    animation: guaranteePulse 2.2s ease-in-out infinite;
}
@keyframes guaranteePulse {
    0%, 100% { transform: scale(1); opacity: .6; }
    50%       { transform: scale(1.12); opacity: 0; }
}
.guarantee-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: .6rem;
}
.guarantee-eyebrow i { font-size: .85rem; }
.guarantee-heading {
    font-size: 1.65rem;
    font-weight: 800;
    color: var(--white);
    line-height: 1.25;
    margin-bottom: .5rem;
}
.guarantee-accent {
    color: var(--accent);
}
.guarantee-sub {
    font-size: .95rem;
    color: rgba(255,255,255,.6);
    margin-bottom: 1rem;
}
.guarantee-pledge {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .75rem;
    background: rgba(82,183,136,.1);
    border: 1px solid rgba(82,183,136,.25);
    border-left: 4px solid var(--accent);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    padding: 1rem 1.25rem;
}
.guarantee-pledge-icon i {
    font-size: 1.5rem;
    color: #ffd700;
    flex-shrink: 0;
}
.guarantee-pledge-text {
    color: rgba(255,255,255,.88);
    font-size: 1rem;
    line-height: 1.5;
    flex: 1;
}
.guarantee-pledge-text strong {
    color: var(--accent);
    font-weight: 700;
}
.guarantee-nqa-badge {
    background: linear-gradient(135deg, #ffd700, #f5a623);
    color: #1a1a1a;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: .3rem .7rem;
    border-radius: 30px;
    white-space: nowrap;
    flex-shrink: 0;
}
.guarantee-cta-col { display: flex; justify-content: center; }
.guarantee-stamp {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 96px; height: 96px;
    border: 3px solid rgba(82,183,136,.5);
    border-radius: 50%;
    padding: .5rem;
    text-align: center;
    position: relative;
    transform: rotate(-8deg);
}
.guarantee-stamp::before {
    content: '';
    position: absolute;
    inset: 4px;
    border: 1px dashed rgba(82,183,136,.4);
    border-radius: 50%;
}
.guarantee-stamp-top { font-size: 1.5rem; font-weight: 900; color: var(--accent); line-height: 1; }
.guarantee-stamp-mid { font-size: .72rem; font-weight: 800; color: rgba(255,255,255,.9); letter-spacing: .08em; text-transform: uppercase; }
.guarantee-stamp-bot { font-size: .72rem; font-weight: 800; color: rgba(255,255,255,.9); letter-spacing: .08em; text-transform: uppercase; }

@media (max-width: 900px) {
    .guarantee-inner { grid-template-columns: 1fr; text-align: center; gap: 1.5rem; }
    .guarantee-icon-col, .guarantee-cta-col { justify-content: center; }
    .guarantee-pledge { justify-content: center; text-align: left; }
    .guarantee-stamp { transform: none; }
}
@media (max-width: 600px) {
    .guarantee-heading { font-size: 1.3rem; }
    .guarantee-pledge { flex-direction: column; align-items: flex-start; }
}

/* ================================================================
   TRUST HIGHLIGHTS
================================================================ */
.trust-section {
    padding: 4rem 0;
    background: var(--light);
    border-bottom: 1px solid var(--border);
}
.trust-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
.trust-card {
    background: var(--white);
    border-radius: var(--radius);
    padding: 2rem 1.5rem;
    text-align: center;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.trust-card::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: var(--accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .4s ease;
}
.trust-card:hover::after { transform: scaleX(1); }
.trust-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 36px rgba(0,0,0,.1);
}
.trust-icon-wrap {
    width: 64px; height: 64px;
    background: var(--primary);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    color: var(--accent);
    margin: 0 auto 1.25rem;
    transition: var(--transition);
}
.trust-card:hover .trust-icon-wrap { background: var(--accent); color: var(--primary); }
.trust-card h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .6rem;
}
.trust-card p { font-size: .88rem; color: var(--text-muted); line-height: 1.65; }


/* ================================================================
   STATS BAND
================================================================ */
.stats-band {
    background: var(--primary);
    padding: 3rem 0;
    position: relative;
    overflow: hidden;
}
.stats-band::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        45deg,
        transparent,
        transparent 40px,
        rgba(82,183,136,.04) 40px,
        rgba(82,183,136,.04) 80px
    );
}
.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    text-align: center;
    position: relative;
}
.stat-item { color: var(--white); padding: 1rem; }
.stat-number {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2.8rem;
    font-weight: 800;
    color: #55b88a;
    line-height: 1;
    display: flex;
    justify-content: center;
    align-items: baseline;
    gap: .1rem;
}
.stat-suffix { font-size: 1.8rem; }
.stat-label {
    font-size: .88rem;
    color: rgb(85 184 138);
    margin-top: .5rem;
    font-weight: 500;
    letter-spacing: .5px;
}


/* ================================================================
   ABOUT SECTION
================================================================ */
.about-section {
    padding: 6rem 0;
    background: var(--white);
}
.about-grid {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 4rem;
    align-items: center;
}
.about-img-wrap {
    position: relative;
}
.about-main-img {
    width: 100%;
    height: 460px;
    object-fit: cover;
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
}
.about-exp-badge {
    position: absolute;
    bottom: -1.5rem;
    right: -1.5rem;
    background: var(--accent);
    color: var(--primary);
    padding: 1.5rem 1.25rem;
    border-radius: var(--radius);
    text-align: center;
    box-shadow: 0 8px 28px rgba(82,183,136,.4);
}
.badge-num {
    display: block;
    font-family: 'Rajdhani', sans-serif;
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
}
.badge-lbl {
    display: block;
    font-size: .72rem;
    font-weight: 600;
    margin-top: .25rem;
    opacity: .85;
}
.about-verify-badge {
    position: absolute;
    top: 1.25rem;
    left: 1.25rem;
    background: var(--primary);
    color: var(--accent);
    padding: .45rem .9rem;
    border-radius: 50px;
    font-size: .78rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: .4rem;
    box-shadow: var(--shadow);
}

.about-content .section-title { text-align: left; }
.about-desc {
    color: var(--text-muted);
    margin-bottom: 1.25rem;
    line-height: 1.8;
}
.about-features {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
    margin: 1.75rem 0;
}
.feature-item {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: .9rem;
    font-weight: 600;
    color: var(--text);
}
.check {
    width: 22px; height: 22px;
    background: rgba(82,183,136,.15);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);
    font-size: .65rem;
    flex-shrink: 0;
}


/* ================================================================
   BOOKING / HOW IT WORKS SECTION
================================================================ */
.booking-section {
    padding: 6rem 0;
    background: var(--primary);
    position: relative;
    overflow: hidden;
}
.booking-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 30px,
        rgba(255,255,255,.02) 30px,
        rgba(255,255,255,.02) 60px
    );
}
.booking-section .container { position: relative; }
.booking-section .section-badge { margin-bottom: .85rem; }
.booking-section .section-title { color: var(--white); }
.booking-section .section-subtitle { color: rgba(255,255,255,.6); }

.steps-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-top: 2.5rem;
    position: relative;
}
.step-card {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--radius);
    padding: 2rem 1.5rem;
    text-align: center;
    position: relative;
    transition: var(--transition);
}
.step-card:hover {
    background: rgba(255,255,255,.08);
    border-color: rgba(82,183,136,.3);
    transform: translateY(-6px);
}
.step-num {
    font-family: 'Rajdhani', sans-serif;
    font-size: 3.5rem;
    font-weight: 900;
    color: rgba(82,183,136,.12);
    line-height: 1;
    margin-bottom: .5rem;
}
.step-icon {
    width: 60px; height: 60px;
    background: var(--accent);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--primary);
    margin: 0 auto 1.25rem;
    transition: var(--transition);
}
.step-card:hover .step-icon { transform: scale(1.1) rotate(5deg); }
.step-card h3 {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: .65rem;
}
.step-card p {
    font-size: .87rem;
    color: rgba(255,255,255,.6);
    line-height: 1.7;
}
.step-arrow {
    position: absolute;
    top: 50%;
    right: -1.25rem;
    transform: translateY(-50%);
    color: var(--accent);
    font-size: 1.1rem;
    z-index: 1;
    opacity: .7;
}
.step-arrow.last { display: none; }


/* ================================================================
   MATERIALS SECTION
================================================================ */
.materials-section {
    padding: 6rem 0;
    background: var(--light);
}
.materials-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
}
.material-card {
    background: var(--white);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border);
    transition: var(--transition);
}
.material-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 44px rgba(0,0,0,.12);
}
.mat-img-wrap {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
}
.mat-img-wrap img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.material-card:hover .mat-img-wrap img { transform: scale(1.07); }
.mat-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(26,71,49,.8) 0%, transparent 60%);
    opacity: 0;
    transition: var(--transition);
    display: flex;
    align-items: flex-end;
    padding: 1.25rem;
}
.material-card:hover .mat-overlay { opacity: 1; }
.mat-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: var(--accent);
    color: var(--primary);
    font-size: .82rem;
    font-weight: 700;
    padding: .45rem 1rem;
    border-radius: 6px;
    transition: var(--transition);
}
.mat-body { padding: 1.5rem; }
.mat-grade {
    display: inline-block;
    background: rgba(26,71,49,.08);
    color: var(--primary-mid);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: .2rem .6rem;
    border-radius: 4px;
    border: 1px solid rgba(26,71,49,.15);
    margin-bottom: .6rem;
}
.mat-grade-premium {
    /* background: rgba(82,183,136,.1); */
    color: var(--accent-dark);
    border-color: rgba(82,183,136,.3);
}
.mat-body h3 {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .6rem;
}
.mat-body p {
    font-size: .87rem;
    color: var(--text-muted);
    line-height: 1.65;
    margin-bottom: 1rem;
}
.mat-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
}
.mat-tags li {
    font-size: .75rem;
    font-weight: 600;
    color: var(--steel);
    background: var(--light-2);
    padding: .2rem .6rem;
    border-radius: 4px;
}

/* CTA Material Card */
.mat-card-cta {
    background: var(--primary);
    border-color: var(--primary);
    display: flex;
    align-items: center;
    justify-content: center;
}
.mat-cta-inner { text-align: center; padding: 2rem; }
.mat-cta-icon {
    font-size: 3rem;
    color: var(--accent);
    margin-bottom: 1rem;
    display: block;
}
.mat-cta-inner h3 {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: .75rem;
}
.mat-cta-inner p {
    font-size: .88rem;
    color: rgba(255,255,255,.6);
    margin-bottom: 0;
}
.mat-wa-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    margin-top: .85rem;
    background: rgba(37,211,102,.15);
    color: #25d366;
    border: 1px solid rgba(37,211,102,.3);
    padding: .55rem 1.2rem;
    border-radius: 6px;
    font-size: .88rem;
    font-weight: 600;
    transition: var(--transition);
}
.mat-wa-btn:hover { background: #25d366; color: var(--white); }


/* ================================================================
   HONEST WEIGHT GUARANTEE
================================================================ */
.weight-section {
    padding: 5rem 0;
    background: var(--primary);
    position: relative;
    overflow: hidden;
}
.weight-section::before {
    content: '';
    position: absolute;
    right: -100px; top: 50%;
    transform: translateY(-50%);
    width: 500px; height: 500px;
    background: rgba(82,183,136,.04);
    border-radius: 50%;
    border: 80px solid rgba(82,183,136,.06);
}
.weight-inner {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 3rem;
    align-items: center;
    position: relative;
}
.weight-shield {
    width: 160px; height: 160px;
    background: rgba(82,183,136,.12);
    border: 3px solid rgba(82,183,136,.3);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    color: var(--accent);
    animation: pulse-shield 2.5s ease infinite;
}
@keyframes pulse-shield {
    0%,100% { box-shadow: 0 0 0 0 rgba(82,183,136,.3); }
    50% { box-shadow: 0 0 0 20px rgba(82,183,136,.0); }
}
.weight-badge {
    display: inline-block;
    background: rgba(82,183,136,.15);
    color: var(--accent);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: .3rem .9rem;
    border-radius: 50px;
    border: 1px solid rgba(82,183,136,.3);
    margin-bottom: .75rem;
}
.weight-content h2 {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--white);
    margin-bottom: 1rem;
}
.weight-main-text {
    color: rgba(255,255,255,.7);
    margin-bottom: 1.5rem;
    line-height: 1.8;
}
.weight-promise-box {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    background: rgba(82,183,136,.08);
    border: 1px solid rgba(82,183,136,.2);
    border-left: 4px solid var(--accent);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    padding: 1.25rem;
    margin-bottom: 1.5rem;
}
.weight-promise-box i {
    font-size: 2rem;
    color: var(--accent);
    flex-shrink: 0;
    margin-top: .1rem;
}
.weight-promise-box p {
    color: rgba(255,255,255,.8);
    font-size: .95rem;
    line-height: 1.7;
}
.highlight-text {
    color: var(--accent);
    font-weight: 700;
}
.weight-features {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .65rem;
}
.wf-item {
    display: flex;
    align-items: center;
    gap: .6rem;
    color: rgba(255,255,255,.7);
    font-size: .88rem;
    font-weight: 500;
}
.wf-item i { color: var(--accent); font-size: .9rem; }


/* ================================================================
   TESTIMONIALS
================================================================ */
.testimonials-section {
    padding: 6rem 0;
    background: var(--dark);
    position: relative;
    overflow: hidden;
}
.testimonials-section::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--accent), transparent);
}
.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.75rem;
}
.testimonials-marquee-wrap {
    overflow: hidden;
    margin-top: 2.5rem;
    -webkit-mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
    mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
}
.testimonials-marquee {
    display: flex;
    gap: 1.75rem;
    width: max-content;
    animation: testimonialsScroll 32s linear infinite;
}
.testimonials-marquee:hover {
    animation-play-state: paused;
}
.testimonials-marquee .testimonial-card {
    width: 420px;
    flex-shrink: 0;
}
@keyframes testimonialsScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.testimonial-card {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: var(--radius);
    padding: 2rem;
    transition: var(--transition);
    position: relative;
}
.testimonial-card::before {
    content: '"';
    position: absolute;
    top: 1rem; right: 1.5rem;
    font-size: 5rem;
    font-family: Georgia, serif;
    color: rgba(82,183,136,.1);
    line-height: 1;
}
.testimonial-card:hover {
    background: rgba(255,255,255,.07);
    border-color: rgba(82,183,136,.2);
    transform: translateY(-4px);
}
.stars { color: var(--accent); margin-bottom: 1rem; font-size: .9rem; }
.testimonial-card p {
    color: rgba(255,255,255,.75);
    font-size: .93rem;
    line-height: 1.8;
    font-style: italic;
    margin-bottom: 1.5rem;
}
.testimonial-author { display: flex; align-items: center; gap: .85rem; }
.author-avatar-placeholder {
    width: 48px; height: 48px;
    background: var(--primary-mid);
    border: 2px solid var(--accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);
    font-weight: 800;
    font-size: .88rem;
    flex-shrink: 0;
    font-family: 'Rajdhani', sans-serif;
}
.author-info h5 { color: var(--white); font-size: .95rem; font-weight: 700; margin-bottom: .15rem; }
.author-info span { color: rgba(255,255,255,.45); font-size: .8rem; }


/* ================================================================
   CTA SECTION
================================================================ */
.cta-section {
    padding: 5.5rem 0;
    background: var(--accent);
    text-align: center;
    position: relative;
    overflow: hidden;
}
.cta-bg-pattern {
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        45deg,
        transparent,
        transparent 30px,
        rgba(26,71,49,.06) 30px,
        rgba(26,71,49,.06) 60px
    );
}
.cta-content { position: relative; z-index: 1; max-width: 720px; margin: 0 auto; padding: 0 1.5rem; }
.cta-badge {
    display: inline-block;
    background: rgba(26,71,49,.12);
    color: var(--primary);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: .3rem .9rem;
    border-radius: 50px;
    margin-bottom: 1rem;
}
.cta-section h2 {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    color: var(--primary);
    margin-bottom: 1rem;
    line-height: 1.15;
}
.cta-section h2 span { color: rgba(26,71,49,.7); }
.cta-section > .container > .cta-content > p {
    color: rgba(26,71,49,.75);
    font-size: 1rem;
    margin-bottom: 2rem;
    line-height: 1.8;
}
.cta-actions {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}
.btn-cta-primary {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: var(--primary);
    color: var(--white);
    font-weight: 700;
    font-size: 1rem;
    padding: .9rem 2rem;
    border-radius: 6px;
    transition: var(--transition);
}
.btn-cta-primary:hover {
    background: var(--dark);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(10,31,19,.3);
}
.btn-cta-secondary {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: rgba(26,71,49,.1);
    color: var(--primary);
    font-weight: 700;
    font-size: 1rem;
    padding: .9rem 2rem;
    border-radius: 6px;
    border: 2px solid rgba(26,71,49,.25);
    transition: var(--transition);
}
.btn-cta-secondary:hover {
    background: var(--primary);
    color: var(--white);
    border-color: var(--primary);
    transform: translateY(-2px);
}
.btn-cta-whatsapp {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: #25d366;
    color: var(--white);
    font-weight: 700;
    font-size: 1rem;
    padding: .9rem 2rem;
    border-radius: 6px;
    transition: var(--transition);
}
.btn-cta-whatsapp:hover {
    background: #1aa650;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(37,211,102,.3);
}
.cta-note {
    font-size: .84rem;
    color: rgba(26,71,49,.6);
    display: flex;
    justify-content: center;
    gap: .5rem;
    flex-wrap: wrap;
}
.cta-note i { color: var(--primary); }


/* ================================================================
   FOOTER
================================================================ */
.footer {
    background: var(--primary);
    color: rgba(255,255,255,1);
}
.footer-top {
    display: grid;
    grid-template-columns: 1.8fr 1fr 1.1fr 1.6fr;
    gap: 3rem;
    max-width: 1200px;
    margin: 0 auto;
    padding: 4rem 1.5rem 3rem;
    border-bottom: 1px solid rgba(255,255,255,.08);
}

/* Footer Brand */
.footer-brand .footer-logo-wrap { margin-bottom: 1.25rem; display: flex; justify-content: center; }
.footer-brand .brand-name { color: var(--white); }
.footer-brand p {
    font-size: .88rem;
    line-height: 1.85;
    color: rgba(255,255,255,1);
    margin-bottom: 1.25rem;
}
.footer-badges {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1.25rem;
}
.f-badge {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: rgba(82,183,136,.1);
    border: 1px solid rgba(82,183,136,.2);
    color: var(--accent);
    font-size: .73rem;
    font-weight: 600;
    padding: .25rem .7rem;
    border-radius: 50px;
}

.social-links { display: flex; gap: .65rem; justify-content: center; }
.social-link {
    width: 38px; height: 38px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,1);
    font-size: .9rem;
    transition: var(--transition);
}
.social-link:hover {
    transform: translateY(-3px);
}
.social-link[aria-label="Facebook"]:hover  { background: #1877F2; border-color: #1877F2; color: #fff; }
.social-link[aria-label="Instagram"]:hover { background: #E1306C; border-color: #E1306C; color: #fff; }
.social-link[aria-label="LinkedIn"]:hover  { background: #0A66C2; border-color: #0A66C2; color: #fff; }
.social-link[aria-label="WhatsApp"]:hover  { background: #25D366; border-color: #25D366; color: #fff; }
.social-link[aria-label="YouTube"]:hover   { background: #FF0000; border-color: #FF0000; color: #fff; }

/* Footer Columns */
.footer-col { }
.footer-heading {
    color: var(--white);
    font-size: .95rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    padding-bottom: .65rem;
    position: relative;
}
.footer-heading::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 28px; height: 2px;
    background: var(--accent);
    border-radius: 2px;
}
.footer-links li { margin-bottom: .6rem; }
.footer-links a {
    display: flex;
    align-items: center;
    gap: .5rem;
    color: rgba(255,255,255,1);
    font-size: .87rem;
    transition: var(--transition);
}
.footer-links a i { font-size: .7rem; color: var(--accent); }
.footer-links a:hover { color: var(--accent); padding-left: .4rem; }

/* Footer Contact */
.footer-contact-col { width: 100%; }
.footer-contact-item {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    margin-bottom: .55rem;
    font-size: .84rem;
    color: rgba(255,255,255,1);
    line-height: 1.4;
    padding: .45rem .6rem;
    border-radius: 8px;
}
.footer-contact-item strong { color: rgba(255,255,255,1); display: block; margin-bottom: .05rem; font-size: .78rem; }
.footer-contact-item a { color: rgba(255,255,255,1); transition: var(--transition); }
.footer-contact-item a:hover { color: var(--accent); }
.footer-contact-icon {
    width: 36px; height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    flex-shrink: 0;
    margin-top: 2px;
}
/* Individual icon colors */
.footer-contact-item:nth-child(2) .footer-contact-icon { color: #ea4335; }
.footer-contact-item:nth-child(3) .footer-contact-icon { color: #34a853; }
.footer-contact-item:nth-child(3) .footer-contact-icon i { display: inline-block; }
.footer-contact-item:nth-child(4) .footer-contact-icon { color: #4285f4; }
.footer-contact-item:nth-child(5) .footer-contact-icon { color: #25d366; }

.footer-map {
    margin-top: 1.25rem;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.1);
}

/* Query Form */
.footer-query-section {
    border-top: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.03);
}
.footer-query-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 2.5rem 1.5rem;
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 2rem;
    align-items: center;
}
.footer-query-text h3 {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: .35rem;
}
.footer-query-text p {
    font-size: .85rem;
    color: rgba(255,255,255,.45);
    line-height: 1.65;
}
.footer-query-form { }
.fq-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1.5fr auto;
    gap: .6rem;
    align-items: start;
}
.footer-query-form input,
.footer-query-form select,
.footer-query-form textarea {
    width: 100%;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--radius-sm);
    padding: .65rem 1rem;
    color: var(--white);
    font-size: .86rem;
    outline: none;
    font-family: 'Inter', sans-serif;
    transition: var(--transition);
    resize: none;
}
.footer-query-form input::placeholder,
.footer-query-form textarea::placeholder {
    color: rgba(255,255,255,.3);
}
.footer-query-form select { color: rgba(255,255,255,.5); }
.footer-query-form select option { background: var(--primary); color: var(--white); }
.footer-query-form input:focus,
.footer-query-form select:focus,
.footer-query-form textarea:focus {
    border-color: var(--accent);
    background: rgba(255,255,255,.09);
}
.fq-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    background: var(--accent);
    color: var(--primary);
    font-weight: 700;
    font-size: .88rem;
    padding: .65rem 1.25rem;
    border-radius: var(--radius-sm);
    border: none;
    cursor: pointer;
    white-space: nowrap;
    transition: var(--transition);
}
.fq-submit:hover { background: var(--accent-hover); transform: translateY(-1px); }

/* Footer Bottom */
.footer-bottom {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    border-top: 1px solid rgba(255,255,255,.06);
}
.footer-bottom p { font-size: .82rem; color: rgba(255,255,255,1); }
.footer-bottom-links { display: flex; gap: 1.5rem; }
.footer-bottom-links a {
    font-size: .8rem;
    color: rgba(255,255,255,1);
    transition: var(--transition);
}
.footer-bottom-links a:hover { color: var(--accent); }


/* ================================================================
   FLOATING BUTTONS
================================================================ */
.floating-buttons {
    position: fixed;
    bottom: 5rem;
    right: 1.5rem;
    z-index: 990;
    display: flex;
    flex-direction: column;
    gap: .6rem;
}
.float-btn {
    width: 52px; height: 52px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    box-shadow: 0 4px 20px rgba(0,0,0,.3);
    transition: var(--transition);
    position: relative;
    cursor: pointer;
}
.float-btn:hover { transform: scale(1.12); }
.float-whatsapp { background: #25d366; color: var(--white); }
.float-whatsapp:hover { background: #1aa650; }
.float-call { background: var(--accent); color: var(--primary); }
.float-call:hover { background: var(--accent-hover); }

.float-tooltip {
    position: absolute;
    right: calc(100% + .6rem);
    top: 50%;
    transform: translateY(-50%);
    background: var(--dark);
    color: var(--white);
    font-size: .75rem;
    font-weight: 600;
    white-space: nowrap;
    padding: .35rem .75rem;
    border-radius: 6px;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition);
    pointer-events: none;
}
.float-btn:hover .float-tooltip { opacity: 1; visibility: visible; }

/* ================================================================
   SCROLL TO TOP
================================================================ */
.scroll-top {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    width: 44px; height: 44px;
    background: var(--primary-mid);
    color: var(--white);
    border-radius: 10px;
    border: 1px solid rgba(82,183,136,.3);
    font-size: .9rem;
    cursor: pointer;
    z-index: 999;
    opacity: 0;
    transform: translateY(15px);
    transition: var(--transition);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 16px rgba(0,0,0,.3);
}
.scroll-top.visible { opacity: 1; transform: translateY(0); }
.scroll-top:hover { background: var(--accent); color: var(--primary); }


/* ================================================================
   REVEAL ANIMATION
================================================================ */
.reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .7s ease, transform .7s ease;
}
.reveal.revealed {
    opacity: 1;
    transform: translateY(0);
}


/* ================================================================
   RESPONSIVE
================================================================ */

/* ── Tablet landscape (≤1100px) ── */
@media (max-width: 1100px) {
    .hero-content-wrap { grid-template-columns: 1fr; }
    .hero-info-card { display: none; }
    .trust-grid { grid-template-columns: repeat(2, 1fr); }
    .steps-grid { grid-template-columns: repeat(2, 1fr); }
    .step-arrow { display: none; }
    .materials-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-top { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
    .footer-brand { grid-column: 1 / -1; display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 2rem; text-align: left; }
    .footer-brand .footer-logo-wrap { justify-content: flex-start; margin-bottom: 0; }
    .footer-brand .footer-logo-wrap img { height: 100px; }
    .footer-brand .social-links { justify-content: flex-start; }
    .footer-brand .footer-badges { justify-content: flex-start !important; }
    .fq-row { grid-template-columns: 1fr 1fr 1fr; }
    .footer-query-inner { grid-template-columns: 1fr; }
}

/* ── Tablet portrait (≤900px) ── */
@media (max-width: 900px) {
    .about-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .about-exp-badge { bottom: 1rem; right: 1rem; }
    .about-section { padding: 4rem 0; }
    .testimonials-grid { grid-template-columns: 1fr; }
    .weight-inner { grid-template-columns: 1fr; text-align: center; }
    .weight-shield { margin: 0 auto 1.5rem; }
    .weight-features { justify-items: start; }
    .weight-promise-box { text-align: left; }
}

/* ── Mobile (≤768px) ── */
@media (max-width: 768px) {
    /* Navbar */
    .nav-container { height: 70px; }
    .brand-logo-img { height: 60px; }
    .nav-actions { display: none; }
    .hamburger { display: flex; }
    .nav-menu { display: none; }
    .mobile-menu { top: 70px; }
    .mobile-menu.open { display: block; }

    /* Hero */
    .hero-section { padding: 5rem 0 3rem; min-height: auto; }
    .hero-heading { font-size: clamp(1.6rem, 6vw, 2.2rem); }
    .hero-subtext { font-size: .95rem; }
    .hero-micro-stats {
        gap: .6rem;
        padding: .7rem 1rem;
        flex-wrap: wrap;
        justify-content: center;
        width: 100%;
    }
    .micro-divider { display: none; }
    .micro-num { font-size: 1.1rem; }
    .hero-actions { flex-direction: column; align-items: center; }
    .btn-hero-primary, .btn-hero-secondary, .btn-hero-outline {
        width: 100%; max-width: 340px; justify-content: center;
    }
    .hero-contact-strip { flex-direction: column; align-items: center; gap: .5rem; }
    .hero-strip-btn { width: 100%; max-width: 260px; justify-content: center; }

    /* Sections common */
    .section-title { font-size: 1.75rem; }
    .section-subtitle { margin-bottom: 2rem; }

    /* Guarantee */
    .guarantee-banner { padding: 1.5rem 0; }

    /* Trust */
    .trust-section { padding: 3rem 0; }
    .trust-grid { grid-template-columns: 1fr 1fr; }

    /* Stats */
    .stats-band { padding: 2rem 0; }
    .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
    .stat-number { font-size: 2rem; }
    .stat-suffix { font-size: 1.3rem; }

    /* About */
    .about-section { padding: 3rem 0; }
    .about-main-img { height: 280px; }
    .about-features { grid-template-columns: 1fr; }
    .about-exp-badge { bottom: .75rem; right: .75rem; padding: 1rem; }
    .badge-num { font-size: 1.5rem; }

    /* How it works */
    .booking-section { padding: 3rem 0; }
    .steps-grid { grid-template-columns: 1fr; }

    /* Materials */
    .materials-section { padding: 3rem 0; }
    .materials-grid { grid-template-columns: 1fr; }

    /* Testimonials */
    .testimonials-section { padding: 3rem 0; }

    /* CTA */
    .cta-section { padding: 3rem 0; }
    .cta-actions { flex-direction: column; align-items: center; }
    .btn-cta-primary, .btn-cta-secondary, .btn-cta-whatsapp {
        width: 100%; max-width: 320px; justify-content: center;
    }

    /* Footer */
    /* Footer */
    .footer-top { grid-template-columns: 1fr; gap: 2rem; padding: 3rem 1.5rem 2rem; }
    .footer-brand { grid-column: auto; display: block; text-align: center; }
    .footer-brand .footer-logo-wrap { justify-content: center; margin-bottom: 1rem; }
    .footer-brand .footer-logo-wrap img { height: 90px; }
    .footer-brand .social-links { justify-content: center; }
    .footer-brand .footer-badges { justify-content: center !important; }
    .footer-col { text-align: center; }
    .footer-heading::after { left: 50%; transform: translateX(-50%); }
    .footer-links a { justify-content: center; }
    .footer-contact-item { justify-content: center; text-align: left; }
    .footer-bottom { flex-direction: column; align-items: center; text-align: center; gap: .75rem; padding: 1.25rem 1.5rem; }
    .footer-bottom-links { gap: 1rem; flex-wrap: wrap; justify-content: center; }
    .footer-query-inner { grid-template-columns: 1fr; padding: 2rem 1.5rem; }
    .fq-row { grid-template-columns: 1fr; gap: .5rem; }
}

/* ── Small mobile (≤480px) ── */
@media (max-width: 480px) {
    .nav-container { height: 64px; }
    .brand-logo-img { height: 52px; }
    .mobile-menu { top: 64px; }

    .hero-section { padding: 4.5rem 0 2.5rem; }
    .hero-subtext { font-size: .9rem; }
    .hero-micro-stats { gap: .5rem; padding: .6rem .75rem; }
    .micro-num { font-size: 1rem; }
    .micro-lbl { font-size: .58rem; }
    .hero-strip-btn { font-size: .82rem; }

    .trust-grid { grid-template-columns: 1fr; }
    .stats-grid { grid-template-columns: repeat(2, 1fr); gap: .75rem; }
    .stat-number { font-size: 1.75rem; }

    .about-main-img { height: 220px; }
    .about-exp-badge { position: static; margin-top: 1rem; display: inline-flex; gap: .5rem; align-items: center; border-radius: 8px; }
    .about-verify-badge { top: .75rem; left: .75rem; font-size: .7rem; }

    .weight-inner { grid-template-columns: 1fr; }
    .section-title { font-size: 1.5rem; }
}


/* ================================================================
   ABOUT PAGE — Page-specific styles
================================================================ */

/* ----------------------------------------------------------------
   PAGE BANNER (shared across inner pages)
---------------------------------------------------------------- */
.page-banner {
    /* position: relative; */
    transform: translate(0, 0);
    min-height: 320px;
    padding: 5rem 0 2.5rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}
.page-banner-bg {
    position: absolute;
    inset: 0;
    background:
        url('https://images.unsplash.com/photo-1586528116311-ad8dd3c8310d?w=1400&q=70') center/cover no-repeat;
    z-index: 0;
}
.page-banner-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(10,31,19,.72) 0%, rgba(26,71,49,.65) 100%);
}
.page-banner-pattern {
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        -45deg, transparent, transparent 30px,
        rgba(82,183,136,.04) 30px, rgba(82,183,136,.04) 60px
    );
}
.page-banner-content {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 2rem;
    flex-wrap: wrap;
}
.page-banner-badge {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: rgba(82,183,136,.15);
    border: 1px solid rgba(82,183,136,.3);
    color: var(--accent);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: .3rem .85rem;
    border-radius: 50px;
    margin-bottom: .85rem;
    display: block;
}
.page-banner-title {
    font-family: 'Rajdhani', 'Inter', sans-serif;
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 800;
    color: var(--white);
    line-height: 1.1;
    margin-bottom: .75rem;
}
.page-banner-title span { color: var(--accent); }
.page-banner-sub {
    font-size: 1rem;
    color: rgba(255,255,255,.65);
    max-width: 560px;
    line-height: 1.75;
}

/* Breadcrumb */
.breadcrumb-nav { align-self: flex-end; flex-shrink: 0; }
.breadcrumb-list {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .85rem;
}
.breadcrumb-list li { display: flex; align-items: center; gap: .5rem; }
.breadcrumb-list a {
    color: rgba(255,255,255,.55);
    transition: var(--transition);
    display: flex;
    align-items: center;
    gap: .35rem;
}
.breadcrumb-list a:hover { color: var(--accent); }
.breadcrumb-list .fa-chevron-right { font-size: .65rem; color: rgba(255,255,255,.3); }
.breadcrumb-list .active { color: var(--accent); font-weight: 600; }

/* Decorative lines at banner bottom */
.banner-deco-lines {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    display: flex;
    height: 4px;
    z-index: 3;
}
.banner-deco-lines span:nth-child(1) { flex: 3; background: var(--accent); }
.banner-deco-lines span:nth-child(2) { flex: 1; background: var(--primary-mid); }
.banner-deco-lines span:nth-child(3) { flex: 6; background: rgba(255,255,255,.08); }


/* ----------------------------------------------------------------
   COMPANY INTRODUCTION SECTION
---------------------------------------------------------------- */
.company-intro-section {
    padding: 6rem 0;
    background: var(--white);
}
.company-intro-grid {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 4.5rem;
    align-items: center;
}

/* Image stack */
.ci-img-stack {
    position: relative;
}
.ci-img-main {
    width: 100%;
    height: 460px;
    object-fit: cover;
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
}
.ci-img-secondary {
    position: absolute;
    bottom: -2rem;
    right: -2rem;
    width: 200px;
    height: 150px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    border: 4px solid var(--white);
    box-shadow: var(--shadow-lg);
}
.ci-img-badge {
    position: absolute;
    top: 1.5rem;
    left: -1.5rem;
    background: var(--primary);
    border: 2px solid var(--accent);
    color: var(--white);
    padding: 1rem 1.25rem;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    gap: .65rem;
    box-shadow: var(--shadow-lg);
}
.ci-img-badge i { font-size: 1.6rem; color: var(--accent); flex-shrink: 0; }
.ci-img-badge span {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.3;
    color: var(--white);
}

/* Content */
.ci-content .section-title { text-align: left; margin-bottom: 1rem; }
.ci-lead {
    font-size: 1.05rem;
    color: var(--text);
    font-weight: 500;
    line-height: 1.8;
    margin-bottom: 1rem;
}
.ci-body {
    color: var(--text-muted);
    line-height: 1.85;
    margin-bottom: 1rem;
}
.ci-body strong { color: var(--primary); }

/* Company facts */
.ci-facts {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .85rem;
    margin: 1.75rem 0;
    padding: 1.5rem;
    background: var(--light);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
}
.ci-fact {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    font-size: .87rem;
}
.ci-fact > i {
    color: var(--accent);
    font-size: 1rem;
    margin-top: .15rem;
    flex-shrink: 0;
}
.ci-fact strong {
    display: block;
    color: var(--primary);
    font-weight: 700;
    margin-bottom: .15rem;
}
.ci-fact span { color: var(--text-muted); line-height: 1.5; }

.ci-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 1.5rem; }
.btn-outline-dark {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: transparent;
    color: var(--primary);
    border: 2px solid var(--primary);
    padding: .75rem 1.6rem;
    border-radius: 6px;
    font-weight: 700;
    font-size: .95rem;
    transition: var(--transition);
}
.btn-outline-dark:hover {
    background: var(--primary);
    color: var(--white);
    transform: translateY(-2px);
}


/* ----------------------------------------------------------------
   MISSION & VISION
---------------------------------------------------------------- */
.mv-section {
    padding: 6rem 0;
    background: var(--light);
}
.mv-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    margin-top: 2.5rem;
}
.mv-card {
    border-radius: var(--radius);
    padding: 2.5rem;
    position: relative;
    overflow: hidden;
    transition: var(--transition);
}
.mv-mission {
    background: var(--primary);
    border: 1px solid rgba(82,183,136,.2);
}
.mv-vision {
    background: var(--white);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
}
.mv-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.mv-mission:hover { background: #1a3a2a; }
.mv-vision:hover  { background: #f0f7f4; border-color: var(--primary); }

.mv-icon-wrap {
    width: 64px; height: 64px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.7rem;
    margin-bottom: 1.25rem;
}
.mv-mission .mv-icon-wrap {
    background: rgba(82,183,136,.15);
    color: var(--accent);
}
.mv-vision .mv-icon-wrap {
    background: rgba(26,71,49,.08);
    color: var(--primary);
}

.mv-tag {
    font-size: .73rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: .6rem;
}
.mv-mission .mv-tag { color: var(--accent); }
.mv-vision .mv-tag { color: var(--steel); }

.mv-card h3 {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.25;
    margin-bottom: 1rem;
}
.mv-mission h3 { color: var(--white); }
.mv-vision h3  { color: var(--primary); }

.mv-card p { font-size: .93rem; line-height: 1.8; margin-bottom: 1.5rem; }
.mv-mission p { color: rgba(255,255,255,.65); }
.mv-vision p  { color: var(--text-muted); }

.mv-points { display: grid; gap: .55rem; }
.mv-points li {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: .87rem;
    font-weight: 500;
}
.mv-points li i { font-size: .7rem; flex-shrink: 0; }
.mv-mission .mv-points li { color: rgba(255,255,255,.8); }
.mv-mission .mv-points li i { color: var(--accent); }
.mv-vision .mv-points li  { color: var(--text); }
.mv-vision .mv-points li i { color: var(--primary); }


/* ----------------------------------------------------------------
   WHY CHOOSE US
---------------------------------------------------------------- */
.why-section {
    padding: 6rem 0;
    background: var(--white);
}
.why-grid {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 4rem;
    align-items: start;
}
.why-content .section-title { text-align: left; }
.why-intro {
    font-size: 1rem;
    font-weight: 500;
    color: var(--text);
    line-height: 1.8;
    margin-bottom: 1rem;
}
.why-body { color: var(--text-muted); line-height: 1.85; }

.why-features { display: grid; gap: 1.1rem; }
.why-feature-card {
    display: flex;
    align-items: flex-start;
    gap: 1.1rem;
    padding: 1.25rem 1.5rem;
    background: var(--light);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
    transition: var(--transition);
}
.why-feature-card:hover {
    background: var(--white);
    box-shadow: var(--shadow);
    border-left-color: var(--primary);
    transform: translateX(4px);
}
.wf-icon {
    width: 44px; height: 44px;
    background: var(--primary);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: var(--accent);
    flex-shrink: 0;
    transition: var(--transition);
}
.why-feature-card:hover .wf-icon { background: var(--accent); color: var(--primary); }
.wf-body h4 {
    font-size: .97rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .3rem;
}
.wf-body p {
    font-size: .85rem;
    color: var(--text-muted);
    line-height: 1.65;
}


/* ----------------------------------------------------------------
   CORE VALUES
---------------------------------------------------------------- */
.values-section {
    padding: 6rem 0;
    background: var(--primary);
    position: relative;
    overflow: hidden;
}
.values-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        45deg, transparent, transparent 40px,
        rgba(82,183,136,.03) 40px, rgba(82,183,136,.03) 80px
    );
}
.values-section .container { position: relative; }
.values-section .section-title { color: var(--white); }
.values-section .section-subtitle { color: rgba(255,255,255,.5); }

.values-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1.25rem;
}
.value-card {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--radius);
    padding: 2rem 1.5rem 1.75rem;
    text-align: center;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.value-card:hover {
    background: rgba(255,255,255,.09);
    border-color: rgba(82,183,136,.3);
    transform: translateY(-6px);
}
.value-num {
    position: absolute;
    top: .75rem; right: .85rem;
    font-family: 'Rajdhani', sans-serif;
    font-size: 2.2rem;
    font-weight: 900;
    color: rgba(82,183,136,.1);
    line-height: 1;
}
.value-icon-wrap {
    width: 60px; height: 60px;
    background: rgba(82,183,136,.12);
    border: 1px solid rgba(82,183,136,.2);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--accent);
    margin: 0 auto 1.25rem;
    transition: var(--transition);
}
.value-card:hover .value-icon-wrap {
    background: var(--accent);
    color: var(--primary);
    border-color: var(--accent);
}
.value-card h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: .75rem;
}
.value-card p {
    font-size: .83rem;
    color: rgba(255,255,255,.55);
    line-height: 1.7;
}
.value-accent-bar {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: var(--accent);
    transform: scaleX(0);
    transition: transform .4s ease;
}
.value-card:hover .value-accent-bar { transform: scaleX(1); }


/* ----------------------------------------------------------------
   ACHIEVEMENT STRIP
---------------------------------------------------------------- */
.achievement-strip {
    background: var(--accent);
    padding: 2.5rem 0;
}
.achievement-grid {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    flex-wrap: wrap;
}
.achievement-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: .75rem 2.5rem;
    text-align: center;
}
.ach-num {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2.4rem;
    font-weight: 900;
    color: var(--primary);
    line-height: 1;
    display: flex;
    align-items: baseline;
    gap: .1rem;
}
.ach-label {
    font-size: .8rem;
    font-weight: 600;
    color: rgba(26,71,49,.65);
    margin-top: .3rem;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.achievement-divider {
    width: 1px;
    height: 40px;
    background: rgba(26,71,49,.2);
    flex-shrink: 0;
}


/* ----------------------------------------------------------------
   NETWORK SECTION
---------------------------------------------------------------- */
.network-section {
    padding: 6rem 0;
    background: var(--light);
}
.network-grid {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 4rem;
    align-items: center;
}
.network-content .section-title { text-align: left; }
.network-intro {
    color: var(--text-muted);
    line-height: 1.85;
    margin-bottom: 2rem;
}
.network-states h4 {
    font-size: .9rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .85rem;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.states-grid {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 2rem;
}
.state-tag {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    background: var(--white);
    border: 1px solid var(--border);
    color: var(--primary);
    font-size: .8rem;
    font-weight: 600;
    padding: .3rem .75rem;
    border-radius: 50px;
    transition: var(--transition);
}
.state-tag:hover { background: var(--primary); color: var(--accent); border-color: var(--primary); }
.state-tag i { color: var(--accent); font-size: .65rem; }

.network-highlights { display: grid; gap: 1rem; }
.nh-item {
    display: flex;
    align-items: flex-start;
    gap: .85rem;
    padding: 1rem 1.25rem;
    background: var(--white);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    transition: var(--transition);
}
.nh-item:hover { border-color: var(--accent); box-shadow: var(--shadow-sm); }
.nh-item > i {
    font-size: 1.25rem;
    color: var(--accent);
    flex-shrink: 0;
    margin-top: .1rem;
    width: 28px;
    text-align: center;
}
.nh-item strong {
    display: block;
    font-size: .9rem;
    color: var(--primary);
    font-weight: 700;
    margin-bottom: .2rem;
}
.nh-item span { font-size: .83rem; color: var(--text-muted); line-height: 1.6; }

/* Network Map Card */
.network-map-card {
    background: var(--primary);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    border: 1px solid rgba(82,183,136,.2);
}
.nmap-header {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .9rem 1.25rem;
    background: rgba(82,183,136,.1);
    border-bottom: 1px solid rgba(82,183,136,.15);
    color: var(--accent);
    font-size: .85rem;
    font-weight: 600;
}
.nmap-header i { font-size: 1rem; }
.nmap-header span { flex: 1; }
.nmap-live-dot {
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .75rem;
    color: rgba(255,255,255,.6);
}
.nmap-live-dot span {
    width: 7px; height: 7px;
    background: #34d399;
    border-radius: 50%;
    animation: pulse-dot 1.5s infinite;
}
.nmap-body {
    padding: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 280px;
    background: rgba(26,71,49,.5);
    position: relative;
}
.india-map-visual { position: relative; }
.india-map-img { width: 100%; height: auto; display: block; border-radius: var(--radius); object-fit: cover; }
.india-svg { width: 280px; height: auto; filter: drop-shadow(0 4px 12px rgba(0,0,0,.3)); }
.map-hq-label {
    position: absolute;
    top: 1rem;
    right: 0;
    background: var(--accent);
    color: var(--primary);
    font-size: .72rem;
    font-weight: 700;
    padding: .3rem .7rem;
    border-radius: 50px;
    display: flex;
    align-items: center;
    gap: .3rem;
    white-space: nowrap;
}
.nmap-footer {
    display: flex;
    align-items: center;
    justify-content: space-around;
    padding: 1rem 1.25rem;
    border-top: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.03);
}
.nmap-stat { text-align: center; }
.nmap-stat-val {
    display: block;
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--accent);
    line-height: 1;
}
.nmap-stat-lbl {
    font-size: .73rem;
    color: rgba(255,255,255,.45);
    text-transform: uppercase;
    letter-spacing: .5px;
    margin-top: .2rem;
    display: block;
}
.nmap-divider { width: 1px; height: 32px; background: rgba(255,255,255,.08); }


/* ----------------------------------------------------------------
   PROCESS / TIMELINE
---------------------------------------------------------------- */
.process-section {
    padding: 6rem 0;
    background: var(--white);
}
.process-section .section-title { text-align: center; }

.timeline {
    position: relative;
    max-width: 800px;
    margin: 3.5rem auto 0;
    padding: 0 1rem;
}
.timeline::before {
    content: '';
    position: absolute;
    top: 0; bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 2px;
    background: linear-gradient(to bottom, var(--accent), rgba(82,183,136,.2));
}
.timeline-item {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 1.5rem;
    align-items: center;
    margin-bottom: 3rem;
    position: relative;
}
.timeline-item.tl-left .tl-content {
    grid-column: 1;
    grid-row: 1;
    text-align: right;
}
.timeline-item.tl-left .tl-dot { grid-column: 2; grid-row: 1; }
.timeline-item.tl-left::after {
    content: '';
    grid-column: 3;
    grid-row: 1;
}
.timeline-item.tl-right .tl-content {
    grid-column: 3;
    grid-row: 1;
    text-align: left;
}
.timeline-item.tl-right .tl-dot { grid-column: 2; grid-row: 1; }
.timeline-item.tl-right::before {
    content: '';
    grid-column: 1;
    grid-row: 1;
}

.tl-dot {
    width: 50px; height: 50px;
    background: var(--primary);
    border: 3px solid var(--accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);
    font-size: .95rem;
    flex-shrink: 0;
    z-index: 1;
    box-shadow: 0 0 0 6px rgba(82,183,136,.1);
    transition: var(--transition);
}
.timeline-item:hover .tl-dot { background: var(--accent); color: var(--primary); }

.tl-content {
    background: var(--light);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 1.25rem 1.5rem;
    transition: var(--transition);
}
.timeline-item:hover .tl-content {
    border-color: rgba(82,183,136,.3);
    box-shadow: var(--shadow);
}
.tl-year {
    display: inline-block;
    background: var(--accent);
    color: var(--primary);
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: 1px;
    padding: .2rem .65rem;
    border-radius: 4px;
    margin-bottom: .5rem;
    font-family: 'Rajdhani', sans-serif;
}
.tl-content h4 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .4rem;
}
.tl-content p {
    font-size: .85rem;
    color: var(--text-muted);
    line-height: 1.7;
}


/* ----------------------------------------------------------------
   ABOUT PAGE CTA
---------------------------------------------------------------- */
.about-cta-section {
    padding: 5.5rem 0;
    background: var(--primary);
    position: relative;
    overflow: hidden;
}
.about-cta-bg {
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        -45deg, transparent, transparent 35px,
        rgba(82,183,136,.04) 35px, rgba(82,183,136,.04) 70px
    );
}
.about-cta-inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 4rem;
    align-items: center;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(82,183,136,.15);
    border-radius: var(--radius);
    padding: 3rem;
}
.about-cta-text .cta-badge {
    display: inline-block;
    background: rgba(82,183,136,.15);
    color: var(--accent);
    font-size: .73rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: .3rem .85rem;
    border-radius: 50px;
    border: 1px solid rgba(82,183,136,.25);
    margin-bottom: 1rem;
}
.about-cta-text h2 {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(1.8rem, 3.5vw, 2.8rem);
    font-weight: 800;
    color: var(--white);
    line-height: 1.15;
    margin-bottom: 1rem;
}
.about-cta-text h2 span { color: var(--accent); }
.about-cta-text p {
    color: rgba(255,255,255,.65);
    font-size: .95rem;
    line-height: 1.8;
    margin-bottom: 1.5rem;
}
.about-cta-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
}
.about-cta-list li {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .87rem;
    color: rgba(255,255,255,.7);
    font-weight: 500;
}
.about-cta-list li i { color: var(--accent); font-size: .8rem; }

.about-cta-actions {
    display: flex;
    flex-direction: column;
    gap: .85rem;
}
.about-cta-actions .btn-cta-primary,
.about-cta-actions .btn-cta-secondary,
.about-cta-actions .btn-cta-whatsapp {
    justify-content: center;
    width: 100%;
}
.about-cta-note {
    font-size: .8rem;
    color: rgba(255,255,255,.4);
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
}
.about-cta-note i { color: var(--accent); }


/* ----------------------------------------------------------------
   ABOUT PAGE RESPONSIVE
---------------------------------------------------------------- */
@media (max-width: 1100px) {
    .values-grid { grid-template-columns: repeat(3, 1fr); }
    .company-intro-grid,
    .network-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .ci-img-secondary { display: none; }
    .ci-img-badge { left: 1rem; }
    .about-cta-inner { grid-template-columns: 1fr; gap: 2rem; padding: 2rem; }
    .about-cta-actions { flex-direction: row; flex-wrap: wrap; }
    .about-cta-actions a { flex: 1; min-width: 160px; }
}

@media (max-width: 900px) {
    .mv-grid,
    .why-grid { grid-template-columns: 1fr; gap: 2rem; }
    .why-content .section-title { text-align: center; }
    .why-content { text-align: center; }
    .values-grid { grid-template-columns: repeat(2, 1fr); }
    .timeline::before { left: 25px; }
    .timeline-item { grid-template-columns: auto 1fr; }
    .timeline-item.tl-left .tl-content,
    .timeline-item.tl-right .tl-content {
        grid-column: 2; grid-row: 1; text-align: left;
    }
    .timeline-item.tl-left .tl-dot,
    .timeline-item.tl-right .tl-dot { grid-column: 1; grid-row: 1; }
    .timeline-item.tl-left::after,
    .timeline-item.tl-right::before { display: none; }
}

@media (max-width: 768px) {
    .page-banner { padding: 4rem 0 2rem; }
    .page-banner-content { flex-direction: column; align-items: flex-start; gap: 1rem; }
    .breadcrumb-nav { align-self: flex-start; }
    .ci-facts { grid-template-columns: 1fr; }
    .values-grid { grid-template-columns: repeat(2, 1fr); }
    .achievement-grid { gap: 0; }
    .achievement-item { padding: .75rem 1.25rem; }
    .achievement-divider { display: none; }
    .about-cta-list { grid-template-columns: 1fr; }
    .about-cta-actions { flex-direction: column; }
    .about-cta-actions a { width: 100%; }
}

@media (max-width: 540px) {
    .values-grid { grid-template-columns: 1fr; }
    .ci-img-main { height: 280px; }
    .mv-card { padding: 1.75rem; }
    .timeline { padding: 0; }
}


/* ================================================================
   SERVICES PAGE — Specific styles
================================================================ */

/* ----------------------------------------------------------------
   Services Banner override bg image
---------------------------------------------------------------- */
.services-banner .page-banner-bg {
    background-image: url('https://images.unsplash.com/photo-1504328345606-18bbc8c9d7d1?w=1400&q=70');
}
.materials-banner .page-banner-bg {
    background-image: url('https://images.unsplash.com/photo-1565008576549-57569a49371d?w=1400&q=70');
}

/* ----------------------------------------------------------------
   Services Intro
---------------------------------------------------------------- */
.srv-intro-section {
    padding: 5rem 0;
    background: var(--white);
    border-bottom: 1px solid var(--border);
}
.srv-intro-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 4rem;
    align-items: center;
}
.srv-intro-text .section-title { text-align: left; }
.srv-intro-text p { color: var(--text-muted); line-height: 1.85; margin-top: .75rem; }

.srv-intro-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.srv-stat-box {
    display: flex;
    align-items: center;
    gap: .85rem;
    background: var(--light);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 1.1rem 1.25rem;
    transition: var(--transition);
}
.srv-stat-box:hover { border-color: var(--accent); box-shadow: var(--shadow-sm); }
.srv-stat-box > i {
    font-size: 1.5rem;
    color: var(--accent);
    width: 36px;
    text-align: center;
    flex-shrink: 0;
}
.srv-stat-box strong {
    display: block;
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--primary);
    line-height: 1;
}
.srv-stat-box span { font-size: .78rem; color: var(--text-muted); }

/* ----------------------------------------------------------------
   Service Detail Sections (alternating)
---------------------------------------------------------------- */
.srv-detail-section { padding: 6rem 0; }
.srv-odd  { background: var(--white); }
.srv-even { background: var(--light); }

.srv-detail-grid {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 4.5rem;
    align-items: center;
}
.srv-reverse { grid-template-columns: 1.1fr 1fr; }
.srv-reverse .srv-detail-content { order: 1; }
.srv-reverse .srv-detail-img     { order: 2; }

/* Image frame */
.srv-img-frame {
    position: relative;
    border-radius: var(--radius);
    overflow: visible;
}
.srv-img-frame img {
    width: 100%;
    height: 420px;
    object-fit: cover;
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    display: block;
}
.srv-img-badge {
    position: absolute;
    top: 1.5rem;
    left: -1.5rem;
    background: var(--accent);
    color: var(--primary);
    padding: .85rem 1.1rem;
    border-radius: var(--radius-sm);
    box-shadow: 0 6px 24px rgba(82,183,136,.35);
    display: flex;
    align-items: center;
    gap: .6rem;
}
.srv-badge-right {
    left: auto;
    right: -1.5rem;
}
.sib-num {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2rem;
    font-weight: 900;
    line-height: 1;
}
.sib-label {
    font-size: .72rem;
    font-weight: 700;
    line-height: 1.35;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.srv-img-accent-card {
    position: absolute;
    bottom: -1.5rem;
    right: -1.5rem;
    background: var(--primary);
    border: 1px solid rgba(82,183,136,.25);
    border-radius: var(--radius-sm);
    padding: 1rem 1.25rem;
    display: flex;
    align-items: flex-start;
    gap: .7rem;
    max-width: 220px;
    box-shadow: var(--shadow-lg);
}
.srv-acc-right {
    right: auto;
    left: -1.5rem;
}
.srv-img-accent-card i {
    font-size: 1.25rem;
    color: var(--accent);
    flex-shrink: 0;
    margin-top: .1rem;
}
.srv-img-accent-card p {
    font-size: .8rem;
    color: rgba(255,255,255,.7);
    line-height: 1.55;
}

/* Content */
.srv-number-tag {
    font-size: .7rem;
    font-weight: 800;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--steel);
    margin-bottom: .5rem;
}
.srv-detail-content .section-title { text-align: left; }
.srv-lead {
    font-size: 1.05rem;
    font-weight: 500;
    color: var(--text);
    line-height: 1.8;
    margin-bottom: 1rem;
}
.srv-body {
    color: var(--text-muted);
    line-height: 1.85;
    margin-bottom: 1.5rem;
}

/* Feature grid */
.srv-features-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .6rem;
    margin-bottom: 1.75rem;
}
.srv-feat {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .87rem;
    font-weight: 500;
    color: var(--text);
}
.srv-feat i { color: var(--accent); font-size: .75rem; flex-shrink: 0; }

/* Alloy tags */
.srv-alloy-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1.25rem;
}
.alloy-tag {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: var(--primary);
    color: var(--accent);
    font-size: .78rem;
    font-weight: 700;
    padding: .3rem .8rem;
    border-radius: 50px;
    border: 1px solid rgba(82,183,136,.25);
    transition: var(--transition);
}
.alloy-tag:hover { background: var(--accent); color: var(--primary); }
.alloy-tag i { font-size: .65rem; }

/* Premium note */
.srv-premium-note {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    background: rgba(82,183,136,.08);
    border: 1px solid rgba(82,183,136,.2);
    border-left: 4px solid var(--accent);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
}
.srv-premium-note i { color: var(--accent); font-size: 1rem; flex-shrink: 0; margin-top: .1rem; }
.srv-premium-note p { font-size: .87rem; color: var(--text-muted); line-height: 1.65; }

/* Process steps (Service 03) */
.srv-process-steps {
    display: grid;
    gap: .75rem;
    margin-bottom: 1.75rem;
}
.srv-step {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: .85rem 1rem;
    background: var(--light);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    transition: var(--transition);
}
.srv-step:hover { border-color: var(--accent); background: var(--white); }
.ss-dot {
    width: 32px; height: 32px;
    background: var(--primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Rajdhani', sans-serif;
    font-size: .9rem;
    font-weight: 800;
    color: var(--accent);
    flex-shrink: 0;
}
.ss-text strong {
    display: block;
    font-size: .9rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .1rem;
}
.ss-text span { font-size: .82rem; color: var(--text-muted); }

/* CTA row inside service */
.srv-cta-row {
    display: flex;
    gap: .85rem;
    flex-wrap: wrap;
    margin-top: 1.5rem;
}
.btn-srv-wa {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    background: rgba(37,211,102,.1);
    color: #25d366;
    border: 1px solid rgba(37,211,102,.3);
    padding: .75rem 1.5rem;
    border-radius: 6px;
    font-weight: 700;
    font-size: .95rem;
    transition: var(--transition);
}
.btn-srv-wa:hover { background: #25d366; color: var(--white); transform: translateY(-2px); }


/* ----------------------------------------------------------------
   Service Cards (04, 05, 06)
---------------------------------------------------------------- */
.srv-cards-section {
    padding: 6rem 0;
    background: var(--primary);
    position: relative;
    overflow: hidden;
}
.srv-cards-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        -45deg, transparent, transparent 30px,
        rgba(82,183,136,.025) 30px, rgba(82,183,136,.025) 60px
    );
}
.srv-cards-section .container { position: relative; }
.srv-cards-section .section-title { color: var(--white); }
.srv-cards-section .section-subtitle { color: rgba(255,255,255,.5); }

.srv-cards-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
}
.srv-card {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--radius);
    display: flex;
    flex-direction: column;
    transition: var(--transition);
    overflow: hidden;
}
.srv-card:hover {
    background: rgba(255,255,255,.08);
    border-color: rgba(82,183,136,.3);
    transform: translateY(-6px);
}
.srv-card-accent {
    background: var(--accent);
    border-color: var(--accent);
}
.srv-card-accent:hover { background: var(--accent-hover); }

.srv-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.5rem 1.75rem 0;
}
.srv-card-icon {
    width: 56px; height: 56px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    transition: var(--transition);
}
.srv-card:not(.srv-card-accent) .srv-card-icon {
    background: rgba(82,183,136,.12);
    color: var(--accent);
}
.srv-card-accent .srv-card-icon {
    background: rgba(26,71,49,.2);
    color: var(--primary);
}
.srv-card:hover .srv-card-icon { transform: rotate(8deg) scale(1.1); }
.srv-card-num {
    font-family: 'Rajdhani', sans-serif;
    font-size: 3rem;
    font-weight: 900;
    line-height: 1;
    opacity: .12;
    color: var(--white);
}
.srv-card-accent .srv-card-num { color: var(--primary); opacity: .15; }

.srv-card-body {
    padding: 1.25rem 1.75rem;
    flex: 1;
}
.srv-card-body h3 {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: .65rem;
}
.srv-card:not(.srv-card-accent) .srv-card-body h3 { color: var(--white); }
.srv-card-accent .srv-card-body h3 { color: var(--primary); }

.srv-card-body p { font-size: .88rem; line-height: 1.7; margin-bottom: 1.1rem; }
.srv-card:not(.srv-card-accent) .srv-card-body p { color: rgba(255,255,255,.6); }
.srv-card-accent .srv-card-body p { color: rgba(26,71,49,.7); }

/* Card list */
.srv-card-list { display: grid; gap: .45rem; margin-bottom: 1.1rem; }
.srv-card-list li {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .83rem;
    font-weight: 500;
}
.srv-card:not(.srv-card-accent) .srv-card-list li { color: rgba(255,255,255,.7); }
.srv-card:not(.srv-card-accent) .srv-card-list li i { color: var(--accent); font-size: .75rem; }
.srv-card-accent .srv-card-list li { color: rgba(26,71,49,.75); }
.srv-card-accent .srv-card-list li i { color: var(--primary); font-size: .75rem; }

/* Card guarantee badge */
.srv-card-guarantee {
    display: flex;
    align-items: center;
    gap: .5rem;
    background: rgba(82,183,136,.1);
    border: 1px solid rgba(82,183,136,.2);
    border-radius: 6px;
    padding: .6rem .85rem;
    font-size: .8rem;
    font-weight: 700;
    color: var(--accent);
}
.srv-card-guarantee i { font-size: .9rem; }

/* Payment modes */
.srv-payment-modes { display: grid; gap: .65rem; margin-bottom: 1.1rem; }
.pay-mode {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .65rem .9rem;
    background: rgba(26,71,49,.15);
    border-radius: var(--radius-sm);
    border: 1px solid rgba(26,71,49,.1);
}
.pay-mode > i { font-size: 1.15rem; color: var(--primary); width: 22px; text-align: center; flex-shrink: 0; }
.pay-mode strong { display: block; font-size: .85rem; color: var(--primary); font-weight: 700; }
.pay-mode span { font-size: .78rem; color: rgba(26,71,49,.65); }

.srv-card-highlight {
    display: flex;
    align-items: center;
    gap: .5rem;
    background: rgba(26,71,49,.12);
    border-radius: 6px;
    padding: .6rem .85rem;
    font-size: .82rem;
    color: var(--primary);
    font-weight: 500;
}
.srv-card-highlight i { color: var(--primary); }
.srv-card-highlight strong { font-weight: 800; }

/* Partnership count */
.srv-partner-count {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .85rem 1rem;
    background: rgba(82,183,136,.08);
    border: 1px solid rgba(82,183,136,.15);
    border-radius: var(--radius-sm);
}
.spc-num {
    font-family: 'Rajdhani', sans-serif;
    font-size: 2rem;
    font-weight: 900;
    color: var(--accent);
    line-height: 1;
}
.spc-label { font-size: .82rem; color: rgba(255,255,255,.6); line-height: 1.4; }

/* Card footer */
.srv-card-footer {
    padding: 1rem 1.75rem 1.5rem;
    border-top: 1px solid rgba(255,255,255,.07);
}
.srv-card-accent .srv-card-footer { border-top-color: rgba(26,71,49,.1); }
.srv-card-link {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-size: .87rem;
    font-weight: 700;
    color: var(--accent);
    transition: var(--transition);
}
.srv-card-link:hover { gap: .7rem; }
.srv-card-link-light { color: var(--primary) !important; }
.srv-card-link-light:hover { color: var(--dark) !important; }


/* ----------------------------------------------------------------
   Services Overview Strip
---------------------------------------------------------------- */
.srv-overview-strip {
    background: var(--dark);
    padding: 1.5rem 0;
    border-top: 1px solid rgba(82,183,136,.15);
    border-bottom: 1px solid rgba(82,183,136,.15);
}
.srv-overview-grid {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0;
}
.srv-ov-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .5rem 1.4rem;
    color: rgba(255,255,255,.55);
    font-size: .82rem;
    font-weight: 600;
    transition: var(--transition);
    white-space: nowrap;
}
.srv-ov-item i { color: var(--accent); font-size: .85rem; }
.srv-ov-item:hover { color: var(--accent); }
.srv-ov-divider {
    width: 1px; height: 20px;
    background: rgba(255,255,255,.1);
    flex-shrink: 0;
}


/* ----------------------------------------------------------------
   Why Our Services
---------------------------------------------------------------- */
.srv-why-section {
    padding: 6rem 0;
    background: var(--white);
}
.srv-why-grid {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 4rem;
    align-items: center;
}
.srv-why-content .section-title { text-align: left; }
.srv-why-content p { color: var(--text-muted); line-height: 1.85; }

.srv-why-metrics {
    display: grid;
    grid-template-columns: 1fr;
    gap: .85rem;
    margin-top: 2rem;
}
.swm-item {
    display: flex;
    align-items: center;
    gap: 1.1rem;
    padding: 1rem 1.25rem;
    background: var(--light);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
}
.swm-val {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--accent);
    white-space: nowrap;
    min-width: 90px;
}
.swm-label { font-size: .85rem; color: var(--text-muted); line-height: 1.4; }

/* Why visual */
.srv-why-cards { display: grid; gap: .85rem; }
.swc-row { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; }
.swc-box {
    background: var(--light);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 1.25rem;
    transition: var(--transition);
}
.swc-box:hover { border-color: var(--accent); box-shadow: var(--shadow-sm); transform: translateY(-2px); }
.swc-highlight {
    background: var(--primary);
    border-color: rgba(82,183,136,.2);
}
.swc-box i {
    font-size: 1.3rem;
    color: var(--accent);
    margin-bottom: .6rem;
    display: block;
}
.swc-box h4 { font-size: .9rem; font-weight: 700; margin-bottom: .3rem; }
.swc-box:not(.swc-highlight) h4 { color: var(--primary); }
.swc-highlight h4 { color: var(--white); }
.swc-box p { font-size: .8rem; line-height: 1.6; }
.swc-box:not(.swc-highlight) p { color: var(--text-muted); }
.swc-highlight p { color: rgba(255,255,255,.6); }


/* ----------------------------------------------------------------
   Industries Section
---------------------------------------------------------------- */
.industries-section {
    padding: 6rem 0;
    background: var(--light);
}
.industries-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
}
.industry-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 1.75rem 1.25rem;
    text-align: center;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.industry-card::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: var(--accent);
    transform: scaleX(0);
    transition: transform .35s ease;
}
.industry-card:hover::after { transform: scaleX(1); }
.industry-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: rgba(82,183,136,.25); }
.ind-icon {
    width: 56px; height: 56px;
    background: var(--primary);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    color: var(--accent);
    margin: 0 auto 1rem;
    transition: var(--transition);
}
.industry-card:hover .ind-icon { background: var(--accent); color: var(--primary); }
.industry-card h4 {
    font-size: .95rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .5rem;
}
.industry-card p { font-size: .82rem; color: var(--text-muted); line-height: 1.65; }


/* ----------------------------------------------------------------
   Services CTA Section
---------------------------------------------------------------- */
.srv-cta-section {
    padding: 5.5rem 0;
    background: transparent;
    position: relative;
    overflow: hidden;
}
.srv-cta-bg-pattern {
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        45deg, transparent, transparent 30px,
        rgba(26,71,49,.06) 30px, rgba(26,71,49,.06) 60px
    );
}
.srv-cta-inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 4rem;
    align-items: center;
    background: rgba(26,71,49,.06);
    border: 1px solid rgba(26,71,49,.1);
    border-radius: var(--radius);
    padding: 3rem;
}
.srv-cta-content .cta-badge {
    display: inline-block;
    background: rgba(26,71,49,.12);
    color: var(--primary);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: .28rem .85rem;
    border-radius: 50px;
    margin-bottom: 1rem;
}
.srv-cta-content h2 {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    color: var(--primary);
    line-height: 1.15;
    margin-bottom: 1rem;
}
.srv-cta-content h2 span { color: rgba(26,71,49,.6); }
.srv-cta-content p {
    color: rgba(26,71,49,.7);
    font-size: .95rem;
    line-height: 1.8;
    margin-bottom: 1.25rem;
}
.srv-cta-trust {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
}
.srv-cta-trust span {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-size: .82rem;
    font-weight: 600;
    color: rgba(26,71,49,.7);
}
.srv-cta-trust i { color: var(--primary); font-size: .75rem; }

.srv-cta-actions {
    display: flex;
    flex-direction: column;
    gap: .85rem;
}
.btn-cta-call {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    background: rgba(26,71,49,.1);
    color: var(--primary);
    font-weight: 700;
    font-size: .95rem;
    padding: .85rem 2rem;
    border-radius: 6px;
    border: 2px solid rgba(26,71,49,.2);
    transition: var(--transition);
}
.btn-cta-call:hover {
    background: var(--primary);
    color: var(--white);
    border-color: var(--primary);
    transform: translateY(-2px);
}
.srv-cta-actions .btn-cta-primary,
.srv-cta-actions .btn-cta-secondary,
.srv-cta-actions .btn-cta-whatsapp,
.srv-cta-actions .btn-cta-call { width: 100%; justify-content: center; }


/* ----------------------------------------------------------------
   Services Page Responsive
---------------------------------------------------------------- */
@media (max-width: 1100px) {
    .srv-intro-grid   { grid-template-columns: 1fr; gap: 2.5rem; }
    .srv-detail-grid,
    .srv-reverse      { grid-template-columns: 1fr; gap: 3rem; }
    .srv-reverse .srv-detail-content { order: 2; }
    .srv-reverse .srv-detail-img     { order: 1; }
    .srv-cards-grid   { grid-template-columns: 1fr 1fr; }
    .industries-grid  { grid-template-columns: repeat(2, 1fr); }
    .srv-why-grid     { grid-template-columns: 1fr; gap: 2.5rem; }
    .srv-cta-inner    { grid-template-columns: 1fr; gap: 2rem; padding: 2rem; }
    .srv-img-badge { left: 1rem; top: 1rem; }
    .srv-badge-right { right: 1rem; left: auto; }
    .srv-img-accent-card { display: none; }
}
@media (max-width: 768px) {
    .srv-cards-grid  { grid-template-columns: 1fr; }
    .industries-grid { grid-template-columns: repeat(2, 1fr); }
    .swc-row         { grid-template-columns: 1fr; }
    .srv-overview-strip { display: none; }
    .srv-features-grid  { grid-template-columns: 1fr; }
    .srv-cta-actions { flex-direction: column; }
    .srv-intro-stats { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 540px) {
    .industries-grid { grid-template-columns: 1fr; }
    .srv-intro-stats { grid-template-columns: 1fr; }
    .srv-cta-inner   { padding: 1.5rem; }
}


/* ================================================================
   CONTACT PAGE — Specific styles
================================================================ */

/* ----------------------------------------------------------------
   Contact Banner override
---------------------------------------------------------------- */
.contact-banner .page-banner-bg {
    background-image: url('https://images.unsplash.com/photo-1586528116311-ad8dd3c8310d?w=1400&q=70');
    background-position: center 40%;
}

/* ----------------------------------------------------------------
   Quick Contact Strip
---------------------------------------------------------------- */
.quick-contact-strip {
    background: var(--primary);
    border-bottom: 2px solid var(--accent);
    position: sticky;
    top: 72px;
    z-index: 90;
    box-shadow: 0 4px 20px rgba(0,0,0,.25);
}
.qc-strip-inner {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .75rem 0;
    flex-wrap: wrap;
}
.qc-label {
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .8rem;
    font-weight: 700;
    color: rgba(255,255,255,.5);
    text-transform: uppercase;
    letter-spacing: 1px;
    white-space: nowrap;
    margin-right: .25rem;
}
.qc-label i { color: var(--accent); }
.qc-btn {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .55rem 1.1rem;
    border-radius: 8px;
    font-weight: 600;
    transition: var(--transition);
    text-decoration: none;
}
.qc-btn > i { font-size: 1.1rem; flex-shrink: 0; }
.qc-btn span { display: flex; flex-direction: column; line-height: 1; }
.qc-btn strong { font-size: .85rem; font-weight: 700; }
.qc-btn small  { font-size: .72rem; opacity: .75; margin-top: .1rem; }
.qc-call {
    background: rgba(82,183,136,.12);
    color: var(--accent);
    border: 1px solid rgba(82,183,136,.25);
}
.qc-call:hover { background: var(--accent); color: var(--primary); }
.qc-whatsapp {
    background: rgba(37,211,102,.1);
    color: #25d366;
    border: 1px solid rgba(37,211,102,.2);
}
.qc-whatsapp:hover { background: #25d366; color: var(--white); }
.qc-pickup {
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.8);
    border: 1px solid rgba(255,255,255,.12);
}
.qc-pickup:hover { background: var(--white); color: var(--primary); }
.qc-response {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .8rem;
    color: rgba(255,255,255,.45);
    white-space: nowrap;
}
.qc-response i { color: var(--accent); }
.qc-response strong { color: var(--accent); font-weight: 700; }

/* ----------------------------------------------------------------
   Contact Info Cards
---------------------------------------------------------------- */
.contact-info-section {
    padding: 5rem 0 3rem;
    background: var(--light);
}
.contact-info-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    margin-bottom: 1.75rem;
}
.ci-info-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.75rem 1.5rem;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.ci-info-card::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .4s ease;
}
.ci-info-card:hover::after { transform: scaleX(1); }
.ci-info-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }

.ci-info-icon {
    width: 52px; height: 52px;
    background: var(--primary);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    color: var(--accent);
    margin-bottom: 1.1rem;
    transition: var(--transition);
}
.ci-icon-call  { background: #e8f5e9; color: #2e7d32; }
.ci-icon-wa    { background: #e8f5e9; color: #25d366; }
.ci-icon-email { background: #e3f2fd; color: #1565c0; }
.ci-info-card:hover .ci-info-icon { transform: scale(1.1) rotate(5deg); }

.ci-info-label {
    display: block;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--steel);
    margin-bottom: .35rem;
}
.ci-info-card h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .5rem;
    line-height: 1.3;
    word-break: break-word;
}
.ci-info-card p {
    font-size: .85rem;
    color: var(--text-muted);
    line-height: 1.7;
    margin-bottom: .9rem;
}
.ci-info-link {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-size: .83rem;
    font-weight: 700;
    color: var(--primary);
    transition: var(--transition);
}
.ci-info-link:hover { color: var(--accent); gap: .65rem; }
.ci-link-wa { color: #25d366; }
.ci-link-wa:hover { color: #1aa650; }

/* Service Area Banner */
.service-area-banner {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    background: var(--primary);
    border: 1px solid rgba(82,183,136,.2);
    border-radius: var(--radius-sm);
    padding: 1.25rem 1.75rem;
    flex-wrap: wrap;
}
.sa-icon {
    font-size: 1.75rem;
    color: var(--accent);
    flex-shrink: 0;
}
.sa-content { flex: 1; min-width: 200px; }
.sa-content strong {
    display: block;
    color: var(--white);
    font-size: .95rem;
    font-weight: 700;
    margin-bottom: .25rem;
}
.sa-content p { font-size: .83rem; color: rgba(255,255,255,.55); line-height: 1.6; }
.sa-link {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: var(--accent);
    color: var(--primary);
    font-weight: 700;
    font-size: .85rem;
    padding: .6rem 1.25rem;
    border-radius: 6px;
    transition: var(--transition);
    white-space: nowrap;
    flex-shrink: 0;
}
.sa-link:hover { background: var(--accent-hover); transform: translateY(-2px); }

/* ----------------------------------------------------------------
   Contact Main — Form + Map
---------------------------------------------------------------- */
.contact-main-section {
    padding: 5rem 0 6rem;
    background: var(--white);
}
.contact-main-grid {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 3rem;
    align-items: start;
}

/* Form Card */
.contact-form-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: hidden;
}
.cfc-header {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.75rem 2rem;
    background: var(--primary);
    border-bottom: 3px solid var(--accent);
}
.cfc-header-icon {
    width: 46px; height: 46px;
    background: rgba(82,183,136,.2);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    color: var(--accent);
    flex-shrink: 0;
}
.cfc-header h2 {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: .2rem;
}
.cfc-header p { font-size: .83rem; color: rgba(255,255,255,.55); line-height: 1.5; }

/* Success message */
.form-success-msg {
    display: flex;
    align-items: flex-start;
    gap: .85rem;
    margin: 1.5rem 2rem 0;
    background: #e8f5e9;
    border: 1px solid #a5d6a7;
    border-left: 4px solid #2e7d32;
    border-radius: var(--radius-sm);
    padding: 1rem 1.25rem;
}
.form-success-msg i { font-size: 1.3rem; color: #2e7d32; flex-shrink: 0; margin-top: .1rem; }
.form-success-msg strong { display: block; color: #1b5e20; font-weight: 700; font-size: .95rem; }
.form-success-msg span  { font-size: .85rem; color: #2e7d32; line-height: 1.5; }

/* Form */
.inquiry-form { padding: 1.75rem 2rem 2rem; }
.form-row-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-bottom: 1rem;
}
.form-group { margin-bottom: 0; display: flex; flex-direction: column; }
.form-group label {
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .83rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .45rem;
}
.form-group label i { color: var(--steel); font-size: .8rem; }
.req { color: #c0392b; font-weight: 800; margin-left: .1rem; }

.form-group input,
.form-group select,
.form-group textarea {
    width: 100%;
    border: 1.5px solid var(--border);
    border-radius: var(--radius-sm);
    padding: .7rem 1rem;
    font-size: .9rem;
    font-family: 'Inter', sans-serif;
    color: var(--text);
    background: var(--white);
    outline: none;
    transition: var(--transition);
    resize: vertical;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: #bdbdbd; }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(82,183,136,.12);
}
.input-error { border-color: #c0392b !important; background: #fff8f8 !important; }
.field-error {
    display: flex;
    align-items: center;
    gap: .3rem;
    font-size: .78rem;
    color: #c0392b;
    margin-top: .3rem;
    font-weight: 500;
}

.form-note {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .78rem;
    color: var(--text-muted);
    margin-bottom: 1.25rem;
    padding: .65rem .9rem;
    background: var(--light);
    border-radius: 6px;
    border: 1px solid var(--border);
}
.form-note i { color: var(--steel); flex-shrink: 0; }

.form-submit-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .65rem;
    width: 100%;
    background: var(--accent);
    color: var(--primary);
    border: none;
    border-radius: var(--radius-sm);
    padding: .95rem 2rem;
    font-size: 1rem;
    font-weight: 800;
    font-family: 'Inter', sans-serif;
    cursor: pointer;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.form-submit-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(26,71,49,.08);
    transform: translateX(-100%);
    transition: transform .4s ease;
}
.form-submit-btn:hover::before { transform: translateX(0); }
.form-submit-btn:hover { background: var(--accent-hover); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(82,183,136,.3); }
.form-submit-btn:disabled { opacity: .7; cursor: not-allowed; transform: none; }
.submit-arrow { margin-left: auto; font-size: .85rem; }

.form-alt-contact {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    margin-top: 1rem;
    font-size: .83rem;
    color: var(--text-muted);
}
.form-alt-contact a {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: #25d366;
    font-weight: 700;
    transition: var(--transition);
}
.form-alt-contact a:hover { color: #1aa650; }
.form-alt-contact a i { font-size: 1rem; }

/* ----------------------------------------------------------------
   Map Column
---------------------------------------------------------------- */
.contact-map-col { display: flex; flex-direction: column; gap: 1.25rem; }

.contact-map-card {
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-sm);
}
.map-card-header {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .9rem 1.25rem;
    background: var(--primary);
    border-bottom: 2px solid var(--accent);
}
.map-card-header i { color: var(--accent); font-size: 1.1rem; flex-shrink: 0; }
.map-card-header > div { flex: 1; }
.map-card-header strong { display: block; color: var(--white); font-size: .9rem; font-weight: 700; }
.map-card-header span   { font-size: .78rem; color: rgba(255,255,255,.5); }
.map-open-btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .75rem;
    font-weight: 600;
    color: var(--accent);
    border: 1px solid rgba(82,183,136,.3);
    padding: .3rem .65rem;
    border-radius: 6px;
    transition: var(--transition);
    white-space: nowrap;
}
.map-open-btn:hover { background: var(--accent); color: var(--primary); }
.map-embed-wrap { display: block; }
.map-card-footer {
    padding: .85rem 1.25rem;
    background: var(--light);
    border-top: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: .45rem;
}
.mcf-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .82rem;
    color: var(--text-muted);
}
.mcf-item i { color: var(--accent); width: 14px; text-align: center; flex-shrink: 0; }

/* Side contact cards */
.side-contact-cards { display: flex; flex-direction: column; gap: .75rem; }
.side-contact-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    transition: var(--transition);
    text-decoration: none;
    background: var(--white);
}
.side-contact-card:hover { transform: translateX(4px); box-shadow: var(--shadow); }
.scc-call:hover  { border-color: var(--accent); background: rgba(82,183,136,.04); }
.scc-wa:hover    { border-color: #25d366; background: rgba(37,211,102,.04); }
.scc-pickup:hover{ border-color: var(--primary-mid); background: rgba(26,71,49,.03); }

.scc-icon {
    width: 44px; height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    flex-shrink: 0;
    transition: var(--transition);
}
.scc-call .scc-icon   { background: rgba(82,183,136,.12); color: var(--accent); }
.scc-wa .scc-icon     { background: rgba(37,211,102,.12); color: #25d366; }
.scc-pickup .scc-icon { background: rgba(26,71,49,.08);  color: var(--primary); }
.side-contact-card:hover .scc-icon { transform: scale(1.1); }

.scc-body { flex: 1; }
.scc-body strong { display: block; font-size: .9rem; font-weight: 700; color: var(--primary); margin-bottom: .12rem; }
.scc-body span   { display: block; font-size: .82rem; color: var(--text-muted); margin-bottom: .1rem; }
.scc-body small  { font-size: .75rem; color: var(--steel); }
.scc-arrow { font-size: .75rem; color: var(--border); transition: var(--transition); }
.side-contact-card:hover .scc-arrow { color: var(--accent); }

/* Trust badges */
.contact-trust-badges {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .6rem;
}
.ctb-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    background: var(--light);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: .6rem .85rem;
    font-size: .8rem;
    font-weight: 600;
    color: var(--primary);
}
.ctb-item i { color: var(--accent); font-size: .85rem; flex-shrink: 0; }

/* ----------------------------------------------------------------
   Why Contact Us / Steps
---------------------------------------------------------------- */
.why-contact-section {
    padding: 6rem 0;
    background: var(--primary);
    position: relative;
    overflow: hidden;
}
.why-contact-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        -45deg, transparent, transparent 30px,
        rgba(82,183,136,.03) 30px, rgba(82,183,136,.03) 60px
    );
}
.why-contact-section .container { position: relative; }
.why-contact-section .section-title { color: var(--white); }
.why-contact-section .section-badge { margin-bottom: .85rem; }

.wc-steps-grid {
    display: flex;
    align-items: flex-start;
    gap: 0;
    margin-top: 3rem;
    flex-wrap: wrap;
}
.wc-step {
    flex: 1;
    min-width: 180px;
    text-align: center;
    padding: 0 1rem;
    position: relative;
}
.wc-step-icon {
    width: 70px; height: 70px;
    background: rgba(82,183,136,.12);
    border: 2px solid rgba(82,183,136,.25);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    color: var(--accent);
    margin: 0 auto 1rem;
    position: relative;
    z-index: 1;
    transition: var(--transition);
}
.wc-step:hover .wc-step-icon { background: var(--accent); color: var(--primary); border-color: var(--accent); }
.wc-step-num {
    font-family: 'Rajdhani', sans-serif;
    font-size: 3rem;
    font-weight: 900;
    color: rgba(82,183,136,.08);
    position: absolute;
    top: -.5rem;
    left: 50%;
    transform: translateX(-50%);
    line-height: 1;
    z-index: 0;
}
.wc-step h4 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--white);
    margin-bottom: .5rem;
}
.wc-step p { font-size: .85rem; color: rgba(255,255,255,.55); line-height: 1.7; }

.wc-arrow {
    display: flex;
    align-items: center;
    padding-top: 1.75rem;
    color: rgba(82,183,136,.35);
    font-size: 1.25rem;
    flex-shrink: 0;
}

/* ----------------------------------------------------------------
   Contact FAQ
---------------------------------------------------------------- */
.contact-faq-section {
    padding: 6rem 0;
    background: var(--light);
}
.contact-faq-grid {
    display: grid;
    grid-template-columns: 1fr 1.6fr;
    gap: 4rem;
    align-items: start;
}
.faq-heading .section-title { text-align: left; }
.faq-heading p { color: var(--text-muted); line-height: 1.8; }

.faq-list { display: flex; flex-direction: column; gap: .75rem; }
.faq-item {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    overflow: hidden;
    transition: var(--transition);
}
.faq-item.faq-open {
    border-color: rgba(82,183,136,.35);
    box-shadow: var(--shadow-sm);
}
.faq-q {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    width: 100%;
    padding: 1.1rem 1.25rem;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: var(--transition);
}
.faq-q span {
    font-size: .93rem;
    font-weight: 600;
    color: var(--primary);
    line-height: 1.45;
}
.faq-q:hover span { color: var(--accent); }
.faq-icon {
    font-size: .8rem;
    color: var(--accent);
    flex-shrink: 0;
    transition: transform .3s ease;
}
.faq-open .faq-icon { transform: rotate(0deg); }
.faq-a {
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s ease;
}
.faq-a p {
    padding: 0 1.25rem 1.25rem;
    font-size: .88rem;
    color: var(--text-muted);
    line-height: 1.75;
    border-top: 1px solid var(--border);
    padding-top: .85rem;
}

/* ----------------------------------------------------------------
   Contact Bottom CTA
---------------------------------------------------------------- */
.contact-cta-section {
    padding: 5rem 0;
    background: var(--accent);
    text-align: center;
    position: relative;
    overflow: hidden;
}
.contact-cta-bg {
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        45deg, transparent, transparent 30px,
        rgba(26,71,49,.06) 30px, rgba(26,71,49,.06) 60px
    );
}
.contact-cta-inner { position: relative; z-index: 1; max-width: 700px; margin: 0 auto; padding: 0 1.5rem; }
.contact-cta-inner h2 {
    font-family: 'Rajdhani', sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    color: var(--primary);
    line-height: 1.15;
    margin-bottom: 1rem;
}
.contact-cta-inner h2 span { color: rgba(26,71,49,.6); }
.contact-cta-inner p {
    color: rgba(26,71,49,.7);
    font-size: 1rem;
    line-height: 1.8;
    margin-bottom: 2rem;
}
.contact-cta-actions {
    display: flex;
    justify-content: center;
    gap: .85rem;
    flex-wrap: wrap;
}
.contact-cta-actions .btn-cta-primary,
.contact-cta-actions .btn-cta-secondary,
.contact-cta-actions .btn-cta-whatsapp { min-width: 180px; justify-content: center; }

/* ----------------------------------------------------------------
   Contact Page Responsive
---------------------------------------------------------------- */
@media (max-width: 1100px) {
    .contact-info-grid  { grid-template-columns: repeat(2, 1fr); }
    .contact-main-grid  { grid-template-columns: 1fr; }
    .contact-faq-grid   { grid-template-columns: 1fr; gap: 2.5rem; }
    .faq-heading .section-title { text-align: center; }
    .faq-heading { text-align: center; }
    .faq-heading .btn-primary-custom { margin: 1.5rem auto 0; display: inline-flex; }
}
@media (max-width: 768px) {
    .quick-contact-strip { position: static; top: auto; }
    .qc-strip-inner { justify-content: center; gap: .5rem; }
    .qc-label { display: none; }
    .qc-response { margin-left: 0; width: 100%; justify-content: center; }
    .contact-info-grid { grid-template-columns: 1fr; }
    .service-area-banner { flex-direction: column; text-align: center; }
    .form-row-2 { grid-template-columns: 1fr; }
    .wc-steps-grid { flex-direction: column; align-items: center; gap: 1.5rem; }
    .wc-arrow { transform: rotate(90deg); padding: 0; }
    .contact-trust-badges { grid-template-columns: 1fr; }
    .contact-cta-actions { flex-direction: column; align-items: center; }
    .contact-cta-actions a { width: 100%; max-width: 320px; }
}
@media (max-width: 540px) {
    .inquiry-form { padding: 1.25rem 1.1rem 1.5rem; }
    .cfc-header { padding: 1.25rem; }
}

/* ================================================================
   MATERIALS PAGE
================================================================ */

/* Intro Strip */
.mat-intro-strip {
    background: var(--primary);
    padding: 1.75rem 0;
}
.mat-intro-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
.mat-intro-item {
    display: flex;
    align-items: center;
    gap: .85rem;
    color: var(--white);
}
.mat-intro-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(82,183,136,.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);
    font-size: 1.1rem;
    flex-shrink: 0;
}
.mat-intro-item strong {
    display: block;
    font-weight: 700;
    font-size: .92rem;
    margin-bottom: .15rem;
}
.mat-intro-item span {
    font-size: .8rem;
    color: rgba(255,255,255,.65);
}

/* Material Detail Cards */
.mat-detail-card {
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: 3rem;
    align-items: start;
    padding: 3rem 0;
    border-bottom: 1px solid var(--border);
}
.mat-detail-card:last-child { border-bottom: none; }
.mat-detail-card-alt {
    grid-template-columns: 420px 1fr;
}
.mat-detail-card-alt .mat-detail-left { order: 2; }
.mat-detail-card-alt .mat-detail-right { order: 1; }

.mat-grade-badge {
    display: inline-flex;
    align-items: center;
    font-size: .78rem;
    font-weight: 700;
    padding: .3rem .85rem;
    border-radius: 50px;
    background: var(--primary);
    color: var(--white);
    margin-bottom: 1rem;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.mat-grade-premium { /* background: #2d6a4f; */ }
.mat-grade-high    { background: #1b5e40; }
.mat-grade-elite   { background: #0d3b25; }
.mat-grade-std     { background: #40916c; }

.mat-detail-left h3 {
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--primary);
    margin-bottom: .85rem;
    font-family: 'Rajdhani', sans-serif;
}
.mat-desc {
    color: var(--text-light);
    line-height: 1.8;
    margin-bottom: 1.5rem;
    font-size: .97rem;
}
.mat-specs {
    background: var(--light);
    border-radius: 10px;
    padding: 1.1rem 1.25rem;
    margin-bottom: 1.25rem;
    border: 1px solid var(--border);
}
.mat-spec-row {
    display: flex;
    gap: 1rem;
    padding: .6rem 0;
    border-bottom: 1px solid var(--border);
    font-size: .88rem;
}
.mat-spec-row:last-child { border-bottom: none; }
.mat-spec-label {
    font-weight: 700;
    color: var(--primary);
    min-width: 120px;
    flex-shrink: 0;
}
.mat-spec-val { color: var(--text-light); }
.mat-rate {
    color: var(--primary) !important;
    font-weight: 700;
}
.rate-live-badge {
    display: inline-block;
    background: rgba(82,183,136,.15);
    color: var(--primary-light);
    font-size: .7rem;
    font-weight: 700;
    padding: .15rem .45rem;
    border-radius: 50px;
    margin-left: .4rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.mat-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1.25rem;
}
.mat-tags span {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .8rem;
    font-weight: 600;
    color: var(--primary-mid);
    background: var(--light-2);
    border: 1px solid var(--border);
    padding: .35rem .75rem;
    border-radius: 50px;
}
.mat-tags span i { color: var(--accent); font-size: .75rem; }
.mt-3 { margin-top: 1rem !important; }

/* Detail Right Image */
.mat-detail-img-wrap { position: relative; }
.mat-detail-img {
    border-radius: 16px;
    height: 260px;
    overflow: hidden;
    border: 2px solid var(--border);
    margin-bottom: 1rem;
}
.mat-detail-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.mat-img-icon {
    font-size: 3.5rem;
    color: var(--primary);
    opacity: .35;
    margin-bottom: .75rem;
}
.mat-img-label {
    font-size: .9rem;
    font-weight: 700;
    color: var(--primary);
    opacity: .6;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.mat-detail-info-box {
    background: var(--primary);
    border-radius: 12px;
    padding: 1.1rem 1.25rem;
}
.mat-info-row {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: .85rem;
    color: rgba(255,255,255,.85);
    padding: .45rem 0;
    border-bottom: 1px solid rgba(255,255,255,.07);
}
.mat-info-row:last-child { border-bottom: none; }
.mat-info-row i { color: var(--accent); font-size: .75rem; flex-shrink: 0; }

/* Industries Section */
.industries-section { background: var(--light); }
.industries-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
.industry-card {
    background: var(--white);
    border-radius: 14px;
    padding: 1.75rem 1.4rem;
    border: 1px solid var(--border);
    transition: var(--transition);
    text-align: center;
}
.industry-card:hover {
    border-color: var(--accent);
    box-shadow: 0 8px 28px rgba(26,71,49,.12);
    transform: translateY(-4px);
}
.industry-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: var(--light-2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    color: var(--primary);
    margin: 0 auto 1rem;
    transition: var(--transition);
}
.industry-card:hover .industry-icon {
    background: var(--primary);
    color: var(--accent);
}
.industry-card h4 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .5rem;
    font-family: 'Rajdhani', sans-serif;
}
.industry-card p {
    font-size: .83rem;
    color: var(--text-light);
    line-height: 1.6;
    margin-bottom: .85rem;
}
.industry-grades {
    font-size: .75rem;
    font-weight: 700;
    color: var(--primary-light);
    background: var(--light-2);
    border-radius: 50px;
    padding: .3rem .7rem;
    display: inline-block;
    letter-spacing: .03em;
}

/* Benefits Grid */
.benefits-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
}
.benefit-card {
    background: var(--light);
    border-radius: 14px;
    padding: 2rem 1.75rem;
    border: 1px solid var(--border);
    position: relative;
    transition: var(--transition);
}
.benefit-card:hover {
    border-color: var(--accent);
    box-shadow: 0 10px 32px rgba(26,71,49,.1);
    transform: translateY(-4px);
}
.benefit-num {
    font-size: 3.5rem;
    font-weight: 900;
    color: var(--border);
    line-height: 1;
    font-family: 'Rajdhani', sans-serif;
    position: absolute;
    top: 1.25rem;
    right: 1.5rem;
}
.benefit-icon {
    width: 52px;
    height: 52px;
    background: var(--primary);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);
    font-size: 1.25rem;
    margin-bottom: 1rem;
}
.benefit-card h4 {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .5rem;
    font-family: 'Rajdhani', sans-serif;
}
.benefit-card p {
    font-size: .88rem;
    color: var(--text-light);
    line-height: 1.7;
}

/* Rate Table */
.mat-rate-section {
    background: var(--primary);
    padding: 5rem 0;
}
.rate-table-wrap {
    background: rgba(255,255,255,.04);
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.1);
    overflow: hidden;
}
.rate-table-header {
    display: grid;
    grid-template-columns: 2fr 1fr 1.5fr 2fr 1fr;
    gap: 1rem;
    padding: 1rem 1.5rem;
    background: rgba(82,183,136,.15);
    font-size: .82rem;
    font-weight: 700;
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: .06em;
}
.rate-table-body { }
.rate-table-row {
    display: grid;
    grid-template-columns: 2fr 1fr 1.5fr 2fr 1fr;
    gap: 1rem;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid rgba(255,255,255,.06);
    align-items: center;
    transition: var(--transition);
}
.rate-table-row:last-child { border-bottom: none; }
.rate-table-row:hover { background: rgba(255,255,255,.04); }
.rt-grade {
    display: flex;
    align-items: center;
    gap: .6rem;
    color: var(--white);
    font-weight: 600;
    font-size: .92rem;
}
.rt-dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}
.rt-green  { background: #52b788; }
.rt-teal   { background: #40916c; }
.rt-blue   { background: #74c69d; }
.rt-purple { background: #2d6a4f; }
.rt-gold   { background: #f4a261; }
.rt-orange { background: #e76f51; }
.rt-red    { background: #e63946; }
.rt-val    { color: rgba(255,255,255,.65); font-size: .88rem; }
.rt-price  { color: var(--accent); font-weight: 700; font-size: .95rem; }
.rt-source { color: rgba(255,255,255,.5); font-size: .82rem; }
.rt-btn {
    display: inline-flex;
    align-items: center;
    background: var(--accent);
    color: var(--primary);
    font-weight: 700;
    font-size: .78rem;
    padding: .4rem .85rem;
    border-radius: 6px;
    transition: var(--transition);
    white-space: nowrap;
}
.rt-btn:hover { background: var(--accent-hover); }
.rate-table-footer {
    padding: .85rem 1.5rem;
    background: rgba(255,255,255,.03);
    font-size: .8rem;
    color: rgba(255,255,255,.45);
    border-top: 1px solid rgba(255,255,255,.06);
    display: flex;
    align-items: center;
    gap: .5rem;
}
.rate-table-footer i { color: var(--accent); }

/* Sell Steps */
.sell-steps-grid {
    display: flex;
    align-items: flex-start;
    gap: 0;
    margin-bottom: 2.5rem;
}
.sell-step {
    flex: 1;
    text-align: center;
    padding: 1.75rem 1.25rem;
    background: var(--white);
    border-radius: 14px;
    border: 1px solid var(--border);
    position: relative;
}
.sell-step-num {
    position: absolute;
    top: -1px;
    left: -1px;
    background: var(--primary);
    color: var(--white);
    font-size: .75rem;
    font-weight: 800;
    width: 28px;
    height: 28px;
    border-radius: 14px 0 10px 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.sell-step-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: var(--light-2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    color: var(--primary);
    margin: 0 auto 1rem;
}
.sell-step h4 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: .5rem;
    font-family: 'Rajdhani', sans-serif;
}
.sell-step p {
    font-size: .83rem;
    color: var(--text-light);
    line-height: 1.6;
}
.sell-step-arrow {
    display: flex;
    align-items: center;
    padding: 0 .75rem;
    color: var(--accent);
    font-size: 1.1rem;
    flex-shrink: 0;
    margin-top: 3rem;
}
.sell-steps-cta {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

/* ----------------------------------------------------------------
   Materials Page Responsive
---------------------------------------------------------------- */
@media (max-width: 1100px) {
    .mat-intro-grid     { grid-template-columns: repeat(2, 1fr); }
    .mat-detail-card,
    .mat-detail-card-alt { grid-template-columns: 1fr; gap: 2rem; }
    .mat-detail-card-alt .mat-detail-left { order: 1; }
    .mat-detail-card-alt .mat-detail-right { order: 2; }
    .industries-grid    { grid-template-columns: repeat(3, 1fr); }
    .benefits-grid      { grid-template-columns: repeat(2, 1fr); }
    .rate-table-header,
    .rate-table-row     { grid-template-columns: 2fr 1fr 1.5fr 1fr; }
    .rate-table-header > div:nth-child(4),
    .rate-table-row > div:nth-child(4) { display: none; }
}
@media (max-width: 768px) {
    .mat-intro-grid     { grid-template-columns: 1fr; gap: 1rem; }
    .industries-grid    { grid-template-columns: repeat(2, 1fr); }
    .benefits-grid      { grid-template-columns: 1fr; }
    .sell-steps-grid    { flex-direction: column; }
    .sell-step-arrow    { transform: rotate(90deg); margin: 0 auto; }
    .rate-table-header,
    .rate-table-row     { grid-template-columns: 2fr 1.5fr 1fr; font-size: .8rem; }
    .rate-table-header > div:nth-child(2),
    .rate-table-row > div:nth-child(2) { display: none; }
}
@media (max-width: 540px) {
    .mat-detail-left h3 { font-size: 1.4rem; }
    .industries-grid    { grid-template-columns: 1fr; }
    .rate-table-header,
    .rate-table-row     { grid-template-columns: 1fr 1.2fr 1fr; padding: .75rem 1rem; }
    .sell-steps-cta     { flex-direction: column; align-items: center; }
    .sell-steps-cta a   { width: 100%; max-width: 320px; }
}


/* ================================================================
   ALL-PAGE RESPONSIVE SUPPLEMENT
   Covers padding reductions + overflow fixes not yet handled above
================================================================ */

/* ── Fix: contact strip top must match desktop navbar (100px) ── */
.quick-contact-strip { top: 100px; }
@media (max-width: 768px) {
    .quick-contact-strip { top: auto; position: static; }
}

/* ================================================================
   TABLET (≤1100px) — section padding reductions
================================================================ */
@media (max-width: 1100px) {
    /* About */
    .company-intro-section,
    .mv-section,
    .why-section,
    .values-section,
    .network-section,
    .process-section  { padding: 4rem 0; }
    .about-cta-section { padding: 4rem 0; }

    /* Services */
    .srv-intro-section,
    .srv-detail-section,
    .srv-cards-section,
    .srv-why-section,
    .industries-section,
    .srv-cta-section  { padding: 4rem 0; }

    /* Materials */
    .mat-rate-section { padding: 4rem 0; }

    /* Contact */
    .contact-info-section,
    .contact-main-section,
    .why-contact-section,
    .contact-faq-section,
    .contact-cta-section { padding: 4rem 0; }
}

/* ================================================================
   MOBILE (≤768px) — section padding reductions + layout fixes
================================================================ */
@media (max-width: 768px) {

    /* ── About page ── */
    .company-intro-section,
    .mv-section,
    .why-section,
    .values-section,
    .network-section,
    .process-section  { padding: 3rem 0; }
    .about-cta-section { padding: 3rem 0; }

    .ci-img-main   { height: 280px; }
    .ci-img-badge  { left: .75rem; top: .75rem; padding: .75rem; }
    .ci-img-badge i { font-size: 1.2rem; }
    .ci-img-badge span { font-size: .85rem; }

    .achievement-strip { padding: 1.5rem 0; }
    .ach-num { font-size: 1.75rem; }

    .mv-card { padding: 1.75rem; }

    .network-grid { grid-template-columns: 1fr; gap: 2rem; }
    .network-content .section-title { text-align: center; }
    .network-intro { text-align: center; }

    .process-section { padding: 3rem 0; }
    .timeline { padding: 0; }
    .timeline-item { margin-bottom: 2rem; gap: 1rem; }

    /* ── Services page ── */
    .srv-intro-section,
    .srv-detail-section,
    .srv-cards-section,
    .srv-why-section,
    .industries-section,
    .srv-cta-section  { padding: 3rem 0; }

    .srv-img-frame img { height: 260px; }
    .srv-img-badge  { left: .75rem; top: .75rem; }
    .srv-badge-right { right: .75rem; left: auto; }
    .srv-cta-row    { flex-direction: column; }
    .srv-cta-row a  { width: 100%; justify-content: center; }

    /* ── Materials page ── */
    .mat-rate-section { padding: 3rem 0; }
    .mat-detail-card  { padding: 2rem 0; }
    .mat-detail-left h3 { font-size: 1.4rem; }
    .mat-detail-img   { height: 220px; }

    /* Rate table: hide source column on mobile */
    .rate-table-header > div:nth-child(3),
    .rate-table-row > div:nth-child(3) { display: none; }

    /* ── Contact page ── */
    .contact-info-section,
    .contact-main-section,
    .why-contact-section,
    .contact-faq-section,
    .contact-cta-section { padding: 3rem 0; }

    .qc-btn small { display: none; }
    .qc-pickup    { display: none; }

    .contact-faq-grid { grid-template-columns: 1fr; gap: 2rem; }
    .faq-heading .section-title { text-align: center; }
    .faq-heading { text-align: center; }

    /* ── Page banner (all inner pages) ── */
    .page-banner { min-height: 240px; padding: 5rem 0 2rem; }
    .page-banner-title { font-size: clamp(1.6rem, 6vw, 2.5rem); }
    .breadcrumb-nav { display: none; }
}

/* ================================================================
   SMALL MOBILE (≤480px) — final cleanup
================================================================ */
@media (max-width: 480px) {

    /* ── About ── */
    .ci-img-main { height: 220px; }
    .ci-img-badge { display: none; }
    .ci-facts { grid-template-columns: 1fr; }

    .values-grid { grid-template-columns: 1fr 1fr; }

    .mv-grid { gap: 1.25rem; }
    .mv-card { padding: 1.5rem 1.25rem; }

    .timeline::before { left: 20px; }
    .tl-dot { width: 40px; height: 40px; font-size: .8rem; }
    .tl-content { padding: 1rem; }

    .about-cta-inner { padding: 1.5rem; }
    .about-cta-list  { grid-template-columns: 1fr; }

    /* ── Services ── */
    .srv-img-frame img { height: 220px; }
    .srv-img-badge { display: none; }
    .srv-features-grid { grid-template-columns: 1fr; }
    .srv-cards-grid { grid-template-columns: 1fr; }
    .industries-grid { grid-template-columns: 1fr; }
    .srv-cta-inner  { padding: 1.5rem; }
    .srv-intro-stats { grid-template-columns: 1fr; }

    /* ── Materials ── */
    .mat-intro-grid { grid-template-columns: 1fr; gap: .75rem; }
    .mat-detail-img { height: 180px; }
    .benefits-grid  { grid-template-columns: 1fr; }
    .sell-steps-grid { gap: .5rem; }

    /* Rate table — 2 column only on very small screens */
    .rate-table-header,
    .rate-table-row { grid-template-columns: 1.5fr 1fr; padding: .6rem .75rem; font-size: .78rem; }
    .rate-table-header > div:nth-child(n+3),
    .rate-table-row > div:nth-child(n+3) { display: none; }
    .rate-table-row > div:nth-child(2) { display: block; }

    /* ── Contact ── */
    .contact-info-grid { grid-template-columns: 1fr; }
    .contact-trust-badges { grid-template-columns: 1fr; }
    .inquiry-form { padding: 1.25rem 1rem; }
    .cfc-header   { padding: 1.25rem; }
    .form-row-2   { grid-template-columns: 1fr; }
    .contact-cta-actions a { width: 100%; max-width: 100%; }

    /* ── Common ── */
    .page-banner { min-height: 200px; padding: 4.5rem 0 1.75rem; }
    .page-banner-title { font-size: 1.5rem; }
    .section-title { font-size: 1.4rem; }

    /* ── Footer ── */
    .footer-top { padding: 2.5rem 1rem 1.75rem; gap: 1.5rem; }
    .footer-brand .footer-logo-wrap img { height: 75px; }
    .footer-bottom { padding: 1rem; }
    .footer-bottom p { font-size: .75rem; }
    .footer-bottom-links { gap: .75rem; }
    .footer-bottom-links a { font-size: .73rem; }
    .footer-query-inner { padding: 1.5rem 1rem; }
    .fq-submit { width: 100%; }
}
