/* =============================================================================
   Global tokens & helpers — Corporate Palette
   ============================================================================= */
:root {
    /* Brand palette */
    --c-primary: #000080; /* Deep Navy */
    --c-secondary: #808080; /* Elegant Gray */
    --c-accent: #FF5733; /* Bright Orange */
    --c-white: #FFFFFF; /* Clean White */

    /* Derived neutrals */
    --c-ink: #0E1333; /* readable dark text */
    --c-ink-2: #111111;
    --c-muted: #6b7280;

    /* Subtle borders & tints */
    --c-border: rgba(0, 0, 128, 0.12); /* navy-tinted border */
    --c-border-strong: rgba(0, 0, 128, 0.18);
    --c-soft-primary: rgba(0, 0, 128, 0.06); /* gentle navy chip bg */
    --c-soft-accent: rgba(255, 87, 51, 0.10); /* gentle orange chip bg */

    /* Elevation */
    --shadow-sm: 0 6px 20px rgba(14, 21, 51, .10);
    --shadow-md: 0 10px 30px rgba(14, 21, 51, .16);

    /* Radii */
    --radius-xl: 80px;
    --radius-lg: 40px;
    --radius-md: 20px;

    /* Site width */
    --site-max: 1200px;
    --site-gutter: clamp(12px, 3vw, 24px);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

.rounded-xxl {
    border-radius: var(--radius-xl);
}

.rounded-xl {
    border-radius: var(--radius-lg);
}

.rounded-md {
    border-radius: var(--radius-md);
}

.shadow-sm {
    box-shadow: var(--shadow-sm);
}

.shadow-md {
    box-shadow: var(--shadow-md);
}

[hidden] {
    display: none !important;
}

/* Legacy mobile helper */
@media (max-width: 768px) {
    .author-img {
        width: 100% !important;
        height: auto !important;
        display: block;
        margin: 0 auto;
    }

    .propertie-details-wrapper {
        text-align: center;
    }
}

/* =============================================================================
   HERO (v3)
   ============================================================================= */
.hero-v3 {
    padding: clamp(16px, 3vw, 36px) 0;
    background: var(--c-white);
}

.hero-v3__wrap {
    width: 100%;
    max-width: var(--site-max);
    margin-inline: auto;
    padding-inline: var(--site-gutter);
}

.hero-v3__card {
    position: relative;
    min-height: clamp(420px, 60vh, 720px);
    border-radius: clamp(20px, 3.2vw, 48px);
    overflow: hidden;
    background: var(--c-ink);
}

/* Media */
.hero-v3__media {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.hero-v3__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
}

.hero--obj-left .hero-v3__media img {
    object-position: 30% 50%;
}

.hero--obj-right .hero-v3__media img {
    object-position: 70% 50%;
}

.hero--obj-top .hero-v3__media img {
    object-position: 50% 30%;
}

.hero--obj-bot .hero-v3__media img {
    object-position: 50% 70%;
}

/* Navy-tinted overlay */
.hero-v3__card::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(90deg, rgba(0, 0, 128, .65) 0%, rgba(0, 0, 128, .45) 35%, rgba(0, 0, 128, .18) 60%, rgba(0, 0, 128, 0) 100%);
}

/* Copy */
.hero-v3__copy {
    position: absolute;
    z-index: 2;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: min(580px, 56%);
    padding-left: clamp(18px, 5vw, 64px);
    padding-right: clamp(12px, 3vw, 24px);
    color: var(--c-white);
    text-align: left;
}

/* Justified paragraphs but left last-line */
.hero-v3__copy p {
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
    text-align-last: left;
}

.hero-v3__eyebrow {
    margin: 0 0 .35rem 0;
    font-weight: 700;
    font-size: clamp(1rem, 2.2vw, 1.25rem);
    letter-spacing: .02em;
    color: var(--c-white);
}

.hero-v3__title {
    margin: 0 0 .6rem 0;
    font-weight: 900;
    line-height: 1.1;
    font-size: clamp(1.8rem, 4.4vw, 3.1rem);
    color: var(--c-white);
}

.hero-v3__text {
    margin: 0 0 1rem 0;
    max-width: 62ch;
    font-size: clamp(.98rem, 2vw, 1.05rem);
    line-height: 1.65;
    opacity: .95;
    color: var(--c-white);
}

