/*
 * PMAP Brand Override
 * ----------------------------------------------------------------------------
 * Bu dosya orijinal pmap-original.css'ten SONRA yuklenir. Amaci yalnizca
 * marka renk token'larini PMAP paletine cevirmektir. Layout, spacing,
 * typography ve component yapilari ORIJINAL halinde birakilir.
 *
 * Notrleri (anthracite, almost-black, dark-gray, light-gray, smokey-white,
 * almost-white, very-light-gray) ozellikle korunur cunku tasarim kontrasti
 * bunlara dayaniyor.
 */

:root {
    /* Primary marka renkleri - bf-purple ailesi PMAP koyu lacivertine cevriliyor. */
    --color-bf-purple: #041361;
    --color-plum: #020A3D;
    --color-dark-purple: #151821;

    /* Aksan teal'lari PMAP cyan/teal paletine cevriliyor. */
    --color-teal-1: #3138A8;
    --color-teal-2: #232A86;
    --color-teal-3: #1B1F66;

    /* Mavi destek tonlari. */
    --color-blue-1: #041361;
    --color-blue-2: #1E2C7A;

    /* Notr koyu tonlari PMAP paletine cekiyoruz: gri yerine hafif lacivert egilimli. */
    --color-anthracite: #151821;
    --color-almost-black: #0E1322;
    --color-dark-gray: #2A2F45;
}

/*
 * Buton gradient'i orijinal CSS'te inline gradient ile yaziliyor (token kullanmiyor).
 * Bu yuzden burada acikca override edilir.
 */
