/* ahmetenes.tr — portfolyo bileşenleri (Avlu Base üzerine) */

/* ── Animasyonlar ── */

@keyframes heroIn {
    from { transform: translate3d(0, 20px, 0); }
    to { transform: translate3d(0, 0, 0); }
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translate3d(0, 24px, 0); }
    to { opacity: 1; transform: translate3d(0, 0, 0); }
}

.reveal {
    opacity: 0;
    transform: translate3d(0, 32px, 0);
    transition: opacity 0.6s ease, transform 0.7s ease;
}

.reveal.revealed,
.fade-in {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
}

.animate-hero-title {
    opacity: 1;
    animation: heroIn 0.85s ease 0.1s both;
}

.animate-hero-tagline {
    opacity: 1;
    animation: heroIn 0.8s ease 0.25s both;
}

.animate-hero-links {
    opacity: 1;
    animation: heroIn 0.9s ease 0.4s both;
}

/* ── Navbar ── */

.navbar {
    position: fixed;
    inset: 0 0 auto;
    z-index: 1030;
    padding: 1rem 0;
    transition: background 0.3s ease, backdrop-filter 0.3s ease, border-color 0.3s ease;
}

.nav-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.logo {
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--cream);
    text-decoration: none;
    transition: color 0.2s ease, transform 0.2s ease;
}

.logo:hover {
    color: var(--violet);
    transform: translateY(-1px);
}

.nav-menu {
    display: none;
    list-style: none;
    gap: 1.5rem;
    align-items: center;
}

.nav-link {
    font-family: "DM Mono", monospace;
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--cream-dim);
    text-decoration: none;
    padding: 0.25rem 0;
    position: relative;
    transition: color 0.2s ease;
}

.nav-link::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--violet), var(--mint));
    border-radius: 2px;
    transition: width 0.25s ease;
}

.nav-link:hover,
.nav-link:focus,
.nav-link.active {
    color: var(--cream);
}

.nav-link:hover::after,
.nav-link:focus::after,
.nav-link.active::after {
    width: 100%;
}

.nav-right {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.navbar.scrolled {
    background: rgba(12, 11, 16, 0.88);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(243, 235, 224, 0.08);
}

.hamburger {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    background: transparent;
    border: none;
    padding: 0.35rem;
    cursor: pointer;
}

.hamburger span {
    display: block;
    width: 1.5rem;
    height: 2px;
    background: var(--cream);
    border-radius: 2px;
    transition: transform 0.25s ease, opacity 0.25s ease;
}

.hamburger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (min-width: 768px) {
    .nav-menu { display: flex; }
    .hamburger { display: none; }
}

@media (max-width: 767px) {
    .nav-menu {
        position: fixed;
        top: 0;
        right: -100%;
        width: min(18rem, 78vw);
        height: 100vh;
        height: 100dvh;
        flex-direction: column;
        align-items: flex-start;
        gap: 1.5rem;
        padding: calc(var(--nav-height) + 1.5rem) 1.5rem 2rem;
        background: rgba(12, 11, 16, 0.96);
        backdrop-filter: blur(20px);
        border-left: 1px solid rgba(243, 235, 224, 0.08);
        transition: right 0.3s ease;
    }

    .nav-menu.active {
        right: 0;
        display: flex;
    }

    .navbar:not(.scrolled) {
        background: rgba(12, 11, 16, 0.75);
        backdrop-filter: blur(16px);
    }
}

/* ── Hero ── */

.hero {
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
    padding: calc(var(--nav-height) + 1.5rem) 1rem calc(2.5rem + env(safe-area-inset-bottom, 0px));
}

.hero-content {
    position: relative;
    z-index: 2;
    width: min(72rem, 100%);
    padding-inline: 1rem;
}

.hero-title {
    font-size: clamp(2rem, 7vw, 3.25rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.1;
    margin-bottom: 1rem;
    background: linear-gradient(135deg, var(--cream) 25%, var(--violet));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-wrap: balance;
}

.tagline {
    font-family: "DM Mono", monospace;
    font-size: clamp(0.72rem, 2vw, 0.82rem);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--cream-dim);
    margin-bottom: 2rem;
}

/* ── Hero hub ── */

.hero-links {
    margin-top: 1.75rem;
    width: 100%;
}

.hero-hub {
    display: grid;
    gap: 1rem;
    max-width: 56rem;
    margin-inline: auto;
    text-align: left;
}

@media (min-width: 900px) {
    .hero-hub {
        grid-template-columns: repeat(3, 1fr);
        align-items: start;
    }
}

.hub-section {
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.08);
    border-radius: var(--radius-md);
    padding: 1.1rem 0.95rem 1.15rem;
    backdrop-filter: blur(12px);
}

.hub-section__title {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--cream-dim);
    margin-bottom: 0.85rem;
}

.hub-section__title::before {
    content: "";
    width: 0.22rem;
    height: 0.95rem;
    border-radius: 2px;
    flex-shrink: 0;
}

.hub-section--violet .hub-section__title::before { background: var(--violet); }
.hub-section--mint .hub-section__title::before { background: var(--mint); }
.hub-section--coral .hub-section__title::before { background: var(--coral); }

