/* ═══════════════════════════════════════════════════════════════════
   ЛЕСО СТРОЙ 2010 — Design System v3
   Navy · Gold · Cream — Professional Construction
   ═══════════════════════════════════════════════════════════════════ */

/* ── VARIABLES ──────────────────────────────────────────────────────── */
:root {
    --ls-navy:      #0D1B2A;
    --ls-navy2:     #162436;
    --ls-navy3:     #1D2E40;
    --ls-navy4:     #243549;
    --ls-gold:      #C49A3C;
    --ls-gold2:     #D9AE50;
    --ls-gold-dim:  rgba(196,154,60,0.12);
    --ls-cream:     #F8F5EF;
    --ls-cream2:    #EDE9E0;
    --ls-white:     #FFFFFF;
    --ls-border:    #DDD8CE;
    --ls-border-dk: rgba(255,255,255,0.07);
    --ls-text:      #1C1C1E;
    --ls-muted:     #6B7280;
    --ls-muted-dk:  rgba(255,255,255,0.55);
    --ls-font-h:    'Oswald', sans-serif;
    --ls-font-b:    'Inter', sans-serif;
    --ls-radius:    0px;
    --ls-trans:     0.26s ease;
    --ls-nav-h:     90px;
    --ls-shadow:    0 2px 16px rgba(13,27,42,0.08);
    --ls-shadow-lg: 0 8px 40px rgba(13,27,42,0.14);
}

/* ── RESET & BASE ───────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body {
    font-family: var(--ls-font-b);
    background: var(--ls-white);
    color: var(--ls-text);
    line-height: 1.65;
    overflow-x: hidden;
}
h1, h2, h3, h4, h5, h6 {
    font-family: var(--ls-font-h);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: 0.3px;
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }

/* Полиран фокус за клавиатурна навигация */
:focus-visible {
    outline: 2px solid var(--ls-gold);
    outline-offset: 2px;
}

/* ── LOADER (брандиран екран при зареждане) ─────────────────────────── */
.ls-loader {
    position: fixed;
    inset: 0;
    z-index: 3000;
    background: var(--ls-navy);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity .5s ease, visibility .5s ease;
    animation: lsLoaderSafety 0.4s ease 2.5s forwards; /* fallback ако JS не се зареди */
}
.ls-loader.is-done {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}
.ls-loader__badge {
    position: relative;
    width: 88px; height: 88px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--ls-navy);
}
.ls-loader__badge img {
    width: 100%; height: 100%;
    object-fit: cover;
    transform: scale(1.10);
}
.ls-loader__badge::before {
    content: '';
    position: absolute;
    inset: -8px;
    border-radius: 50%;
    border: 2px solid transparent;
    border-top-color: var(--ls-gold);
    border-right-color: var(--ls-gold);
    animation: lsLoaderSpin 0.9s linear infinite;
}
@keyframes lsLoaderSpin { to { transform: rotate(360deg); } }
@keyframes lsLoaderSafety { to { opacity: 0; visibility: hidden; } }

/* ── LAYOUT ─────────────────────────────────────────────────────────── */
.ls-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 2.5rem;
}

/* ── SECTION PATTERNS ───────────────────────────────────────────────── */
.ls-section        { padding: 6rem 0; }
.ls-section--dark  { background: var(--ls-navy); }
.ls-section--cream { background: var(--ls-cream); }

/* ── SECTION HEADINGS ───────────────────────────────────────────────── */
.ls-section-label {
    font-family: var(--ls-font-h);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 4.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-bottom: .6rem;
    display: flex;
    align-items: center;
    gap: .7rem;
}
.ls-section-label::before {
    content: '';
    display: block;
    width: 24px;
    height: 2px;
    background: var(--ls-gold);
    flex-shrink: 0;
}

.ls-section-title {
    font-family: var(--ls-font-h);
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 700;
    color: var(--ls-text);
    text-transform: uppercase;
    letter-spacing: .5px;
}
.ls-section-title--light { color: var(--ls-white); }

.ls-divider {
    width: 48px;
    height: 3px;
    background: var(--ls-gold);
    margin: 1rem 0 2.5rem;
}

/* ── PAGE HEADER (dark top band for inner pages) ────────────────────── */
.ls-page-header {
    padding-top: var(--ls-nav-h);
    background: var(--ls-navy);
    border-bottom: 3px solid var(--ls-gold);
}
.ls-page-header__inner { padding-top: 4rem; padding-bottom: 3.25rem; }

/* Brutal variant — giant outline display type */
.ls-page-header--brutal {
    position: relative;
    overflow: hidden;
}
.ls-page-header--brutal .ls-page-header__inner { padding-top: 4rem; padding-bottom: 3.5rem; }
.ls-page-header__giant {
    font-family: var(--ls-font-h);
    font-size: clamp(3.5rem, 10vw, 7.5rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    line-height: .95;
    color: var(--ls-white); /* fallback за browser-и без text-stroke */
    margin: 0;
}
@supports (-webkit-text-stroke: 2px white) {
    .ls-page-header__giant {
        color: transparent;
        -webkit-text-stroke: 2px var(--ls-white);
    }
}
.ls-page-header__giant span {
    color: var(--ls-gold);
    -webkit-text-stroke: 0;
}

/* ── BUTTONS ────────────────────────────────────────────────────────── */
.ls-btn {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    font-family: var(--ls-font-h);
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: .85rem 2rem;
    border: 2px solid transparent;
    cursor: pointer;
    transition: all var(--ls-trans);
    white-space: nowrap;
}
.ls-btn--gold {
    background: var(--ls-gold);
    color: var(--ls-navy);
    border-color: var(--ls-gold);
}
.ls-btn--gold:hover {
    background: var(--ls-gold2);
    border-color: var(--ls-gold2);
    color: var(--ls-navy);
    transform: translateY(-2px);
}
.ls-btn--outline-white {
    background: transparent;
    color: var(--ls-white);
    border-color: rgba(255,255,255,0.38);
}
.ls-btn--outline-white:hover {
    background: rgba(255,255,255,0.07);
    border-color: var(--ls-white);
    color: var(--ls-white);
    transform: translateY(-2px);
}
.ls-btn--outline-dark {
    background: transparent;
    color: var(--ls-navy);
    border-color: var(--ls-navy);
}
.ls-btn--outline-dark:hover {
    background: var(--ls-navy);
    color: var(--ls-white);
    transform: translateY(-2px);
}
.ls-btn--navy {
    background: var(--ls-navy);
    color: var(--ls-white);
    border-color: var(--ls-navy);
}
.ls-btn--navy:hover {
    background: var(--ls-navy2);
    color: var(--ls-white);
    transform: translateY(-2px);
}

/* ── NAVBAR — BRUTAL ─────────────────────────────────────────────────── */
.ls-nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1000;
    transition: background var(--ls-trans), box-shadow var(--ls-trans);
}
.ls-nav::before {
    content: '';
    display: block;
    height: 4px;
    background: var(--ls-gold);
}
.ls-nav__inner {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 2.5rem;
    height: var(--ls-nav-h);
    transition: height var(--ls-trans);
}
.ls-nav:not(.ls-nav--scrolled) .ls-nav__inner {
    border-bottom: 1px solid rgba(255,255,255,0.14);
}
.ls-nav--scrolled {
    background: var(--ls-navy);
    box-shadow: 0 6px 0 rgba(0,0,0,0.25);
    border-bottom: 1px solid rgba(255,255,255,0.1);
}
.ls-nav--scrolled .ls-nav__inner { height: 70px; }

/* Logo */
.ls-logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    transition: opacity var(--ls-trans);
}
.ls-logo:hover { opacity: .85; }
.ls-logo__mark {
    width: 74px;
    height: 74px;
    flex-shrink: 0;
    border-radius: 50%;
    overflow: hidden;
    display: inline-block;
    background: var(--ls-navy);
    transition: width var(--ls-trans), height var(--ls-trans);
}
.ls-logo__mark img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.10);
}
.ls-nav--scrolled .ls-logo__mark { width: 58px; height: 58px; }

/* Nav links — full-height brutal blocks */
.ls-nav__links {
    display: flex;
    list-style: none;
    gap: 0;
    align-items: stretch;
    height: 100%;
}
.ls-nav__links li { display: flex; align-items: stretch; }
.ls-nav__link {
    font-family: var(--ls-font-h);
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.78);
    display: flex;
    align-items: center;
    padding: 0 1.3rem;
    position: relative;
    transition: background 0.15s ease, color 0.15s ease;
}
.ls-nav__link:hover,
.ls-nav__link--active {
    background: var(--ls-gold);
    color: var(--ls-navy);
}
.ls-nav__link--admin { color: var(--ls-gold); }
.ls-nav__link--admin:hover { background: var(--ls-gold); color: var(--ls-navy); }
.ls-nav__right { display: flex; align-items: center; gap: 1.1rem; }

/* Език превключвател */
.ls-lang { display: flex; align-items: center; gap: .35rem; font-family: var(--ls-font-h); font-size: .72rem; font-weight: 600; letter-spacing: 1px; }
.ls-lang__opt { color: rgba(255,255,255,0.55); transition: color var(--ls-trans); padding: 2px 0; }
.ls-lang__opt:hover { color: var(--ls-gold); }
.ls-lang__opt.is-active { color: var(--ls-gold); border-bottom: 2px solid var(--ls-gold); }
.ls-lang__sep { color: rgba(255,255,255,0.25); }
.ls-nav__mobile-lang { display: flex !important; gap: 1.2rem; padding: 1.1rem 2.5rem !important; }
.ls-nav__mobile-lang a { font-family: var(--ls-font-h); font-weight: 600; letter-spacing: 1px; color: rgba(255,255,255,0.6); padding: 0 !important; border: none !important; }
.ls-nav__mobile-lang a.is-active { color: var(--ls-gold); }
.ls-nav__right > form,
.ls-nav__right .navbar-nav { align-self: center; }

/* Nav CTA — proper brutal button: gold fill, hard offset shadow on hover */
.ls-nav__cta {
    font-family: var(--ls-font-h);
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    background: var(--ls-gold);
    color: var(--ls-navy);
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .72rem 1.55rem;
    border: 2px solid var(--ls-gold);
    transition: all 0.16s ease;
    white-space: nowrap;
}
.ls-nav__cta:hover {
    background: var(--ls-navy);
    color: var(--ls-gold);
    border-color: var(--ls-gold);
    box-shadow: 5px 5px 0 var(--ls-gold);
    transform: translate(-2px, -2px);
}

/* Burger */
.ls-nav__burger {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    align-self: center;
    margin-right: 1.25rem;
}
.ls-nav__burger span {
    display: block;
    width: 26px;
    height: 2px;
    background: var(--ls-white);
    transition: var(--ls-trans);
    transform-origin: center;
}
.ls-nav__burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.ls-nav__burger.open span:nth-child(2) { opacity: 0; }
.ls-nav__burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.ls-nav__mobile {
    display: none;
    background: var(--ls-navy2);
    border-top: 1px solid var(--ls-border-dk);
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.38s ease;
}
.ls-nav__mobile.open { max-height: 420px; }
.ls-nav__mobile ul { list-style: none; }
.ls-nav__mobile a {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-family: var(--ls-font-h);
    font-size: 1rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.85);
    padding: .9rem 2.5rem;
    border-bottom: 1px solid var(--ls-border-dk);
    transition: color var(--ls-trans), padding-left var(--ls-trans);
}
.ls-nav__mobile a:hover { color: var(--ls-gold); padding-left: 3rem; }