.btn-teal,
button.btn-teal,
a.btn-teal {
    background: linear-gradient(to right, #232A86, #3138A8) !important;
    color: #ffffff !important;
}

.btn-teal:hover,
button.btn-teal:hover,
a.btn-teal:hover {
    background: linear-gradient(to right, #1B1F66, #232A86) !important;
    color: #ffffff !important;
}

/*
 * btn-stroked.btn-teal kombinasyonu icin metin rengi override.
 * Aksi halde teal gradient zemine teal metin gelir, okunmaz.
 */
.btn-stroked.btn-teal,
a.btn-stroked.btn-teal {
    color: #ffffff !important;
    border-color: rgba(255, 255, 255, 0.35) !important;
}

/*
 * Mor gradient'ler hardcoded hex ile yazildigi icin token override etmiyor;
 * PMAP lacivert paletine cevirmek icin acikca override edilirler.
 *
 * #241334, #151515 -> #020A3D (PMAP primary-deep), #0E1322 (PMAP text/neutral-dark)
 * #40225c, #40115c, #281539 -> #041361 (PMAP primary) tonlari
 */
.bg-gradient-purple-header {
    background: #0E1322 !important;
    background: linear-gradient(38deg, #041361 50%, #0E1322) !important;
}

.bg-gradient-purple-header--home {
    background: #0E1322 !important;
    background: linear-gradient(325deg, #041361 50%, #0E1322) !important;
}

.bg-gradient-purple {
    --tw-gradient-from: #041361 !important;
    --tw-gradient-to: #020A3D !important;
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important;
    background-image: linear-gradient(to bottom right, var(--tw-gradient-stops)) !important;
}

.bg-gradient-special {
    background: #041361 !important;
    background: linear-gradient(125deg, #041361, #020A3D 38%, #041361 0, #000) !important;
}

/*
 * Teal gradient (CTA): "to right, #008da2 -> #00fff4" PMAP cyan paletine.
 */
.bg-gradient-teal {
    --tw-gradient-from: #232A86 !important;
    --tw-gradient-to: #3138A8 !important;
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important;
    background-image: linear-gradient(to right, var(--tw-gradient-stops)) !important;
}

/*
 * Blue gradient: "#00c2f3 -> --color-blue-1" zaten token kullaniyor (yukarida override edildi).
 * Sadece light-cyan stop'unu PMAP aksan rengiyle hizalayalim.
 */
.bg-gradient-blue {
    background: var(--color-blue-1) !important;
    background: linear-gradient(135deg, #3138A8 0, var(--color-blue-1) 100%) !important;
}

.bg-gradient-blue-reversed {
    background: var(--color-blue-1) !important;
    background: linear-gradient(135deg, var(--color-blue-1) 0, #3138A8 100%) !important;
}

/*
 * Koyu gri arka plan gradient'leri orijinal CSS'te hardcoded hex (#151515, #3f4447, #060606, #202324)
 * iceriyor. Bunlari PMAP koyu lacivert ailesine cekiyoruz.
 *   #151515 -> #0E1322 (PMAP text/derin koyu)
 *   #3f4447 -> #1E2C7A (PMAP primary-soft)
 *   #202324 -> #151821 (PMAP neutral-dark)
 *   #060606 -> #020A3D (PMAP primary-deep)
 */
.bg-gradient-dark-gray {
    background: #0E1322 !important;
    background: linear-gradient(135deg, #0E1322 50%, #1E2C7A) !important;
}

.bg-gradient-dark-gray-to-transparent {
    background: #0E1322 !important;
    background: linear-gradient(180deg, #0E1322 60%, transparent) !important;
}

.bg-gradient-dark-gray-reversed {
    background: #151821 !important;
    background: linear-gradient(135deg, #151821 50%, #020A3D) !important;
}

/*
 * Front-page Services bolumu (8. bolum) sag ust mavi "shard" gorseli normalde
 * shard-dark-gray.svg (kose pahlari olan beveled chevron) ile ciziliyordu.
 * Kullanici istegi: net duz kenarli trapez; sag ust ve alttaki pah/kesikler
 * gorunmesin, sol capraz kenar korunsun. SVG yerine ayni navy ton (#041361 ->
 * #1A4A8C) gradient ile doldurulup keskin koseli clip-path trapez uygulanir.
 * Polygon noktalari shard-dark-gray.svg geometrisinden turetildi: ust-sol (0,0),
 * duz ust kenar, dik sag kenar, alt %60'a kadar duz, sonra sol capraz kenar
 * tepeye. Sadece bu shard'a uygulanir (modifier class front-page.php'de).
 */
/*
 * Mavi shard'i tasiyan overlay normalde -mt-20 (-80px) ile yerlesir ve
 * overflow-hidden ile shard'i ust kenarindan kirpar. Mavi alani kartalin
 * kanat uclarini da kapsayacak sekilde ~100px yukari buyutmek icin overlay
 * 100px daha yukari cekilir (-180px). Alt kenar konumu shard yuksekligi ile
 * korunur (asagi bkz). Sadece Services bolumu overlay'ine uygulanir.
 */
.pmap-services-bluewrap {
    margin-top: -180px !important;
}

.bg-graphic-shard-dark-gray.pmap-shard--clean-trapezoid {
    /* Overlay 100px yukari cekildi; shard yuksekligi 650 -> 750 yapilarak ust
       kenar 100px yukari cikar, alt kenar eski konumunda (section-rel ~570)
       kalir. Boylece kartalin ust kanat uclari da mavi zemine girer. Sol
       capraz kenar (alt nokta %50) korunur. */
    height: 750px !important;
    background-image: none !important;
    background: linear-gradient(73deg, #041361 0%, #1A4A8C 100%) !important;
    -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 50% 100%);
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 50% 100%);
}

/*
 * Sayfa genelinde yatay taÅŸmayÄ± Ã¶nle (hex stack 3D transform'lardan kaynaklÄ±
 * marjinal taÅŸmalarÄ±n body'de horizontal scroll yaratmasÄ±nÄ± engeller).
 */
html, body {
    overflow-x: clip;
}

/*
 * Erisilebilirlik: klavye focus halkasi PMAP marka rengi ile vurgulanir.
 * Orijinal tasarim outline'i kaldirmamis ise mevcut stile dokunulmaz.
 */
:focus-visible {
    outline-color: #3138A8;
}

/* ============================================================================
 * Sayfa tepesindeki beyaz serit fix'i.
 * - WordPress admin bar logged-in kullaniciya html { margin-top: 32px !important }
 *   ekler; tema admin bar render etmeyince bu 32px bos beyaz alan birakir.
 * - Bazi browser'larda body veya html'in default margin'i etkili olur.
 * - body > a.skip-link inline rendered ise inline anchor olarak gorunur kalir.
 * Asagidaki kurallar tum bu kaynaklari defansif olarak sifirlar.
 * ========================================================================== */
html {
    margin-top: 0 !important;
    padding-top: 0 !important;
}
body {
    margin-top: 0 !important;
    padding-top: 0 !important;
}
/* Logged-in WP admin bar yine de gorunsun ama html offset'i kaldirildi */
#wpadminbar {
    position: fixed !important;
    top: 0 !important;
}

/* ============================================================================
 * WordPress standart .screen-reader-text + skip-link CSS'i.
 * header.php icindeki "Skip to content" linki bu kural olmadan beyaz seritle
 * sayfanin tepesinde gorunuyordu. WP core (Twenty Twenty-One ailesi) kalibi.
 * Klavyeyle :focus alaninda gorunur hale gelir; aksi halde tamamen gizlidir.
 * ========================================================================== */
.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute !important;
    width: 1px;
    word-wrap: normal !important;
}

.screen-reader-text:focus {
    background-color: #FFFFFF;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    -webkit-clip-path: none !important;
    clip-path: none !important;
    color: #041361;
    display: block;
    font-size: 0.875rem;
    font-weight: 700;
    height: auto !important;
    left: 5px !important;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px !important;
    width: auto !important;
    overflow: visible !important;
    z-index: 100000;
}

/* ============================================================================
 * Promo Bar (header.php) - DFIR launch duyurusu icin link hover polish.
 * Orijinal stiller koyu renkli linki tema lacivertiyle birakiyordu; teal'e
 * cevrilerek anthracite arka planda WCAG kontrasti saglanir, hover'da
 * underline ve hafif arrow translate ile detay durumu eklenir.
 * ========================================================================== */
.prose-promo-bar a,
.prose-promo-bar a:link,
.prose-promo-bar a:visited {
    color: #5EE5FF !important;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    padding-bottom: 1px;
    margin-left: 0.35rem;
    transition: color 200ms ease, border-color 200ms ease, letter-spacing 200ms ease;
}
.prose-promo-bar a:hover,
.prose-promo-bar a:focus,
.prose-promo-bar a:focus-visible {
    color: #FFFFFF !important;
    border-bottom-color: #5EE5FF;
    letter-spacing: 0.01em;
    outline: none;
}

/* ============================================================================
 * Hero (front-page.php) - DFIR konumlandirmasi icin proof bar + secondary CTA.
 * - hero-proofbar : platform metriklerini (600+ artifact, 30 triaj, 3 OS)
 *   sosyal kanit olarak gosterir; mobil 1 sutun, tablet+ tek satir.
 * - hero-cta-primary : "Request a Live Demo" btn-stroked uzerine ince glow
 *   eklenir; hover'da hafif yukseltme + ek glow ile detay vurgulanir.
 * - hero-cta-secondary : Ikincil link, sade beyaz metin + teal ok, hover'da
 *   ok translate eder ve metin teal'e gecer.
 * ========================================================================== */
/* Hero baslik: PMAP icin tek basamak kucultulmus ozel boyutlandirma.
 * Iki kisa kelime: "Triage. Contain." satira sigsin diye clamp ile
 * responsive olceklendiriyoruz. */
.hero-headline.hero-headline--pmap {
    font-size: clamp(2.75rem, 6vw, 4.75rem);
    line-height: 0.98;
    letter-spacing: -0.02em;
    font-weight: 800;
    margin: 0;
}
.hero-headline.hero-headline--pmap .hero-headline__line {
    display: block;
}

.hero-proofbar {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.6rem 1.5rem;
    margin: 0;
    padding: 0.85rem 1.1rem;
    list-style: none;
    border: 1px solid rgba(94, 229, 255, 0.18);
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(4, 19, 97, 0.55), rgba(2, 10, 61, 0.45));
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    max-width: 26rem;
}
@media (min-width: 640px) {
    .hero-proofbar { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.hero-proofbar__item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0 0.25rem;
    border-left: 2px solid rgba(94, 229, 255, 0.35);
}
.hero-proofbar__item:first-child { border-left: 0; padding-left: 0; }
@media (max-width: 639px) {
    .hero-proofbar__item { border-left: 0; border-top: 1px solid rgba(94, 229, 255, 0.18); padding: 0.6rem 0 0; }
    .hero-proofbar__item:first-child { border-top: 0; padding-top: 0; }
}
.hero-proofbar__metric {
    font-size: clamp(1.25rem, 1.8vw, 1.55rem);
    font-weight: 800;
    line-height: 1.05;
    background: linear-gradient(120deg, #FFFFFF 0%, #5EE5FF 70%, #3138A8 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    letter-spacing: -0.01em;
}

/*
 * 3 OS metrigi altindaki Win/Linux/Mac SVG ikonlari.
 * Text yerine logo gosterimi, brand-uyumlu teal renkte.
 */
/*
 * Hero scanning light beams (FAVORI - hafiza aday secimi).
 * 4 dikey yumusak isik huzmesi, hafif egim, sola-saga drift.
 * Tarama / Ä±ÅŸÄ±n izlenimi verir, forensics temasÄ± ile uyumlu.
 */
#hero-flow-bg {
    pointer-events: none;
}
#hero-flow-bg .hero-beam {
    position: absolute;
    top: -15%;
    height: 130%;
    width: 260px;
    filter: blur(70px);
    will-change: transform;
}
#hero-flow-bg .hero-beam--teal {
    background: linear-gradient(to bottom,
        transparent 0%,
        rgba(94, 229, 255, 0) 10%,
        rgba(94, 229, 255, 0.55) 50%,
        rgba(94, 229, 255, 0) 90%,
        transparent 100%);
    transform: rotate(14deg);
    opacity: 0.7;
    animation: hero-beam-drift-1 28s linear infinite;
}
#hero-flow-bg .hero-beam--purple {
    background: linear-gradient(to bottom,
        transparent 0%,
        rgba(167, 139, 250, 0) 10%,
        rgba(167, 139, 250, 0.5) 50%,
        rgba(167, 139, 250, 0) 90%,
        transparent 100%);
    transform: rotate(14deg);
    opacity: 0.55;
    animation: hero-beam-drift-2 36s linear infinite;
    width: 320px;
}
#hero-flow-bg .hero-beam--white {
    background: linear-gradient(to bottom,
        transparent 0%,
        rgba(230, 240, 255, 0) 10%,
        rgba(230, 240, 255, 0.32) 50%,
        rgba(230, 240, 255, 0) 90%,
        transparent 100%);
    transform: rotate(14deg);
    opacity: 0.5;
    animation: hero-beam-drift-3 44s linear infinite;
    width: 200px;
}
#hero-flow-bg .hero-beam--teal-slow {
    background: linear-gradient(to bottom,
        transparent 0%,
        rgba(13, 186, 197, 0) 15%,
        rgba(13, 186, 197, 0.4) 50%,
        rgba(13, 186, 197, 0) 85%,
        transparent 100%);
    transform: rotate(14deg);
    opacity: 0.45;
    animation: hero-beam-drift-4 52s linear infinite;
    width: 280px;
}
@keyframes hero-beam-drift-1 {
    0%   { transform: translateX(-15vw) rotate(14deg); }
    100% { transform: translateX(115vw) rotate(14deg); }
}
@keyframes hero-beam-drift-2 {
    0%   { transform: translateX(110vw) rotate(14deg); }
    100% { transform: translateX(-20vw) rotate(14deg); }
}
@keyframes hero-beam-drift-3 {
    0%   { transform: translateX(-10vw) rotate(14deg); }
    100% { transform: translateX(110vw) rotate(14deg); }
}
@keyframes hero-beam-drift-4 {
    0%   { transform: translateX(105vw) rotate(14deg); }
    100% { transform: translateX(-15vw) rotate(14deg); }
}

.hero-proofbar__os-icons {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    color: #5EE5FF;
    height: 100%;
    min-height: 38px;
}
.hero-proofbar__os-icons svg {
    width: 26px;
    height: 26px;
    flex-shrink: 0;
    opacity: 0.92;
    transition: opacity 200ms ease, transform 200ms ease;
}
.hero-proofbar__os-icons svg:hover {
    opacity: 1;
    transform: translateY(-1px);
}
.hero-proofbar__label {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.78);
    white-space: nowrap;
}

.hero-cta-primary {
    position: relative;
    box-shadow: 0 8px 28px -10px rgba(0, 180, 216, 0.55);
    transition: transform 220ms ease, box-shadow 220ms ease, filter 220ms ease;
}

/*
 * Body paragraflarini ince (light) gostermek icin.
 * Inter webfont 300 weight yuklu degilse fallback olusur. Bu yuzden
 * dogrudan -apple-system / Segoe UI Light / system-ui gibi sistem fontuna
 * geciliyor (bunlar 300 weight'i guvenilir sekilde render eder).
 *
 * Kapsam: hero body + .text-copy-lg (Outpace Modern Adversaries vb. uzun
 * paragraflar).
 */
#hero .hero-body,
#hero .hero-body p,
#hero .hero-body .text-copy,
#hero .hero-body .text-copy p,
.hero-body p,
.hero-body .text-copy,
.hero-body .text-copy p,
.text-copy-lg,
.text-copy-lg p,
.text-copy.prose,
.text-copy.prose p,
.pmap-overview-pillar-body,
.pmap-overview-pillar-body p {
    font-weight: 300 !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', system-ui, sans-serif !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: 0.015em;
}
.hero-cta-primary:hover,
.hero-cta-primary:focus-visible {
    transform: translateY(-2px);
    box-shadow: 0 14px 32px -8px rgba(0, 180, 216, 0.75);
    filter: brightness(1.05);
}

.hero-cta-secondary {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 0.25rem;
    color: #FFFFFF;
    font-weight: 600;
    font-size: 0.95rem;
    letter-spacing: 0.01em;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: color 220ms ease, border-color 220ms ease;
}
.hero-cta-secondary:hover,
.hero-cta-secondary:focus-visible {
    color: #5EE5FF;
    border-bottom-color: rgba(94, 229, 255, 0.6);
    outline: none;
}
.hero-cta-secondary__icon {
    transition: transform 220ms ease;
    color: #5EE5FF;
}
.hero-cta-secondary:hover .hero-cta-secondary__icon,
.hero-cta-secondary:focus-visible .hero-cta-secondary__icon {
    transform: translateX(4px);
    color: #FFFFFF;
}

/* Hero gradient text uclu satir detayini koy kontrastta isiltili tut */
#hero .hero-headline__line:nth-child(2) {
    text-shadow: 0 0 32px rgba(0, 180, 216, 0.35);
}