.hub-grid {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.hub-link {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.65rem 0.7rem;
    border-radius: 0.75rem;
    border: 1px solid transparent;
    background: rgba(154, 143, 130, 0.04);
    color: var(--cream);
    text-decoration: none;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.hub-link:hover {
    transform: translateY(-1px);
    border-color: rgba(243, 235, 224, 0.1);
    background: rgba(154, 143, 130, 0.08);
}

.hub-link--featured {
    background: rgba(157, 122, 255, 0.08);
    border-color: rgba(157, 122, 255, 0.18);
}

.hub-link--featured:hover {
    border-color: rgba(157, 122, 255, 0.35);
    background: rgba(157, 122, 255, 0.12);
}

.hub-link__icon {
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.55rem;
    background: rgba(157, 122, 255, 0.1);
    color: var(--violet);
    flex-shrink: 0;
    font-size: 0.85rem;
}

.hub-section--mint .hub-link__icon {
    background: rgba(94, 228, 199, 0.1);
    color: var(--mint);
}

.hub-section--coral .hub-link__icon {
    background: rgba(255, 92, 77, 0.1);
    color: var(--coral);
}

.hub-link__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.hub-link__label {
    font-size: 0.86rem;
    font-weight: 600;
    line-height: 1.25;
}

.hub-link__meta {
    font-family: "DM Mono", monospace;
    font-size: 0.58rem;
    letter-spacing: 0.05em;
    color: var(--cream-dim);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.hub-link__ext {
    color: var(--cream-dim);
    font-size: 0.62rem;
    opacity: 0.45;
    flex-shrink: 0;
    transition: opacity 0.2s ease, color 0.2s ease;
}

.hub-link:hover .hub-link__ext {
    opacity: 1;
    color: var(--mint);
}

.hero-social {
    margin-top: 1.35rem;
    padding-top: 1.15rem;
    border-top: 1px solid rgba(243, 235, 224, 0.06);
}

.hero-social__label {
    font-family: "DM Mono", monospace;
    font-size: 0.6rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--cream-dim);
    margin-bottom: 0.65rem;
}

.hero-scroll {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    margin-top: 2rem;
    color: var(--cream-dim);
    text-decoration: none;
    transition: color 0.2s ease, transform 0.2s ease;
}

.hero-scroll__label {
    font-family: "DM Mono", monospace;
    font-size: 0.6rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.hero-scroll i {
    font-size: 0.75rem;
    animation: heroScrollBounce 2s ease-in-out infinite;
}

.hero-scroll:hover {
    color: var(--mint);
    transform: translateY(2px);
}

@keyframes heroScrollBounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(4px); }
}

/* Eski hero-link sınıfları (blog vb. uyumluluk) */
.hero-link {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.85rem 1rem;
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.08);
    border-radius: var(--radius-md);
    backdrop-filter: blur(12px);
    color: var(--cream);
    text-decoration: none;
    font-size: 0.88rem;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.hero-link:hover {
    transform: translateY(-2px);
    border-color: rgba(157, 122, 255, 0.35);
    background: rgba(22, 20, 31, 0.95);
}

.hero-link i {
    color: var(--violet);
    font-size: 1rem;
    flex-shrink: 0;
}

.cinema-link {
    flex-direction: column;
    text-align: center;
    padding: 1rem 0.65rem;
    gap: 0.45rem;
}

.cinema-link i { font-size: 1.35rem; }

.cinema-link span {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    line-height: 1.35;
    color: var(--cream-dim);
}

@media (max-width: 639px) {
    .links-row.cinema-links { grid-template-columns: 1fr; }
    .links-row.other-links { grid-template-columns: 1fr; }
}

/* ── Sosyal linkler ── */

.social-links {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.social-links a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 50%;
    background: rgba(154, 143, 130, 0.08);
    border: 1px solid rgba(243, 235, 224, 0.08);
    color: var(--cream);
    text-decoration: none;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.social-links a:hover {
    transform: translateY(-2px);
    border-color: rgba(157, 122, 255, 0.4);
    background: rgba(157, 122, 255, 0.12);
}

/* ── Bölümler ── */

.section {
    padding: 4rem 0;
    position: relative;
}

.section-title h2::before {
    content: "";
    display: inline-block;
    width: 0.22rem;
    height: 1.1em;
    margin-right: 0.55rem;
    vertical-align: -0.1em;
    background: var(--violet);
    border-radius: 2px;
}

/* ── Hakkımda ── */

.about {
    position: relative;
    overflow: hidden;
}

.about::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse 55% 45% at 12% 40%, rgba(157, 122, 255, 0.08), transparent 70%),
        radial-gradient(ellipse 40% 35% at 88% 60%, rgba(94, 228, 199, 0.06), transparent 65%);
}

.about-content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    align-items: center;
    position: relative;
    z-index: 1;
}

.about-image {
    display: flex;
    justify-content: center;
}

.about-frame {
    position: relative;
    width: min(18rem, 78vw);
    cursor: pointer;
    border-radius: var(--radius-lg);
}

.about-frame::before {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(145deg, rgba(157, 122, 255, 0.45), rgba(94, 228, 199, 0.2), rgba(243, 235, 224, 0.08));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
}

.about-frame img,
.about-picture img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(243, 235, 224, 0.08);
    transition: transform 0.35s ease, filter 0.35s ease;
}

.about-picture {
    display: block;
    width: 100%;
}

.about-frame--placeholder {
    min-height: 20rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(22, 20, 31, 0.65);
    border: 1px dashed rgba(243, 235, 224, 0.12);
}