/* CTA(s) — accent button by default */
.hero-v3__actions .btn {
    padding: .7rem 1.4rem;
    border-radius: 999px;
    font-weight: 700;
    box-shadow: 0 6px 18px rgba(255, 87, 51, .25);
    background: var(--c-accent);
    color: var(--c-white);
    border: none;
    transition: transform .05s ease, box-shadow .2s ease, background .2s ease;
}

.hero-v3__actions .btn:hover,
.hero-v3__actions .btn:focus {
    background: #e64e2e;
    box-shadow: 0 8px 22px rgba(255, 87, 51, .3);
}

.hero-v3__actions .btn:active {
    transform: translateY(1px);
}

@media (max-width: 768px) {
    .hero-v3__card {
        min-height: 56vh;
    }

    .hero-v3__copy {
        top: auto;
        bottom: 0;
        transform: none;
        width: 100%;
        padding: clamp(14px, 4.5vw, 22px);
    }

    .hero-v3__card::before {
        background: linear-gradient(180deg, rgba(0, 0, 128, 0) 0%, rgba(0, 0, 128, .55) 65%, rgba(0, 0, 128, .7) 100%),
        linear-gradient(90deg, rgba(0, 0, 128, .55) 0%, rgba(0, 0, 128, .15) 60%, rgba(0, 0, 128, 0) 100%);
    }
}

/* =============================================================================
   SECTION 2 · Features
   ============================================================================= */
.features-2 {
    padding: clamp(24px, 4vw, 48px) 0;
    background: var(--c-white);
}

.features-2__wrap {
    width: 100%;
    max-width: var(--site-max);
    margin-inline: auto;
    padding-inline: var(--site-gutter);
}

.features-2__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(16px, 2.6vw, 28px);
}

@media (max-width: 992px) {
    .features-2__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 576px) {
    .features-2__grid {
        grid-template-columns: 1fr;
    }
}

.feature-card {
    background: var(--c-white);
    border: 1px solid var(--c-border);
    border-radius: 24px;
    padding: clamp(16px, 2.4vw, 22px);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(12px, 1.6vw, 16px);
    transition: box-shadow .25s ease, transform .25s ease, border-color .2s ease;
}

.feature-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(14, 21, 51, .10);
    border-color: var(--c-border-strong);
}

/* Avatar ring */
.feature-card__avatar {
    --ring-color: var(--c-primary);
    --ring-width: 2px;
    --ring-inset: clamp(6px, .8vw, 10px);
    --img-gap: calc(var(--ring-inset) + 10px);
    width: clamp(128px, 15vw, 176px);
    aspect-ratio: 1/1;
    border-radius: 50%;
    overflow: hidden;
    position: relative;
    display: grid;
    place-items: center;
    background: var(--c-white);
}

.feature-card__avatar::after {
    content: "";
    position: absolute;
    inset: var(--ring-inset);
    border: var(--ring-width) dashed var(--ring-color);
    border-radius: 50%;
    pointer-events: none;
    z-index: 2;
}

.feature-card__avatar img {
    width: calc(100% - (var(--img-gap) * 2));
    height: calc(100% - (var(--img-gap) * 2));
    object-fit: contain;
    object-position: 50% 50%;
    transition: transform .3s cubic-bezier(.2, .6, .2, 1);
    z-index: 1;
}

.feature-card:hover .feature-card__avatar img {
    transform: scale(1.03);
}

.feature-card__title {
    font-size: clamp(1.05rem, 2.1vw, 1.25rem);
    font-weight: 800;
    color: var(--c-primary);
    margin: 0;
}

.feature-card__text {
    font-size: .98rem;
    line-height: 1.7;
    color: var(--c-ink);
    opacity: .9;
    margin: 0;
    max-width: 38ch;
}

/* =============================================================================
   SECTION 3 · Promos (Text on RIGHT) — right-anchored + vertically centered
   ============================================================================= */
.section-3 > .container{
    width:100%;
    max-width:var(--site-max);
    margin-inline:auto;
    padding-inline:var(--site-gutter);
}