/* Login partial in nav */
.ls-nav__right .navbar-nav { flex-direction: row; gap: .4rem; align-items: center; }
.ls-nav__right .nav-link,
.ls-nav__right form button {
    font-family: var(--ls-font-h);
    font-size: .72rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.65);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: color var(--ls-trans);
}
.ls-nav__right .nav-link:hover,
.ls-nav__right form button:hover { color: var(--ls-gold); }

/* ── HERO VIDEO ──────────────────────────────────────────────────────── */
.hero-section {
    position: relative;
    width: 100%;
    height: 100vh;
    min-height: 620px;
    overflow: hidden;
    display: flex;
    align-items: center;
    background: var(--ls-navy); /* до зареждане на видеото — без черен flash */
}
.hero-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
}
.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        105deg,
        rgba(13,27,42,0.92) 0%,
        rgba(13,27,42,0.70) 55%,
        rgba(13,27,42,0.45) 100%
    );
    z-index: 1;
}
.hero-content {
    position: relative;
    z-index: 2;
    width: 100%;
    text-align: center;
    padding: 0 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .7rem;
    font-family: var(--ls-font-h);
    font-size: .72rem;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-bottom: 1.4rem;
    justify-content: center;
}
.hero-eyebrow::before,
.hero-eyebrow::after {
    content: '';
    display: block;
    width: 28px;
    height: 2px;
    background: var(--ls-gold);
    opacity: .7;
}
.hero-title {
    font-family: var(--ls-font-h);
    font-size: clamp(2.8rem, 6.5vw, 5.5rem);
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--ls-white);
    line-height: 1;
    margin-bottom: .4rem;
}
.hero-title span {
    color: var(--ls-gold);
    display: block;
}
.hero-year {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 4px;
    color: var(--ls-gold);
    text-transform: uppercase;
    border: 1px solid rgba(196,154,60,0.4);
    padding: 5px 16px;
    margin-bottom: 1.4rem;
}
.hero-rule {
    width: 48px;
    height: 2px;
    background: var(--ls-gold);
    opacity: .55;
    margin: 0 auto 1.6rem;
}
.hero-subtitle {
    font-size: clamp(1rem, 1.8vw, 1.2rem);
    color: rgba(255,255,255,0.82);
    max-width: 600px;
    margin-bottom: 2.5rem;
    font-weight: 400;
    line-height: 1.75;
}
.hero-subtitle strong {
    color: var(--ls-gold2);
    font-weight: 600;
}
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }

/* ── PROJECT CAROUSEL ────────────────────────────────────────────────── */
.ls-carousel {
    position: relative;
    overflow: hidden;
    width: 100%;
    aspect-ratio: 16/7;
    min-height: 360px;
    background: var(--ls-navy3);
}
.ls-carousel__track {
    position: relative;
    height: 100%;
}
.ls-carousel__slide {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    z-index: 0;
    transition: opacity 0.8s ease, visibility 0.8s ease;
}
.ls-carousel__slide--active {
    opacity: 1;
    visibility: visible;
    z-index: 1;
}
.ls-carousel__slide-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 6s ease;
}
.ls-carousel__slide--active .ls-carousel__slide-img {
    transform: scale(1.06);
}
.ls-carousel__slide-placeholder {
    width: 100%; height: 100%;
    background: var(--ls-navy3);
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,0.1); font-size: 5rem;
}
.ls-carousel__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to right,
        rgba(13,27,42,0.82) 0%,
        rgba(13,27,42,0.35) 55%,
        rgba(13,27,42,0.1) 100%
    );
    display: flex;
    align-items: flex-end;
    padding: 3rem 4rem;
}
.ls-carousel__info {
    max-width: 480px;
}
.ls-carousel__cat {
    font-family: var(--ls-font-h);
    font-size: .65rem;
    letter-spacing: 3.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-bottom: .6rem;
    opacity: 0;
    transform: translateY(10px);
    transition: all 0.6s ease 0.2s;
}
.ls-carousel__title {
    font-family: var(--ls-font-h);
    font-size: clamp(1.4rem, 2.8vw, 2.2rem);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--ls-white);
    letter-spacing: .5px;
    line-height: 1.1;
    margin-bottom: .5rem;
    opacity: 0;
    transform: translateY(14px);
    transition: all 0.6s ease 0.35s;
}
.ls-carousel__meta {
    font-size: .8rem;
    color: rgba(255,255,255,0.55);
    letter-spacing: 1px;
    margin-bottom: 1.2rem;
    opacity: 0;
    transform: translateY(10px);
    transition: all 0.6s ease 0.45s;
}
.ls-carousel__link {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-family: var(--ls-font-h);
    font-size: .72rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    border-bottom: 1px solid rgba(196,154,60,0.4);
    padding-bottom: 2px;
    transition: gap 0.2s ease, border-color 0.2s ease;
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.6s ease 0.55s, transform 0.6s ease 0.55s, gap 0.2s ease, border-color 0.2s ease;
}
.ls-carousel__link:hover { gap: .75rem; border-color: var(--ls-gold); color: var(--ls-gold); }

/* Animate text in on active slide */
.ls-carousel__slide--active .ls-carousel__cat,
.ls-carousel__slide--active .ls-carousel__title,
.ls-carousel__slide--active .ls-carousel__meta,
.ls-carousel__slide--active .ls-carousel__link {
    opacity: 1;
    transform: translateY(0);
}

/* Navigation arrows */
.ls-carousel__prev,
.ls-carousel__next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 48px;
    height: 48px;
    background: rgba(13,27,42,0.65);
    border: 1px solid rgba(255,255,255,0.12);
    color: var(--ls-white);
    font-size: 1.1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.22s ease;
    backdrop-filter: blur(6px);
}
.ls-carousel__prev { left: 1.5rem; }
.ls-carousel__next { right: 1.5rem; }
.ls-carousel__prev:hover,
.ls-carousel__next:hover {
    background: var(--ls-gold);
    border-color: var(--ls-gold);
    color: var(--ls-navy);
}

/* Dots */
.ls-carousel__dots {
    position: absolute;
    bottom: 1.5rem;
    right: 2rem;
    display: flex;
    gap: 6px;
    z-index: 10;
}
.ls-carousel__dot {
    width: 24px;
    height: 3px;
    background: rgba(255,255,255,0.25);
    cursor: pointer;
    transition: all 0.3s ease;
    border: none;
    padding: 0;
    appearance: none;
}
.ls-carousel__dot:focus-visible { outline: 2px solid var(--ls-gold); outline-offset: 3px; }
.ls-carousel__dot--active {
    background: var(--ls-gold);
    width: 40px;
}

/* Progress bar */
.ls-carousel__progress {
    position: absolute;
    bottom: 0; left: 0;
    height: 3px;
    background: var(--ls-gold);
    width: 0%;
    transition: width linear;
    z-index: 10;
    opacity: 0.7;
}

/* ── PROJECT STATUS BADGE ────────────────────────────────────────────── */
.ls-status {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-family: var(--ls-font-h);
    font-size: .6rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: .3rem .75rem;
    border-radius: 2px;
}
.ls-status::before {
    content: '';
    display: block;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: currentColor;
}
.ls-status--done    { background: rgba(34,197,94,.13);  color: #22c55e; }
.ls-status--rough   { background: rgba(59,130,246,.13); color: #60a5fa; }
.ls-status--finish  { background: rgba(251,146,60,.13); color: #fb923c; }
.ls-status--plan    { background: rgba(168,85,247,.13); color: #c084fc; }
.ls-status--active  { background: rgba(234,179,8,.13);  color: #eab308; }

/* ── LIGHTBOX ────────────────────────────────────────────────────────── */
.ls-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(5,10,18,0.97);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
    cursor: zoom-out;
}
.ls-lightbox--open {
    opacity: 1;
    pointer-events: all;
}
.ls-lightbox__img {
    max-width: 95vw;
    max-height: 95vh;
    object-fit: contain;
    box-shadow: 0 24px 80px rgba(0,0,0,0.8);
    transition: transform 0.35s ease;
}
.ls-lightbox__close {
    position: absolute;
    top: 1.5rem; right: 2rem;
    background: none; border: none;
    color: rgba(255,255,255,0.7);
    font-size: 2.2rem;
    cursor: pointer;
    line-height: 1;
    transition: color 0.2s ease;
    z-index: 10;
}
.ls-lightbox__close:hover { color: var(--ls-gold); }
.ls-lightbox__caption {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    font-family: var(--ls-font-h);
    font-size: .75rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
    white-space: nowrap;
}

/* ── PROJECT DETAIL PAGE ─────────────────────────────────────────────── */
.ls-project-hero {
    width: 100%;
    aspect-ratio: 16/7;
    min-height: 420px;
    position: relative;
    overflow: hidden;
    background: var(--ls-navy3);
    cursor: zoom-in;
}
.ls-project-hero__img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 6s ease;
}
.ls-project-hero:hover .ls-project-hero__img { transform: scale(1.03); }
.ls-project-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(13,27,42,0.9) 0%, rgba(13,27,42,0) 50%);
}
.ls-project-hero__caption {
    position: absolute;
    bottom: 2.5rem; left: 3rem;
    z-index: 2;
    display: flex;
    align-items: center;
    gap: .75rem;
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.6);
}
.ls-project-hero__zoom {
    position: absolute;
    bottom: 2rem; right: 2rem;
    z-index: 2;
    display: flex;
    align-items: center;
    gap: .5rem;
    font-family: var(--ls-font-h);
    font-size: .65rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
    transition: color 0.2s;
}
.ls-project-hero:hover .ls-project-hero__zoom { color: var(--ls-gold); }

.ls-project-body {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 5rem;
    align-items: start;
    padding: 4rem 0 6rem;
}
.ls-project-body__title {
    font-family: var(--ls-font-h);
    font-size: clamp(1.8rem, 3.5vw, 2.8rem);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--ls-text);
    margin-bottom: 1rem;
    line-height: 1.05;
}
.ls-project-body__desc {
    font-size: 1rem;
    color: var(--ls-muted);
    line-height: 1.9;
    margin-top: 1.5rem;
}
.ls-project-meta-card {
    background: var(--ls-navy);
    padding: 2.2rem;
    position: sticky;
    top: calc(var(--ls-nav-h) + 2rem);
}
.ls-project-meta-card__row {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    padding: 1rem 0;
    border-bottom: 1px solid var(--ls-border-dk);
}
.ls-project-meta-card__row:first-child { padding-top: 0; }
.ls-project-meta-card__row:last-child { border-bottom: none; }
.ls-project-meta-card__label {
    font-family: var(--ls-font-h);
    font-size: .62rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
}
.ls-project-meta-card__val {
    font-size: .92rem;
    color: rgba(255,255,255,0.75);
}

/* Stats bar */
.hero-stats {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    z-index: 2;
    display: flex;
    background: rgba(13,27,42,0.85);
    backdrop-filter: blur(10px);
    border-top: 1px solid rgba(196,154,60,0.2);
}
.hero-stat {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1.4rem 1rem;
    border-right: 1px solid var(--ls-border-dk);
}
.hero-stat:last-child { border-right: none; }
.hero-stat__num {
    font-family: var(--ls-font-h);
    font-size: 2.1rem;
    font-weight: 700;
    color: var(--ls-gold);
    line-height: 1;
}
.hero-stat__label {
    font-size: .65rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.5);
    margin-top: .35rem;
    text-align: center;
}