.about-frame__placeholder {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.about-frame__glow {
    position: absolute;
    inset: 12% -8% -12% -8%;
    background: radial-gradient(circle at 50% 40%, rgba(157, 122, 255, 0.22), transparent 68%);
    filter: blur(28px);
    z-index: -1;
    pointer-events: none;
}

.about-frame__hint {
    position: absolute;
    right: 0.65rem;
    bottom: 0.65rem;
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(12, 11, 16, 0.72);
    border: 1px solid rgba(243, 235, 224, 0.12);
    color: var(--cream);
    font-size: 0.72rem;
    opacity: 0;
    transform: translateY(4px);
    transition: opacity 0.25s ease, transform 0.25s ease;
}

.about-frame:hover img,
.about-frame:focus-visible img {
    transform: translateY(-4px) scale(1.01);
    filter: contrast(1.04) brightness(1.03);
}

.about-frame:hover .about-frame__hint,
.about-frame:focus-visible .about-frame__hint {
    opacity: 1;
    transform: translateY(0);
}

.about-kicker {
    font-family: "DM Mono", monospace;
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--mint);
    margin-bottom: 0.55rem;
}

.about-text h2 {
    font-size: clamp(1.35rem, 4vw, 1.85rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.2;
    text-wrap: balance;
    margin-bottom: 1rem;
}

.about-lead {
    color: var(--cream-dim);
    line-height: 1.75;
    font-size: clamp(0.95rem, 2.2vw, 1.02rem);
    margin-bottom: 1.25rem;
}

.about-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
}

.about-meta__item {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.4rem 0.75rem;
    border-radius: var(--radius-pill);
    background: rgba(154, 143, 130, 0.08);
    border: 1px solid rgba(243, 235, 224, 0.08);
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cream-dim);
}

.about-meta__item i {
    color: var(--violet);
    font-size: 0.7rem;
}

.about-chips {
    padding: 1.35rem 1.25rem;
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.08);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(12px);
    border-left: 3px solid var(--mint);
}

.about-chips__label {
    font-family: "DM Mono", monospace;
    font-size: 0.65rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--cream-dim);
    margin-bottom: 0.85rem;
}

.about-chips__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    list-style: none;
    padding: 0;
    margin: 0;
}

.about-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.5rem 0.8rem;
    border-radius: var(--radius-pill);
    background: rgba(157, 122, 255, 0.08);
    border: 1px solid rgba(157, 122, 255, 0.18);
    font-size: 0.84rem;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.about-chip i {
    color: var(--violet);
    font-size: 0.78rem;
}

.about-chip:hover {
    transform: translateY(-2px);
    border-color: rgba(157, 122, 255, 0.35);
    background: rgba(157, 122, 255, 0.12);
}

@media (min-width: 640px) {
    .about-content {
        gap: 2.5rem;
    }

    .about-chips__list {
        gap: 0.65rem;
    }
}

@media (min-width: 900px) {
    .about-content {
        grid-template-columns: minmax(15rem, 0.85fr) 1.35fr;
        gap: 3rem;
    }

    .about-image {
        justify-content: flex-start;
    }

    .about-frame {
        width: min(20rem, 100%);
    }
}

@media (max-width: 639px) {
    .about-text {
        text-align: center;
    }

    .about-meta {
        justify-content: center;
    }

    .about-chips {
        text-align: center;
    }

    .about-chips__list {
        justify-content: center;
    }
}

/* ── Ekipman ── */

.equipment {
    position: relative;
}

.equipment::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    translate: -50% 0;
    width: min(42rem, 90%);
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(243, 235, 224, 0.12), transparent);
}

.equipment-summary {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.45rem;
    list-style: none;
    padding: 0;
    margin: -1.25rem 0 1.75rem;
}

.equipment-summary__pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.7rem;
    border-radius: var(--radius-pill);
    background: rgba(22, 20, 31, 0.65);
    border: 1px solid rgba(243, 235, 224, 0.08);
    font-family: "DM Mono", monospace;
    font-size: 0.58rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cream-dim);
}

.equipment-summary__dot {
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 50%;
    flex-shrink: 0;
}

.equipment-summary__dot--camera { background: var(--violet); }
.equipment-summary__dot--lens { background: var(--mint); }
.equipment-summary__dot--audio { background: #7eb8ff; }
.equipment-summary__dot--light { background: #ffd166; }
.equipment-summary__dot--accessory { background: var(--cream-dim); }

.equipment-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.85rem;
}

.equipment-card {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 1.25rem 1.15rem 1.15rem;
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.08);
    border-radius: 0.85rem;
    backdrop-filter: blur(12px);
    text-decoration: none;
    color: inherit;
    overflow: hidden;
    transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.equipment-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.85rem;
    bottom: 0.85rem;
    width: 3px;
    border-radius: 0 2px 2px 0;
    background: var(--violet);
    opacity: 0.85;
}