/* ============================================================================
 * Eksik responsive width utility — lg:w-1/6
 * Customers logo wall (template-parts/customers/sections.php) lg ekranda
 * 6 sutunlu satir kullanir. Onceki markup tanimsiz bir arbitrary class
 * (lg:w-[14%]) tasiyordu; purge edilmis pmap-original.css'te bu class ve
 * lg:w-1/6 yoktu, bu yuzden lg ekranda logo genisligi md:w-1/5'e dusup
 * satir duzeni bozuluyordu. Tanimli, temiz bir 1/6 fraksiyonu eklenir.
 * ========================================================================== */
@media (min-width: 1024px) {
    .lg\:w-1\/6 { width: 16.666667%; }
}

/* ============================================================================
 * PMAP Hizmet Kartlari (front-page.php) - "Related Content" tarzi kart yapisi
 * 3 sutunlu kart: PMAP marka paleti. Icerik aynen korunur.
 * ========================================================================== */
.pmap-card-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}
/* Ara adim: 640-1023px arasinda 2 sutun (1->3 sicramasi yerine yumusak
 * gecis). Bu grid ana sayfa dahil birden cok sayfada kullanildigi icin
 * tum kullanim alanlarinda tutarli davranir. >=1024px'te 3 sutun. */
@media (min-width: 640px) {
    .pmap-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.75rem; }
}
@media (min-width: 1024px) {
    .pmap-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

.pmap-section-intro {
    max-width: 56rem;
    margin: 0 auto 3rem;
    text-align: center;
    padding: 0 1rem;
}
.pmap-section-intro__eyebrow {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #3138A8;
    margin: 0 0 0.75rem;
}
.pmap-section-intro__title {
    font-size: clamp(1.75rem, 3vw, 2.6rem);
    line-height: 1.2;
    font-weight: 800;
    color: #041361;
    margin: 0 0 1rem;
}
.pmap-section-intro__lede {
    font-size: 1.05rem;
    line-height: 1.6;
    color: #2A2F45;
    margin: 0 auto;
    max-width: 48rem;
}

.pmap-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: #FFFFFF;
    border: 2px solid var(--pmap-card-color, #041361);
    border-radius: 20px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
.pmap-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 18px;
    pointer-events: none;
    box-shadow: inset 0 0 0 0 var(--pmap-card-color, #041361);
    transition: box-shadow 0.3s ease;
}
.pmap-card:hover,
.pmap-card:focus-visible {
    transform: translateY(-6px);
    box-shadow: 0 26px 52px rgba(4, 19, 97, 0.22);
    border-color: var(--pmap-card-color, #041361);
    outline: none;
}
.pmap-card:hover::before,
.pmap-card:focus-visible::before {
    box-shadow: inset 0 0 0 1px var(--pmap-card-color, #041361);
}

.pmap-card__visual {
    position: relative;
    aspect-ratio: 16 / 9;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--pmap-card-visual-bg, linear-gradient(135deg, #041361 0%, #1E2C7A 100%));
    overflow: hidden;
}
.pmap-card__visual::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at top right, rgba(255,255,255,0.18), transparent 60%);
    pointer-events: none;
}
.pmap-card__visual-glow {
    position: absolute;
    inset: auto -20% -40% auto;
    width: 80%;
    height: 80%;
    background: radial-gradient(circle, rgba(0, 180, 216, 0.45) 0%, transparent 65%);
    opacity: 0;
    transition: opacity 0.4s ease, transform 0.4s ease;
    pointer-events: none;
}
.pmap-card:hover .pmap-card__visual-glow,
.pmap-card:focus-visible .pmap-card__visual-glow {
    opacity: 1;
    transform: translate(-10%, -10%) scale(1.1);
}
.pmap-card__icon {
    position: relative;
    z-index: 1;
    width: 38%;
    max-width: 110px;
    height: auto;
    filter: drop-shadow(0 6px 16px rgba(0,0,0,0.25));
    transition: transform 0.35s ease;
}
.pmap-card:hover .pmap-card__icon,
.pmap-card:focus-visible .pmap-card__icon {
    transform: scale(1.06) translateY(-2px);
}

/* Media varyanti: ikon yerine full-bleed fotograf */
.pmap-card--media .pmap-card__visual {
    background: #0E1322;
}
.pmap-card--media .pmap-card__visual::after {
    display: none;
}
.pmap-card__media {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
/* Marka tutarliligi icin fotograf uzerine ince lacivert scrim:
   ust kosede hafif derinlik, alt kenarda beyaz govdeye yumusak gecis. */
.pmap-card__visual-scrim {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background:
        linear-gradient(180deg, rgba(4, 19, 97, 0.30) 0%, rgba(4, 19, 97, 0) 32%, rgba(4, 19, 97, 0.55) 100%),
        linear-gradient(135deg, rgba(4, 19, 97, 0.18) 0%, rgba(4, 19, 97, 0) 55%);
}
.pmap-card--accent .pmap-card__visual-scrim {
    background:
        linear-gradient(180deg, rgba(0, 70, 92, 0.28) 0%, rgba(0, 70, 92, 0) 32%, rgba(0, 70, 92, 0.5) 100%),
        linear-gradient(135deg, rgba(0, 109, 134, 0.16) 0%, rgba(0, 109, 134, 0) 55%);
}

.pmap-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1.75rem 1.75rem 2rem;
    flex: 1 1 auto;
}
.pmap-card__eyebrow {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--pmap-card-color, #041361);
    margin: 0;
}
.pmap-card__title {
    font-size: 1.25rem;
    line-height: 1.3;
    font-weight: 700;
    color: #041361;
    margin: 0;
}
.pmap-card__desc {
    font-size: 0.95rem;
    line-height: 1.55;
    color: #2A2F45;
    margin: 0;
}
.pmap-card__highlights {
    list-style: none;
    padding: 0;
    margin: 0.5rem 0 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.pmap-card__chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.7rem;
    background: rgba(4, 19, 97, 0.06);
    border: 1px solid rgba(4, 19, 97, 0.12);
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 600;
    color: #041361;
    line-height: 1;
    transition: background 0.25s ease, border-color 0.25s ease, color 0.25s ease, transform 0.25s ease;
}
.pmap-card__chip-icon {
    color: var(--pmap-card-color, #041361);
    flex-shrink: 0;
    transition: color 0.25s ease;
}
.pmap-card:hover .pmap-card__chip,
.pmap-card:focus-visible .pmap-card__chip {
    background: var(--pmap-card-color, #041361);
    border-color: var(--pmap-card-color, #041361);
    color: #FFFFFF;
}
.pmap-card:hover .pmap-card__chip-icon,
.pmap-card:focus-visible .pmap-card__chip-icon {
    color: #FFFFFF;
}
.pmap-card--accent .pmap-card__chip {
    background: rgba(0, 180, 216, 0.08);
    border-color: rgba(0, 180, 216, 0.25);
    color: #006D86;
}
.pmap-card--accent .pmap-card__chip-icon {
    color: #3138A8;
}
.pmap-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: auto;
    padding-top: 0.5rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--pmap-card-color, #041361);
}
.pmap-card__cta svg {
    transition: transform 0.2s ease;
}
.pmap-card:hover .pmap-card__cta svg {
    transform: translateX(4px);
}

/* Kart renk varyantlari */
.pmap-card--primary {
    --pmap-card-color: #041361;
    --pmap-card-visual-bg: linear-gradient(135deg, #041361 0%, #1E2C7A 100%);
}
.pmap-card--accent {
    --pmap-card-color: #3138A8;
    --pmap-card-visual-bg: linear-gradient(135deg, #3138A8 0%, #232A86 100%);
}
.pmap-card--soft {
    --pmap-card-color: #1E2C7A;
    --pmap-card-visual-bg: linear-gradient(135deg, #1E2C7A 0%, #041361 100%);
}

/* Labs media kartlari: hover ve detay durumu */
.pmap-card--media .pmap-card__visual {
    overflow: hidden;
}
.pmap-card--media .pmap-card__media {
    transition: transform 0.6s ease, filter 0.4s ease;
    will-change: transform;
}
.pmap-card--media:hover .pmap-card__media,
.pmap-card--media:focus-visible .pmap-card__media {
    transform: scale(1.08);
    filter: saturate(1.1) brightness(1.05);
}
.pmap-card__media-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(14, 19, 34, 0) 55%, rgba(14, 19, 34, 0.55) 100%);
    opacity: 0;
    transition: opacity 0.35s ease;
    pointer-events: none;
}
.pmap-card--media:hover .pmap-card__media-overlay,
.pmap-card--media:focus-visible .pmap-card__media-overlay {
    opacity: 1;
}
.pmap-card__desc--reveal {
    max-height: 0;
    margin: 0;
    overflow: hidden;
    opacity: 0;
    transform: translateY(6px);
    transition: max-height 0.45s ease, opacity 0.3s ease, transform 0.35s ease, margin 0.35s ease;
}
.pmap-card--media:hover .pmap-card__desc--reveal,
.pmap-card--media:focus-visible .pmap-card__desc--reveal,
.pmap-card--media:focus-within .pmap-card__desc--reveal {
    max-height: 320px;
    opacity: 1;
    transform: translateY(0);
    margin-top: 0.25rem;
}
.pmap-card__meta {
    margin: 0.4rem 0 0;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: var(--pmap-card-color, #041361);
    opacity: 0.85;
}
.pmap-card--media .pmap-card__cta {
    margin-top: auto;
}
@media (prefers-reduced-motion: reduce) {
    .pmap-card--media .pmap-card__media,
    .pmap-card__desc--reveal,
    .pmap-card__media-overlay {
        transition: none;
    }
}

/* Alpine x-cloak: Alpine yuklenmeden once tum x-show bloklari gizli kalsin. */
[x-cloak] { display: none !important; }

/* ============================================================================
 * F26-G1: Mega-menu hayalet golge global fix (2026-05-28).
 * ----------------------------------------------------------------------------
 * template-parts/header/nav-primary.php satir 59'daki
 * `<div class="relative w-section shadow-custom">` mega-menu dropdown
 * wrapper'i. Wrapper her zaman DOM'da; ICINDEKI dropdown'lar Alpine
 * x-show ile gizli ama wrapper'in `shadow-custom` box-shadow'u
 * (0 18px 40px 0 rgba(0,0,0,.2)) HER ZAMAN aktif → menu altinda
 * gorunmez yatay golge band'i tum sayfa hero'larinda gozukuyor.
 *
 * Scope: SADECE #masthead icindeki .shadow-custom. Diger yerlerde
 * (pmap-stats.php stat kartlari, testimonial-grid.php testimonial
 * kartlari) shadow-custom KULLANILIYOR ve oralarda gerekli → bozulmaz.
 * ============================================================================ */
#masthead .shadow-custom {
    box-shadow: none !important;
}

/* ============================================================================
 * Ana sayfa kapanis CTA'si: About (referans) final-cta paneliyle ayni
 * yukseklik. Ana sayfada icerik daha az (eyebrow, paragraf ve ikinci buton
 * yok) oldugu icin panel About'tan kisa kaliyordu (340px vs 461px). Bu kural
 * paneli referansla esitler. Sadece desktop'ta uygulanir; mobilde foto full
 * genislige gectigi responsive desende panel icerik akisina birakilir.
 * ============================================================================ */
@media (min-width: 1024px) {
    .home-cta-equal .bg-gradient-purple {
        min-height: 461px;
    }
    /* Ana sayfa CTA fotografi (home-cta-equal): kullanici istegiyle biraz
     * zoom-out. cover yerine contain kullanilarak uretilen 16:9 gorselin tamami
     * (ayakta duran ozne dahil) kirpilmadan gosterilir; sag/orta hizalanir, sol
     * kenardaki ince bosluk zaten panelin maskeli (transparan) bolgesine denk
     * gelir. Diger sayfalarin final-cta gorselleri paylasilan varsayilani korur. */
    .home-cta-equal .pmap-overview-cta-photo {
        background-size: contain;
        background-position: right center;
    }
}

/* Ana sayfa kapanis CTA'sinin mor panelinin iki yanindaki bos alanlar, ust
 * taraftaki SSS (pmap-faq) bolumuyle ayni gri arka plana sahip olsun.
 *
 * Sorun: bu bolum `w-section` ile max-width 1536px ve `margin: 0 auto` aliyor;
 * bu yuzden genis ekranda iki yanda body'nin beyazi gorunuyordu. Ayrica
 * `px-section` (96px) yan dolgu da var. Arka plani yalnizca bolume vermek
 * yetmez; griyi tum viewport genisligine (full-bleed) yaymak gerekir.
 *
 * Cozum: bolumun arka planini 100vw genisliginde bir ::before ile, panelin
 * arkasinda (z-index:-1) ciziyoruz. Boylece panelin gercek genisligi (icerik
 * akisi) hic degismez; sadece yanlardaki bos serit gri olur.
 * html/body { overflow-x: clip } oldugu icin 100vw yatay scroll yaratmaz.
 * Renk referansi: template-parts/sections/pmap-faq.php -> .pmap-faq { background: #f7f8fb; } */
.home-cta-equal {
    position: relative;
}
.home-cta-equal::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    margin-left: -50vw;
    width: 100vw;
    background-color: #f7f8fb;
    z-index: -1;
    pointer-events: none;
}


/* ==========================================================================
   F34b: Resources mega-menu featured e-book sunumu
   Resources dropdown sol paneli, kapagi golgeli/hafif egik bir kitap urunu
   olarak gosterir. Komsu Datasheet/E-book kartlariyla ayni "gerçek kapak"
   hissini tasir. Panelin kendisi tiklanabilir (<a>), CTA gorsel span'dir.
   ========================================================================== */
.pmap-menu-ebook {
    align-items: center;
    justify-content: space-between;
    text-align: center;
    text-decoration: none;
}
.pmap-menu-ebook__glow {
    position: absolute;
    left: 50%;
    top: 46%;
    width: 80%;
    height: 50%;
    transform: translate(-50%, -50%);
    background: radial-gradient(ellipse at center, rgba(0, 150, 199, 0.30), transparent 68%);
    filter: blur(8px);
    pointer-events: none;
}
.pmap-menu-ebook__coverwrap {
    display: block;
    perspective: 1000px;
    margin: 0.5rem 0;
}
.pmap-menu-ebook__cover {
    display: block;
    width: 100%;
    max-width: 290px;
    height: auto;
    margin: 0 auto;
    border-radius: 8px;
    box-shadow:
        0 2px 4px rgba(0, 0, 0, 0.45),
        0 26px 50px -14px rgba(0, 0, 0, 0.78),
        0 0 0 1px rgba(255, 255, 255, 0.08);
    transform: rotateY(-9deg) rotateZ(-1.5deg);
    transition: transform 0.45s ease, box-shadow 0.45s ease;
}
.pmap-menu-ebook:hover .pmap-menu-ebook__cover,
.pmap-menu-ebook:focus-visible .pmap-menu-ebook__cover {
    transform: rotateY(-4deg) rotateZ(0deg) translateY(-4px);
    box-shadow:
        0 2px 4px rgba(0, 0, 0, 0.45),
        0 34px 64px -14px rgba(0, 0, 0, 0.82),
        0 0 0 1px rgba(255, 255, 255, 0.12);
}
.pmap-menu-ebook__cta {
    align-self: center;
}

/* ==========================================================================
   Footer legal links — tek satir, dikey bullet listesi yerine yatay,
   aralarinda ince " | " ayraci. Global footer.php .footer-legal <ul>'sine
   uygulanir; brand-override global enqueue edildigi icin her sayfada gecerli.
   ========================================================================== */
.footer-legal {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}
@media (min-width: 768px) {
    .footer-legal {
        justify-content: flex-end;
    }
}
.footer-legal li {
    display: inline-flex;
    align-items: center;
}
.footer-legal li + li::before {
    content: "|";
    margin: 0 0.7rem;
    color: rgba(255, 255, 255, 0.22);
    font-weight: 400;
}
.footer-legal a {
    color: #fff;
    font-weight: 600;
    text-decoration: none;
    transition: color 0.2s ease;
}
.footer-legal a:hover,
.footer-legal a:focus-visible {
    color: #5EE5FF;
}

/*
 * Mega-menu (desktop dropdown) okunabilirlik duzeltmesi.
 * ----------------------------------------------------------------------------
 * Aksan token'i --color-teal-2 (#232A86) acik zeminler icin koyu laciverte
 * cevrildi. Ancak mega-menu panellerinin zemini de koyu lacivert gradient
 * (linear-gradient(38deg,#041361 -> #0E1322)). Bu yuzden .text-teal ile basilan
 * sutun basliklari (Platform overview, Capabilities, Identity RBAC vb.) ve sol
 * promo kolonundaki eyebrow yazilari (The PMAP platform, We're Hiring! vb.)
 * okunmuyordu.
 *
 * Karar (kullanici): teal aksan kaldirildi; koyu panelde beyaz / acik gri
 * okunabilir hiyerarsi kullanilir.
 *   - Sutun basliklari (font-semibold)      -> beyaz #ffffff
 *   - Eyebrow etiketleri (headline-whisper) -> yumusak gri #AEB4C7
 *   - Alt linkler (text-sm font-light)      -> acik gri-mavi #C7CCEA
 *   - Hover/focus                           -> hafif soluk beyaz
 * Kapsam .mainmenu-container ile sinirli; global token degismez.
 */
.mainmenu-container .text-teal {
    color: #ffffff;
}
.mainmenu-container .text-headline-whisper.text-teal {
    color: #AEB4C7;
}
.mainmenu-container a.text-sm.text-teal {
    color: #C7CCEA;
}
.mainmenu-container a.text-teal:hover,
.mainmenu-container a.text-teal:focus-visible,
.mainmenu-container .hover\:text-teal-3:hover,
.mainmenu-container .hover\:text-teal-3:focus-visible {
    color: rgba(255, 255, 255, 0.72);
}