/* Scroll hint */
.hero-scroll {
    position: absolute;
    bottom: 7rem;
    right: 2.5rem;
    z-index: 2;
    writing-mode: vertical-rl;
    font-family: var(--ls-font-h);
    font-size: .62rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.35);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}
.hero-scroll::after {
    content: '';
    display: block;
    width: 1px;
    height: 56px;
    background: linear-gradient(to bottom, rgba(196,154,60,0.6), transparent);
    animation: scrollLine 1.9s infinite;
}
@keyframes scrollLine {
    0%   { transform: scaleY(0); transform-origin: top; }
    50%  { transform: scaleY(1); transform-origin: top; }
    51%  { transform: scaleY(1); transform-origin: bottom; }
    100% { transform: scaleY(0); transform-origin: bottom; }
}

/* ── PROCESS — КАК РАБОТИМ ───────────────────────────────────────────── */
.ls-process-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border: 1px solid var(--ls-border-dk);
}
.ls-process-step {
    padding: 2.5rem 2rem;
    border-right: 1px solid var(--ls-border-dk);
    position: relative;
    transition: background var(--ls-trans);
}
.ls-process-step:last-child { border-right: none; }
.ls-process-step:hover { background: var(--ls-navy2); }
.ls-process-step__num {
    font-family: var(--ls-font-h);
    font-size: 3.5rem;
    font-weight: 700;
    color: var(--ls-gold);
    line-height: 1;
    margin-bottom: 1.2rem;
    opacity: .6;
}
.ls-process-step__title {
    font-family: var(--ls-font-h);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--ls-white);
    margin-bottom: .7rem;
}
.ls-process-step__text {
    font-size: .85rem;
    color: var(--ls-muted-dk);
    line-height: 1.75;
}

/* ── SERVICE CARDS ───────────────────────────────────────────────────── */
.ls-services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    gap: 1.5rem;
}
.ls-service-card {
    background: var(--ls-white);
    padding: 2.5rem 2rem;
    border: 1px solid var(--ls-border);
    border-top: 3px solid transparent;
    box-shadow: var(--ls-shadow);
    transition: all var(--ls-trans);
    cursor: default;
}
.ls-service-card:hover {
    border-top-color: var(--ls-gold);
    box-shadow: var(--ls-shadow-lg);
    transform: translateY(-5px);
}
.ls-service-card__icon {
    font-size: 2rem;
    color: var(--ls-gold);
    margin-bottom: 1.2rem;
    display: block;
    transition: transform var(--ls-trans);
}
.ls-service-card:hover .ls-service-card__icon { transform: scale(1.1); }
.ls-service-card__title {
    font-family: var(--ls-font-h);
    font-size: 1.05rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--ls-text);
    margin-bottom: .75rem;
}
.ls-service-card__desc { font-size: .88rem; color: var(--ls-muted); line-height: 1.75; }

/* ── PROJECT CARDS — BRUTAL ──────────────────────────────────────────── */
.ls-projects-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 2.5rem 2rem;
}
.ls-project-card {
    position: relative;
    display: block;
    background: var(--ls-navy);
    border: 3px solid var(--ls-navy);
    box-shadow: 8px 8px 0 var(--ls-cream2);
    transition: box-shadow 0.22s ease, transform 0.22s ease;
}
.ls-project-card:hover {
    transform: translate(-3px, -3px);
    box-shadow: 14px 14px 0 var(--ls-gold);
}
.ls-project-card__media {
    position: relative;
    aspect-ratio: 16/10;
    overflow: hidden;
}
.ls-project-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(35%);
    transition: transform 0.55s ease, filter 0.4s ease;
}
.ls-project-card:hover .ls-project-card__img {
    transform: scale(1.07);
    filter: grayscale(0%);
}
.ls-project-card__placeholder {
    width: 100%; height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--ls-navy3);
    color: rgba(255,255,255,0.15);
    font-size: 3rem;
}
.ls-project-card__num {
    position: absolute;
    top: 0; right: 0;
    z-index: 2;
    font-family: var(--ls-font-h);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 1px;
    background: var(--ls-gold);
    color: var(--ls-navy);
    padding: .45rem .9rem;
}
.ls-project-card__cat-strip {
    position: absolute;
    bottom: 0; left: 0;
    z-index: 2;
    font-family: var(--ls-font-h);
    font-size: .62rem;
    font-weight: 600;
    letter-spacing: 3px;
    text-transform: uppercase;
    background: var(--ls-navy);
    color: var(--ls-gold);
    padding: .5rem 1.1rem;
    border-top: 2px solid var(--ls-gold);
    border-right: 2px solid var(--ls-gold);
}
.ls-project-card__body {
    padding: 1.5rem 1.6rem 1.7rem;
    border-top: 3px solid var(--ls-gold);
}
.ls-project-card__title {
    font-family: var(--ls-font-h);
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--ls-white);
    margin-bottom: .45rem;
    line-height: 1.15;
}
.ls-project-card__meta {
    font-size: .75rem;
    color: rgba(255,255,255,0.5);
    letter-spacing: 1px;
    margin-bottom: 1rem;
}
.ls-project-card__specs {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem 1rem;
    margin-bottom: 1rem;
}
.ls-project-card__specs span {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.6);
}
.ls-project-card__specs i { color: var(--ls-gold); font-size: .8rem; }
.ls-project-card__link {
    font-family: var(--ls-font-h);
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    transition: gap 0.2s ease;
}
.ls-project-card:hover .ls-project-card__link { gap: .8rem; }

/* ── CTA SECTION ─────────────────────────────────────────────────────── */
.ls-cta {
    background: var(--ls-navy);
    padding: 6rem 0;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.ls-cta::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent 0%, var(--ls-gold) 30%, var(--ls-gold) 70%, transparent 100%);
}
.ls-cta__label {
    font-family: var(--ls-font-h);
    font-size: .72rem;
    letter-spacing: 5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .7rem;
    margin-bottom: 1rem;
}
.ls-cta__label::before, .ls-cta__label::after {
    content: '';
    display: block;
    width: 28px;
    height: 1px;
    background: var(--ls-gold);
    opacity: .5;
}
.ls-cta__title {
    font-family: var(--ls-font-h);
    font-size: clamp(2rem, 5vw, 3.4rem);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--ls-white);
    letter-spacing: .5px;
    margin-bottom: .8rem;
}
.ls-cta__sub {
    font-size: 1rem;
    color: rgba(255,255,255,0.55);
    margin-bottom: 2.5rem;
    font-weight: 300;
}

/* ── PROJECT FILTER BUTTONS ─────────────────────────────────────────── */
.ls-filter-wrap { display: flex; gap: .8rem; flex-wrap: wrap; margin-top: 2rem; }
.ls-filter-btn {
    font-family: var(--ls-font-h);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    padding: .55rem 1.35rem;
    border: 2px solid rgba(255,255,255,0.3);
    color: rgba(255,255,255,0.7);
    background: transparent;
    transition: all 0.15s ease;
    cursor: pointer;
}
.ls-filter-btn:hover {
    border-color: var(--ls-gold);
    color: var(--ls-gold);
    box-shadow: 4px 4px 0 rgba(196,154,60,0.35);
    transform: translate(-1px, -1px);
}
.ls-filter-btn.active {
    background: var(--ls-gold);
    border-color: var(--ls-gold);
    color: var(--ls-navy);
    font-weight: 700;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.45);
}

/* ── FLASH / ALERTS ──────────────────────────────────────────────────── */
.ls-flash {
    position: relative;
    z-index: 900;
    padding-top: var(--ls-nav-h);
}
.ls-flash--success .ls-flash__inner {
    background: #0e2e1a;
    border-left: 4px solid #38a169;
    color: #9ae6b4;
}
.ls-flash__inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: .9rem 2.5rem;
    display: flex;
    align-items: center;
    gap: .8rem;
    font-size: .88rem;
}
.ls-flash__close {
    margin-left: auto;
    background: none;
    border: none;
    color: inherit;
    font-size: 1.3rem;
    cursor: pointer;
    opacity: .65;
    line-height: 1;
}

/* ── FOOTER ──────────────────────────────────────────────────────────── */
.ls-footer {
    background: var(--ls-navy);
    color: var(--ls-white);
    border-top: 4px solid var(--ls-gold);
}
.ls-footer__inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 4.5rem 2.5rem 3.5rem;
    display: grid;
    grid-template-columns: minmax(240px, 320px) 170px 230px 250px;
    justify-content: start;
    gap: 2.5rem 4.5rem;
    align-items: start;
    border-bottom: 1px solid var(--ls-border-dk);
}

/* Brand column */
.ls-footer__brand { max-width: 320px; }
.ls-footer__logo {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 1.3rem;
}
.ls-footer__logo .ls-logo__mark { width: 56px; height: 56px; }
.ls-footer__brand-text { display: flex; flex-direction: column; line-height: 1.15; }
.ls-footer__brand-name {
    font-family: var(--ls-font-h);
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--ls-white);
}
.ls-footer__brand-sub {
    font-family: var(--ls-font-h);
    font-size: .62rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-top: 4px;
}
.ls-footer__tagline {
    color: rgba(255,255,255,0.5);
    font-size: .9rem;
    line-height: 1.8;
    margin-bottom: 1.8rem;
}
.ls-footer__social { display: flex; gap: .65rem; }
.ls-footer__social a {
    width: 40px; height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--ls-border-dk);
    color: rgba(255,255,255,0.6);
    font-size: 1.05rem;
    transition: all var(--ls-trans);
}
.ls-footer__social a:hover {
    background: var(--ls-gold);
    border-color: var(--ls-gold);
    color: var(--ls-navy);
    transform: translateY(-3px);
}

/* Columns */
.ls-footer__heading {
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 3.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-bottom: 1.4rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid var(--ls-border-dk);
}
.ls-footer__list { list-style: none; }
.ls-footer__list li { margin-bottom: .7rem; }
.ls-footer__list a {
    color: rgba(255,255,255,0.55);
    font-size: .9rem;
    transition: color var(--ls-trans), padding-left var(--ls-trans);
    display: inline-flex;
    align-items: center;
}
.ls-footer__list a::before {
    content: '›';
    color: var(--ls-gold);
    margin-right: .5rem;
    opacity: 0;
    transition: opacity var(--ls-trans);
}
.ls-footer__list a:hover { color: var(--ls-gold); padding-left: 4px; }
.ls-footer__list a:hover::before { opacity: 1; }
.ls-footer__contact { list-style: none; }
.ls-footer__contact li {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    margin-bottom: 1rem;
    color: rgba(255,255,255,0.55);
    font-size: .9rem;
    line-height: 1.5;
}
.ls-footer__contact i { color: var(--ls-gold); margin-top: 3px; flex-shrink: 0; }
.ls-footer__contact a { color: inherit; transition: color var(--ls-trans); word-break: break-word; }
.ls-footer__contact a:hover { color: var(--ls-gold); }

/* CTA column */
.ls-footer__cta-text {
    color: rgba(255,255,255,0.45);
    font-size: .9rem;
    line-height: 1.8;
    margin-bottom: 1.6rem;
}
.ls-footer__cta-btn { display: inline-flex; }

/* Bottom bar */
.ls-footer__bottom {
    max-width: 1280px;
    margin: 0 auto;
    padding: 1.6rem 2.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    font-size: .78rem;
    color: rgba(255,255,255,0.35);
}
.ls-footer__bottom-links { display: flex; gap: 1.5rem; }
.ls-footer__bottom-links a {
    color: rgba(255,255,255,0.45);
    transition: color var(--ls-trans);
}
.ls-footer__bottom-links a:hover { color: var(--ls-gold); }