.equipment-card.camera::before { background: var(--violet); }
.equipment-card.lens::before { background: var(--mint); }
.equipment-card.microphone::before { background: #7eb8ff; }
.equipment-card.flash::before { background: #ffd166; }
.equipment-card.light::before { background: #ffb347; }
.equipment-card.accessory::before { background: var(--cream-dim); }

.equipment-card[role="link"] { cursor: pointer; }

.equipment-card:hover,
.equipment-card:focus-visible {
    transform: translateY(-3px);
    border-color: rgba(157, 122, 255, 0.28);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.22);
}

.equipment-card__badge {
    position: absolute;
    top: 0.85rem;
    right: 0.85rem;
    font-family: "DM Mono", monospace;
    font-size: 0.52rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--cream-dim);
    padding: 0.2rem 0.45rem;
    border-radius: var(--radius-pill);
    background: rgba(154, 143, 130, 0.1);
    border: 1px solid rgba(243, 235, 224, 0.06);
}

.equipment-card__link {
    position: absolute;
    right: 0.85rem;
    bottom: 0.85rem;
    font-size: 0.65rem;
    color: var(--cream-dim);
    opacity: 0;
    transform: translate(-2px, 2px);
    transition: opacity 0.2s ease, transform 0.2s ease, color 0.2s ease;
}

.equipment-card:hover .equipment-card__link,
.equipment-card:focus-visible .equipment-card__link {
    opacity: 1;
    transform: translate(0, 0);
    color: var(--mint);
}

.equipment-icon {
    width: 2.5rem;
    height: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.75rem;
    margin-left: 0.35rem;
    border-radius: 50%;
    background: rgba(157, 122, 255, 0.1);
    border: 1px solid rgba(157, 122, 255, 0.2);
}

.equipment-card.lens .equipment-icon {
    background: rgba(94, 228, 199, 0.1);
    border-color: rgba(94, 228, 199, 0.22);
}

.equipment-card.lens .equipment-icon i { color: var(--mint); }

.equipment-card.microphone .equipment-icon {
    background: rgba(126, 184, 255, 0.12);
    border-color: rgba(126, 184, 255, 0.25);
}

.equipment-card.microphone .equipment-icon i { color: #7eb8ff; }

.equipment-card.flash .equipment-icon,
.equipment-card.light .equipment-icon {
    background: rgba(255, 209, 102, 0.1);
    border-color: rgba(255, 209, 102, 0.22);
}

.equipment-card.flash .equipment-icon i,
.equipment-card.light .equipment-icon i { color: #ffd166; }

.equipment-icon i { color: var(--violet); }

.equipment-info {
    padding-left: 0.35rem;
    padding-right: 2rem;
}

.equipment-info h4 {
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: 0.3rem;
    line-height: 1.25;
}

.equipment-type {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.06em;
    color: var(--cream-dim);
    margin-bottom: 0.35rem;
}

.equipment-specs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-top: 0.5rem;
}

.spec.filter-spec {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.28rem 0.55rem;
    border-radius: var(--radius-pill);
    background: rgba(94, 228, 199, 0.08);
    border: 1px solid rgba(94, 228, 199, 0.2);
    font-family: "DM Mono", monospace;
    font-size: 0.55rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--mint);
    text-decoration: none;
    transition: background 0.2s ease, transform 0.2s ease;
}

.spec.filter-spec:hover {
    background: rgba(94, 228, 199, 0.14);
    transform: translateY(-1px);
}

@media (min-width: 640px) {
    .equipment-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1rem;
    }
}

@media (min-width: 900px) {
    .equipment-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .equipment-card {
        min-height: 11.5rem;
    }
}

/* ── Portfolyo ── */

.portfolio-grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 0.35rem;
}

@media (min-width: 640px) {
    .portfolio-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 900px) {
    .portfolio-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1200px) {
    .portfolio-grid { grid-template-columns: repeat(4, 1fr); }
}

.portfolio-item {
    position: relative;
    border-radius: var(--radius-md);
    overflow: hidden;
    cursor: pointer;
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.06);
    transition: transform 0.25s ease, border-color 0.25s ease;
}

.portfolio-item:hover {
    transform: translateY(-4px);
    border-color: rgba(157, 122, 255, 0.25);
}

.portfolio-item img,
.portfolio-picture img {
    width: 100%;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.portfolio-picture {
    display: block;
    width: 100%;
}

.portfolio-item:hover img { transform: scale(1.04); }

.portfolio-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(12, 11, 16, 0.72);
    opacity: 0;
    transition: opacity 0.25s ease;
}

.portfolio-item:hover .portfolio-overlay { opacity: 1; }

.portfolio-item:focus-visible .portfolio-overlay,
.portfolio-item:focus-within .portfolio-overlay {
    opacity: 1;
}

.portfolio-item:focus-visible img,
.portfolio-item:focus-within img {
    transform: scale(1.04);
}

.portfolio-overlay i {
    color: var(--mint);
    font-size: 1.35rem;
}

.icon-fallback { display: none; }

img[data-src] {
    opacity: 0.45;
    filter: blur(8px);
    transition: opacity 0.45s ease, filter 0.45s ease, transform 0.25s ease;
    background: rgba(22, 20, 31, 0.6);
}

img.loaded,
.portfolio-item img:not([data-src]) {
    opacity: 1;
    filter: none;
}

.portfolio-item.is-loading {
    background: linear-gradient(
        110deg,
        rgba(22, 20, 31, 0.9) 8%,
        rgba(157, 122, 255, 0.08) 18%,
        rgba(22, 20, 31, 0.9) 33%
    );
    background-size: 200% 100%;
    animation: portfolioShimmer 1.4s linear infinite;
}

@keyframes portfolioShimmer {
    to { background-position-x: -200%; }
}

/* ── Blog kartları ── */

.blog {
    position: relative;
}

.blog::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(ellipse 50% 40% at 80% 20%, rgba(157, 122, 255, 0.07), transparent 70%);
}

.blog > .container {
    position: relative;
    z-index: 1;
}

.blog-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 640px) {
    .blog-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.15rem;
    }
}

@media (min-width: 900px) {
    .blog-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 1.25rem;
    }
}

.blog-card {
    position: relative;
    height: 100%;
    overflow: hidden;
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.08);
    border-radius: 0.85rem;
    backdrop-filter: blur(12px);
    transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.blog-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.85rem;
    bottom: 0.85rem;
    width: 3px;
    border-radius: 0 2px 2px 0;
    background: linear-gradient(180deg, var(--violet), var(--mint));
    opacity: 0.85;
    z-index: 2;
    pointer-events: none;
}

.blog-card:hover {
    transform: translateY(-4px);
    border-color: rgba(157, 122, 255, 0.28);
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.24);
}

