/* ============================================
   CSS RESET & NORMALIZE (Cross-Browser Fix)
   ============================================ */

/* Modern CSS Reset */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    -webkit-text-size-adjust: 100%;
    -moz-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    padding: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

/* iOS/Android Input & Button Reset */
input,
button,
textarea,
select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0;
    font-family: inherit;
}

/* iOS Safari specific fixes */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="password"],
textarea {
    -webkit-appearance: none;
    border-radius: 0;
}

button {
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
}

a {
    -webkit-tap-highlight-color: rgba(225, 29, 72, 0.3);
    touch-action: manipulation;
}

/* ============================================
   GLOBAL RESİM KURALLARI (Kesilme Olmasın)
   ============================================ */

/* Logo'lar hariç tüm resimler için global kurallar */
img:not([alt*="Logo"]):not([alt*="logo"]) {
    max-width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
    /* cover yerine contain kullan */
}

/* ============================================
   LOGO ÖZEL KURALLARI (Global img kurallarını ezer)
   ============================================ */

/* Navbar/Header Logo - Global img kuralını override et */
/* Çok küçük ekranlar (0-480px) */
nav img[alt*="Logo"],
nav img[alt*="logo"],
header img[alt*="Logo"],
header img[alt*="logo"] {
    max-width: 75px !important;
    width: auto !important;
    display: inline-block !important;
}

/* Küçük mobil (481px-640px) */
@media (min-width: 481px) {

    nav img[alt*="Logo"],
    nav img[alt*="logo"],
    header img[alt*="Logo"],
    header img[alt*="logo"] {
        max-width: 85px !important;
    }
}

/* Tablet (641px-768px) */
@media (min-width: 641px) {

    nav img[alt*="Logo"],
    nav img[alt*="logo"],
    header img[alt*="Logo"],
    header img[alt*="logo"] {
        max-width: 95px !important;
    }
}

/* Küçük masaüstü (769px-1024px) */
@media (min-width: 769px) {

    nav img[alt*="Logo"],
    nav img[alt*="logo"],
    header img[alt*="Logo"],
    header img[alt*="logo"] {
        max-width: 105px !important;
    }
}

/* Orta masaüstü (1025px-1440px) */
@media (min-width: 1025px) {

    nav img[alt*="Logo"],
    nav img[alt*="logo"],
    header img[alt*="Logo"],
    header img[alt*="logo"] {
        max-width: 115px !important;
    }
}

/* Büyük masaüstü (1441px+) */
@media (min-width: 1441px) {

    nav img[alt*="Logo"],
    nav img[alt*="logo"],
    header img[alt*="Logo"],
    header img[alt*="logo"] {
        max-width: 130px !important;
    }
}

/* Footer Logo - Responsive ve Dengeli */
footer img[alt*="Logo"],
footer img[alt*="logo"] {
    max-width: 80px !important;
    width: auto !important;
    display: inline-block !important;
}

/* Footer - Küçük mobil */
@media (min-width: 481px) {

    footer img[alt*="Logo"],
    footer img[alt*="logo"] {
        max-width: 90px !important;
    }
}

/* Footer - Tablet */
@media (min-width: 641px) {

    footer img[alt*="Logo"],
    footer img[alt*="logo"] {
        max-width: 100px !important;
    }
}

/* Footer - Küçük masaüstü */
@media (min-width: 769px) {

    footer img[alt*="Logo"],
    footer img[alt*="logo"] {
        max-width: 110px !important;
    }
}

/* Footer - Orta masaüstü */
@media (min-width: 1025px) {

    footer img[alt*="Logo"],
    footer img[alt*="logo"] {
        max-width: 130px !important;
    }
}

/* Footer - Büyük masaüstü */
@media (min-width: 1441px) {

    footer img[alt*="Logo"],
    footer img[alt*="logo"] {
        max-width: 150px !important;
    }
}