/* ── ABOUT PAGE ──────────────────────────────────────────────────────── */

/* Hero (с фоново изображение) */
.about-hero {
    position: relative;
    min-height: 68vh;
    background: var(--ls-navy);
    border-top: 4px solid var(--ls-gold);
    padding-top: var(--ls-nav-h);
    display: flex;
    align-items: center;
    overflow: hidden;
}
.about-hero__img {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    z-index: 0;
}
.about-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(105deg,
        rgba(13,27,42,0.95) 0%,
        rgba(13,27,42,0.80) 50%,
        rgba(13,27,42,0.55) 100%);
}
.about-hero .ls-container { position: relative; z-index: 2; width: 100%; }
.about-hero__ghost {
    position: absolute;
    font-family: var(--ls-font-h);
    font-size: clamp(6rem, 20vw, 17rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: transparent;
    -webkit-text-stroke: 1px rgba(196,154,60,0.07);
    user-select: none;
    white-space: nowrap;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
    pointer-events: none;
}
.about-hero__inner {
    padding: 4rem 0 4.5rem;
    max-width: 720px;
}
.about-hero__title {
    font-family: var(--ls-font-h);
    font-size: clamp(2.6rem, 5.5vw, 4.8rem);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--ls-white);
    line-height: 1.05;
    letter-spacing: 1px;
    margin: 1.2rem 0 1.5rem;
}
.about-hero__title em {
    color: var(--ls-gold);
    font-style: normal;
    display: block;
}
.about-hero__sub {
    font-size: clamp(.95rem, 1.6vw, 1.12rem);
    color: rgba(255,255,255,0.72);
    max-width: 560px;
    line-height: 1.8;
    font-weight: 400;
}
.about-hero__chips {
    display: flex;
    flex-wrap: wrap;
    gap: .7rem;
    margin-top: 2rem;
}
.about-hero__chips span {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.85);
    border: 1px solid rgba(196,154,60,0.4);
    padding: .5rem .9rem;
}
.about-hero__chips i { color: var(--ls-gold); }

/* Story media (образ + значка) */
.about-story-media {
    position: relative;
    aspect-ratio: 4/5;
    overflow: hidden;
    background: var(--ls-navy3);
    box-shadow: var(--ls-shadow-lg);
}
.about-story-media img { width: 100%; height: 100%; object-fit: cover; }
.about-story-media__badge {
    position: absolute;
    left: 0; bottom: 2rem;
    background: var(--ls-gold);
    color: var(--ls-navy);
    padding: 1rem 1.7rem;
    display: flex;
    flex-direction: column;
    line-height: 1;
}
.about-story-media__year { font-family: var(--ls-font-h); font-size: 2rem; font-weight: 700; }
.about-story-media__txt { font-family: var(--ls-font-h); font-size: .6rem; letter-spacing: 3px; text-transform: uppercase; margin-top: 5px; }

/* Ценности */
.about-values-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
.about-value-card {
    background: var(--ls-white);
    border: 1px solid var(--ls-border);
    border-top: 3px solid var(--ls-gold);
    padding: 2.4rem 1.6rem;
    text-align: center;
    transition: transform var(--ls-trans), box-shadow var(--ls-trans);
}
.about-value-card:hover { transform: translateY(-5px); box-shadow: var(--ls-shadow-lg); }
.about-value-card__icon { font-size: 2.4rem; color: var(--ls-gold); display: block; margin-bottom: 1.2rem; }
.about-value-card__title {
    font-family: var(--ls-font-h);
    font-size: 1.05rem; font-weight: 700; letter-spacing: 1px;
    text-transform: uppercase; color: var(--ls-text); margin-bottom: .7rem;
}
.about-value-card__text { font-size: .85rem; color: var(--ls-muted); line-height: 1.72; }

/* Нашият път (timeline център) */
.about-path { max-width: 640px; margin: 3.5rem auto 0; }

/* Основател / мисия */
.about-founder {
    background: var(--ls-navy);
    padding: 5rem 0;
    border-top: 3px solid var(--ls-gold);
    border-bottom: 3px solid var(--ls-gold);
}
.about-founder__inner {
    display: grid;
    grid-template-columns: 160px 1fr;
    gap: 3rem;
    align-items: center;
    max-width: 920px;
    margin: 0 auto;
}
.about-founder__media { display: flex; align-items: flex-start; justify-content: center; }
.about-founder__mark {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 11rem;
    line-height: .7;
    color: var(--ls-gold);
}
.about-founder__quote {
    font-family: var(--ls-font-b);
    font-size: clamp(1.15rem, 2vw, 1.55rem);
    line-height: 1.6;
    color: #fff;
    font-weight: 300;
    margin: .6rem 0 1.6rem;
}
.about-founder__quote strong { color: var(--ls-gold); font-weight: 600; }
.about-founder__attr { display: flex; flex-direction: column; }
.about-founder__name {
    font-family: var(--ls-font-h);
    font-size: 1rem; letter-spacing: 1px; text-transform: uppercase; color: #fff;
}
.about-founder__role {
    font-family: var(--ls-font-h);
    font-size: .65rem; letter-spacing: 2.5px; text-transform: uppercase;
    color: var(--ls-gold); margin-top: 4px;
}

/* История split */
.about-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6rem;
    align-items: start;
}
.about-split__title {
    font-family: var(--ls-font-h);
    font-size: clamp(2rem, 3.5vw, 3rem);
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--ls-navy);
    margin: .5rem 0 1rem;
    line-height: 1.1;
}
.about-split__rule {
    width: 40px;
    height: 3px;
    background: var(--ls-gold);
    margin-bottom: 1.8rem;
}
.about-split__left p {
    color: var(--ls-muted);
    line-height: 1.85;
    font-size: .95rem;
}
.about-split__left p + p { margin-top: 1rem; }

/* Timeline */
.about-timeline { position: relative; padding-left: 2rem; }
.about-timeline__line {
    position: absolute;
    left: 0; top: 6px; bottom: 6px;
    width: 2px;
    background: linear-gradient(to bottom, var(--ls-gold) 70%, rgba(196,154,60,0.08) 100%);
}
.about-timeline__item {
    position: relative;
    padding: 0 0 2.5rem 2rem;
}
.about-timeline__item:last-child { padding-bottom: 0; }
.about-timeline__dot {
    position: absolute;
    left: -2rem;
    top: 5px;
    width: 10px; height: 10px;
    background: var(--ls-white);
    border: 2px solid var(--ls-gold);
    transform: translateX(-4px);
}
.about-timeline__item--active .about-timeline__dot {
    background: var(--ls-gold);
    width: 12px; height: 12px;
    top: 4px;
}
.about-timeline__year {
    font-family: var(--ls-font-h);
    font-size: .65rem;
    letter-spacing: 3.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-bottom: .25rem;
}
.about-timeline__event { font-size: .9rem; color: var(--ls-muted); line-height: 1.65; }
.about-timeline__item--active .about-timeline__event { color: var(--ls-text); font-weight: 500; }

/* Stats band */
.about-stats-band {
    background: var(--ls-navy);
    padding: 4rem 0;
    border-top: 3px solid var(--ls-gold);
    border-bottom: 3px solid var(--ls-gold);
}
.about-stats-band__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    text-align: center;
}
.about-stats-band__item {
    padding: 0 2rem;
    border-right: 1px solid rgba(255,255,255,0.07);
}
.about-stats-band__item:last-child { border-right: none; }
.about-stats-band__num {
    font-family: var(--ls-font-h);
    font-size: clamp(2.8rem, 4.5vw, 4rem);
    font-weight: 700;
    color: var(--ls-gold);
    display: block;
    line-height: 1;
    margin-bottom: .6rem;
}
.about-stats-band__num sup { font-size: .45em; vertical-align: super; line-height: 0; }
.about-stats-band__label {
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 3.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.38);
    display: block;
}

/* Mission quote */
.about-mission {
    background: var(--ls-cream);
    padding: 7rem 0;
    text-align: center;
}
.about-mission__inner { max-width: 780px; margin: 0 auto; padding: 0 2rem; }
.about-mission__mark {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 7rem;
    line-height: .7;
    color: var(--ls-gold);
    opacity: .2;
    display: block;
    margin-bottom: -.5rem;
    user-select: none;
}
.about-mission__quote {
    font-family: var(--ls-font-h);
    font-size: clamp(1.3rem, 2.4vw, 2rem);
    font-weight: 300;
    color: var(--ls-navy);
    line-height: 1.55;
    letter-spacing: .2px;
    margin: 0 0 1.5rem;
    border: none;
    padding: 0;
}
.about-mission__quote strong { font-weight: 700; color: var(--ls-navy); }
.about-mission__attr {
    font-family: var(--ls-font-h);
    font-size: .7rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--ls-gold);
}

/* Why-us numbered */
.about-why-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
    margin-top: 3rem;
    background: rgba(255,255,255,0.05);
}
.about-why-card {
    background: var(--ls-navy2);
    padding: 2.5rem;
    position: relative;
    border-top: 3px solid transparent;
    transition: all var(--ls-trans);
    overflow: hidden;
}
.about-why-card:hover { border-top-color: var(--ls-gold); background: var(--ls-navy3); }
.about-why-card__num {
    position: absolute;
    top: -.8rem; right: 1rem;
    font-family: var(--ls-font-h);
    font-size: 5.5rem;
    font-weight: 700;
    color: rgba(196,154,60,0.07);
    line-height: 1;
    user-select: none;
    pointer-events: none;
    letter-spacing: -3px;
}
.about-why-card__icon { font-size: 1.6rem; color: var(--ls-gold); display: block; margin-bottom: .9rem; }
.about-why-card__title {
    font-family: var(--ls-font-h);
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--ls-white);
    margin-bottom: .85rem;
}
.about-why-card__text { font-size: .84rem; color: var(--ls-muted-dk); line-height: 1.78; }

/* Team */
.about-team-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 2.5rem;
    margin-top: .5rem;
}
.about-team-card__photo {
    position: relative;
    overflow: hidden;
    aspect-ratio: 3/4;
    background: var(--ls-navy3);
    margin-bottom: 1.2rem;
}
.about-team-card__photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
.about-team-card:hover .about-team-card__photo img { transform: scale(1.05); }
.about-team-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(13,27,42,.65) 0%, transparent 55%);
    pointer-events: none;
}
.about-team-card__placeholder {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,.12); font-size: 4rem;
}
.about-team-card__info { border-left: 3px solid var(--ls-gold); padding-left: 1rem; }
.about-team-card__name {
    font-family: var(--ls-font-h);
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--ls-text);
    line-height: 1.2;
}
.about-team-card__position {
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin: .3rem 0 .5rem;
}
.about-team-card__bio { font-size: .83rem; color: var(--ls-muted); line-height: 1.65; margin-top: .5rem; }

/* Certificates */
.about-cert-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
    gap: 1.5rem;
    margin-top: .5rem;
}
.about-cert-card {
    background: var(--ls-white);
    border: 1px solid var(--ls-border);
    border-top: 3px solid var(--ls-gold);
    padding: 2rem 1.5rem;
    text-align: center;
    transition: all var(--ls-trans);
}
.about-cert-card:hover { transform: translateY(-4px); box-shadow: var(--ls-shadow-lg); }
.about-cert-card__top { margin-bottom: 1rem; }
.about-cert-card__img { max-height: 58px; width: auto; margin: 0 auto; object-fit: contain; }
.about-cert-card__icon { font-size: 2.4rem; color: var(--ls-gold); }
.about-cert-card__year {
    font-family: var(--ls-font-h);
    font-size: .65rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-bottom: .35rem;
}
.about-cert-card__title {
    font-family: var(--ls-font-h);
    font-size: .95rem;
    font-weight: 700;
    letter-spacing: .3px;
    color: var(--ls-text);
    margin-bottom: .4rem;
    line-height: 1.3;
}
.about-cert-card__desc { font-size: .8rem; color: var(--ls-muted); line-height: 1.6; }