/* Card */
.section-3 .card{
    position:relative;
    width:100%;
    aspect-ratio:16/9;
    min-height:260px;
    border-radius:28px;
    overflow:hidden;
    background:var(--c-white);
    box-shadow:0 10px 26px rgba(14,21,51,.10);
    border:1px solid var(--c-border);
    transition:transform .35s cubic-bezier(.2,.6,.2,1), box-shadow .35s cubic-bezier(.2,.6,.2,1);
    will-change:transform;
}

/* Background */
.section-3 .card__bg{
    position:absolute;
    inset:0;
    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
    transform:scale(1);
    transition:transform .6s cubic-bezier(.2,.6,.2,1), filter .6s cubic-bezier(.2,.6,.2,1);
    will-change:transform;
    z-index:1;
}

/* readability gradient on the right (because copy is on right) */
.section-3 .card.has-gradient::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(270deg, rgba(0,0,0,.42) 0%, rgba(0,0,0,.22) 38%, rgba(0,0,0,0) 64%);
    z-index:1;
}

/* Overlay (always right anchored + vertically centered) */
.section-3 .card__overlay{
    position:absolute;
    top:50%;
    right:var(--pad-right, 14%);
    left:auto;
    transform:translateY(-50%); /* center vertically */
    max-width:var(--copy-max, 46%);

    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
    color:var(--c-white);
    text-align:left;
    text-align-last:left;
    white-space:normal;
    word-break:normal;
    overflow-wrap:anywhere;
    word-spacing:normal;
    letter-spacing:.02em;
    z-index:2;
    transition:transform .35s cubic-bezier(.2,.6,.2,1), opacity .35s ease;
    will-change:transform;
}

/* Text */
.section-3 .card__cap{
    margin:0;
    font-size:.92rem;
    line-height:1.35;
    font-weight:600;
    opacity:.95;
    color: #000000;
}
.section-3 .card__title{
    margin:0;
    font-weight:800;
    letter-spacing:.02em;
    text-transform:uppercase;
    line-height:1.22;
    font-size:clamp(1.02rem, 2.2vw, 1.38rem);
    color:var(--c-white);
}
.section-3 .card__label{
    position:relative;
    display:inline-block;
    margin-top:.15rem;
    font-size:.88rem;
    font-weight:800;
    text-transform:uppercase;
    padding-bottom:.18rem;
    color:#000000;
}
.section-3 .card__label::after{
    content:"";
    position:absolute;
    left:0; bottom:0;
    height:2px; width:44px;
    background:#000000;
    transform-origin:left center;
    transform:scaleX(.55);
    transition:transform .35s cubic-bezier(.2,.6,.2,1);
}

/* Hover */
.section-3 .card:hover,
.section-3 .card:focus-within{
    box-shadow:0 14px 34px rgba(14,21,51,.14);
    transform:translateY(-2px);
}
.section-3 .card:hover .card__bg,
.section-3 .card:focus-within .card__bg{
    transform:scale(1.06);
    filter:saturate(1.02);
}
/* keep centering on hover: nudge by 2px without losing -50% */
.section-3 .card:hover .card__overlay,
.section-3 .card:focus-within .card__overlay{
    transform:translateY(calc(-50% - 2px));
}
.section-3 .card:hover .card__label::after,
.section-3 .card:focus-within .card__label::after{
    transform:scaleX(1);
}

/* Focal helpers */
.section-3 .card__bg.bg-left{background-position:30% center;}
.section-3 .card__bg.bg-right{background-position:70% center;}
.section-3 .card__bg.bg-top{background-position:center 30%;}
.section-3 .card__bg.bg-bottom{background-position:center 70%;}

/* Positioning helpers (right & width) */
.section-3 .padR-10{--pad-right:10%;}
.section-3 .padR-12{--pad-right:12%;}
.section-3 .padR-14{--pad-right:14%;}
.section-3 .padR-16{--pad-right:16%;}
.section-3 .padR-18{--pad-right:18%;}
.section-3 .copy-50{--copy-max:50%;}
.section-3 .copy-54{--copy-max:54%;}

