body {
    background-color: #020617;
    color: #f8fafc;
    font-family: 'Plus Jakarta Sans', sans-serif;
    scroll-behavior: smooth;
}


/* Cam Efekti (Karanlık Mod Uyumu) */
.nav-glass {
    background: rgba(15, 23, 42, 0.7);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.05);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
}

/* Navigasyon Linkleri */
.nx-link {
    color: #94a3b8;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.nx-link:hover {
    color: #38bdf8;
    transform: translateY(-1px);
}

/* Hamburger Menü Çizgileri */
.menu-line {
    transition: all 0.3s ease;
    background-color: #f8fafc;
}

.menu-open .line1 {
    transform: translateY(7px) rotate(45deg);
}

.menu-open .line2 {
    opacity: 0;
}

.menu-open .line3 {
    transform: translateY(-7px) rotate(-45deg);
}

/* Mobil Menü */
#mobile-menu {
    transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    visibility: hidden;
    opacity: 0;
    transform: translateY(-20px);
}

#mobile-menu.active {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
}

/* Aydınlık Mod Renkleri */
body.light-mode {
    background-color: #f8fafc !important;
    /* Soft beyaz */
    color: #0f172a !important;
    /* Koyu lacivert metin */
}

/* Ana Başlık (Hero Title) */
body.light-mode .hero-title {
    color: #0f172a !important;
}

/* Alt Açıklama Metni */
body.light-mode p {
    color: #475569 !important;
    /* Slate-600: Okunabilir orta gri */
}

/* Navigasyon Linkleri */
body.light-mode .nx-link {
    color: #334155 !important;
}

body.light-mode .nx-link:hover {
    color: #2563eb !important;
    /* Hover'da belirgin mavi */
}

/* Navbar Cam Efekti */
body.light-mode .nav-glass {
    background: rgba(255, 255, 255, 0.8) !important;
    border: 1px solid rgba(15, 23, 42, 0.08) !important;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05) !important;
}

/* Mod Değiştirici Buton Arka Planı */
body.light-mode #theme-toggle {
    background-color: #e2e8f0 !important;
    /* Açık gri ray */
}

/* Aydınlık modda NODEX yazısını koyu lacivert yap */
body.light-mode #logo-text {
    color: #0f172a !important;
    background: none !important;
    /* Eğer gradyan varsa temizler */

    -webkit-text-fill-color: initial !important;
}

/* Aydınlık modda SOFT yazısının mavisini biraz daha belirgin yap (Opsiyonel) */
body.light-mode #logo-text span {
    color: #2563eb !important;
}

body.light-mode .project-card>div {
    background-color: #ffffff !important;
    /* Kartın kenarlarını hafif bir gri tonuyla ayırıyoruz */
    border: 1px solid rgba(0, 0, 0, 0.04) !important;
    /* Hafif ama geniş bir gölge ile yükselti hissi veriyoruz */
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 10px 15px -3px rgba(0, 0, 0, 0.03) !important;
}

body.light-mode .project-card:hover>div {
    transform: translateY(-4px);
    /* Hafif yukarı kalkma efekti */
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.08) !important;
    border-color: rgba(37, 99, 235, 0.2) !important;
    /* Hover'da markanın mavisiyle hafif çerçeve */
}

/* projeler css */

/* 3D Sahne ve Işıklandırma */
.showcase-stage {
    perspective: 4000px;
    overflow: visible;
    /* Cihazların taşması durumunda kesilmemesi için */
    z-index: 10 !important;
    height: 550px;
    display: flex;
    align-items: center;
    justify-content: center;
    /* Alttaki yansıma için zemin */
    background: radial-gradient(circle at 50% 50%, rgba(59, 130, 246, 0.03) 0%, transparent 70%);
}

/* ANA MATERYAL YAPISI */
/* CİHAZ GÖVDESİ: Gerçek metalik his için çok katmanlı gölge */
.device-master {
    position: relative;
    background: #0a0f1a;
    /* Dış gölge (Derinlik) + İç parlama (Kenar keskinliği) */
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.08),
        /* İnce metalik kenar */
        0 30px 100px -20px rgba(0, 0, 0, 0.5),
        /* Ana gölge */
        inset 0 0 15px rgba(255, 255, 255, 0.02);
    /* İç derinlik */
    transition: all 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    transform-style: preserve-3d;
}

/* Tüm cihazlar modu için kapsayıcı */
.all-devices-wrap {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    transform-style: preserve-3d;
}