.blog-card__link {
    display: flex;
    flex-direction: column;
    height: 100%;
    color: inherit;
    text-decoration: none;
}

.blog-card__media {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 10;
    background:
        linear-gradient(145deg, rgba(157, 122, 255, 0.12), rgba(94, 228, 199, 0.08)),
        rgba(22, 20, 31, 0.9);
}

.blog-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease, opacity 0.35s ease;
}

.blog-card:hover .blog-card__media img {
    transform: scale(1.04);
}

.blog-card__category {
    position: absolute;
    top: 0.65rem;
    left: 0.65rem;
    z-index: 1;
    padding: 0.22rem 0.5rem;
    border-radius: var(--radius-pill);
    background: rgba(12, 11, 16, 0.72);
    border: 1px solid rgba(243, 235, 224, 0.1);
    font-family: "DM Mono", monospace;
    font-size: 0.52rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--cat-color, var(--violet));
}

.blog-content {
    padding: 1.1rem 1.15rem 1.2rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.blog-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem 0.65rem;
    margin-bottom: 0.55rem;
}

.blog-date {
    font-family: "DM Mono", monospace;
    font-size: 0.58rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--mint);
}

.blog-read-time {
    font-family: "DM Mono", monospace;
    font-size: 0.55rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cream-dim);
}

.blog-read-time::before {
    content: "·";
    margin-right: 0.45rem;
    opacity: 0.6;
}

.blog-card .blog-content h3 {
    font-size: clamp(1rem, 2.2vw, 1.08rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.3;
    margin-bottom: 0.45rem;
    text-wrap: balance;
    transition: color 0.2s ease;
}

.blog-card:hover .blog-content h3 {
    color: var(--cream);
}

.blog-card .blog-content p {
    color: var(--cream-dim);
    font-size: 0.86rem;
    line-height: 1.6;
    margin-bottom: 0.95rem;
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.read-more {
    font-family: "DM Mono", monospace;
    font-size: 0.58rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--violet);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    transition: color 0.2s ease, gap 0.2s ease;
}

.blog-card:hover .read-more {
    color: var(--mint);
    gap: 0.55rem;
}

.blog-more {
    margin-top: 1.35rem;
    text-align: center;
}

.blog-more__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cream-dim);
    transition: color 0.2s ease, gap 0.2s ease;
}

.blog-more__link:hover {
    color: var(--mint);
    gap: 0.65rem;
}

/* ── Blog arşiv ── */

.page--blog-archive .section-title h1 {
    font-size: clamp(1.75rem, 5vw, 2.25rem);
    font-weight: 700;
    letter-spacing: -0.03em;
}

.blog-archive {
    padding-top: 0.5rem;
}

.blog-filters {
    margin-bottom: 1.75rem;
    padding: 1.15rem 1.1rem;
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.08);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(12px);
    border-left: 3px solid var(--violet);
}

.blog-filters__label {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--cream-dim);
    margin-bottom: 0.75rem;
}

.blog-filters__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    list-style: none;
    padding: 0;
    margin: 0;
}

.blog-filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 0.75rem;
    border-radius: var(--radius-pill);
    background: rgba(157, 122, 255, 0.08);
    border: 1px solid rgba(157, 122, 255, 0.18);
    font-size: 0.82rem;
    color: var(--cream);
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.blog-filter-chip:hover {
    transform: translateY(-1px);
    border-color: rgba(157, 122, 255, 0.35);
    background: rgba(157, 122, 255, 0.12);
}

.blog-filter-chip.is-active {
    background: color-mix(in srgb, var(--cat-color, var(--violet)) 18%, transparent);
    border-color: color-mix(in srgb, var(--cat-color, var(--violet)) 45%, transparent);
    color: var(--cream);
}

.blog-filter-chip__count {
    font-family: "DM Mono", monospace;
    font-size: 0.55rem;
    letter-spacing: 0.06em;
    color: var(--cream-dim);
    padding: 0.1rem 0.35rem;
    border-radius: var(--radius-pill);
    background: rgba(12, 11, 16, 0.35);
}

.blog-pagination {
    margin-top: 2rem;
}

.blog-pagination__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    list-style: none;
    padding: 0;
    margin: 0;
}

.blog-pagination__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    min-width: 2.25rem;
    min-height: 2.25rem;
    padding: 0.35rem 0.65rem;
    border-radius: var(--radius-pill);
    font-family: "DM Mono", monospace;
    font-size: 0.58rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cream-dim);
    background: rgba(154, 143, 130, 0.08);
    border: 1px solid rgba(243, 235, 224, 0.08);
    transition: transform 0.2s ease, border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.blog-pagination__link:hover {
    transform: translateY(-1px);
    border-color: rgba(157, 122, 255, 0.3);
    color: var(--cream);
}

.blog-pagination__link.is-current {
    background: rgba(157, 122, 255, 0.18);
    border-color: rgba(157, 122, 255, 0.35);
    color: var(--cream);
    cursor: default;
}

.blog-archive-back {
    margin-top: 2rem;
    text-align: center;
}

.blog-archive-back__link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-family: "DM Mono", monospace;
    font-size: 0.58rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cream-dim);
    transition: color 0.2s ease, gap 0.2s ease;
}

.blog-archive-back__link:hover {
    color: var(--violet);
    gap: 0.6rem;
}

.blog-empty .btn {
    margin-top: 0.5rem;
}

.portfolio-empty {
    grid-column: 1 / -1;
    max-width: 34rem;
    margin-inline: auto;
    padding: 2rem 1.5rem;
    text-align: center;
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.08);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(12px);
    border-left: 3px solid var(--mint);
}