/* Responsive — keep right anchor AND vertical centering on phones */
@media (max-width: 992px){
    .section-3 .card{ aspect-ratio:4/3; }
    .section-3 .card__overlay{
        right:10%;
        max-width:60%;
        transform:translateY(-50%);
    }
}
@media (max-width: 768px){
    .section-3 .card__overlay{
        top:50% !important;
        right:clamp(8px, 6vw, 20px) !important;
        left:auto !important;
        transform:translateY(-50%) !important;

        max-width:70% !important;
        width:70% !important;

        text-align:left !important;
        text-align-last:left !important;
        align-items:flex-start !important;

        padding-left:clamp(8px,3vw,16px);
        padding-right:clamp(8px,3vw,16px);
    }
    .section-3 .card__cap{font-size:.9rem;}
    .section-3 .card__title{font-size:clamp(1.02rem, 3.8vw, 1.18rem);}
    .section-3 .card__label{font-size:.84rem;}
}

/* Fallback for browsers without aspect-ratio */
@supports not (aspect-ratio: 1 / 1){
    .section-3 .card{height:0; padding-top:56.25%;}
    .section-3 .card__overlay{position:absolute;}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
    .section-3 .card,
    .section-3 .card__bg,
    .section-3 .card__overlay,
    .section-3 .card__label::after{transition:none !important;}
}

/* =============================================================================
   SECTION 4 · Product Grid
   ============================================================================= */
.team-section-4 {
    padding: clamp(28px, 5vw, 56px) 0;
    background: var(--c-white);
}

.team-section-4 > .container {
    width: 100%;
    max-width: var(--site-max);
    margin-inline: auto;
    padding-inline: var(--site-gutter);
}

/* Heading */
.team-section-4 .heading {
    text-align: center;
    max-width: 900px;
    margin: 0 auto clamp(32px, 4vw, 60px);
    padding: 0;
}

.team-section-4 .heading h2 {
    margin: 0 0 .35rem 0;
    font-weight: 800;
    font-size: clamp(1.4rem, 3.2vw, 2rem);
    line-height: 1.1;
    letter-spacing: .02em;
    color: var(--c-primary);
    position: relative;
}

.team-section-4 .heading h2::after {
    content: "";
    display: block;
    width: clamp(44px, 6vw, 72px);
    height: 3px;
    margin: clamp(6px, 1vw, 10px) auto 0;
    background: var(--c-accent);
    border-radius: 2px;
}

.team-section-4 .heading p {
    max-width: 70ch;
    margin: 0 auto;
    color: var(--c-ink);
    opacity: .9;
    line-height: 1.7;
    text-align: center !important;
    text-align-last: center !important;
    hyphens: none;
}

/* Default paragraphs justified */
.team-section-4 p {
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
    text-align-last: left;
}

/* Grid */
.catalog-grid {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(14px, 2.4vw, 24px);
}

@media (max-width: 992px) {
    .catalog-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 576px) {
    .catalog-grid {
        grid-template-columns: 1fr;
    }
}

/* Cards */
.catalog-item {
    height: 100%;
}

.catalog-card {
    position: relative;
    overflow: hidden;
    border-radius: 18px;
    background: transparent;
    display: flex;
    height: 100%;
    transition: transform .25s ease, box-shadow .25s ease;
    border: 1px solid var(--c-border);
}

.catalog-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 26px rgba(14, 21, 51, .12);
}

.catalog-img {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    display: block;
    transition: transform .45s cubic-bezier(.2, .6, .2, 1);
    will-change: transform;
}

.catalog-card:hover .catalog-img {
    transform: scale(1.06);
}

/* Always visible (avoid lazy/hover paint issues) */
.team-section-4 .catalog-card,
.team-section-4 .catalog-img {
    content-visibility: visible !important;
    opacity: 1 !important;
    visibility: visible !important;
    filter: none !important;
}

.team-section-4 img.lazyload,
.team-section-4 img.lazyloading,
.team-section-4 img.is-lazy,
.team-section-4 img[data-lazy="true"] {
    opacity: 1 !important;
    visibility: visible !important;
    filter: none !important;
}

/* Overlay & title */
.catalog-overlay {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    background: transparent !important;
}

.catalog-title {
    margin: 0;
    font-size: clamp(1rem, 1.9vw, 1.15rem);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .02em;
    color: var(--c-ink-2);
    background: transparent !important;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity .28s ease, transform .28s cubic-bezier(.2, .6, .2, 1);
}

.catalog-title a {
    color: inherit;
    text-decoration: none;
    pointer-events: auto;
}

.catalog-card:hover .catalog-title,
.catalog-card:focus-within .catalog-title {
    opacity: 1;
    transform: translateY(0);
}

