/* ============================================================
   INNER PAGES — page hero, service, about, gallery, contact
   ============================================================ */

/* --- Page hero (inner) --- */
.page-hero { position: relative; background: var(--color-surface-dark); color: #fff; overflow: hidden; }
.page-hero__bg { position: absolute; inset: 0; }
.page-hero__bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.3; }
.page-hero__bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(100deg, rgba(17,17,17,0.95), rgba(17,17,17,0.6)); }
.page-hero__inner { position: relative; padding-block: clamp(3rem, 7vw, 5.5rem); }
.page-hero__title { color: #fff; font-size: var(--fs-4xl); font-weight: 800; line-height: 1.1; margin-top: var(--space-4); }
.page-hero__sub { margin-top: var(--space-4); font-size: var(--fs-lg); color: rgba(255,255,255,0.82); max-width: 56ch; }

/* --- Breadcrumb --- */
.crumbs { display: flex; gap: var(--space-2); font-size: var(--fs-sm); color: rgba(255,255,255,0.6); flex-wrap: wrap; }
.crumbs a:hover { color: var(--color-brand); }
.crumbs li:not(:last-child)::after { content: "/"; margin-left: var(--space-2); color: rgba(255,255,255,0.3); }
.crumbs [aria-current] { color: var(--color-brand); }

/* --- Service detail layout --- */
.service-layout { display: grid; grid-template-columns: 1fr 320px; gap: clamp(2rem,5vw,4rem); align-items: start; }
.service-body > * + * { margin-top: var(--space-6); }
.service-body h2 { margin-top: var(--space-10); }
.service-body img.service-figure { width: 100%; border-radius: var(--radius); box-shadow: var(--shadow); aspect-ratio: 16/9; object-fit: cover; }
.service-body ul.benefit-list { display: grid; gap: var(--space-5); margin-top: var(--space-6); }

/* sticky sidebar */
.service-aside { position: sticky; top: calc(var(--header-h) + var(--space-6)); display: grid; gap: var(--space-6); }
.aside-card { background: var(--color-surface-dark); color: #fff; border-radius: var(--radius); padding: var(--space-8); }
.aside-card h3 { color: #fff; margin-bottom: var(--space-3); }
.aside-card p { color: rgba(255,255,255,0.8); font-size: var(--fs-sm); margin-bottom: var(--space-6); }
.aside-card .btn { width: 100%; }
.aside-phone { display: flex; align-items: center; gap: var(--space-3); margin-top: var(--space-4); font-weight: 600; color: #fff; }
.aside-phone svg { width: 20px; height: 20px; color: var(--color-brand); }

.aside-nav { background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius); padding: var(--space-4); }
.aside-nav h3 { font-size: var(--fs-base); padding: var(--space-3) var(--space-4) var(--space-2); }
.aside-nav a { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); border-radius: var(--radius-sm); font-size: var(--fs-sm); font-weight: 500; color: var(--color-text-secondary); transition: background var(--t-fast), color var(--t-fast); }
.aside-nav a svg { width: 18px; height: 18px; color: var(--color-brand); flex: none; }
.aside-nav a:hover { background: var(--color-surface-light); color: var(--color-brand-dark); }
.aside-nav a[aria-current="page"] { background: var(--color-brand-soft); color: var(--color-brand-dark); font-weight: 600; }

@media (max-width: 900px) { .service-layout { grid-template-columns: 1fr; } .service-aside { position: static; } }

/* --- CTA banner --- */
.cta-band { background: var(--color-surface-dark); color: #fff; border-radius: var(--radius-lg); padding: clamp(2.5rem,5vw,4rem); text-align: center; }
.cta-band h2 { color: #fff; max-width: 22ch; margin-inline: auto; }
.cta-band p { margin: var(--space-4) auto 0; max-width: 50ch; }
.cta-band__actions { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; margin-top: var(--space-8); }

/* --- Other services strip --- */
.other-services { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--space-4); }
.other-service { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-6); border: 1px solid var(--color-border); border-radius: var(--radius); transition: border-color var(--t-base), transform var(--t-base); }
.other-service:hover { transform: translateY(-4px); border-color: var(--color-brand); }
.other-service svg { width: 26px; height: 26px; color: var(--color-brand-dark); }
.other-service span { font-weight: 600; font-size: var(--fs-sm); }
@media (max-width: 820px) { .other-services { grid-template-columns: repeat(2,1fr); } }

/* --- About story --- */
.story__media { position: relative; }
.story__media img { width: 100%; border-radius: var(--radius); object-fit: cover; aspect-ratio: 3/4; box-shadow: var(--shadow); }
.story__badge { position: absolute; bottom: var(--space-6); left: calc(-1 * var(--space-6)); background: var(--color-brand); color: #fff; border-radius: var(--radius); padding: var(--space-6); box-shadow: var(--shadow-lg); }
.story__badge strong { display: block; font-size: 2.5rem; font-weight: 800; line-height: 1; color: #fff; }
.story__badge span { font-size: var(--fs-sm); }
@media (max-width: 560px) { .story__badge { left: var(--space-4); bottom: var(--space-4); padding: var(--space-4); } .story__badge strong { font-size: 2rem; } }

/* mission / vision / values cards */
.mvv { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-6); }
.mvv__card { background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius); padding: var(--space-8); }
.mvv__card .icon-tile { margin-bottom: var(--space-5); }
@media (max-width: 820px) { .mvv { grid-template-columns: 1fr; } }

.values-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--space-4); }
.value-chip { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-5); background: var(--color-surface-light); border-radius: var(--radius); font-weight: 600; font-size: var(--fs-sm); }
.value-chip svg { width: 24px; height: 24px; color: var(--color-brand-dark); flex: none; }
@media (max-width: 820px) { .values-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 460px) { .values-grid { grid-template-columns: 1fr; } }

