/* Page-specific styles for service.html */

/* Service page hero override: reduce height and add background */
.hero.about-hero {
    min-height: 380px;
    padding: 56px 0;
    background-image: linear-gradient(180deg, rgba(6, 10, 10, 0.35), rgba(6, 10, 10, 0.18)), url("../images/VedhaWellness/8.jpg");
    background-size: cover;
    background-position: center center;
    color: #fff;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Hero inner layout */
.hero.about-hero .hero-inner {
    text-align: center;
    max-width: 1200px;
    width: 100%;
    padding: 12px 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Heading gradient & design */
.hero.about-hero .hero-inner h1 {
    font-size: 2.6rem;
    line-height: 1.05;
    margin: 0 0 8px 0;
    background: linear-gradient(90deg, var(--accent), var(--accent-2));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-weight: 800;
    text-shadow: 0 8px 30px rgba(65, 13, 224, 0.25);
}

.hero.about-hero .hero-inner h1::after {
    content: "";
    display: block;
    width: 72px;
    height: 5px;
    border-radius: 4px;
    margin-top: 12px;
    background: linear-gradient(90deg, rgba(8, 117, 77, 0.144), rgba(14, 180, 157, 0));
}

/* Subtle tagline */
.hero.about-hero .subtle {
    color: rgba(255, 255, 255, 0.95);
    font-style: italic;
    opacity: 0.95;
    margin-top: 6px;
    font-weight: 600;
}

@media (max-width:768px) {
    .hero.about-hero .hero-inner h1 {
        font-size: 1.6rem;
    }
}

/* Stronger overlay and text panel for hero readability */
.hero.about-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(6, 10, 10, 0.45), rgba(6, 10, 10, 0.25));
    z-index: 1;
}

.hero.about-hero .hero-inner>div {
    position: relative;
    z-index: 2;
    display: block;
    text-align: center;
    background: transparent;
    padding: 6px 12px;
    border-radius: 8px;
    backdrop-filter: none;
    max-width: 980px;
    width: 100%;
}

.hero.about-hero .hero-inner>div h1 {
    /* fallback color if background-clip/text isn't supported */
    color: var(--hero-text, #487607);
    font-size: 3.0rem;
    margin: 0 0 10px 0;
    letter-spacing: 0.4px;
    font-weight: 800;
    text-shadow: 0 6px 18px rgba(0, 0, 0, 0.35);
}

.hero.about-hero .hero-inner>div p {
    color: rgba(255, 255, 255, 0.95);
    margin: 0 0 8px 0;
}

/* Prominent, pill-style strapline like the reference */
.hero.about-hero .hero-inner>div .subtle {
    display: inline-block;
    background: rgba(255, 255, 255, 0.12);
    padding: 8px 14px;
    border-radius: 20px;
    font-style: italic;
    font-weight: 700;
    color: #fff;
    margin-bottom: 8px;
}

.hero.about-hero .hero-inner>div .lead {
    color: rgba(255, 255, 255, 0.95);
    margin-top: 8px;
    font-size: 1rem;
}

@media (max-width:768px) {
    .hero.about-hero {
        min-height: 300px;
        padding: 34px 0;
    }

    .hero.about-hero .hero-inner>div {
        padding: 12px 14px;
    }

    .hero.about-hero .hero-inner>div h1 {
        font-size: 1.8rem;
    }
}

/* keep explicit color fallback for non-heading text so small specificity issues don't hide it */
.hero.about-hero .subtle,
.hero.about-hero .hero-inner>div p {
    color: var(--hero-text, #ffffff) !important;
}

/* Services grid and cards */
.services {
    padding: 56px 0;
}

.services .container h3 {
    color: var(--accent-2);
    font-size: 1.25rem;
    margin-bottom: 18px;
}

.services-grid {
    display: grid;
    grid-template-columns: 1fr;
    /* mobile-first: single column */
    gap: 28px;
    margin-top: 22px;
}

@media (min-width: 641px) {
    .services-grid {
        grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    }
}

.service-card {
    background: var(--card);
    padding: 26px 22px;
    border-radius: 14px;
    box-shadow: 0 20px 48px rgba(20, 30, 10, 0.06);
    position: relative;
    transition: transform 220ms ease, box-shadow 220ms ease, transform 180ms;
    min-height: 200px;
    overflow: hidden;
}

.service-card:hover {
    transform: translateY(-8px) scale(1.01);
    box-shadow: 0 36px 90px rgba(20, 30, 10, 0.10);
}

.service-no {
    display: inline-block;
    font-weight: 700;
    color: var(--accent);
    background: linear-gradient(90deg, rgba(90, 111, 76, 0.08), rgba(139, 111, 61, 0.06));
    padding: 6px 10px;
    border-radius: 10px;
    position: absolute;
    right: 16px;
    font-size: 0.95rem;
}

.service-card h4 {
    margin: 12px 0 8px 0;
    color: var(--accent-2);
    font-size: 1.12rem;
    line-height: 1.15;
    font-weight: 700;
}

.service-card h4::after {
    content: "";
    display: block;
    width: 56px;
    height: 4px;
    margin-top: 8px;
    border-radius: 4px;
    background: linear-gradient(90deg, var(--accent), var(--accent-2));
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);
}

.service-card p {
    color: rgba(30, 36, 32, 0.8);
    line-height: 1.75;
    margin: 0;
    font-size: 0.98rem;
    max-width: 52ch;
}

/* subtle left accent bar for cards */
.service-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 6px;
    background: linear-gradient(180deg, var(--accent), var(--accent-2));
    border-radius: 8px 0 0 8px;
    opacity: 0.98;
}

