/* ========================================
   PROJECTS PAGE
   ======================================== */

/* --- Hero Description Light Variant --- */
.projects-page .hero-split-description--light { font-weight: 400; }

/* --- Hero Sizing Override --- */
.projects-page .hero-section-split.projects-hero { min-height: 670px; height: 670px; }
.projects-page .projects-hero .container { position: relative; z-index: 2; max-width: 1920px; margin: 0 auto; }
.projects-page .projects-hero .section { margin: 0; padding: 0; column-gap: 0; align-items: flex-start; }
.projects-page .projects-hero .section > div { padding: 0; }
.projects-page .projects-hero .hero-split-content { width: clamp(460px, 34vw, 706px); max-width: calc(100vw - 700px); padding: clamp(112px, 7.76vw, 149px) 0 0; margin-left: clamp(24px, 6.25vw, 120px); gap: 16px; flex: 0 0 auto; }
.projects-page .projects-hero .hero-split-text { gap: 16px; }
.projects-page .projects-hero .intro-content,
.projects-page .projects-hero .intro-text { display: flex; flex-direction: column; gap: 8px; }
.projects-page .projects-hero .hero-split-description { max-width: 687px; }

/* --- Hero Images (Desktop) - 3 staggered photos --- */
.projects-page .projects-hero { position: relative; overflow: hidden; }
.projects-page .projects-hero-images { position: absolute; top: 50%; right: clamp(24px, 6.15vw, 118px); z-index: 2; width: clamp(420px, 43vw, 915px); aspect-ratio: 915 / 670; pointer-events: none; transform: translateY(-50%); }
.projects-page .projects-hero-frame { position: absolute; overflow: hidden; background: var(--surface-page-default); }
.projects-page .projects-hero-frame--1 { top: 6.12%; left: 0; width: 37.81%; height: 62.54%; z-index: 3; }
.projects-page .projects-hero-frame--2 { top: 22.24%; left: 30.71%; width: 37.81%; height: 62.54%; z-index: 2; }
.projects-page .projects-hero-frame--3 { top: 41.49%; left: 62.30%; width: 37.81%; height: 58.51%; z-index: 1; }
.projects-page .projects-hero-img { display: block; width: 100%; height: 100%; object-fit: cover; }

/* --- Projects Section --- */
.projects-page .projects-section { background: var(--surface-page-neutral); padding: 80px 0 100px; }
.projects-page .projects-container { width: 100%; max-width: 1920px; margin: 0 auto; padding-left: clamp(24px, 6.25vw, 120px); padding-right: clamp(24px, 6.25vw, 120px); box-sizing: border-box; }
.projects-page .projects-section__heading { font: var(--heading-h2-bold); letter-spacing: var(--heading-h2-bold-letter-spacing); color: var(--text-secondary-heading); margin: 0 0 40px; }

/* --- Project Cards Grid --- */
.projects-page .project-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 44px 16px; }

/* --- Individual Project Card --- */
.projects-page .project-card { display: grid; grid-template-columns: 48.6% 1fr; background: var(--surface-page-default); overflow: hidden; width: 100%; height: 455px; box-sizing: border-box; border: 1px solid transparent; transition: border-color 0.2s ease; }
.projects-page .project-card:hover { transform: none; box-shadow: none; border-color: var(--surface-default-default); }