/* --- Gallery --- */
.gallery-grid { columns: 3; column-gap: var(--space-4); }
.gallery-grid figure { break-inside: avoid; margin-bottom: var(--space-4); border-radius: var(--radius); overflow: hidden; cursor: pointer; position: relative; }
.gallery-grid img { width: 100%; transition: transform var(--t-base); }
.gallery-grid figure::after { content: ""; position: absolute; inset: 0; background: rgba(17,17,17,0); transition: background var(--t-base); }
.gallery-grid figure:hover img { transform: scale(1.05); }
.gallery-grid figure:hover::after { background: rgba(17,17,17,0.15); }
@media (max-width: 820px) { .gallery-grid { columns: 2; } }
@media (max-width: 480px) { .gallery-grid { columns: 1; } }

/* lightbox */
.lightbox { position: fixed; inset: 0; z-index: 300; background: rgba(10,10,10,0.94); display: none; align-items: center; justify-content: center; padding: var(--space-6); }
.lightbox.is-open { display: flex; }
.lightbox img { max-width: 90vw; max-height: 86vh; border-radius: var(--radius); }
.lightbox__btn { position: absolute; background: rgba(255,255,255,0.12); color: #fff; width: 52px; height: 52px; border-radius: 50%; display: grid; place-items: center; transition: background var(--t-fast); }
.lightbox__btn:hover { background: var(--color-brand); }
.lightbox__btn svg { width: 24px; height: 24px; }
.lb-close { top: var(--space-6); right: var(--space-6); }
.lb-prev { left: var(--space-6); top: 50%; transform: translateY(-50%); }
.lb-next { right: var(--space-6); top: 50%; transform: translateY(-50%); }
@media (max-width: 560px) { .lb-prev { left: var(--space-3); } .lb-next { right: var(--space-3); } .lightbox__btn { width: 44px; height: 44px; } }

/* --- Contact page --- */
.contact-cards { display: grid; grid-template-columns: repeat(2,1fr); gap: var(--space-4); }
.contact-card { display: flex; align-items: flex-start; gap: var(--space-4); padding: var(--space-6); border: 1px solid var(--color-border); border-radius: var(--radius); }
.contact-card .icon-tile { margin: 0; flex: none; }
.contact-card h3 { font-size: var(--fs-base); margin-bottom: var(--space-1); }
.contact-card p, .contact-card a { font-size: var(--fs-sm); color: var(--color-text-secondary); }
.contact-card a:hover { color: var(--color-brand-dark); }
@media (max-width: 560px) { .contact-cards { grid-template-columns: 1fr; } }

.contact-form-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,3.5rem); align-items: start; }
.contact-form-wrap .map-embed iframe { width: 100%; min-height: 100%; height: 100%; border: 0; border-radius: var(--radius); }
.contact-form-wrap .map-embed { min-height: 480px; }
@media (max-width: 820px) { .contact-form-wrap { grid-template-columns: 1fr; } .contact-form-wrap .map-embed { min-height: 360px; } }

/* --- Legal / policy pages (readable prose) --- */
.legal-body { max-width: var(--container-narrow); }
.legal-body > * + * { margin-top: var(--space-5); }
.legal-body h2 { margin-top: var(--space-12); font-size: var(--fs-2xl); }
.legal-body h3 { margin-top: var(--space-8); font-size: var(--fs-xl); }
.legal-body p, .legal-body li { color: var(--color-text-secondary); line-height: 1.7; }
.legal-body ul, .legal-body ol { padding-left: var(--space-6); display: grid; gap: var(--space-2); }
.legal-body ul { list-style: disc; }
.legal-body ol { list-style: decimal; }
.legal-body a:not(.btn) { color: var(--color-brand-dark); text-decoration: underline; }
.legal-body a:not(.btn):hover { color: var(--color-brand); }
.legal-body strong { color: var(--color-text-primary); }
.legal-note { margin-top: var(--space-10); padding: var(--space-5) var(--space-6); background: var(--color-brand-soft); border-radius: var(--radius); font-size: var(--fs-sm); }
.legal-updated { font-size: var(--fs-sm); color: var(--color-text-muted); }