/* Tümü modunda ortak küçültme ve konumlandırma */
.all-devices-wrap .device-master {
    position: absolute;
    opacity: 1 !important;
    transition: all 1s cubic-bezier(0.23, 1, 0.32, 1);
}

/* Laptop: Arka Plan - En Büyük */
.all-devices-wrap .laptop-node {
    transform: scale(0.45) translateX(-180px) rotateY(-15deg);
    z-index: 1;
}

/* Tablet: Orta Plan - Orta Boy */
.all-devices-wrap .tablet-node {
    transform: scale(0.4) translateX(20px) translateY(40px) translateZ(100px) rotateY(10deg);
    z-index: 2;
}

/* Telefon: Ön Plan - En Küçük Ama En Yakın */
.all-devices-wrap .phone-node {
    transform: scale(0.45) translateX(190px) translateY(80px) translateZ(200px) rotateY(-5deg);
    z-index: 3;
}

/* LAPTOP: Alt kasa detayları */
.laptop-frame {
    width: 480px;
    height: 300px;
    border-radius: 16px 16px 4px 4px;
    border: 12px solid #1e293b;
    border-bottom-width: 2px;
}

.laptop-frame::after {
    content: '';
    position: absolute;
    bottom: -18px;
    left: -10%;
    width: 120%;
    height: 12px;
    background: linear-gradient(to bottom, #2d3a4f, #0f172a);
    border-radius: 2px 2px 24px 24px;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.4);
}

/* MONİTÖR: Desktop için yeni ve şık tasarım */
.monitor-frame {
    width: 520px;
    height: 300px;
    border-radius: 12px;
    border: 14px solid #1e293b;
    border-bottom-width: 25px;
    /* Alt çerçeve daha kalın (Marka alanı gibi) */
    position: relative;
    background: #0a0f1a;
}

/* Monitör Ayağı */
.monitor-frame::after {
    content: '';
    position: absolute;
    bottom: -65px;
    left: 50%;
    transform: translateX(-50%);
    width: 120px;
    height: 40px;
    background: #1e293b;
    clip-path: polygon(20% 0%, 80% 0%, 100% 100%, 0% 100%);
}

.monitor-frame::before {
    content: '';
    position: absolute;
    bottom: -25px;
    left: 50%;
    transform: translateX(-50%);
    width: 40px;
    height: 25px;
    background: #0f172a;
}

/* Tablet Frame (Desktop yerine tablet isterseniz diye yedek) */
.tablet-frame {
    width: 400px;
    height: 280px;
    border-radius: 24px;
    border: 15px solid #1e293b;
    box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.5);
}

/* Görsel Uyum Ayarları */
#screen-img {
    transition: opacity 0.4s ease, transform 0.6s ease;
    width: 100%;
    height: 100%;
}

/* Cihaz bazlı görsel kesme (Object-position) */
.phone-frame #screen-img {
    object-fit: cover;
    object-position: top;
}

.laptop-frame #screen-img {
    object-fit: cover;
    object-position: top;
}

.monitor-frame #screen-img {
    object-fit: cover;
    object-position: center;
}

/* IPHONE PRO MOCKUP - Derinlik ve Materyal Güncellemesi */
.phone-frame {
    width: 195px;
    height: 390px;
    border-radius: 50px;
    background: #0f172a;
    /* İç kasa rengi */
    /* Katmanlı Kasa Derinliği */
    border: 10px solid #1e293b;
    position: relative;
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.1),
        /* Metalik kenar parlaması */
        -4px 0 15px rgba(0, 0, 0, 0.5),
        /* Sol yan gölge */
        inset 0 0 4px rgba(0, 0, 0, 0.8);
    /* Ekranın kasaya oturduğu kanal */
}