.portfolio-empty__icon {
    width: 3rem;
    height: 3rem;
    margin: 0 auto 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(94, 228, 199, 0.1);
    border: 1px solid rgba(94, 228, 199, 0.22);
    color: var(--mint);
    font-size: 1.1rem;
}

.portfolio-empty__kicker {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--mint);
    margin-bottom: 0.45rem;
}

.portfolio-empty__title {
    font-size: clamp(1.15rem, 3vw, 1.35rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: 0.65rem;
}

.portfolio-empty__text {
    color: var(--cream-dim);
    line-height: 1.65;
    font-size: 0.92rem;
}

.blog-empty {
    max-width: 34rem;
    margin-inline: auto;
    padding: 2rem 1.5rem;
    text-align: center;
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.08);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(12px);
    border-left: 3px solid var(--violet);
}

.blog-empty__icon {
    width: 3rem;
    height: 3rem;
    margin: 0 auto 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(157, 122, 255, 0.12);
    border: 1px solid rgba(157, 122, 255, 0.22);
    color: var(--violet);
    font-size: 1.1rem;
}

.blog-empty__kicker {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--mint);
    margin-bottom: 0.45rem;
}

.blog-empty__title {
    font-size: clamp(1.15rem, 3vw, 1.35rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: 0.65rem;
}

.blog-empty__text {
    color: var(--cream-dim);
    line-height: 1.65;
    font-size: 0.92rem;
    margin-bottom: 1.15rem;
}

.blog-empty__topics {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.45rem;
    list-style: none;
    padding: 0;
    margin: 0;
}

.blog-empty__topic {
    padding: 0.35rem 0.65rem;
    border-radius: var(--radius-pill);
    background: rgba(154, 143, 130, 0.08);
    border: 1px solid rgba(243, 235, 224, 0.08);
    font-family: "DM Mono", monospace;
    font-size: 0.55rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cream-dim);
}

@media (max-width: 639px) {
    .blog-card .blog-content p {
        -webkit-line-clamp: 2;
    }

    .blog-empty {
        padding: 1.65rem 1.15rem;
    }
}

/* ── İletişim ── */

.contact {
    position: relative;
}

.contact::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(ellipse 45% 40% at 15% 80%, rgba(94, 228, 199, 0.06), transparent 70%);
}

.contact > .container {
    position: relative;
    z-index: 1;
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    align-items: start;
}

.contact-card {
    border-left: 3px solid var(--violet);
}

.contact-card__kicker {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--mint);
    margin-bottom: 0.45rem;
}

.contact-card__title {
    font-size: clamp(1.1rem, 2.5vw, 1.35rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: 0.65rem;
}

.contact-card__text {
    color: var(--cream-dim);
    line-height: 1.65;
    font-size: 0.92rem;
    margin-bottom: 1rem;
}

.contact-details {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.65rem;
}

.contact-details li {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 0.88rem;
    color: var(--cream-dim);
}

.contact-details i {
    color: var(--violet);
    margin-top: 0.15rem;
    width: 1rem;
    text-align: center;
}

.contact-details a {
    color: var(--cream);
    text-decoration: none;
    transition: color 0.2s ease;
}

.contact-details a:hover {
    color: var(--mint);
}

.contact-topics {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    list-style: none;
    padding: 0;
    margin: 0.85rem 0 0;
}

.contact-topics__item {
    padding: 0.35rem 0.65rem;
    border-radius: var(--radius-pill);
    background: rgba(154, 143, 130, 0.08);
    border: 1px solid rgba(243, 235, 224, 0.08);
    font-family: "DM Mono", monospace;
    font-size: 0.55rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cream-dim);
}

.contact-form {
    border-left: 3px solid var(--mint);
}

.field-honey {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.contact-form__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem 1rem;
    margin-top: 0.35rem;
}

.contact-form__submit.is-loading {
    opacity: 0.7;
    pointer-events: none;
}

.contact-form__status {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.06em;
    color: var(--cream-dim);
    margin: 0;
    min-height: 1rem;
}

.contact-form__status.is-success {
    color: var(--mint);
}

.contact-form__status.is-error {
    color: var(--coral);
}

@media (min-width: 900px) {
    .contact-grid {
        grid-template-columns: minmax(16rem, 0.9fr) 1.25fr;
        gap: 1.5rem;
    }
}

/* ── Footer ── */

.footer {
    position: relative;
    margin-top: 0.5rem;
    padding: 0;
    border-top: 1px solid rgba(243, 235, 224, 0.08);
    background: rgba(12, 11, 16, 0.72);
    backdrop-filter: blur(14px);
}

.footer::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    translate: -50% 0;
    width: min(36rem, 88%);
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(157, 122, 255, 0.35), transparent);
}

.footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    padding: 2.5rem 0 1.75rem;
    text-align: center;
}

.footer-brand {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.footer-logo {
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.footer-tagline {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--cream-dim);
}

.footer-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.45rem 0.85rem;
}

.footer-nav a {
    font-family: "DM Mono", monospace;
    font-size: 0.58rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--cream-dim);
    text-decoration: none;
    transition: color 0.2s ease;
}

.footer-nav a:hover {
    color: var(--mint);
}

.footer-social-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.65rem;
}

.footer-social-label {
    font-family: "DM Mono", monospace;
    font-size: 0.55rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--cream-dim);
}

.footer-social {
    justify-content: center;
}