/* ── NEWS ────────────────────────────────────────────────────────────── */

/* Featured (last article) */
.news-featured {
    display: grid;
    grid-template-columns: 1.15fr 1fr;
    background: var(--ls-white);
    border: 1px solid var(--ls-border);
    margin-bottom: 3rem;
    overflow: hidden;
    transition: box-shadow var(--ls-trans), transform var(--ls-trans);
}
.news-featured:hover { box-shadow: var(--ls-shadow-lg); transform: translateY(-4px); }
.news-featured__media { position: relative; overflow: hidden; min-height: 320px; background: var(--ls-navy3); }
.news-featured__img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.news-featured:hover .news-featured__img { transform: scale(1.04); }
.news-featured__placeholder {
    width: 100%; height: 100%; min-height: 320px;
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,0.14); font-size: 3.5rem;
}
.news-featured__tag {
    position: absolute;
    top: 1.2rem; left: 1.2rem;
    background: var(--ls-gold);
    color: var(--ls-navy);
    font-family: var(--ls-font-h);
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    padding: .4rem .9rem;
}
.news-featured__body {
    padding: 2.8rem 2.6rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.news-featured__date {
    display: inline-flex; align-items: center; gap: .5rem;
    font-family: var(--ls-font-h);
    font-size: .7rem; letter-spacing: 2.5px; text-transform: uppercase;
    color: var(--ls-gold); margin-bottom: 1rem;
}
.news-featured__title {
    font-family: var(--ls-font-h);
    font-size: clamp(1.5rem, 2.6vw, 2.1rem);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--ls-text);
    line-height: 1.15;
    margin-bottom: 1rem;
}
.news-featured__summary {
    font-size: .95rem;
    color: var(--ls-muted);
    line-height: 1.8;
    margin-bottom: 1.8rem;
}
.news-featured__link {
    font-family: var(--ls-font-h);
    font-size: .75rem; letter-spacing: 2px; text-transform: uppercase;
    color: var(--ls-navy);
    display: inline-flex; align-items: center; gap: .5rem;
    transition: gap var(--ls-trans), color var(--ls-trans);
}
.news-featured:hover .news-featured__link { color: var(--ls-gold); gap: .8rem; }

.news-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 2rem;
}
.news-card {
    display: block;
    background: var(--ls-white);
    border: 1px solid var(--ls-border);
    overflow: hidden;
    transition: all var(--ls-trans);
}
.news-card:hover {
    border-color: var(--ls-gold);
    box-shadow: var(--ls-shadow-lg);
    transform: translateY(-4px);
}
.news-card__img-wrap { position: relative; overflow: hidden; aspect-ratio: 16/9; }
.news-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.news-card:hover .news-card__img { transform: scale(1.04); }
.news-card__date-badge {
    position: absolute;
    top: 1rem; left: 1rem;
    background: var(--ls-navy);
    color: var(--ls-white);
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
    padding: .5rem .7rem;
    border-bottom: 2px solid var(--ls-gold);
}
.news-card__date-badge strong { font-family: var(--ls-font-h); font-size: 1.2rem; font-weight: 700; }
.news-card__date-badge span {
    font-family: var(--ls-font-h);
    font-size: .58rem; letter-spacing: 1.5px; text-transform: uppercase;
    color: var(--ls-gold); margin-top: 2px;
}
.news-card__img-placeholder {
    width: 100%; aspect-ratio: 16/9;
    background: var(--ls-navy3);
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,0.15); font-size: 2.5rem;
}
.news-card__body { padding: 1.6rem; }
.news-card__date {
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-bottom: .6rem;
}
.news-card__title {
    font-family: var(--ls-font-h);
    font-size: 1.1rem;
    font-weight: 600;
    letter-spacing: .3px;
    color: var(--ls-text);
    margin-bottom: .75rem;
    line-height: 1.3;
}
.news-card__summary {
    font-size: .86rem;
    color: var(--ls-muted);
    line-height: 1.75;
    margin-bottom: 1.1rem;
}
.news-card__link {
    font-family: var(--ls-font-h);
    font-size: .72rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--ls-navy);
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    transition: color var(--ls-trans), gap var(--ls-trans);
}
.news-card:hover .news-card__link { color: var(--ls-gold); gap: .6rem; }

/* News detail — article header */
.news-hero {
    padding-top: var(--ls-nav-h);
    background: var(--ls-navy);
    border-bottom: 3px solid var(--ls-gold);
}
.news-hero .ls-container { padding-top: 2.5rem; padding-bottom: 2.75rem; }
.news-hero__back {
    display: inline-flex; align-items: center; gap: .5rem;
    font-family: var(--ls-font-h);
    font-size: .68rem; letter-spacing: 2.5px; text-transform: uppercase;
    color: rgba(255,255,255,0.55);
    margin-bottom: 1.8rem;
    transition: color var(--ls-trans), gap var(--ls-trans);
}
.news-hero__back:hover { color: var(--ls-gold); gap: .8rem; }
.news-hero__meta {
    display: flex; align-items: center; gap: .7rem; flex-wrap: wrap;
    font-family: var(--ls-font-h);
    font-size: .7rem; letter-spacing: 2px; text-transform: uppercase;
    color: var(--ls-gold);
    margin-bottom: 1rem;
}
.news-hero__meta i { margin-right: .35rem; }
.news-hero__dot { color: rgba(255,255,255,0.3); }
.news-hero__title {
    font-family: var(--ls-font-h);
    font-size: clamp(1.9rem, 4vw, 3.2rem);
    font-weight: 700; color: var(--ls-white);
    text-transform: uppercase; line-height: 1.08;
    max-width: 900px;
}

/* News detail — body */
.news-detail {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 4rem;
    align-items: start;
}
.news-detail__img {
    width: 100%; aspect-ratio: 16/9;
    object-fit: cover; margin-bottom: 2.2rem;
}
.news-detail__lead {
    font-family: var(--ls-font-b);
    font-size: 1.18rem;
    line-height: 1.7;
    color: var(--ls-text);
    font-weight: 500;
    padding-left: 1.2rem;
    border-left: 3px solid var(--ls-gold);
    margin-bottom: 2rem;
}
.news-detail__content { font-size: 1.05rem; line-height: 1.95; color: #33373d; }
.news-detail__content p { margin-bottom: 1.3rem; }
.news-detail__share {
    display: flex; align-items: center; gap: .8rem;
    margin-top: 2.5rem; padding-top: 1.8rem;
    border-top: 1px solid var(--ls-border);
}
.news-detail__share-label {
    font-family: var(--ls-font-h);
    font-size: .68rem; letter-spacing: 2px; text-transform: uppercase;
    color: var(--ls-muted);
}
.news-detail__share a {
    width: 38px; height: 38px;
    display: flex; align-items: center; justify-content: center;
    border: 1px solid var(--ls-border);
    color: var(--ls-navy); font-size: 1rem;
    transition: all var(--ls-trans);
}
.news-detail__share a:hover { background: var(--ls-gold); border-color: var(--ls-gold); color: var(--ls-navy); transform: translateY(-3px); }

/* News detail — sidebar */
.news-detail__sidebar { position: sticky; top: calc(var(--ls-nav-h) + 2rem); display: flex; flex-direction: column; gap: 2rem; }
.news-aside-block .ls-section-label { margin-bottom: 1.4rem; }
.news-related {
    display: flex; gap: 1rem; align-items: flex-start;
    margin-bottom: 1.2rem; padding-bottom: 1.2rem;
    border-bottom: 1px solid var(--ls-border);
}
.news-related:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.news-related:hover .news-related__title { color: var(--ls-gold); }
.news-related__img { width: 74px; height: 56px; object-fit: cover; flex-shrink: 0; }
.news-related__img--ph {
    display: flex; align-items: center; justify-content: center;
    background: var(--ls-navy3); color: rgba(255,255,255,0.18); font-size: 1.2rem;
}
.news-related__date { font-size: .68rem; color: var(--ls-muted); letter-spacing: 1px; margin-bottom: .3rem; }
.news-related__title {
    font-family: var(--ls-font-h);
    font-size: .9rem; color: var(--ls-text);
    line-height: 1.3; transition: color var(--ls-trans);
}
.news-aside-cta {
    background: var(--ls-navy);
    border-top: 3px solid var(--ls-gold);
    padding: 2rem 1.8rem;
    text-align: center;
}
.news-aside-cta__icon { font-size: 2rem; color: var(--ls-gold); display: block; margin-bottom: .8rem; }
.news-aside-cta__title {
    font-family: var(--ls-font-h);
    font-size: 1.1rem; font-weight: 700; letter-spacing: 1px;
    text-transform: uppercase; color: var(--ls-white); margin-bottom: .6rem;
}
.news-aside-cta__text { font-size: .85rem; color: rgba(255,255,255,0.5); line-height: 1.7; margin-bottom: 1.4rem; }
.news-aside-cta__btn { width: 100%; justify-content: center; }

/* ── HOME — АКЦЕНТ НА НОВИНИТЕ ───────────────────────────────────────── */
.news-grid--home .news-card {
    border: 1px solid var(--ls-border);
    border-top: 3px solid var(--ls-gold);
    box-shadow: var(--ls-shadow);
}
.news-grid--home .news-card:hover {
    border-color: var(--ls-gold);
    box-shadow: var(--ls-shadow-lg);
    transform: translateY(-5px);
}

/* ── ОБСЛУЖВАНИ РАЙОНИ (чипове) ──────────────────────────────────────── */
.ls-areas {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .8rem;
}
.ls-areas span {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    font-family: var(--ls-font-h);
    font-size: .82rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--ls-navy);
    background: var(--ls-white);
    border: 1px solid var(--ls-border);
    border-bottom: 3px solid var(--ls-gold);
    padding: .7rem 1.3rem;
}
.ls-areas span i { color: var(--ls-gold); }

/* ── BEFORE / AFTER SLIDER ───────────────────────────────────────────── */
.ba-intro {
    color: var(--ls-muted);
    max-width: 560px;
    margin: -1rem 0 2rem;
    font-size: .95rem;
    line-height: 1.7;
}
.ba-slider {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    user-select: none;
    background: var(--ls-navy3);
    box-shadow: var(--ls-shadow-lg);
    touch-action: pan-y;
}
.ba-slider__img {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    pointer-events: none;
}
.ba-slider__before { clip-path: inset(0 50% 0 0); }
.ba-slider__tag {
    position: absolute;
    top: 1rem;
    z-index: 3;
    font-family: var(--ls-font-h);
    font-size: .62rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    padding: .4rem .9rem;
    color: #fff;
    background: rgba(13,27,42,0.6);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    pointer-events: none;
}
.ba-slider__tag--before { left: 1rem; }
.ba-slider__tag--after  { right: 1rem; }
.ba-slider__handle {
    position: absolute;
    top: 0; bottom: 0;
    left: 50%;
    width: 3px;
    background: var(--ls-gold);
    transform: translateX(-50%);
    z-index: 4;
    pointer-events: none;
}
.ba-slider__knob {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 46px; height: 46px;
    border-radius: 50%;
    background: var(--ls-gold);
    color: var(--ls-navy);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    box-shadow: 0 4px 14px rgba(0,0,0,0.3);
}
.ba-slider__range {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    margin: 0;
    opacity: 0;
    cursor: ew-resize;
    z-index: 5;
}
@media (max-width: 580px) {
    .ba-slider { aspect-ratio: 4/3; }
    .ba-slider__knob { width: 40px; height: 40px; font-size: 1.05rem; }
}