.team-section-4 .content,
.team-section-4 .content * {
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
}

@media (prefers-reduced-motion: reduce) {
    .catalog-card, .catalog-img, .catalog-title {
        transition: none !important;
    }
}

/* =============================================================================
   SECTION 5 · Why Choose Us
   ============================================================================= */
.why-v3 {
    --pad-y: clamp(28px, 5vw, 56px);
    --gap: clamp(16px, 3vw, 28px);
    --card-radius: 20px;
    --card-border: 1px solid var(--c-border);
    --card-shadow: 0 10px 24px rgba(14, 21, 51, .10);
    padding: var(--pad-y) 0;
    background: var(--c-white);
}

.why-v3__wrap {
    width: 100%;
    max-width: var(--site-max);
    margin-inline: auto;
    padding-inline: var(--site-gutter);
}

/* Default paragraphs justified */
.why-v3 p {
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
    text-align-last: left;
}

/* Heading */
.why-v3__head {
    text-align: center;
    max-width: 900px;
    margin: 0 auto clamp(32px, 4vw, 60px);
    padding: 0;
}

.why-v3__title {
    margin: 0 0 .35rem 0;
    font-weight: 800;
    font-size: clamp(1.4rem, 3.2vw, 2rem);
    line-height: 1.1;
    letter-spacing: .02em;
    color:var(--c-primary);
    position: relative;
}

.why-v3__title::after {
    content: "";
    display: block;
    width: clamp(44px, 6vw, 72px);
    height: 3px;
    margin: clamp(6px, 1vw, 10px) auto 0;
    background: var(--c-accent);
    border-radius: 2px;
}

/* Intro centered (override) */
.why-v3 .why-v3__intro {
    max-width: 70ch;
    margin-left: auto;
    margin-right: auto;
    color: var(--c-ink);
    text-align: center !important;
    text-align-last: center !important;
    hyphens: none;
}

/* Layout */
.why-v3__grid {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: var(--gap);
    align-items: stretch;
}

/* Left media card */
.why-v3__media-card {
    border: var(--card-border);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    overflow: hidden;
    background: var(--c-white);
    height: 100%;
}

.why-v3__media {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 320px;
    background: var(--c-white);
}

.why-v3__media img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
    transition: transform .4s cubic-bezier(.2, .6, .2, 1);
}

.why-v3__media-card:hover .why-v3__media img {
    transform: scale(1.03);
}

/* Right list */
.why-v3__list {
    display: grid;
    gap: var(--gap);
    margin: 0;
    padding: 0;
    list-style: none;
}

.why-v3__item-card {
    border: var(--card-border);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    background: var(--c-white);
    padding: clamp(14px, 2.6vw, 18px);
    display: grid;
    grid-template-columns: 56px 1fr;
    gap: 14px;
    align-items: center;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.why-v3__item-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(14, 21, 51, .12);
    border-color: var(--c-border-strong);
}

.why-v3__icon {
    --chip: 56px;
    width: var(--chip);
    height: var(--chip);
    border-radius: 50%;
    overflow: hidden;
    display: grid;
    place-items: center;
    background: var(--c-soft-primary);
    border: 1px solid var(--c-border);
}

.why-v3__icon img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
}

.why-v3__item-title {
    margin: 0 0 .25rem 0;
    font-weight: 700;
    font-size: clamp(1rem, 2vw, 1.15rem);
    color: var(--c-ink-2);
}

.why-v3__item-text {
    margin: 0;
    color: var(--c-ink);
    opacity: .9;
    line-height: 1.65;
    font-size: .96rem;
}

@media (max-width: 992px) {
    .why-v3__grid {
        grid-template-columns: 1fr;
    }

    .why-v3__media {
        height: auto;
        aspect-ratio: 16/10;
        min-height: unset;
    }
}

@media (prefers-reduced-motion: reduce) {
    .why-v3__media img, .why-v3__item-card {
        transition: none !important;
    }
}

/* =============================================================================
   SECTION 6 · Author / Contact
   ============================================================================= */
.author-v2 {
    --pad-y: clamp(28px, 5vw, 56px);
    --gap: clamp(16px, 3vw, 28px);
    --card-radius: 20px;
    --card-border: 1px solid var(--c-border);
    --card-shadow: 0 10px 24px rgba(14, 21, 51, .10);
    padding: var(--pad-y) 0;
    background: var(--c-white);
}