@media (max-width:1024px) {
    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .service-card {
        min-height: 0;
    }
}

@media (max-width:640px) {
    .services-grid {
        grid-template-columns: 1fr;
    }

    /* Mobile-critical override: ensure text is visible and above images
       (kept at this breakpoint so it applies on small screens) */

    .services .service-card h4,
    .services .service-card p {
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        visibility: visible !important;
        opacity: 1 !important;
        transform: none !important;
        position: relative !important;
        z-index: 5 !important;
        color: #1b1b1b !important;
    }

    .services .service-card .service-media {
        z-index: 0 !important;
        position: relative !important;
    }

    /* Remove any accidental clipping from ancestor containers */
    .services,
    .services .container,
    .services-grid {
        overflow: visible !important;
    }

    .service-no {
        top: 12px;
        right: 12px;
    }

    .service-card {
        padding: 18px;
    }
}

/* Ensure descriptions remain visible on small screens by limiting image height
   and allowing content to flow. Strengthen text color for contrast. */
@media (max-width:640px) {
    .service-media img {
        max-height: 180px;
        width: 100%;
        object-fit: cover;
        aspect-ratio: 3 / 2;
    }

    .service-card {
        overflow: visible !important;
        padding: 16px;
        min-height: auto !important;
    }

    .service-card p {
        color: rgba(20, 20, 20, 0.95);
        font-size: 0.98rem;
        max-width: none;
        margin-top: 10px;
    }
}

/* Extra safeguard for very small or high-dpr viewports: force content flow */
@media (max-width:440px) {
    .service-card {
        padding: 14px !important;
    }

    .service-media img {
        max-height: 140px;
    }
}

/* Temporary safeguard: ensure services intro is visible on small screens */
@media (max-width:768px) {

    .services-intro p,
    .services-intro .muted {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        color: rgba(20, 20, 20, 0.95) !important;
        position: relative !important;
        z-index: 6 !important;
        margin-top: 10px !important;
        background: #fff !important;
        padding: 10px 12px !important;
        box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06) !important;
        border-radius: 8px !important;
    }
}

/* Swap hero background to smaller images on mobile to save bandwidth */
@media (max-width:640px) {
    .hero.about-hero {
        background-image: linear-gradient(180deg, rgba(6, 10, 10, 0.35), rgba(6, 10, 10, 0.18)), url("../images/VedhaWellness/2.jpg");
        min-height: 300px;
    }
}

@media (min-width:641px) and (max-width:1024px) {
    .hero.about-hero {
        background-image: linear-gradient(180deg, rgba(6, 10, 10, 0.35), rgba(6, 10, 10, 0.18)), url("../images/VedhaWellness/8.jpg");
        min-height: 360px;
    }
}

/* service card icon */
.service-icon {
    display: inline-grid;
    place-items: center;
    width: 46px;
    height: 46px;
    border-radius: 10px;
    background: linear-gradient(180deg, var(--accent), var(--accent-2));
    color: #fff;
    margin-right: 10px;
}

.service-card .service-icon svg {
    width: 20px;
    height: 20px;
}

.service-card .service-icon i {
    font-size: 18px;
    line-height: 1;
}