/* ── CONTACT FORM ────────────────────────────────────────────────────── */
.ls-contact-grid {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 5rem;
    align-items: start;
}
.ls-contact-form-card {
    background: var(--ls-white);
    border: 1px solid var(--ls-border);
    border-top: 3px solid var(--ls-gold);
    padding: 2.5rem;
    box-shadow: var(--ls-shadow);
}
.ls-form-group { margin-bottom: 1.4rem; }
.ls-form-label {
    display: block;
    font-family: var(--ls-font-h);
    font-size: .72rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--ls-text);
    margin-bottom: .5rem;
}
.ls-form-control {
    width: 100%;
    padding: .8rem 1rem;
    border: 1.5px solid var(--ls-border);
    background: var(--ls-cream);
    font-family: var(--ls-font-b);
    font-size: .9rem;
    color: var(--ls-text);
    transition: border-color var(--ls-trans), box-shadow var(--ls-trans);
    outline: none;
    appearance: none;
}
.ls-form-control:focus {
    border-color: var(--ls-gold);
    background: var(--ls-white);
    box-shadow: 0 0 0 3px rgba(196,154,60,0.12);
}
.ls-form-control::placeholder { color: #9ca3af; }
textarea.ls-form-control { resize: vertical; min-height: 130px; }
.ls-form-error { font-size: .78rem; color: #e53e3e; margin-top: .35rem; }

.ls-contact-info-card {
    background: var(--ls-navy);
    padding: 2.5rem 2rem;
    color: var(--ls-white);
}
.ls-contact-info-title {
    font-family: var(--ls-font-h);
    font-size: 1.1rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-bottom: 1.6rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--ls-border-dk);
}
.ls-contact-info-list { list-style: none; }
.ls-contact-info-list li {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: 1.2rem;
    font-size: .9rem;
    color: rgba(255,255,255,0.65);
}
.ls-contact-info-list i { color: var(--ls-gold); margin-top: 2px; flex-shrink: 0; font-size: 1rem; }
.ls-contact-info-list a { color: inherit; transition: color var(--ls-trans); }
.ls-contact-info-list a:hover { color: var(--ls-gold); }
.ls-contact-info-list strong { color: var(--ls-white); font-weight: 600; font-size: .75rem; letter-spacing: 1px; text-transform: uppercase; display: block; margin-bottom: 2px; font-family: var(--ls-font-h); }

/* ── ADMIN UTILITIES ─────────────────────────────────────────────────── */
.ls-admin-wrap { padding-top: calc(var(--ls-nav-h) + 1rem); }

/* ── AUTH / LOGIN ────────────────────────────────────────────────────── */
.auth-section {
    min-height: 100vh;
    padding: calc(var(--ls-nav-h) + 3rem) 1.25rem 4rem;
    background: var(--ls-navy);
    display: flex;
    align-items: center;
    justify-content: center;
}
.auth-card {
    width: 100%;
    max-width: 440px;
    background: var(--ls-white);
    border-top: 4px solid var(--ls-gold);
    padding: 2.75rem 2.5rem 2.5rem;
    box-shadow: var(--ls-shadow-lg);
    text-align: center;
}
.auth-card__head { margin-bottom: 2rem; }
.auth-card__logo {
    display: inline-block;
    width: 76px; height: 76px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--ls-navy);
    margin-bottom: 1rem;
}
.auth-card__logo img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.10); }
.auth-card__title {
    font-family: var(--ls-font-h);
    font-size: 1.5rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--ls-text);
}
.auth-card__sub {
    font-family: var(--ls-font-h);
    font-size: .62rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--ls-gold);
    margin-top: .4rem;
}
.auth-form { text-align: left; }
.auth-form__summary {
    color: #e53e3e;
    font-size: .85rem;
    background: rgba(229,62,62,0.08);
    border-left: 3px solid #e53e3e;
    padding: .7rem .9rem;
    margin-bottom: 1.2rem;
}
.auth-form__summary:empty { display: none; }
.auth-form__summary ul { margin: 0; padding-left: 1rem; list-style: none; }
.auth-remember {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .85rem;
    color: var(--ls-muted);
    margin: .3rem 0 1.6rem;
    cursor: pointer;
}
.auth-remember input { width: 16px; height: 16px; accent-color: var(--ls-gold); cursor: pointer; }
.auth-submit { width: 100%; justify-content: center; }
.auth-back {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    margin-top: 1.6rem;
    font-family: var(--ls-font-h);
    font-size: .7rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--ls-muted);
    transition: color var(--ls-trans), gap var(--ls-trans);
}
.auth-back:hover { color: var(--ls-gold); gap: .7rem; }
@media (max-width: 480px) {
    .auth-card { padding: 2rem 1.4rem; }
    .auth-section { padding: calc(var(--ls-nav-h) + 1.5rem) 1rem 2.5rem; }
}

/* Logout бутон в navbar */
.ls-logout-form { display: flex; align-items: center; }
.ls-logout-btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-family: var(--ls-font-h);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.72);
    background: none;
    border: 1px solid rgba(255,255,255,0.22);
    padding: .55rem .95rem;
    cursor: pointer;
    transition: all var(--ls-trans);
    white-space: nowrap;
}
.ls-logout-btn:hover {
    color: var(--ls-navy);
    background: var(--ls-gold);
    border-color: var(--ls-gold);
}

/* ── COOKIE CONSENT ──────────────────────────────────────────────────── */
.ls-cookie {
    position: fixed;
    bottom: 1rem; left: 1rem; right: 1rem;
    max-width: 920px;
    margin: 0 auto;
    z-index: 1400;
    background: var(--ls-navy2);
    border: 1px solid rgba(196,154,60,0.3);
    border-top: 3px solid var(--ls-gold);
    padding: 1.2rem 1.5rem;
    display: flex;
    align-items: center;
    gap: 1.5rem;
    flex-wrap: wrap;
    box-shadow: 0 10px 40px rgba(0,0,0,0.45);
}
.ls-cookie[hidden] { display: none; }
.ls-cookie__text { flex: 1 1 320px; color: rgba(255,255,255,0.75); font-size: .85rem; line-height: 1.6; }
.ls-cookie__text a { color: var(--ls-gold); text-decoration: underline; }
.ls-cookie__actions { display: flex; gap: .7rem; }
.ls-cookie__btn {
    font-family: var(--ls-font-h);
    font-size: .72rem; letter-spacing: 1.5px; text-transform: uppercase;
    padding: .6rem 1.3rem; cursor: pointer;
    border: 1px solid; transition: all var(--ls-trans);
}
.ls-cookie__btn--accept { background: var(--ls-gold); border-color: var(--ls-gold); color: var(--ls-navy); }
.ls-cookie__btn--accept:hover { background: var(--ls-gold2); border-color: var(--ls-gold2); }
.ls-cookie__btn--decline { background: transparent; border-color: rgba(255,255,255,0.3); color: rgba(255,255,255,0.7); }
.ls-cookie__btn--decline:hover { border-color: #fff; color: #fff; }
@media (max-width: 560px) {
    .ls-cookie { flex-direction: column; align-items: stretch; text-align: center; }
    .ls-cookie__actions { justify-content: center; }
}

/* ── PROSE (текстови страници: поверителност и др.) ──────────────────── */
.ls-prose { max-width: 800px; }
.ls-prose h2 {
    font-family: var(--ls-font-h);
    font-size: 1.3rem; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
    color: var(--ls-navy); margin: 2.2rem 0 .9rem;
}
.ls-prose h2:first-child { margin-top: 0; }
.ls-prose p, .ls-prose li { color: var(--ls-muted); line-height: 1.9; font-size: .98rem; }
.ls-prose p { margin-bottom: 1rem; }
.ls-prose ul { padding-left: 1.3rem; margin-bottom: 1rem; }
.ls-prose li { margin-bottom: .5rem; }
.ls-prose a { color: var(--ls-navy); text-decoration: underline; }
.ls-prose strong { color: var(--ls-text); }

/* ── SCROLL-REVEAL ───────────────────────────────────────────────────── */
.js-anim main .ls-container,
.js-anim main .ls-carousel {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 0.7s ease, transform 0.7s ease;
}
.js-anim main .ls-container.is-visible,
.js-anim main .ls-carousel.is-visible {
    opacity: 1;
    transform: none;
}

/* ── RESPONSIVE ──────────────────────────────────────────────────────── */

/* ≤ 1100px — малки лаптопи / таблети landscape */
@media (max-width: 1100px) {
    .ls-footer__inner     { grid-template-columns: 1fr 1fr; gap: 2.5rem 3rem; }
    .ls-footer__brand     { grid-column: 1 / -1; max-width: none; }
    .about-split          { grid-template-columns: 1fr; gap: 3rem; }
    .about-story-media    { aspect-ratio: 16/10; max-height: 420px; }
    .about-values-grid    { grid-template-columns: 1fr 1fr; }
    .about-why-grid       { grid-template-columns: 1fr 1fr; }
    .about-stats-band__grid { grid-template-columns: 1fr 1fr; }
    .news-detail          { grid-template-columns: 1fr; }
    .ls-contact-grid      { grid-template-columns: 1fr; gap: 3rem; }
    .ls-process-grid      { grid-template-columns: 1fr 1fr; }
    .ls-process-step:nth-child(-n+2) { border-bottom: 1px solid var(--ls-border-dk); }
    .ls-process-step:nth-child(2n)   { border-right: none; }
    .ls-project-body      { grid-template-columns: 1fr; }
    .ls-project-meta-card { position: static; }
    .ls-nav__inner        { padding: 0 1.75rem; }
    .ls-nav__link         { padding: 0 1rem; letter-spacing: 2px; }
}

/* ≤ 900px — таблети portrait */
@media (max-width: 900px) {
    .ls-nav__links  { display: none; }
    .ls-nav__cta    { display: none; }
    .ls-nav__burger { display: flex; }
    .ls-nav__mobile { display: block; }
    .ls-container   { padding: 0 1.75rem; }
}

/* ≤ 768px — големи телефони */
@media (max-width: 768px) {
    :root { --ls-nav-h: 70px; }
    .ls-nav--scrolled .ls-nav__inner { height: 60px; }
    .ls-logo__mark { width: 56px; height: 56px; }
    .ls-nav--scrolled .ls-logo__mark { width: 48px; height: 48px; }

    .ls-section        { padding: 4rem 0; }
    .ls-container      { padding: 0 1.25rem; }

    .hero-section { display: block; min-height: 0; height: auto; padding: calc(var(--ls-nav-h) + 3rem) 0 0; }
    .hero-content { padding: 0 1.25rem; }
    .hero-stats   { position: static; flex-wrap: wrap; margin-top: 3rem; backdrop-filter: none; background: rgba(13,27,42,0.55); }
    .hero-stat    { flex: 1 0 50%; border-bottom: 1px solid var(--ls-border-dk); }
    .hero-stat:nth-child(2n) { border-right: none; }
    .hero-scroll  { display: none; }

    .ls-footer__inner  { grid-template-columns: 1fr 1fr; gap: 2.5rem; padding: 3.5rem 1.5rem 2.5rem; }
    .ls-footer__bottom { flex-direction: column; align-items: flex-start; gap: .6rem; text-align: left; padding: 1.4rem 1.5rem; }

    .ls-projects-grid  { grid-template-columns: 1fr; }
    .ls-process-grid   { grid-template-columns: 1fr; }
    .ls-process-step   { border-right: none; border-bottom: 1px solid var(--ls-border-dk); }
    .ls-process-step:last-child { border-bottom: none; }
    .ls-services-grid  { grid-template-columns: 1fr; }
    .news-grid         { grid-template-columns: 1fr; }
    .news-featured     { grid-template-columns: 1fr; }
    .news-featured__media { min-height: 220px; aspect-ratio: 16/9; }
    .news-featured__placeholder { min-height: 220px; }
    .news-featured__body  { padding: 2rem 1.6rem; }

    .ls-carousel       { aspect-ratio: auto; min-height: 320px; height: 68vw; max-height: 460px; }
    .ls-carousel__overlay { padding: 1.75rem 1.5rem 2.75rem;
        background: linear-gradient(to top, rgba(13,27,42,0.9) 0%, rgba(13,27,42,0.3) 60%, rgba(13,27,42,0.05) 100%); }
    .ls-carousel__prev,
    .ls-carousel__next { width: 38px; height: 38px; font-size: .95rem; }
    .ls-carousel__prev { left: .6rem; }
    .ls-carousel__next { right: .6rem; }
    .ls-carousel__dots { bottom: 1rem; right: 1.25rem; }
    .ls-carousel__title { font-size: clamp(1.3rem, 6vw, 1.8rem); }

    .about-founder        { padding: 3.5rem 0; }
    .about-founder__inner { grid-template-columns: 1fr; gap: .25rem; text-align: center; max-width: 560px; }
    .about-founder__media { justify-content: center; }
    .about-founder__mark  { font-size: 6rem; height: 70px; }
    .about-founder__quote { font-size: 1.15rem; margin: .4rem 0 1.2rem; }
    .about-founder__attr  { align-items: center; }

    /* Page header giant + филтри */
    .ls-page-header__giant { font-size: clamp(3rem, 12vw, 5rem); letter-spacing: 1px; }
    .ls-filter-wrap { gap: .6rem; margin-top: 1.6rem; }
    .ls-filter-btn  { padding: .5rem 1.05rem; font-size: .66rem; letter-spacing: 2px; }
}

/* ≤ 560px — телефони */
@media (max-width: 560px) {
    .ls-section          { padding: 3.25rem 0; }
    .ls-page-header__inner { padding-top: 3rem; padding-bottom: 2.25rem; }
    .ls-page-header--brutal .ls-page-header__inner { padding-top: 2.75rem; padding-bottom: 2.25rem; }
    .ls-page-header__giant { font-size: clamp(2.2rem, 13vw, 3rem); letter-spacing: .5px; }
    .ls-filter-wrap { gap: .5rem; margin-top: 1.4rem; }
    .ls-filter-btn  { padding: .48rem .85rem; font-size: .6rem; letter-spacing: 1.5px; border-width: 1px; }

    .ls-footer__inner    { grid-template-columns: 1fr; gap: 2.25rem; text-align: left; padding: 3rem 1.5rem 2.5rem; }
    .ls-footer__brand    { text-align: left; max-width: none; }
    .ls-footer__logo     { justify-content: flex-start; }
    .ls-footer__social   { justify-content: flex-start; }
    .ls-footer__contact li { justify-content: flex-start; }
    .ls-footer__list a   { justify-content: flex-start; }
    .ls-footer__bottom-links { justify-content: flex-start; }

    .ls-process-grid     { grid-template-columns: 1fr; }
    .ls-testi-grid       { grid-template-columns: 1fr; }
    .about-why-grid      { grid-template-columns: 1fr; }
    .about-values-grid   { grid-template-columns: 1fr; }
    .about-stats-band__grid { grid-template-columns: 1fr 1fr; }
    .about-stats-band__item { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.07); padding: 1.5rem 0; }
    .about-stats-band__item:nth-child(2n) { border-right: none; }
    .about-stats-band__item:last-child { border-bottom: none; }

    .hero-actions        { flex-direction: column; width: 100%; }
    .hero-actions .ls-btn { width: 100%; justify-content: center; }
    .ls-cta__title       { font-size: clamp(1.8rem, 8vw, 2.6rem); }

    .ls-btn              { padding: .8rem 1.5rem; font-size: .72rem; }
    .ls-fab              { right: 1rem; bottom: 1rem; gap: .55rem; }
    .ls-fab__btn         { width: 46px; height: 46px; font-size: 1.2rem; }
}