.author-v2__wrap {
    width: 100%;
    max-width: var(--site-max);
    margin-inline: auto;
    padding-inline: var(--site-gutter);
}

/* Heading */
.author-v2__head {
    text-align: center;
    max-width: 900px;
    margin: 0 auto clamp(32px, 4vw, 60px);
    padding: 0;
}

.author-v2__title {
    margin: 0 0 .35rem 0;
    font-weight: 800;
    font-size: clamp(1.4rem, 3.2vw, 2rem);
    line-height: 1.1;
    letter-spacing: .02em;
    color: var(--c-ink-2);
    position: relative;
}

.author-v2__title::after {
    content: "";
    display: block;
    width: clamp(44px, 6vw, 72px);
    height: 3px;
    margin: clamp(6px, 1vw, 10px) auto 0;
    background: var(--c-accent);
    border-radius: 2px;
}

/* Layout */
.author-v2__grid {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: var(--gap);
    align-items: stretch;
}

/* Left image card */
.author-v2__media-card {
    border: var(--card-border);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    background: var(--c-white);
    overflow: hidden;
    height: 100%;
}

.author-v2__media {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 360px;
    background: var(--c-white);
}

.author-v2__media img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
    transition: transform .4s cubic-bezier(.2, .6, .2, 1);
}

.author-v2__media-card:hover .author-v2__media img {
    transform: scale(1.03);
}

/* Right info card */
.author-v2__info-card {
    border: var(--card-border);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    background: var(--c-white);
    padding: clamp(16px, 3vw, 24px);
    display: grid;
    gap: clamp(12px, 2vw, 18px);
    height: 100%;
}

/* Paragraphs justified for consistency */
.author-v2 p {
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
    text-align-last: left;
}

/* Name & rows */
.author-v2__name {
    margin: 0;
    font-weight: 800;
    font-size: clamp(1.1rem, 2.4vw, 1.4rem);
    color: var(--c-ink-2);
    text-align: center;
}

.author-v2__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
}

.author-v2__row {
    display: grid;
    grid-template-columns: 28px 1fr;
    align-items: start;
    gap: 10px;
    color: var(--c-ink);
}

.author-v2__row i {
    color: var(--c-primary);
    font-size: 1.05rem;
    line-height: 1.6;
}

.author-v2__row a {
    color: var(--c-primary);
    text-decoration: none;
    word-break: break-word;
    transition: color .15s ease;
}

.author-v2__row a:hover {
    color: var(--c-accent);
}

/* Socials */
.author-v2__social {
    display: flex;
    gap: 10px;
    justify-content: center;
}

.author-v2__social a {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: var(--c-soft-primary);
    color: var(--c-primary);
    border: 1px solid var(--c-border);
    transition: transform .2s ease, box-shadow .2s ease, background .15s ease, color .15s ease;
}

.author-v2__social a:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(14, 21, 51, .10);
    background: var(--c-accent);
    color: var(--c-white);
    border-color: var(--c-accent);
}

/* Visitor counter */
.author-v2__counter {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: center;
}

.author-v2__counter-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid var(--c-border);
    border-radius: 999px;
    background: var(--c-white);
    padding: 8px 12px;
    cursor: pointer;
    font-weight: 700;
    color: var(--c-ink);
    transition: background .15s ease, border-color .15s ease, color .15s ease, box-shadow .2s ease;
}

.author-v2__counter-btn i {
    color: var(--c-primary);
}

.author-v2__counter-btn:hover {
    background: var(--c-soft-accent);
    border-color: var(--c-border-strong);
    box-shadow: var(--shadow-sm);
}

/* Responsive */
@media (max-width: 992px) {
    .author-v2__grid {
        grid-template-columns: 1fr;
    }

    .author-v2__media {
        height: auto;
        aspect-ratio: 16/10;
        min-height: unset;
    }
}

@media (prefers-reduced-motion: reduce) {
    .author-v2__media img {
        transition: none !important;
    }
}

/* =============================================================================
   Final safety: unified heading spacing across sections
   ============================================================================= */
.team-section-4 .heading,
.why-v3__head,
.author-v2__head {
    margin: 0 auto clamp(32px, 4vw, 60px);
}