.service-card h4 {
    display: inline-block;
    vertical-align: middle;
}

/* Services intro and FAQ styles */
.services-intro p {
    max-width: 880px;
    color: var(--muted);
    margin: 8px 0 0 0;
}

.services-faq h4 {
    margin-top: 8px;
    color: var(--accent-2);
    font-size: 1.1rem;
}

.faq {
    margin-top: 10px;
    display: grid;
    gap: 12px;
}

.faq .question {
    margin: 0;
}

.faq .answer {
    margin: 6px 0 0 0;
    color: var(--muted);
}

/* Text animations: simple fade-up with staggered delays */
@keyframes fadeUp {
    from {
        opacity: 0;
        transform: translateY(14px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-up {
    opacity: 0;
    transform: translateY(14px);
    animation-name: fadeUp;
    animation-duration: 700ms;
    animation-timing-function: cubic-bezier(.2, .9, .2, 1);
    animation-fill-mode: both;
}

/* Center underline for services heading at all sizes */
.services .container h3::after,
.services h3::after {
    display: block;
    width: 56px;
    margin: 10px auto 0 auto;
    transform-origin: center center !important;
}

.delay-0 {
    animation-delay: 0.12s;
}

.delay-1 {
    animation-delay: 0.34s;
}

.delay-2 {
    animation-delay: 0.56s;
}

/* h1 slight scale for emphasis */
.hero.about-hero .hero-inner>div h1.fade-up {
    transform-origin: center;
}

@media (prefers-reduced-motion: reduce) {
    .fade-up {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
    }
}

/* Ensure service text and media are visible up to 768px (mobile/tablet) */
@media (max-width:768px) {

    .services .service-card h4,
    .services .service-card p {
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        visibility: visible !important;
        opacity: 1 !important;
        transform: none !important;
        position: relative !important;
        z-index: 5 !important;
        color: #1b1b1b !important;
    }

    .services .service-card .service-media {
        z-index: 0 !important;
        position: relative !important;
    }

    .services,
    .services .container,
    .services-grid {
        overflow: visible !important;
    }
}

/* Hero CTA styles */
.hero-actions {
    margin-top: 14px;
}

.hero-cta {
    display: inline-block;
    padding: 12px 20px;
    border-radius: 28px;
    font-weight: 700;
    text-decoration: none;
    color: #fff;
    background: linear-gradient(90deg, var(--accent), var(--accent-2));
    box-shadow: 0 10px 30px rgba(20, 40, 20, 0.18);
    transition: transform 180ms ease, box-shadow 180ms ease, opacity 160ms ease;
}

.hero-cta:hover,
.hero-cta:focus {
    transform: translateY(-4px);
    box-shadow: 0 18px 44px rgba(20, 40, 20, 0.22);
}

@media (max-width:768px) {
    .hero-cta {
        padding: 10px 16px;
        font-size: 0.95rem;
    }
}

/* Service card media: two stacked square images */
.service-media {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 12px;
    width: 100%;
    max-width: 600px;
    /* limit media block to 600px wide */
    margin-left: auto;
    margin-right: auto;
}

.service-media img {
    width: 100%;
    aspect-ratio: 3 / 2;
    /* 600x400 ratio */
    object-fit: cover;
    border-radius: 10px;
    display: block;
    height: auto;
}

/* On very small screens keep images full width but maintain the 3:2 ratio */
@media (max-width:640px) {
    .service-media {
        max-width: 100%;
    }
}

@media (min-width:1025px) {

    /* reduce image height slightly on wide layouts so card content stays visible */
    .service-media img {
        max-height: 220px;
    }
}

/* Diagnostic: highlight services intro on very small screens so it's easy to spot */
@media (max-width:420px) {
    .services-intro p {
        background: rgba(255, 255, 0, 0.14) !important;
        border-left: 4px solid var(--accent) !important;
        padding: 12px !important;
        font-size: 1rem !important;
        color: #111 !important;
        visibility: visible !important;
        opacity: 1 !important;
        transform: none !important;
        z-index: 9999 !important;
    }
}

/* Always show services heading on all viewports (override reveal animation) */
.services .container h3,
.services h3 {
    opacity: 1 !important;
    transform: none !important;
    visibility: visible !important;
    color: var(--accent-2) !important;
    position: relative !important;
    z-index: 999 !important;
}

.services .container h3::after,
.services h3::after {
    transform: scaleX(1) !important;
    transform-origin: center center !important;
}