.footer-bottom {
    padding: 0 0 calc(1.35rem + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid rgba(243, 235, 224, 0.06);
}

.footer-text {
    font-family: "DM Mono", monospace;
    font-size: 0.58rem;
    letter-spacing: 0.06em;
    color: rgba(154, 143, 130, 0.65);
    line-height: 1.7;
    max-width: 42rem;
    margin-inline: auto;
    text-align: center;
    padding-top: 1rem;
}

@media (min-width: 900px) {
    .footer-grid {
        grid-template-columns: 1.1fr 1.4fr 0.9fr;
        align-items: start;
        text-align: left;
    }

    .footer-nav {
        justify-content: center;
    }

    .footer-social-wrap {
        align-items: flex-end;
    }

    .footer-social {
        justify-content: flex-end;
    }
}

/* ── Scroll to top ── */

.scroll-top {
    position: fixed;
    right: calc(1rem + env(safe-area-inset-right, 0px));
    bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
    width: 2.75rem;
    height: 2.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.12);
    color: var(--cream);
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transform: translateY(0.65rem) scale(0.96);
    transition: opacity 0.25s ease, visibility 0.25s ease, transform 0.25s ease, background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    z-index: 1020;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.28);
}

.scroll-top.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}

.scroll-top:hover {
    background: rgba(157, 122, 255, 0.18);
    border-color: rgba(157, 122, 255, 0.4);
    transform: translateY(-2px) scale(1);
}

.scroll-top:focus-visible {
    background: rgba(157, 122, 255, 0.18);
    border-color: rgba(157, 122, 255, 0.4);
    transform: translateY(-2px) scale(1);
}

body.nav-open {
    overflow: hidden;
}

body.has-scroll-top .scroll-top {
    bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
}

/* ── Lightbox ── */

.lightbox {
    position: fixed;
    inset: 0;
    z-index: 1050;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(12, 11, 16, 0.94);
    backdrop-filter: blur(18px);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.28s ease, visibility 0.28s ease;
}

.lightbox.active {
    opacity: 1;
    visibility: visible;
}

.lightbox-content {
    position: relative;
    width: min(92vw, 56rem);
    max-height: 92vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    touch-action: pan-y pinch-zoom;
}

.lightbox-stage {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: min(70vh, 32rem);
}

.lightbox-content img {
    max-width: 92vw;
    max-height: 78vh;
    object-fit: contain;
    border-radius: var(--radius-md);
    border: 1px solid rgba(243, 235, 224, 0.08);
    transition: opacity 0.25s ease, transform 0.28s ease;
    will-change: transform, opacity;
}

.lightbox-content.is-loading img {
    opacity: 0.35;
}

.lightbox-content.is-sliding-left img {
    animation: lightboxSlideInFromRight 0.28s ease;
}

.lightbox-content.is-sliding-right img {
    animation: lightboxSlideInFromLeft 0.28s ease;
}

.lightbox-content.is-dragging img {
    transition: none;
}

@keyframes lightboxSlideInFromRight {
    from { opacity: 0.4; transform: translateX(28px); }
    to { opacity: 1; transform: translateX(0); }
}

@keyframes lightboxSlideInFromLeft {
    from { opacity: 0.4; transform: translateX(-28px); }
    to { opacity: 1; transform: translateX(0); }
}