/* ≤ 400px — малки телефони */
@media (max-width: 400px) {
    .ls-container        { padding: 0 1rem; }
    .hero-stat           { flex: 1 0 100%; border-right: none; }
    .about-stats-band__grid { grid-template-columns: 1fr; }
    .ls-nav__inner       { padding: 0 1rem; }
}

/* ── UTILITY / COMPONENT EXTRAS ──────────────────────────────────────── */
.ls-back-link {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    font-family: var(--ls-font-h);
    font-size: .68rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--ls-muted);
    margin-bottom: 2rem;
    transition: color 0.2s ease, gap 0.2s ease;
}
.ls-back-link:hover { color: var(--ls-gold); gap: .7rem; }

.ls-empty {
    text-align: center;
    padding: 4rem 0;
    color: var(--ls-muted);
}
.ls-empty i {
    font-size: 3rem;
    display: block;
    margin-bottom: 1rem;
    color: var(--ls-gold);
    opacity: .35;
}

.ls-carousel-footer {
    background: var(--ls-cream);
    padding: 2rem 0;
    text-align: center;
}

.ls-project-hero__loc {
    color: rgba(255,255,255,.55);
    font-size: .72rem;
    letter-spacing: 1.5px;
    font-family: var(--ls-font-b);
}
.ls-project-hero--empty {
    padding-top: var(--ls-nav-h);
    height: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.1);
    font-size: 5rem;
    cursor: default;
}
.ls-project-body__badge   { margin-bottom: 1rem; }
.ls-project-body__actions { margin-top: 3rem; }

.ls-project-meta-card__heading {
    font-family: var(--ls-font-h);
    font-size: .65rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--ls-gold);
    padding-bottom: 1.2rem;
    margin-bottom: .5rem;
    border-bottom: 1px solid var(--ls-border-dk);
}
.ls-project-meta-card__cta { margin-top: 2rem; }
.ls-project-meta-card__cta .ls-btn {
    width: 100%;
    justify-content: center;
    font-size: .75rem;
}

/* ── ACCESSIBILITY: reduced motion ───────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    .hero-video { display: none; } /* статичен navy фон вместо видео */
    .ls-carousel__slide--active .ls-carousel__slide-img { transform: none; }
    .ls-project-hero:hover .ls-project-hero__img { transform: none; }
    .ls-fab__btn { animation: none !important; }
}

/* ═══ TRUST BAR (лицензи / сертификати) ══════════════════════════════ */
.ls-trust {
    background: var(--ls-cream);
    border-bottom: 1px solid var(--ls-border);
    padding: 1.6rem 0;
}
.ls-trust__inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1.5rem 2rem;
}
.ls-trust__item {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex: 1 1 auto;
}
.ls-trust__item i {
    font-size: 1.6rem;
    color: var(--ls-gold);
    flex-shrink: 0;
}
.ls-trust__item strong {
    display: block;
    font-family: var(--ls-font-h);
    font-size: .82rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--ls-text);
    line-height: 1.2;
}
.ls-trust__item span {
    font-size: .72rem;
    color: var(--ls-muted);
}

/* ═══ TESTIMONIALS (отзиви) ══════════════════════════════════════════ */
.ls-testi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}
.ls-testi {
    background: var(--ls-navy2);
    border: 1px solid var(--ls-border-dk);
    border-top: 3px solid var(--ls-gold);
    padding: 2rem 1.8rem;
    margin: 0;
    display: flex;
    flex-direction: column;
    transition: transform var(--ls-trans), box-shadow var(--ls-trans);
}
.ls-testi:hover { transform: translateY(-4px); box-shadow: var(--ls-shadow-lg); }
.ls-testi__stars { color: var(--ls-gold); font-size: .8rem; letter-spacing: 2px; margin-bottom: 1rem; }
.ls-testi__stars .bi-star { color: rgba(255,255,255,0.25); }
.ls-testi__quote {
    font-size: .95rem;
    line-height: 1.75;
    color: rgba(255,255,255,0.82);
    font-style: italic;
    margin: 0 0 1.5rem;
    flex-grow: 1;
}
.ls-testi__author { display: flex; align-items: center; gap: .8rem; }
.ls-testi__photo,
.ls-testi__avatar {
    width: 44px; height: 44px;
    border-radius: 50%;
    flex-shrink: 0;
    object-fit: cover;
    border: 2px solid var(--ls-gold);
}
.ls-testi__avatar {
    display: flex; align-items: center; justify-content: center;
    background: var(--ls-gold);
    color: var(--ls-navy);
    font-family: var(--ls-font-h);
    font-weight: 700;
    font-size: 1.1rem;
}
.ls-testi__author strong {
    display: block;
    font-family: var(--ls-font-h);
    font-size: .9rem;
    letter-spacing: .5px;
    color: var(--ls-white);
}
.ls-testi__author small { color: var(--ls-gold); font-size: .72rem; letter-spacing: 1px; }

/* ═══ FAQ (акордеон) ═════════════════════════════════════════════════ */
.ls-faq { max-width: 860px; }
.ls-faq__item {
    border: 1px solid var(--ls-border);
    border-left: 3px solid var(--ls-gold);
    margin-bottom: .8rem;
    background: var(--ls-white);
}
.ls-faq__q {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    cursor: pointer;
    list-style: none;
    padding: 1.2rem 1.5rem;
    font-family: var(--ls-font-h);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: .3px;
    color: var(--ls-text);
}
.ls-faq__q::-webkit-details-marker { display: none; }
.ls-faq__q i { color: var(--ls-gold); transition: transform var(--ls-trans); flex-shrink: 0; }
.ls-faq__item[open] .ls-faq__q i { transform: rotate(45deg); }
.ls-faq__a {
    padding: 0 1.5rem 1.4rem;
    color: var(--ls-muted);
    line-height: 1.8;
    font-size: .92rem;
}

/* ═══ CONTACT — оферта-форма ред ═════════════════════════════════════ */
.ls-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.ls-form-opt { font-size: .62rem; opacity: .55; letter-spacing: 0; text-transform: none; }
select.ls-form-control { cursor: pointer; }