/* SOL YAN BUTONLAR (Ses ve Mod) */
.phone-frame::before {
    content: '';
    position: absolute;
    left: -14px;
    /* Kasanın dışına taşan buton */
    top: 90px;
    width: 4px;
    height: 35px;
    background: linear-gradient(to right, #334155, #1e293b);
    border-radius: 3px 0 0 3px;
    /* Diğer butonları box-shadow ile tek seferde ekliyoruz */
    box-shadow:
        0 50px 0 0 #1e293b,
        /* Ses Kısma */
        0 -30px 0 0 #334155;
    /* Sessiz Mod Anahtarı */
}

/* SAĞ YAN BUTON (Güç Butonu) */
.phone-frame::after {
    content: '';
    position: absolute;
    right: -14px;
    top: 110px;
    width: 4px;
    height: 55px;
    background: linear-gradient(to left, #334155, #1e293b);
    border-radius: 0 3px 3px 0;
}

/* EKRANIN TELEFONA SIFIR OTURMASI */
.phone-frame #device-screen {
    border-radius: 40px;
    /* Kasa kavisiyle matematiksel uyum */
    width: 100%;
    height: 100%;
    margin: 0;
    border: none;
    overflow: hidden;
}

.dynamic-island {
    position: absolute;
    top: 5px;
    left: 50%;
    transform: translateX(-50%);
    width: 58px;
    height: 18px;
    background: #000;
    border-radius: 20px;
    z-index: 50;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

/* EKRAN: Maskeleme katmanı - Taşan parlamayı gizlemek için kritik */
.device-screen {
    width: 100%;
    height: 100%;
    position: relative;
    overflow: hidden;
    border-radius: inherit;
    z-index: 1;
}

/* HAREKETLİ YANSIMA: Başlangıç konumu revize edildi */
.glass-glare {
    position: absolute;
    top: -100%;
    /* Çok dışarıda kalmaması için daraltıldı */
    left: -120%;
    width: 150%;
    height: 300%;
    background: linear-gradient(115deg,
            transparent 40%,
            rgba(255, 255, 255, 0.01) 45%,
            rgba(255, 255, 255, 0.15) 50%,
            rgba(255, 255, 255, 0.01) 55%,
            transparent 60%);
    transform: rotate(-20deg);
    /* Açı sabitlendi */
    z-index: 30;
    opacity: 0;
    pointer-events: none;
    transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
}

/* CİHAZ BAZLI HOVER DÜZELTMELERİ */

/* Laptop ve Monitör (Yatay) */
.laptop-frame:hover .glass-glare,
.monitor-frame:hover .glass-glare {
    opacity: 1;
    transform: rotate(-20deg) translateX(150%) translateY(20%);
}

/* Telefon (Dikey) - Daha uzun bir yol kat etmesi gerekir */
.phone-frame:hover .glass-glare {
    opacity: 1;
    transform: rotate(-20deg) translateX(140%) translateY(40%);
}

/* Tablet (Kareye yakın) */
.tablet-frame:hover .glass-glare {
    opacity: 1;
    transform: rotate(-20deg) translateX(130%) translateY(30%);
}

/* ANIMASYON AYARLARI */
.device-hidden {
    opacity: 0;
    transform: rotateY(45deg) scale(0.7) translateZ(-600px) !important;
}

.device-visible {
    opacity: 1;
    transform: rotateY(-18deg) rotateX(10deg) translateZ(0) !important;
}

/* SYSTEM ENGINE: Özel Yazılımlar ve Otomasyon için */
.engine-frame {
    width: 220px;
    height: 350px;
    border-radius: 12px;
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    border: 8px solid #334155;
    position: relative;
    overflow: hidden;
    box-shadow:
        0 0 40px rgba(59, 130, 246, 0.15),
        inset 0 0 20px rgba(0, 0, 0, 0.5);
}

/* Ön Panel Veri Işıkları */
.engine-frame::before {
    content: '';
    position: absolute;
    top: 20px;
    left: 20px;
    width: 4px;
    height: 100px;
    background: #3b82f6;
    box-shadow:
        0 0 10px #3b82f6,
        0 110px 0 #10b981,
        0 120px 0 #10b981,
        0 130px 0 #ef4444;
    border-radius: 10px;
    animation: pulse-data 2s infinite;
}

/* Port Detayları */
.engine-frame::after {
    content: 'SYSTEM CORE';
    position: absolute;
    bottom: 20px;
    left: 0;
    width: 100%;
    text-align: center;
    color: rgba(255, 255, 255, 0.2);
    font-size: 8px;
    font-weight: 800;
    letter-spacing: 2px;
}

/* Aydınlık modda cihaz gövdelerinin siyah kalmasını garanti altına al */
body.light-mode .device-master,
body.light-mode .laptop-frame,
body.light-mode .phone-frame,
body.light-mode .monitor-frame,
body.light-mode .engine-frame {
    background: #0a0f1a !important;
    border-color: #1e293b !important;
    color: #f8fafc !important;
    /* Cihaz içindeki yazıların (varsa) beyaz kalması için */
}

@keyframes pulse-data {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.4;
    }
}

/* Responsive Fix */
@media (max-width: 768px) {
    .laptop-frame {
        width: 300px;
        height: 190px;
    }
}