/* --- Project Card Slider --- */
.projects-page .project-card__slider { position: relative; width: 100%; height: 455px; overflow: hidden; }
.projects-page .project-card__slide { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; transition: opacity 0.6s ease-in-out; z-index: 0; }
.projects-page .project-card__slide.is-active { opacity: 1; z-index: 1; }
.projects-page .project-card__slide img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Slider Controls */
.projects-page .project-card__controls { position: absolute; bottom: 15px; right: 15px; display: flex; gap: 7px; z-index: 5; }
.projects-page .project-card__arrow { width: 38px; height: 38px; border-radius: 50%; background: #f4ecec; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.2s ease; opacity: 1; padding: 0; }
.projects-page .project-card__arrow:hover { background: #eadcdc; }
.projects-page .project-card__arrow svg { width: 7.2px; height: 13.1px; fill: none; stroke: var(--surface-default-default); stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; }

/* --- Project Card Content --- */
.projects-page .project-card__content { display: flex; flex-direction: column; justify-content: center; gap: 14px; padding: 30px 24px 30px 30px; }
.projects-page .project-card__title { font: 700 26px/34px var(--font-family-base); letter-spacing: -0.50px; color: var(--text-secondary-heading); margin: 0; }
.projects-page .project-card__location { display: flex; align-items: center; gap: 14px; }
.projects-page .project-card__location-icon { width: 23px; height: 30px; flex-shrink: 0; }
.projects-page .project-card__location-text { font-family: var(--font-family-base); font-size: 16px; font-weight: 600; letter-spacing: 0.50px; line-height: 24px; color: var(--text-secondary-heading); margin: 0; }
.projects-page .project-card__details { display: flex; flex-direction: column; gap: 12px; margin: 4px 0 0; padding-left: 18px; }
.projects-page .project-card__detail { font: var(--paragraph-body); letter-spacing: var(--paragraph-body-letter-spacing); color: var(--text-secondary-heading); line-height: 28px; padding-left: 0; }
.projects-page .project-card__detail::marker { color: var(--surface-default-default); font-size: 1.3em; }

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

@media (max-width: 1400px) {
    .projects-page .hero-section-split.projects-hero { height: 620px; min-height: 620px; }
    .projects-page .projects-hero .hero-split-content { width: clamp(420px, 36vw, 620px); max-width: calc(100vw - 560px); padding-top: 120px; margin-left: 40px; }
    .projects-page .projects-hero .hero-split-description { max-width: 620px; }
    .projects-page .projects-hero-images { right: 24px; width: clamp(400px, 38vw, 700px); }
    .projects-page .project-card__content { padding: 24px 20px 24px 24px; }
    .projects-page .project-card__title { font-size: 24px; line-height: 32px; }
}

@media (max-width: 1180px) {
    .projects-page .hero-section-split.projects-hero { height: 580px; min-height: 580px; }
    .projects-page .projects-hero .hero-split-content { width: min(480px, calc(100vw - 440px)); max-width: calc(100vw - 440px); padding-top: 104px; margin-left: 32px; }
    .projects-page .projects-hero .hero-split-description { max-width: 480px; }
    .projects-page .projects-hero-images { top: 50%; right: 20px; width: min(360px, calc(100vw - 700px)); }
}

@media (max-width: 1229px) {
    .projects-page .project-cards { grid-template-columns: 1fr; gap: 30px; }
    .projects-page .project-card { max-width: 832px; }
}

@media (max-width: 991px) {
    .projects-page .projects-hero-images { display: none; }
    .projects-page .hero-section-split.projects-hero { min-height: 0; height: auto; background: var(--surface-page-dark); }
    .projects-page .projects-hero .container { height: auto; }
    .projects-page .projects-hero .section { height: auto; padding: 56px 0; }
    .projects-page .projects-hero .hero-split-content { width: auto; max-width: 100%; padding: 0; margin-left: 0; gap: 16px; }
    .projects-page .projects-hero .intro-content,
    .projects-page .projects-hero .intro-text { gap: 8px; }
    .projects-page .projects-hero .hero-split-description { max-width: none; margin: 0; }
    .projects-page .projects-section { padding: 40px 0 60px; }
    .projects-page .projects-container { padding-left: 24px; padding-right: 24px; }
    .projects-page .projects-section__heading { font-size: 28px; line-height: 36px; margin-bottom: 24px; }
    .projects-page .project-cards { grid-template-columns: 1fr; gap: 18px; }
    .projects-page .project-card { grid-template-columns: 1fr; max-width: none; height: auto; margin: 0; }
    .projects-page .project-card__slider { aspect-ratio: 358 / 260; height: auto; }
    .projects-page .project-card__content { padding: 16px 16px 24px; gap: 10px; justify-content: flex-start; }
    .projects-page .project-card__title { font-size: 20px; line-height: 27px; }
    .projects-page .project-card__location { gap: 14px; align-items: center; }
    .projects-page .project-card__location-icon { width: 22.625px; height: 30.336px; }
    .projects-page .project-card__location-text { font-size: 14px; letter-spacing: 0.50px; line-height: 22px; }
    .projects-page .project-card__details { gap: 8px; margin-top: 0; padding-left: 14px; max-width: none; }
    .projects-page .project-card__detail { font-size: 14px; line-height: 24px; letter-spacing: -0.30px; }
    .projects-page .project-card__detail::marker { font-size: 8px; }
    .projects-page .project-card__controls { bottom: 15px; right: 15px; gap: 7px; }
}

@media (max-width: 480px) {
    .projects-page .projects-container { padding-left: 16px; padding-right: 16px; }
    .projects-page .hero-section-split.projects-hero { min-height: 434px; height: auto; }
    .projects-page .projects-hero .container { height: 100%; }
    .projects-page .hero-section-split.projects-hero::before { left: 0; right: 0; top: 0; bottom: 0; width: 100%; height: 100%; background-size: cover; background-position: left center; }
    .projects-page .projects-hero .section { min-height: 434px; padding: 43px 0 26px; }
    .projects-page .projects-hero .hero-split-content { width: 100%; max-width: 358px; gap: 16px; }
    .projects-page .projects-hero .hero-breadcrumb { font-size: 14px; line-height: 24px; letter-spacing: -0.3px; margin: 0; }
    .projects-page .projects-hero .hero-heading { font-size: 28px; line-height: 34px; letter-spacing: -0.5px; margin: 0; }
    .projects-page .projects-hero .hero-split-description { font-family: var(--font-family-base); font-size: 16px; font-weight: 600; line-height: 26px; letter-spacing: 0.50px; }
    .projects-page .projects-hero .hero-split-description--light { font-weight: 400; }
    .projects-page .projects-section { padding: 22px 0 60px; }
    .projects-page .projects-section__heading { display: none; }
    .projects-page .project-card__content { padding: 15px 16px 18px 11px; gap: 10px; }
    .projects-page .project-card__location { gap: 10px; }
    .projects-page .project-card__location-text { line-height: 22px; }
    .projects-page .project-card__details { gap: 8px; max-width: 280px; padding-left: 14px; }
    .projects-page .project-card__detail { line-height: 24px; }
    .projects-page .project-card__detail::marker { font-size: 10px; }
    .projects-page .project-card__arrow { background: rgba(255, 255, 255, 0.92); box-shadow: 0 1px 4px rgba(27, 26, 26, 0.18); }
    .projects-page .project-card__arrow:hover { background: rgba(255, 255, 255, 0.92); }
    .projects-page .project-card__controls { bottom: 21px; right: 21px; }
}