.lightbox-loader {
    position: absolute;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    border: 2px solid rgba(243, 235, 224, 0.12);
    border-top-color: var(--violet);
    animation: lightboxSpin 0.75s linear infinite;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.lightbox-content.is-loading .lightbox-loader {
    opacity: 1;
}

@keyframes lightboxSpin {
    to { transform: rotate(360deg); }
}

.lightbox-caption {
    margin-top: 0.75rem;
    max-width: 36rem;
    text-align: center;
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.06em;
    color: var(--cream-dim);
    line-height: 1.45;
    padding-inline: 1rem;
}

.lightbox-close,
.lightbox-nav {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: rgba(22, 20, 31, 0.88);
    border: 1px solid rgba(243, 235, 224, 0.1);
    color: var(--cream);
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.lightbox-close { top: 0.5rem; right: 0.5rem; }

.lightbox-prev { left: -0.25rem; top: 50%; transform: translateY(-50%); }
.lightbox-next { right: -0.25rem; top: 50%; transform: translateY(-50%); }

.lightbox-close:hover,
.lightbox-nav:hover {
    background: rgba(157, 122, 255, 0.2);
    border-color: rgba(157, 122, 255, 0.35);
    transform: translateY(calc(-50% - 1px));
}

.lightbox-close:hover { transform: translateY(-1px); }

.lightbox-counter {
    margin-top: 0.85rem;
    padding: 0.35rem 0.8rem;
    border-radius: var(--radius-pill);
    background: rgba(22, 20, 31, 0.9);
    border: 1px solid rgba(243, 235, 224, 0.08);
    font-family: "DM Mono", monospace;
    font-size: 0.65rem;
    letter-spacing: 0.08em;
    color: var(--cream-dim);
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.lightbox-counter__current {
    color: var(--cream);
    font-weight: 500;
    display: inline-block;
    min-width: 1.25rem;
    text-align: center;
    transition: transform 0.2s ease, color 0.2s ease;
}

.lightbox-counter.is-bump .lightbox-counter__current {
    animation: counterBump 0.35s ease;
}

@keyframes counterBump {
    0% { transform: scale(1); color: var(--cream); }
    40% { transform: scale(1.2); color: var(--mint); }
    100% { transform: scale(1); color: var(--cream); }
}

.lightbox-progress {
    width: min(12rem, 40vw);
    height: 3px;
    margin-top: 0.65rem;
    border-radius: var(--radius-pill);
    background: rgba(243, 235, 224, 0.08);
    overflow: hidden;
}

.lightbox-progress__fill {
    display: block;
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--violet), var(--mint));
    border-radius: inherit;
    transition: width 0.35s ease;
}

.lightbox-hints {
    margin-top: 0.75rem;
    font-family: "DM Mono", monospace;
    font-size: 0.58rem;
    letter-spacing: 0.06em;
    text-align: center;
}

.lightbox-hints kbd {
    display: inline-block;
    margin: 0 0.15rem;
    padding: 0.1rem 0.35rem;
    border-radius: 0.3rem;
    border: 1px solid rgba(243, 235, 224, 0.12);
    background: rgba(154, 143, 130, 0.08);
    font-family: inherit;
    font-size: inherit;
}

body.lightbox-open { overflow: hidden; }

@media (max-width: 768px) {
    .lightbox-hints { display: none; }

    .lightbox-prev { left: 0.25rem; }
    .lightbox-next { right: 0.25rem; }

    .lightbox-content img {
        max-height: 72vh;
    }
}

@media (prefers-reduced-motion: reduce) {
    .lightbox-content.is-sliding-left img,
    .lightbox-content.is-sliding-right img,
    .lightbox-counter.is-bump .lightbox-counter__current {
        animation: none;
    }

    .portfolio-item.is-loading {
        animation: none;
    }
}

*:focus-visible {
    outline: 2px solid var(--violet);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    .animate-hero-title,
    .animate-hero-tagline,
    .animate-hero-links {
        opacity: 1;
        animation: none;
    }

    .reveal {
        opacity: 1;
        transform: none;
    }

    .hero-scroll i {
        animation: none;
    }
}

/* ── Nav search ── */

.nav-right {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.nav-search {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    max-width: 14rem;
}

.nav-search__input {
    min-width: 0;
    width: 100%;
    padding: 0.45rem 0.65rem;
    font-size: 0.82rem;
}

.nav-search__btn {
    flex-shrink: 0;
    padding-inline: 0.65rem;
}

@media (max-width: 899px) {
    .nav-search {
        display: none;
    }
}

/* ── Blog search & results ── */

.blog-search {
    margin-bottom: 1.5rem;
}

.blog-search__row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: center;
}

.blog-search__input {
    flex: 1 1 16rem;
}

.blog-search__rss {
    color: var(--violet);
}

.search-results {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.search-result {
    border-radius: var(--radius-lg);
    background: var(--card);
    border: 1px solid rgba(243, 235, 224, 0.08);
    overflow: hidden;
}

.search-result__link {
    display: flex;
    gap: 1rem;
    padding: 1rem;
    color: inherit;
    text-decoration: none;
    transition: border-color 0.2s ease, background 0.2s ease;
}

.search-result__link:hover,
.search-result__link:focus-visible {
    background: rgba(157, 122, 255, 0.06);
}

.search-result__media {
    flex-shrink: 0;
    width: 7.5rem;
    border-radius: 0.65rem;
    overflow: hidden;
}

.search-result__media img {
    width: 100%;
    height: 5rem;
    object-fit: cover;
}

.search-result__type {
    font-family: "DM Mono", monospace;
    font-size: 0.58rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--mint);
}

.search-result__body h2 {
    font-size: 1.05rem;
    margin: 0.25rem 0;
}

.search-result__body p {
    color: var(--cream-dim);
    font-size: 0.9rem;
    line-height: 1.5;
}

.search-result__meta {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    color: var(--cream-dim);
}

/* ── Portfolio filters ── */

.portfolio-filters {
    margin-bottom: 1.25rem;
}

.portfolio-filters__label {
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--cream-dim);
    margin-bottom: 0.65rem;
}

.portfolio-filters__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    list-style: none;
    padding: 0;
    margin: 0;
}

.portfolio-filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.75rem;
    border-radius: var(--radius-pill);
    border: 1px solid rgba(243, 235, 224, 0.1);
    background: rgba(154, 143, 130, 0.08);
    color: var(--cream);
    font-family: "DM Mono", monospace;
    font-size: 0.62rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease;
}

.portfolio-filter-chip.is-active,
.portfolio-filter-chip[aria-pressed="true"] {
    background: rgba(157, 122, 255, 0.16);
    border-color: rgba(157, 122, 255, 0.35);
}

.portfolio-filter-chip__count {
    opacity: 0.75;
}

/* ── 404 ── */

.error-page {
    min-height: calc(100dvh - var(--nav-height, 4.5rem));
    display: flex;
    align-items: center;
    justify-content: center;
    padding: calc(var(--nav-height, 4.5rem) + 2rem) 1rem 3rem;
}

.error-page__inner {
    text-align: center;
    max-width: 32rem;
}

.error-page__title {
    font-size: clamp(1.75rem, 6vw, 2.5rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    margin-bottom: 0.75rem;
}

.error-page__text {
    margin-bottom: 1.5rem;
    line-height: 1.6;
}

.error-page__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    justify-content: center;
}

.section.dash-section,
.section.about,
.section.equipment,
.section.portfolio,
.section.blog,
.section.contact {
    position: relative;
    padding-left: 0.15rem;
}

.section.dash-section::before,
.section.about::before,
.section.equipment::before,
.section.portfolio::before,
.section.blog::before,
.section.contact::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.5rem;
    bottom: 0.5rem;
    width: 3px;
    border-radius: 999px;
    background: linear-gradient(180deg, var(--mint, #5ee4c7), var(--violet, #9d7aff));
    opacity: 0.85;
}

.hero-title,
.dashboard-now__title {
    letter-spacing: -0.03em;
    text-wrap: balance;
}

.section .container {
    display: flex;
    flex-direction: column;
    gap: 1.35rem;
}