/* Footer genel düzen düzeltmeleri */
footer {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

@media (min-width: 768px) {
    footer {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }
}

/* Footer grid dengesi - Eşit boşluklar ve hizalama */
/* Boşluk "NINE PERFORMANCE" yazısının bittiği yerden başlasın */
footer .footer-grid {
    align-items: start;
    gap: 2rem;
    column-gap: 2.5rem !important;
    /* Tüm sütunlar arası EŞİT yatay boşluk */
    row-gap: 2rem;
}

@media (min-width: 768px) {
    footer .footer-grid {
        gap: 2rem;
        column-gap: 3rem !important;
        /* Tüm sütunlar arası EŞİT yatay boşluk */
        row-gap: 2rem;
    }
}

@media (min-width: 1024px) {
    footer .footer-grid {
        gap: 2.5rem;
        column-gap: 3.5rem !important;
        /* Tüm sütunlar arası EŞİT yatay boşluk */
        row-gap: 2.5rem;
    }
}

@media (min-width: 1280px) {
    footer .footer-grid {
        gap: 3rem;
        column-gap: 4rem !important;
        /* Tüm sütunlar arası EŞİT yatay boşluk */
        row-gap: 3rem;
    }
}

/* İlk sütundaki "NINE PERFORMANCE" yazısının sağından itibaren boşluk başlasın */
footer .footer-grid>div:first-child {
    padding-right: 0;
}

/* Diğer sütunların solundan boşluk başlasın */
footer .footer-grid>div:not(:first-child) {
    padding-left: 0;
}

/* Footer sütunlarının eşit genişlikte olması */
footer .footer-grid>div {
    width: 100%;
    min-width: 0;
    /* Grid overflow sorununu önler */
    padding-left: 0;
    padding-right: 0;
}

/* Tüm sütunlara eşit padding ekle - görsel denge için */
footer .footer-grid>div {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

@media (min-width: 768px) {
    footer .footer-grid>div {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }
}

@media (min-width: 1024px) {
    footer .footer-grid>div {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

/* Column-gap'i biraz azalt çünkü padding ekledik */
@media (min-width: 1024px) {
    footer .footer-grid {
        column-gap: 2.5rem !important;
    }
}

@media (min-width: 1280px) {
    footer .footer-grid {
        column-gap: 3rem !important;
    }
}

/* İlk sütundaki logo+yazı bölümünün yüksekliğini hesapla ve diğer sütunları aynı hizaya getir */
footer .footer-grid>div:first-child {
    padding-top: 0;
}

/* Diğer sütunların başlıklarını ilk sütundaki "NINE PERFORMANCE" yazısının bittiği yerle hizala */
/* Logo + yazı + margin yaklaşık 4.5rem (h-14 + gap + mb-3) */
footer .footer-grid>div:nth-child(2),
footer .footer-grid>div:nth-child(3),
footer .footer-grid>div:nth-child(4) {
    padding-top: 0;
}

@media (min-width: 768px) {

    /* İlk sütundaki logo+yazı yüksekliği: h-14 (3.5rem) + gap-2 (0.5rem) + mb-3 (0.75rem) = ~4.75rem */
    /* Diğer sütunların başlıklarını bu seviyeye getir */
    footer .footer-grid>div:nth-child(2) h4,
    footer .footer-grid>div:nth-child(3) h4,
    footer .footer-grid>div:nth-child(4) h4 {
        margin-top: 0;
        padding-top: 0;
    }

    /* İlk sütundaki açıklama paragrafının margin'ini ayarla */
    footer .footer-grid>div:first-child p {
        margin-top: 0;
        margin-bottom: 1.5rem;
    }

    /* Boşluk "NINE PERFORMANCE" yazısının bittiği yerden başlasın */
    /* İlk sütundaki logo+yazı bölümünün margin'i artırıldı, şimdi diğer sütunların başlıklarıyla hizalı */
    /* Column-gap zaten eşit, sadece görsel hizalama için */
}

/* Footer sütunlarının üstten hizalanması */
footer .grid>div {
    display: flex;
    flex-direction: column;
}

/* Footer başlık hizalaması */
footer h4 {
    margin-bottom: 1rem;
}

@media (min-width: 768px) {
    footer h4 {
        margin-bottom: 1.5rem;
    }
}

/* Kart içindeki resimler için özel kurallar */
.group img,
.card img,
.service-card img {
    width: 100%;
    height: auto;
    object-fit: cover;
    /* Sadece kart içinde cover kullan */
    object-position: center;
}

/* Absolute positioned resimler (kart arka planları) */
.absolute img,
.group .absolute img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/* object-fill kullanılan yerler için düzeltme */
.object-fill {
    object-fit: cover !important;
    object-position: center;
}

/* Mobilde object-fill yerine contain kullan (kesilme olmasın) */
@media (max-width: 768px) {
    .object-fill {
        object-fit: contain !important;
    }

    /* Absolute positioned resimler mobilde */
    .absolute img {
        object-fit: cover;
        object-position: center;
    }
}

/* Hero background resimleri için */
.hero-bg {
    background-size: cover !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-attachment: scroll;
    /* Mobilde fixed yerine scroll */
}

/* Aspect ratio koruma */
.aspect-ratio-container {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    /* 16:9 oranı için */
}

.aspect-ratio-container img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ============================================
   CONTAINER VE GRID YAPISI (Mobil Akış)
   ============================================ */

/* Container genel kuralları */
.container,
.max-w-6xl,
.max-w-4xl,
.max-w-5xl,
.max-w-\[1920px\] {
    width: 100%;
    max-width: 100%;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
}

/* Desktop container genişlikleri */
@media (min-width: 640px) {
    .max-w-6xl {
        max-width: 72rem;
    }

    .max-w-4xl {
        max-width: 56rem;
    }

    .max-w-5xl {
        max-width: 64rem;
    }

    .max-w-\[1920px\] {
        max-width: 1920px;
    }
}

/* Grid yapıları mobilde tek sütun */
.grid {
    display: grid;
    gap: 1rem;
}

/* Flex yapıları mobilde column */
@media (max-width: 768px) {
    .flex {
        flex-wrap: wrap;
    }

    .flex-row {
        flex-direction: column;
    }

    /* Grid'leri mobilde tek sütun yap */
    .grid-cols-1,
    .grid-cols-2,
    .grid-cols-3,
    .grid-cols-4,
    .md\:grid-cols-2,
    .lg\:grid-cols-2,
    .lg\:grid-cols-3,
    .lg\:grid-cols-4 {
        grid-template-columns: 1fr !important;
    }

    /* md:col-span-2 gibi class'ları mobilde iptal et */
    .md\:col-span-2,
    .lg\:col-span-2 {
        grid-column: span 1 !important;
    }

    /* Spacing ayarları mobilde */
    .gap-6,
    .gap-8,
    .gap-12 {
        gap: 1rem;
    }

    /* Padding ayarları mobilde */
    .p-6,
    .p-8,
    .p-12 {
        padding: 1rem;
    }

    .px-4,
    .px-6,
    .px-8 {
        padding-left: 15px;
        padding-right: 15px;
    }

    .py-12,
    .py-16 {
        padding-top: 2rem;
        padding-bottom: 2rem;
    }
}

/* ============================================
   FONT VE BUTON BOYUTLARI (Mobil Uyum)
   ============================================ */

/* Başlık font boyutları - clamp kullan */
h1 {
    font-size: clamp(1.75rem, 5vw, 3.5rem);
    line-height: 1.2;
}

h2 {
    font-size: clamp(1.5rem, 4vw, 2.5rem);
    line-height: 1.3;
}

h3 {
    font-size: clamp(1.25rem, 3vw, 2rem);
    line-height: 1.4;
}

h4 {
    font-size: clamp(1.1rem, 2.5vw, 1.5rem);
    line-height: 1.4;
}

/* Buton ve link padding - mobilde daha büyük */
button,
a.button,
.btn {
    min-height: 44px;
    /* iOS dokunma hedefi minimum boyutu */
    padding: 12px 24px;
    font-size: 16px;
    /* iOS zoom engelleme için minimum */
}

@media (max-width: 768px) {

    button,
    a.button,
    .btn {
        min-height: 48px;
        padding: 14px 28px;
        font-size: 16px;
    }

    /* Link'ler için de minimum boyut */
    a {
        min-height: 44px;
        display: inline-flex;
        align-items: center;
    }
}

/* Text boyutları mobilde okunabilir */
p {
    font-size: clamp(0.875rem, 2vw, 1rem);
    line-height: 1.6;
}

/* Küçük text'ler */
.text-sm {
    font-size: clamp(0.75rem, 1.5vw, 0.875rem);
}

.text-xs {
    font-size: clamp(0.625rem, 1.2vw, 0.75rem);
}

/* ============================================
   ÖZEL DÜZELTMELER
   ============================================ */

/* Navbar mobil uyum */
@media (max-width: 768px) {
    nav {
        padding: 0.5rem 1rem;
    }

    nav .flex {
        flex-wrap: nowrap;
    }
}

/* Hero section mobil uyum */
@media (max-width: 768px) {
    .hero-bg {
        min-height: 70vh !important;
        padding: 2rem 1rem;
        background-size: 100% 100% !important;
        /* Kesilme olmasin, sigdir */
    }

    .min-h-screen {
        min-height: 70vh !important;
    }
}

@media (min-width: 769px) {
    .hero-bg {
        background-size: 100% 100% !important;
        background-position: center center !important;
        background-repeat: no-repeat !important;
        min-height: 100vh !important;
        /* Ekran kadar buyuk olsun */
        height: auto !important;
    }
}

/* Kart yükseklikleri mobilde otomatik */
@media (max-width: 768px) {

    .h-\[400px\],
    .h-\[500px\],
    .h-\[300px\] {
        height: auto !important;
        min-height: 250px;
    }

    /* md:h-[500px] gibi responsive yükseklikleri mobilde iptal et */
    .md\:h-\[500px\],
    .md\:h-\[400px\] {
        height: auto !important;
        min-height: 250px;
    }
}

/* İframe responsive */
iframe {
    max-width: 100%;
    height: auto;
}

@media (max-width: 768px) {
    iframe {
        height: 250px;
    }
}

/* Form elemanları mobil uyum */
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
    width: 100%;
    min-height: 44px;
    font-size: 16px;
    /* iOS zoom engelleme */
    padding: 12px;
    border: 1px solid #333;
    background-color: #1a1a1a;
    color: #fff;
}

/* Scrollbar stil (opsiyonel) */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: #000;
}

::-webkit-scrollbar-thumb {
    background: #E11D48;
    border-radius: 4px;
}

/* Selection rengi */
::selection {
    background-color: #E11D48;
    color: white;
}

::-moz-selection {
    background-color: #E11D48;
    color: white;
}

/* ============================================
   VPN WIDGET GİZLEME (Eğer tarayıcı eklentisi ekliyorsa)
   ============================================ */
/* Sağ altta sabit duran VPN widget'ını gizle */
[class*="vpn"],
[id*="vpn"],
[class*="VPN"],
[id*="VPN"],
div[style*="fixed"][style*="bottom"][style*="right"]:not([class*="whatsapp"]):not([id*="whatsapp"]) {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* ============================================
   UTILITY CLASSES
   ============================================ */

/* Safe area için (iPhone X ve üzeri) */
.safe-area-top {
    padding-top: env(safe-area-inset-top);
}

.safe-area-bottom {
    padding-bottom: env(safe-area-inset-bottom);
}

.safe-area-left {
    padding-left: env(safe-area-inset-left);
}

.safe-area-right {
    padding-right: env(safe-area-inset-right);
}

/* Overflow kontrolü */
.overflow-x-hidden {
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

/* Touch action optimizasyonu */
.touch-optimized {
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

/* ============================================
   MEDIA QUERIES - BREAKPOINTS
   ============================================ */

/* Mobil (0-640px) */
@media (max-width: 639px) {
    .container {
        padding-left: 15px;
        padding-right: 15px;
    }
}

/* Tablet (641px-768px) */
@media (min-width: 640px) and (max-width: 768px) {
    .container {
        padding-left: 20px;
        padding-right: 20px;
    }
}

/* Desktop (769px+) */
@media (min-width: 769px) {
    .container {
        padding-left: 24px;
        padding-right: 24px;
    }
}


/* Large Desktop (1024px+) */
@media (min-width: 1024px) {
    .container {
        padding-left: 32px;
        padding-right: 32px;
    }
}

/* ============================================
   MOBILE HERO FIX - STANDARDIZATION
   ============================================ */

@media (max-width: 768px) {

    /* TAMAMEN ELASTİK HERO YAPISI */
    /* Ekran ne olursa olsun genişlik her zaman %100 ekran genişliği olacak */
    .mobile-standard-hero {
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        align-items: center !important;

        /* KRİTİK AYARLAR: Asla küçülme, asla taşma */
        width: 100vw !important;
        /* Viewport Width - Ekran genişliğinin tamamı */
        max-width: 100vw !important;
        min-width: 100vw !important;

        height: 60vh !important;
        min-height: 550px !important;

        margin: 0 !important;
        padding: 0 !important;
        overflow: hidden !important;
        position: relative !important;
        left: 0 !important;
        right: 0 !important;
    }

    /* Görsel her zaman container'ı tam dolduracak */
    .mobile-standard-hero img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        /* En boy oranını koruyarak doldur */
        object-position: center center !important;
        display: block !important;
    }

    /* İçerik de ekran genişliğine göre esneyecek */
    .mobile-standard-hero .z-20 {
        width: 100% !important;
        max-width: 100% !important;
        /* Sınırlama yok, container kadar */
        padding-left: 1.5rem;
        /* Güvenli boşluk */
        padding-right: 1.5rem;
        box-sizing: border-box !important;
        /* Padding genişliğe dahil */

        position: relative;
        z-index: 20;
        margin: 0 auto !important;
        text-align: center !important;
    }
}

/* Çok küçük ekranlar için yazı güvenliği */
@media (max-width: 380px) {
    .mobile-standard-hero h1 {
        font-size: clamp(1.5rem, 8vw, 2.5rem) !important;
    }
}