/* ═══ ПЛАВАЩИ БЪРЗИ КОНТАКТИ (Viber / WhatsApp / звънене) ═════════════ */
.ls-fab {
    position: fixed;
    right: 1.4rem;
    bottom: 1.4rem;
    z-index: 1200;
    display: flex;
    flex-direction: column;
    gap: .7rem;
}
.ls-fab__btn {
    position: relative;
    width: 52px; height: 52px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.4rem;
    box-shadow: 0 6px 18px rgba(0,0,0,0.3);
    transition: transform 0.18s ease;
}
.ls-fab__btn:hover { transform: scale(1.1); color: #fff; }
.ls-fab__btn--viber { background: #7360f2; }
.ls-fab__btn--wa    { background: #25d366; }
.ls-fab__btn--call  { background: var(--ls-gold); color: var(--ls-navy); animation: fabPulse 2.4s infinite; }
.ls-fab__btn--call:hover { color: var(--ls-navy); }
.ls-fab__tip {
    position: absolute;
    right: calc(100% + 12px);
    top: 50%;
    transform: translateY(-50%);
    background: var(--ls-navy);
    color: #fff;
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding: .35rem .7rem;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.18s ease;
}
.ls-fab__btn:hover .ls-fab__tip { opacity: 1; }
@keyframes fabPulse {
    0%   { box-shadow: 0 6px 18px rgba(0,0,0,0.3), 0 0 0 0 rgba(196,154,60,0.5); }
    70%  { box-shadow: 0 6px 18px rgba(0,0,0,0.3), 0 0 0 14px rgba(196,154,60,0); }
    100% { box-shadow: 0 6px 18px rgba(0,0,0,0.3), 0 0 0 0 rgba(196,154,60,0); }
}

@media (max-width: 980px) {
    .ls-trust__inner { gap: 1.2rem; }
    .ls-trust__item { flex: 1 1 40%; }
}
@media (max-width: 768px) {
    .ls-form-row { grid-template-columns: 1fr; gap: 0; }
    .ls-fab__btn { width: 48px; height: 48px; font-size: 1.25rem; }
    .ls-trust__item { flex: 1 1 100%; }
}

/* ═══ PROJECT DETAIL — REDESIGN ═══════════════════════════════════════ */

/* Hero */
.pd-hero-wrap { position: relative; }
.pd-hero {
    position: relative;
    width: 100%;
    height: 78vh;
    min-height: 520px;
    max-height: 860px;
    overflow: hidden;
    background: var(--ls-navy3);
    cursor: zoom-in;
}
.pd-hero--empty {
    height: 46vh;
    min-height: 320px;
    cursor: default;
    display: flex;
    align-items: center;
    justify-content: center;
}
.pd-hero__img {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 8s ease;
}
.pd-hero:hover .pd-hero__img { transform: scale(1.04); }
.pd-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(13,27,42,.96) 0%,
        rgba(13,27,42,.35) 55%,
        rgba(13,27,42,.08) 100%
    );
    z-index: 1;
}
.pd-hero__top {
    position: absolute;
    top: calc(var(--ls-nav-h) + 1.5rem);
    left: 3rem;
    z-index: 3;
}
.pd-back-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-family: var(--ls-font-h);
    font-size: .65rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,.65);
    background: rgba(13,27,42,.45);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    padding: .5rem 1.1rem;
    border: 1px solid rgba(255,255,255,.12);
    transition: color .2s, border-color .2s, background .2s;
}
.pd-back-btn:hover {
    color: var(--ls-gold);
    border-color: var(--ls-gold);
    background: rgba(13,27,42,.65);
}
.pd-hero__bottom {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    z-index: 3;
    padding: 0 3rem 2.8rem;
}
.pd-hero__cat { margin-bottom: .9rem; display: inline-block; }
.pd-hero__title {
    font-family: var(--ls-font-h);
    font-size: clamp(2rem, 5vw, 4.2rem);
    font-weight: 700;
    text-transform: uppercase;
    color: #fff;
    line-height: 1;
    margin: 0 0 .65rem;
    max-width: 800px;
}
.pd-hero__loc {
    font-family: var(--ls-font-h);
    font-size: .7rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,.5);
    display: flex;
    align-items: center;
    gap: .45rem;
}
.pd-hero__loc-sep { opacity: .35; }
.pd-hero__zoom-btn {
    position: absolute;
    bottom: 2.8rem; right: 3rem;
    background: transparent;
    border: 1px solid rgba(255,255,255,.18);
    color: rgba(255,255,255,.4);
    font-family: var(--ls-font-h);
    font-size: .62rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: .5rem 1rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    transition: color .2s, border-color .2s;
}
.pd-hero__zoom-btn:hover { color: var(--ls-gold); border-color: var(--ls-gold); }

/* Specs band */
.pd-specs-band {
    background: var(--ls-navy);
    border-bottom: 1px solid var(--ls-border-dk);
}
.pd-specs-band__grid {
    display: flex;
    flex-wrap: wrap;
}
.pd-specs-band__item {
    flex: 1;
    min-width: 140px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 1.5rem 1.2rem;
    gap: .25rem;
    border-right: 1px solid var(--ls-border-dk);
}
.pd-specs-band__item:last-child { border-right: none; }
.pd-specs-band__icon {
    font-size: 1.25rem;
    color: var(--ls-gold);
    margin-bottom: .15rem;
}
.pd-specs-band__label {
    font-family: var(--ls-font-h);
    font-size: .58rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: rgba(255,255,255,.32);
}
.pd-specs-band__val {
    font-size: .92rem;
    font-weight: 600;
    color: #fff;
}

/* Body layout */
.pd-body {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 5rem;
    align-items: start;
}
.pd-body__heading {
    font-family: var(--ls-font-h);
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--ls-text);
    line-height: 1.05;
    margin-bottom: .5rem;
}
.pd-body__desc {
    font-size: 1.05rem;
    color: var(--ls-muted);
    line-height: 2;
    margin-top: 1.5rem;
}
.pd-body__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 3rem;
}

/* Scope */
.pd-scope { margin-top: 2.5rem; }
.pd-scope__label {
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--ls-text);
    margin-bottom: 1.2rem;
    padding-bottom: .7rem;
    border-bottom: 2px solid var(--ls-gold);
    display: inline-block;
}
.pd-scope-list {
    list-style: none;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
}
.pd-scope-list li {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: .9rem;
    color: var(--ls-muted);
}
.pd-scope-list li .bi {
    color: var(--ls-gold);
    font-size: 1rem;
    flex-shrink: 0;
}

/* Sidebar */
.pd-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    position: sticky;
    top: calc(var(--ls-nav-h) + 2rem);
}

/* Info card */
.pd-info-card { background: var(--ls-navy); overflow: hidden; }
.pd-info-card__header {
    background: var(--ls-gold);
    padding: 1.1rem 1.6rem;
    display: flex;
    align-items: center;
    gap: .65rem;
    font-family: var(--ls-font-h);
    font-size: .68rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--ls-navy);
    font-weight: 700;
}
.pd-info-card__header i { font-size: 1.1rem; }
.pd-info-card__body { padding: .3rem 1.6rem; }
.pd-info-card__row {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    padding: .9rem 0;
    border-bottom: 1px solid var(--ls-border-dk);
}
.pd-info-card__row:last-child { border-bottom: none; }
.pd-info-card__lbl {
    font-family: var(--ls-font-h);
    font-size: .58rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--ls-gold);
    display: flex;
    align-items: center;
    gap: .35rem;
}
.pd-info-card__val {
    font-size: .9rem;
    color: rgba(255,255,255,.75);
}
.pd-info-card__footer {
    padding: 1.4rem 1.6rem;
    border-top: 1px solid var(--ls-border-dk);
}
.pd-info-card__cta-btn { width: 100%; justify-content: center; }

/* Trust strip */
.pd-trust-strip {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    background: var(--ls-cream);
    border-top: 3px solid var(--ls-gold);
}
.pd-trust-strip__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1.1rem .6rem;
    border-right: 1px solid rgba(13,27,42,.08);
    text-align: center;
}
.pd-trust-strip__item:last-child { border-right: none; }
.pd-trust-strip__num {
    font-family: var(--ls-font-h);
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--ls-navy);
    line-height: 1;
}
.pd-trust-strip__num sup { font-size: .65em; }
.pd-trust-strip__lbl {
    font-size: .58rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(13,27,42,.45);
    margin-top: .3rem;
}

/* Phases */
.pd-phases-grid {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 1.5rem;
    margin-top: 3rem;
}
.pd-phase {
    padding: 2rem 1.6rem;
    background: rgba(255,255,255,.02);
    border: 1px solid var(--ls-border-dk);
    transition: border-color .2s, background .2s;
}
.pd-phase:hover {
    border-color: var(--ls-gold);
    background: rgba(196,154,60,.04);
}
.pd-phase__num {
    font-family: var(--ls-font-h);
    font-size: 3.2rem;
    font-weight: 700;
    color: rgba(196,154,60,.1);
    line-height: 1;
    margin-bottom: .4rem;
}
.pd-phase__icon {
    font-size: 1.8rem;
    color: var(--ls-gold);
    display: block;
    margin-bottom: 1rem;
}
.pd-phase__title {
    font-family: var(--ls-font-h);
    font-size: .85rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: #fff;
    margin-bottom: .6rem;
}
.pd-phase__text {
    font-size: .82rem;
    color: rgba(255,255,255,.42);
    line-height: 1.75;
}

/* CTA buttons row */
.pd-cta-btns {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

/* Gallery */
.pd-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1rem;
}
.pd-gallery__item {
    position: relative;
    display: block;
    padding: 0;
    border: none;
    cursor: pointer;
    overflow: hidden;
    aspect-ratio: 4/3;
    background: var(--ls-navy3);
}
.pd-gallery__item img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.pd-gallery__item:hover img { transform: scale(1.06); }
.pd-gallery__zoom {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.6rem;
    background: rgba(13,27,42,0.45);
    opacity: 0;
    transition: opacity .25s ease;
}
.pd-gallery__item:hover .pd-gallery__zoom { opacity: 1; }

/* Lightbox nav */
.ls-lightbox__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 52px; height: 52px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.2);
    color: #fff;
    font-size: 1.5rem;
    cursor: pointer;
    z-index: 11;
    transition: background var(--ls-trans), border-color var(--ls-trans);
}
.ls-lightbox__nav:hover { background: var(--ls-gold); border-color: var(--ls-gold); color: var(--ls-navy); }
.ls-lightbox__nav--prev { left: 2rem; }
.ls-lightbox__nav--next { right: 2rem; }

/* Responsive */
@media (max-width: 960px) {
    .pd-body          { grid-template-columns: 1fr; gap: 2.5rem; }
    .pd-sidebar       { position: static; }
    .pd-phases-grid   { grid-template-columns: repeat(2,1fr); }
    .pd-hero__top     { left: 1.5rem; }
    .pd-hero__bottom  { padding: 0 1.5rem 2.2rem; }
    /* бутонът минава в потока под заглавието — без припокриване */
    .pd-hero__zoom-btn {
        position: static;
        margin-top: 1.1rem;
        bottom: auto; right: auto;
        align-self: flex-start;
    }
}
@media (max-width: 580px) {
    .pd-hero          { height: auto; min-height: 70vh; }
    .pd-hero__bottom  { position: relative; padding: 45vh 1.25rem 2.2rem; }
    .pd-hero__title   { font-size: clamp(1.7rem, 7vw, 2.4rem); }
    .pd-phases-grid   { grid-template-columns: 1fr; }
    .pd-scope-list    { grid-template-columns: 1fr; }
    .pd-specs-band__grid { flex-direction: column; }
    .pd-specs-band__item { border-right: none; border-bottom: 1px solid var(--ls-border-dk); }
    .pd-specs-band__item:last-child { border-bottom: none; }
    .pd-gallery       { grid-template-columns: 1fr 1fr; gap: .6rem; }
    .ls-lightbox__nav { width: 42px; height: 42px; font-size: 1.2rem; }
    .ls-lightbox__nav--prev { left: .6rem; }
    .ls-lightbox__nav--next { right: .6rem; }
}
