/*
Theme Name: Kurumsal Minimal
Theme URI: https://example.com/
Author: Bülent Özçetin
Description: Kurumsal, ultra-minimal, mobil uyumlu, PageSpeed odaklı WordPress teması.
Version: 2.5.3
Requires at least: 6.3
Tested up to: 6.6
Requires PHP: 8.0
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kurumsal-minimal
*/

/* Minimal reset */
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body { margin: 0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; line-height: 1.6; }
img { max-width: 100%; height: auto; }
a { color: inherit; text-underline-offset: .2em; }
.container { width: min(1100px, 92vw); margin-inline: auto; }
.skip-link { position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip-link:focus { left: 1rem; top: 1rem; width:auto; height:auto; padding:.5rem .75rem; background:#fff; border:1px solid #000; z-index:9999; }

.site-header { padding: 1rem 0; border-bottom: 1px solid rgba(0,0,0,.08); }
.site-title { margin: 0; font-size: 1.05rem; font-weight: 700; }
.site-title a { text-decoration: none; }
.site-nav { margin-top: .5rem; }
.site-nav ul { display:flex; flex-wrap:wrap; gap:.75rem 1rem; list-style:none; padding:0; margin:.5rem 0 0; }
.site-nav a { text-decoration: none; opacity: .9; }
.site-nav a:hover { opacity: 1; text-decoration: underline; }

main { padding: 1.25rem 0 2rem; }
.entry-title { margin: 0 0 .5rem; line-height: 1.25; }
.entry-meta { font-size: .9rem; opacity: .75; margin-bottom: 1rem; }
.breadcrumbs { font-size: .9rem; opacity: .75; margin: .75rem 0 1rem; }
.card { padding: 1rem 0; border-bottom: 1px solid rgba(0,0,0,.08); }
.card:last-child { border-bottom: 0; }
.excerpt { margin: .35rem 0 0; opacity: .9; }

.site-footer { padding: 1.5rem 0; border-top: 1px solid rgba(0,0,0,.08); font-size: .95rem; opacity: .9; }
.footer-row { display:flex; flex-wrap:wrap; gap:.5rem 1rem; align-items:center; justify-content:space-between; }

/* Header layout */
.site-brand { display:flex; align-items:center; justify-content:space-between; gap: 1rem; }
.brand-left { display:flex; align-items:center; gap: .75rem; min-width: 0; }
.custom-logo { max-width: 261px; height: 100px; width: auto; display: block; }
.site-title { margin: 0; font-size: 1.05rem; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.site-nav { margin-top: 0; }
.site-nav ul { justify-content: flex-end; }

/* Hero */
.hero { margin: 0; padding: 0; }
.hero-inner { padding: 2.25rem 0 2rem; }
.hero.has-bg { position: relative; border-bottom: 1px solid rgba(0,0,0,.08); }
.hero.has-bg .hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.hero.has-bg .container { position: relative; z-index: 1; }
.hero-title { margin: 0 0 .5rem; line-height: 1.2; font-size: 1.75rem; }
.hero-lead { margin: 0; max-width: 60ch; opacity: .9; }
.hero-actions { margin-top: 1rem; display:flex; flex-wrap:wrap; gap:.75rem; }
.btn { display:inline-block; padding:.6rem .9rem; border:1px solid rgba(0,0,0,.18); border-radius: 999px; text-decoration:none; }
.btn:hover { border-color: rgba(0,0,0,.35); }

/* Responsive */
@media (max-width: 720px) {
  .site-brand { align-items:flex-start; flex-direction:column; }
  .site-nav ul { justify-content:flex-start; }
  .hero-title { font-size: 1.5rem; }
}

/* Breadcrumbs (aesthetic) */
.breadcrumbs { font-size: .9rem; opacity: .85; margin: .75rem 0 0; }
.breadcrumbs a { text-decoration: none; border-bottom: 1px solid rgba(0,0,0,.18); }
.breadcrumbs a:hover { border-bottom-color: rgba(0,0,0,.35); }
.breadcrumbs span { opacity: .9; }

/* Hero refinements (less tall, page-friendly) */
.hero-inner { padding: 1.65rem 0 1.4rem; }
.hero-title { font-size: 1.65rem; }
.hero-lead { margin-top: .25rem; }
/* Color bar when no image */
.hero.no-bg { border-bottom: 1px solid rgba(0,0,0,.08); background: linear-gradient(to bottom, rgba(17,17,17,.04), rgba(17,17,17,0)); }

@media (max-width: 720px) {
  .hero-inner { padding: 1.25rem 0 1.1rem; }
  .hero-title { font-size: 1.35rem; }
}

/* Global accent (Customizer) */
:root { --km-accent: #111111; --km-accent-contrast: #ffffff; }

/* Sticky header */
.site-header { position: sticky; top: 0; z-index: 999; background: color-mix(in srgb, var(--km-accent) 6%, #ffffff); backdrop-filter: saturate(120%) blur(6px); }

/* Mobile logo center without affecting menu */
.brand-spacer { display:none; }
@media (max-width: 720px) {
  .site-brand { display:grid; grid-template-columns: 1fr auto 1fr; align-items:center; gap:.75rem; }
  .brand-spacer { display:block; }
  .brand-left { justify-self:center; }
  .nav-toggle { justify-self:end; }
  .site-nav { grid-column: 1 / -1; }
}

/* Hero background as real img for retina sharpness */
.hero.has-bg .hero-bg-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center; }
.hero.has-bg .hero-bg { display:none; } /* legacy fallback */
/* Breadcrumb inside hero */
.hero .breadcrumbs { margin-top: .65rem; }

/* Bottom sticky contact bar (mobile) */
.km-contactbar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 1000;
  display: none;
  border-top: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px) saturate(120%);
}
.km-contactbar .inner { width: min(1100px, 92vw); margin: 0 auto; padding: .6rem 0; display:flex; gap:.75rem; }
.km-contactbar a { flex: 1; text-align:center; padding: .65rem .75rem; border: 1px solid rgba(0,0,0,.16); border-radius: 999px; text-decoration:none; }
.km-contactbar a:hover { border-color: rgba(0,0,0,.32); }
/* Blog layout mapping */
.km-blog.km-layout-desktop-grid .km-loop { display:grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.km-blog.km-layout-desktop-media .card { display:grid; grid-template-columns: 160px 1fr; gap: 1rem; align-items:start; }
.km-blog.km-layout-desktop-list .km-loop { display:block; }
.km-thumb { aspect-ratio: 16 / 10; width: 100%; border-radius: 12px; overflow:hidden; border:1px solid rgba(0,0,0,.08); }
.km-thumb img { width:100%; height:100%; object-fit:cover; display:block; }

@media (max-width: 900px) {
  .km-blog.km-layout-desktop-grid .km-loop { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .km-blog.km-layout-mobile-grid .km-loop { display:grid; grid-template-columns: 1fr; gap: 1rem; }
  .km-blog.km-layout-mobile-media .card { display:grid; grid-template-columns: 1fr; }
  .km-blog.km-layout-mobile-list .km-loop { display:block; }
}

/* Mobile menu (accessible toggle) */
.nav-toggle{
  display:none;
  padding:.55rem .75rem;
  border:1px solid rgba(0,0,0,.18);
  border-radius:999px;
  background:transparent;
  cursor:pointer;
}
.nav-toggle:focus{ outline:2px solid rgba(0,0,0,.35); outline-offset:2px; }

@media (max-width: 720px){
  .nav-toggle{ display:inline-flex; align-items:center; justify-content:center; }
  .site-nav ul{ display:none !important; flex-direction:column; gap:.35rem; padding-top:.75rem; }
  .site-nav.is-open ul{ display:flex !important; }
  .site-nav a{ padding:.35rem 0; }
}

/* Mobile menu: hide primary links until toggle (tablet+mobile) */
@media (max-width: 992px){
  .nav-toggle{ display:inline-flex !important; align-items:center; justify-content:center; }
  .site-nav ul{ display:none !important; flex-direction:column; gap:.35rem; padding-top:.75rem; }
  .site-nav.is-open ul{ display:flex !important; }
  .site-nav a{ padding:.35rem 0; }

  /* Center logo without affecting menu button */
  .site-brand{ display:grid; grid-template-columns: 1fr auto 1fr; align-items:center; gap:.75rem; }
  .brand-spacer{ display:block; }
  .brand-left{ justify-self:center; }
  .nav-toggle{ justify-self:end; }
  .site-nav{ grid-column: 1 / -1; }
}

/* Mobile menu overlay (does not push content) */
@media (max-width: 992px){
  .site-header .container.site-brand{ position: relative; }

  .site-nav{
    position: absolute;
    left: 0; right: 0;
    top: 100%;
    padding: 0;
    margin: 0;
    background: rgba(255,255,255,.98);
    border-top: 1px solid rgba(0,0,0,.08);
    box-shadow: 0 12px 28px rgba(0,0,0,.08);
    display: none;
  }
  .site-nav.is-open{ display:block; }
  .site-nav ul{ display:flex !important; padding: .85rem 1.1rem .95rem; }
  .site-nav li{ margin: 0; }
  .site-nav a{ padding: .5rem 0; }

  /* Hamburger icon */
  .nav-toggle{
    width: 44px; height: 44px;
    padding: 0;
    border-radius: 12px;
    display:inline-flex !important;
  }
  .nav-icon{ width: 22px; height: 16px; display:inline-flex; flex-direction:column; justify-content:space-between; }
  .nav-icon span{ height: 2px; width: 100%; background: rgba(0,0,0,.75); border-radius: 2px; display:block; }
}

/* Backdrop overlay for mobile menu */
@media (max-width: 992px){
  .km-nav-backdrop{
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.28);
    display: none;
    z-index: 998;
  }
  .site-header{ z-index: 999; }
  .site-nav{ z-index: 999; }
  .km-nav-backdrop.is-open{ display:block; }
}

/* Sticky rules:
   - Desktop: header sticky (logo + menu)
   - Mobile/tablet: header NOT sticky; only hamburger button is sticky
*/
@media (min-width: 993px){
  .site-header{ position: sticky; top: 0; z-index: 999; }
}
@media (max-width: 992px){
  .site-header{ position: static !important; top: auto; }
}

/* Mobile sticky menu button (user-friendly) */
@media (max-width: 992px){
  .km-mobile-menu-btn{
    position: fixed;
    top: 12px;
    right: 12px;
    width: 52px;
    height: 52px;
    border: 1px solid rgba(0,0,0,.12);
    border-radius: 14px;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(8px) saturate(120%);
    box-shadow: 0 10px 24px rgba(0,0,0,.10);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 1100;
    cursor: pointer;
  }
  .km-mobile-menu-btn:focus{ outline: 2px solid rgba(0,0,0,.35); outline-offset: 2px; }

  .km-hamburger{
    width: 22px;
    height: 16px;
    display: inline-flex;
    flex-direction: column;
    justify-content: space-between;
  }
  .km-hamburger span{
    height: 2.5px;
    width: 100%;
    background: rgba(0,0,0,.78);
    border-radius: 3px;
    display: block;
  }

  /* Off-canvas panel for primary menu */
  .site-nav{
    position: fixed !important;
    top: 0;
    right: 0;
    height: 100vh;
    width: min(320px, 86vw);
    background: rgba(255,255,255,.98);
    box-shadow: -18px 0 40px rgba(0,0,0,.14);
    border-left: 1px solid rgba(0,0,0,.08);
    transform: translateX(110%);
    transition: transform .22s ease;
    z-index: 1099;
    display: block !important; /* keep in DOM, hidden by transform */
    padding: 16px 16px 18px;
  }
  .site-nav.is-open{ transform: translateX(0); }
  .site-nav ul{ display:flex !important; flex-direction:column; gap: .35rem; padding-top: 46px; }
  .site-nav a{ padding: .55rem 0; font-size: 1.05rem; }

  /* Hide header inline toggle on mobile */
  .nav-toggle{ display:none !important; }
}

@media (max-width: 992px){
  .km-nav-backdrop{ z-index: 1098; }
}

/* FIX: ensure mobile menu button visible */
@media (max-width: 992px){
  .km-mobile-menu-btn{ display:inline-flex !important; }
}

/* FIX: keep contact bar above content */
@media (max-width: 720px){
  .km-contactbar{
    bottom: 0;
    left: 0;
    right: 0;
    transform: none;
  }
}

/* Admin bar offsets (when logged in) */
@media (max-width: 992px){
  body.admin-bar .km-mobile-menu-btn{ top: calc(12px + 46px); }
}

/* Contact bar should follow same breakpoint as mobile menu */
@media (max-width: 992px){
  body{ padding-bottom: 64px; }
  .km-contactbar{ display:block; }
}
@media (min-width: 993px){
  body{ padding-bottom: 0; }
}

/* HARD OVERRIDES (ensure mobile menu button visible and no layout conflicts) */
.km-mobile-menu-btn{ display:none; }
@media (max-width: 992px){
  .km-mobile-menu-btn{ display:inline-flex !important; z-index: 2000; }
  .site-nav{ z-index: 1999 !important; }
  .km-nav-backdrop{ z-index: 1998 !important; }

  /* make sure header inline elements don't interfere */
  .nav-toggle{ display:none !important; }
}

@media (max-width: 992px){
  .km-contactbar{ z-index: 1200; }
}

/* === MOBILE MENU CLEAN OVERRIDE (v2.1.3) === */
@media (max-width: 992px){
  html, body{ overflow-x: hidden; }

  /* Force off-canvas panel, regardless of earlier rules */
  .site-nav{
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: auto !important;
    height: 100vh !important;
    width: min(320px, 86vw) !important;
    margin: 0 !important;
    padding: 16px 16px 18px !important;

    background: rgba(255,255,255,.98) !important;
    border-left: 1px solid rgba(0,0,0,.08) !important;
    box-shadow: -18px 0 40px rgba(0,0,0,.14) !important;

    display: block !important;

    transform: translateX(110%) !important;
    visibility: hidden !important;
    pointer-events: none !important;

    z-index: 1999 !important;
  }
  .site-nav.is-open{
    transform: translateX(0) !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
  .site-nav ul{
    display: flex !important;
    flex-direction: column !important;
    gap: .35rem !important;
    padding: 46px 0 0 !important;
  }

  /* Ensure header inline menu toggle doesn't appear */
  .nav-toggle{ display:none !important; }

  /* Backdrop sits under panel & button */
  .km-nav-backdrop{ z-index: 1998 !important; }

  /* Menu button always visible */
  .km-mobile-menu-btn{ display:inline-flex !important; z-index: 2000 !important; }

  /* Contact bar stable */
  .km-contactbar{ left:0 !important; right:0 !important; bottom:0 !important; transform:none !important; z-index:1200 !important; }
  body{ padding-bottom: 64px !important; }
}
@media (min-width: 993px){
  body{ padding-bottom: 0 !important; }
}

/* Z-INDEX LAYERING (mobile off-canvas)
   - button stays on top
   - menu panel sits under button but above everything else
   - backdrop under panel
   - contactbar under panel
*/
@media (max-width: 992px){
  .km-mobile-menu-btn{ z-index: 3000 !important; }
  .site-nav{ z-index: 2900 !important; }
  .km-nav-backdrop{ z-index: 2800 !important; }
  .km-contactbar{ z-index: 1200 !important; }

  /* Ensure panel content starts below the icon area */
  .site-nav ul{ padding-top: 72px !important; }
}

/* FIX: ensure off-canvas menu stacks above hero/content (mobile)
   Some browsers create stacking contexts; make header a high z-index context without being sticky.
*/
@media (max-width: 992px){
  .site-header{
    position: relative !important;
    z-index: 3500 !important;
    backdrop-filter: none !important; /* avoid stacking/context bugs */
  }
}

@media (max-width: 992px){
  .km-mobile-menu-btn{ z-index: 3600 !important; }
  .site-nav{ z-index: 3550 !important; }
  .km-nav-backdrop{ z-index: 3540 !important; }
}

/* km-contactbar color system (mobile) */
@media (max-width: 992px){
  .km-contactbar{
    background: rgba(15, 23, 42, .92); /* slate-900 */
    border-top: 1px solid rgba(255,255,255,.10);
  }
  .km-contactbar .inner{ padding: .65rem 0; }
  .km-contactbar a{
    border: 0;
    color: #ffffff;
    font-weight: 700;
  }
  .km-contactbar a[href^="tel:"]{
    background: rgba(37, 99, 235, .98); /* blue-600 */
  }
  .km-contactbar a[href*="wa.me"], .km-contactbar a[href*="whatsapp"]{
    background: rgba(37, 211, 102, .98); /* WhatsApp green */
  }
  .km-contactbar a:focus{
    outline: 2px solid rgba(255,255,255,.65);
    outline-offset: 2px;
  }
}

/* Blog: Görsel (image-forward) layout */
.km-blog.km-layout-desktop-media .card{
  display:block !important;
}
.km-blog.km-layout-desktop-media .km-thumb{
  margin-bottom: .85rem;
  aspect-ratio: 16 / 9;
  border-radius: 16px;
}
.km-blog.km-layout-desktop-media .entry-title a{
  text-decoration: none;
}

/* Hero actions buttons */
.hero-actions{ display:flex; gap:.75rem; flex-wrap:wrap; margin-top: 1rem; }
.hero-actions .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: .70rem 1.05rem;
  border-radius: 999px;
  text-decoration:none;
  font-weight: 700;
  border: 1px solid rgba(0,0,0,.10);
  background: var(--km-accent);
  color: var(--km-accent-contrast);
}
.hero-actions .btn:hover{ filter: brightness(0.96); }
@media (max-width: 720px){
  .hero-actions{ gap:.6rem; }
  .hero-actions .btn{ width: 100%; }
}

/* Hero background overlay (Customizer-controlled) */
.hero.has-bg::after{
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.78),
    rgba(255, 255, 255, 0.96)
  );
}

/* Hero background image visibility (Customizer) */
.hero-bg-img{ opacity: var(--km-hero-img-op, 0.75); }

/* km-contactbar (mobile) – modern, high-contrast */
@media (max-width: 992px){
  .km-contactbar{
    background: rgba(15, 23, 42, .92);
    border-top: 1px solid rgba(255,255,255,.10);
  }
  .km-contactbar a{ border:0; color:#fff; font-weight:700; }
  .km-contactbar a[href^="tel:"]{ background: rgba(37, 99, 235, .98); }
  .km-contactbar a[href*="wa.me"], .km-contactbar a[href*="whatsapp"]{ background: rgba(37, 211, 102, .98); }
}

/* Blog: Görsel (Büyük Görsel) layout */
.km-blog.km-layout-desktop-media .card{ display:block !important; }
.km-blog.km-layout-desktop-media .km-thumb{
  margin-bottom: .85rem;
  aspect-ratio: 16 / 9;
  border-radius: 16px;
}

/* Hero actions buttons */
.hero-actions{ display:flex; gap:.75rem; flex-wrap:wrap; margin-top:1rem; }
.hero-actions .btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.70rem 1.05rem; border-radius:999px;
  text-decoration:none; font-weight:700;
  border:1px solid rgba(0,0,0,.10);
  background: var(--km-accent);
  color: var(--km-accent-contrast);
}
@media (max-width: 720px){ .hero-actions .btn{ width:100%; } }




/* Hero breadcrumbs visibility (esp. on featured image) */
.hero.has-bg .breadcrumbs{
  opacity: 1;
  display: inline-block;
  margin-top: .75rem;
  padding: .35rem .6rem;
  border-radius: 999px;
  background: rgba(255,255,255,.70);
}
.hero.has-bg .breadcrumbs a{ opacity: 1; }

/* ===========================
   KM HOME - HARD SCOPED
   Tema ile çakışmayı azaltmak için izolasyon + reset
   =========================== */

.km-home{
  /* design tokens */
  --km-bg:#fff;
  --km-fg:#0f172a;
  --km-muted:#475569;
  --km-soft:#f1f5f9;
  --km-card:#fff;
  --km-border:#e2e8f0;
  --km-accent:#0ea5e9;
  --km-accent2:#22c55e;
  --km-shadow:0 12px 30px rgba(15,23,42,.10);

  background:var(--km-bg);
  color:var(--km-fg);

  /* theme override safety */
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  font-size:16px;
  line-height:1.6;
}

/* scoped reset */
.km-home, .km-home *{ box-sizing:border-box; }
.km-home :where(h1,h2,h3,p,ul,ol,li){ margin:0; padding:0; }
.km-home :where(ul,ol){ list-style:none; }
.km-home :where(a){ color:inherit; text-decoration:none; }
.km-home :where(img,svg){ max-width:100%; height:auto; display:block; }

/* avoid theme max-width or floats breaking grid */
.km-home :where(.km-home__container, .km-home__hero-grid, .km-home__cards, .km-home__steps){
  float:none !important;
  clear:both;
}

/* layout container */
.km-home__container{
  max-width:1120px;
  margin-inline:auto;
  padding-inline:18px;
}

/* HERO */
.km-home__hero{
  padding:44px 0 28px;
  border-bottom:1px solid var(--km-border);
  background:
    radial-gradient(900px 340px at 10% 10%, rgba(14,165,233,.12), transparent 60%),
    radial-gradient(900px 340px at 90% 30%, rgba(34,197,94,.10), transparent 55%),
    linear-gradient(180deg, #fff, #fff);
}

.km-home__hero-grid{
  display:grid;
  grid-template-columns: 1.25fr .85fr;
  gap:24px;
  align-items:center;
}

/* IMPORTANT: grid overflow fix */
.km-home__hero-copy,
.km-home__hero-visual{ min-width:0; }

.km-home__badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 12px;
  border:1px solid var(--km-border);
  border-radius:999px;
  background:rgba(255,255,255,.78);
  color:var(--km-muted);
  font-size:13px;
  font-weight:700;
}

.km-home__badge-dot{
  width:10px;height:10px;border-radius:999px;
  background:var(--km-accent2);
  box-shadow:0 0 0 4px rgba(34,197,94,.15);
}

.km-home__h1{
  margin-top:14px;
  font-size: clamp(28px, 2.8vw, 44px);
  line-height:1.12;
  letter-spacing:-0.02em;
  font-weight:900;
}

.km-home__h1-sub{
  display:block;
  margin-top:10px;
  color:var(--km-muted);
  font-size:15px;
  font-weight:700;
}

.km-home__lead{
  margin-top:14px;
  color:var(--km-muted);
  font-size:16px;
  max-width:62ch;
}

.km-home__ticks{
  margin-top:16px;
  display:grid;
  gap:10px;
}

.km-home__ticks li{
  position:relative;
  padding-left:28px;
  font-weight:700;
  color:var(--km-fg);
}

.km-home__ticks li::before{
  content:"✓";
  position:absolute;
  left:0; top:0;
  width:20px; height:20px;
  border-radius:6px;
  display:grid;
  place-items:center;
  background: rgba(14,165,233,.12);
  color:#0369a1;
  font-weight:900;
}

.km-home__cta{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.km-home__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 16px;
  border-radius:12px;
  border:1px solid var(--km-border);
  font-weight:900;
  letter-spacing:.01em;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

.km-home__btn:focus-visible{
  outline:3px solid rgba(14,165,233,.25);
  outline-offset:2px;
}

.km-home__btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(15,23,42,.08);
}

.km-home__btn--primary{
  background: linear-gradient(135deg, rgba(14,165,233,1), rgba(59,130,246,1));
  color:#fff;
  border-color:transparent;
}

.km-home__btn--ghost{
  background: rgba(255,255,255,.82);
}

.km-home__trust{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:10px;
}

.km-home__trust-item{
  padding:12px;
  border:1px solid var(--km-border);
  background: rgba(255,255,255,.78);
  border-radius:14px;
}

.km-home__trust-item strong{
  display:block;
  font-size:14px;
  line-height:1.2;
  font-weight:900;
}

.km-home__trust-item span{
  display:block;
  margin-top:4px;
  font-size:13px;
  color:var(--km-muted);
}

/* HERO VISUAL */
.km-home__hero-visual{
  display:grid;
  place-items:center;
}

.km-home__visual-card{
  width:min(420px,100%);
  aspect-ratio: 4 / 3;
  border-radius:22px;
  border:1px solid var(--km-border);
  background:
    radial-gradient(280px 160px at 30% 30%, rgba(14,165,233,.20), transparent 60%),
    radial-gradient(280px 160px at 70% 55%, rgba(34,197,94,.16), transparent 55%),
    linear-gradient(180deg, #ffffff, #f8fafc);
  box-shadow:var(--km-shadow);
  position:relative;
  overflow:hidden;
  padding:18px;
}

.km-home__visual-line{
  height:12px;
  border-radius:999px;
  background: rgba(15,23,42,.08);
  margin-bottom:12px;
}

.km-home__visual-line--2{ width:78%; }
.km-home__visual-line--3{ width:62%; }

.km-home__visual-kpi{
  position:absolute;
  left:16px; right:16px; bottom:16px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:10px;
}

.km-home__kpi{
  border:1px solid var(--km-border);
  background: rgba(255,255,255,.80);
  border-radius:14px;
  padding:10px;
}

.km-home__kpi-title{
  display:block;
  color:var(--km-muted);
  font-size:12px;
  font-weight:800;
}

.km-home__kpi-value{
  display:block;
  margin-top:2px;
  font-weight:1000;
}

/* SECTIONS */
.km-home__section{ padding:34px 0; }

.km-home__section--alt{
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  border-top:1px solid var(--km-border);
  border-bottom:1px solid var(--km-border);
}

.km-home__section-head{
  display:grid;
  gap:8px;
  margin-bottom:18px;
}

.km-home__h2{
  font-size: clamp(20px, 2vw, 30px);
  line-height:1.2;
  letter-spacing:-0.015em;
  font-weight:1000;
}

.km-home__h2--compact{
  font-size: clamp(18px, 1.8vw, 26px);
}

.km-home__sub{
  color:var(--km-muted);
  max-width:75ch;
}

/* CARDS */
.km-home__cards{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:12px;
}

.km-home__card{
  border:1px solid var(--km-border);
  border-radius:18px;
  padding:16px;
  background:var(--km-card);
  box-shadow: 0 1px 0 rgba(15,23,42,.04);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.km-home__card:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(15,23,42,.10);
  border-color: rgba(14,165,233,.35);
}

.km-home__h3{
  font-size:16px;
  line-height:1.25;
  font-weight:900;
  margin-bottom:8px;
}

.km-home__card p{
  color:var(--km-muted);
  font-size:14px;
  margin-bottom:12px;
}

.km-home__link{
  display:inline-flex;
  gap:8px;
  align-items:center;
  font-weight:1000;
  color:#0369a1;
}
.km-home__link::after{ content:"→"; transform: translateY(-1px); }

/* STEPS */
.km-home__steps{ display:grid; gap:10px; }

.km-home__step{
  display:grid;
  grid-template-columns: 44px 1fr;
  gap:12px;
  align-items:start;
  padding:14px;
  border-radius:18px;
  border:1px solid var(--km-border);
  background: rgba(255,255,255,.82);
}

.km-home__step-no{
  width:44px; height:44px;
  border-radius:14px;
  display:grid;
  place-items:center;
  font-weight:1000;
  background: rgba(14,165,233,.12);
  color:#0369a1;
}

.km-home__step-body p{
  color:var(--km-muted);
  font-size:14px;
}

/* CTA BAND */
.km-home__cta-band{
  padding:26px 0;
  background:
    radial-gradient(800px 260px at 15% 50%, rgba(14,165,233,.14), transparent 60%),
    radial-gradient(800px 260px at 85% 40%, rgba(34,197,94,.12), transparent 55%),
    linear-gradient(180deg, #fff, #fff);
  border-top:1px solid var(--km-border);
}

.km-home__cta-band-grid{
  display:grid;
  grid-template-columns: 1.3fr .7fr;
  gap:14px;
  align-items:center;
}

.km-home__cta-band-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  flex-wrap:wrap;
}

/* RESPONSIVE */
@media (max-width: 980px){
  .km-home__hero-grid{ grid-template-columns: 1fr; }
  .km-home__hero-visual{ order:-1; }
  .km-home__trust{ grid-template-columns: 1fr; }
  .km-home__cards{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .km-home__cta-band-grid{ grid-template-columns: 1fr; }
  .km-home__cta-band-actions{ justify-content:flex-start; }
}

@media (max-width: 560px){
  .km-home__cards{ grid-template-columns: 1fr; }
  .km-home__btn{ width:100%; }
}

/* ==== FIX: Nasıl Çalışıyoruz? (Steps) düzgün sıralama ==== */
.km-home .km-home__steps{
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;

  /* tema bazen column/float basabiliyor */
  columns: auto !important;
  column-count: 1 !important;
}

.km-home .km-home__steps > li{
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;

  float: none !important;
  clear: both !important;

  /* her bir step tek satır grid */
  display: grid !important;
  grid-template-columns: 44px 1fr !important;
  gap: 12px !important;
  align-items: start !important;

  padding: 14px !important;
  border-radius: 18px !important;
  border: 1px solid var(--km-border) !important;
  background: rgba(255,255,255,.82) !important;
}

/* Numara kutusu sabit kalsın */
.km-home .km-home__step-no{
  grid-column: 1 !important;
  width: 44px !important;
  height: 44px !important;
  display: grid !important;
  place-items: center !important;
}

/* İçerik sağda kalsın, taşma yapmasın */
.km-home .km-home__step-body{
  grid-column: 2 !important;
  min-width: 0 !important;
}

/* Mobilde de kesin olarak alt alta */
@media (max-width: 560px){
  .km-home .km-home__steps > li{
    grid-template-columns: 44px 1fr !important; /* yine 2 kolon */
  }
}
/* ==== FIX: Hakkımızda hero visual kayma / hizalama ==== */
.km-home .km-home__hero-grid{
  align-items: center !important;
}

.km-home .km-home__hero-visual{
  min-width: 0 !important;
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 0 !important;
  padding: 0 !important;

  /* tema bazen transform ile kaydırıyor */
  transform: none !important;
}

.km-home .km-home__visual-card{
  width: min(420px, 100%) !important;
  max-width: 420px !important;
  margin: 0 auto !important;

  /* kartın grid/flex içinde taşmasını engeller */
  flex: 0 0 auto !important;

  /* tema bazen position/margin oynatıyor */
  position: relative !important;
  left: auto !important;
  right: auto !important;
}

/* Eğer tema "figure" gibi wrapper eklediyse onu da nötrle */
.km-home .km-home__hero-visual :where(figure, .wp-block-image, .wp-block-media-text__media){
  margin: 0 !important;
  float: none !important;
  max-width: 100% !important;
}

/* Tablet ve altı: visual üstte, ortalı dursun */
@media (max-width: 980px){
  .km-home .km-home__hero-visual{
    order: -1 !important;
  }
}

:root{
  --ref-bg:#0b1220;
  --ref-text:#0f172a;
  --ref-muted:#475569;
  --ref-line:rgba(15,23,42,.10);
  --ref-primary:#1d4ed8;
  --ref-accent:#0ea5e9;
  --ref-radius:20px;
  --ref-shadow:0 18px 50px rgba(2,8,23,.12);
  --ref-shadow-soft:0 10px 28px rgba(2,8,23,.08);
  --ref-container:1180px;
}

.ref-section{
  padding:72px 0;
  background:
    radial-gradient(900px 450px at 10% 0%, rgba(14,165,233,.10), transparent 60%),
    radial-gradient(900px 450px at 90% 25%, rgba(29,78,216,.10), transparent 60%),
    linear-gradient(180deg,#ffffff,#ffffff);
  color:var(--ref-text);
}

.ref-container{max-width:var(--ref-container); margin:0 auto; padding:0 22px;}

.ref-head{max-width:900px; margin:0 0 22px;}
.ref-title{
  margin:0 0 10px;
  font-size:38px;
  line-height:1.12;
  letter-spacing:-.02em;
}
.ref-lead{
  margin:0;
  font-size:16px;
  line-height:1.8;
  color:var(--ref-muted);
}

.ref-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin:22px 0 24px;
}
.ref-stat{
  background:rgba(255,255,255,.92);
  border:1px solid var(--ref-line);
  border-radius:16px;
  padding:14px;
  box-shadow:var(--ref-shadow-soft);
  position:relative;
  overflow:hidden;
}
.ref-stat:before{
  content:"";
  position:absolute; inset:-2px;
  background:radial-gradient(260px 160px at 0% 0%, rgba(14,165,233,.12), transparent 60%);
  pointer-events:none;
}
.ref-stat-no{font-weight:900; font-size:18px; letter-spacing:-.01em;}
.ref-stat-txt{margin-top:4px; color:var(--ref-muted); font-size:13.5px; line-height:1.5;}

.ref-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:10px;
}

.ref-card{
  background:#fff;
  border:1px solid var(--ref-line);
  border-radius:var(--ref-radius);
  padding:16px;
  box-shadow:var(--ref-shadow-soft);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  position:relative;
  overflow:hidden;
}
.ref-card:before{
  content:"";
  position:absolute; inset:-1px;
  border-radius:inherit;
  background:radial-gradient(340px 180px at 10% 0%, rgba(29,78,216,.10), transparent 55%);
  pointer-events:none;
}
.ref-card:hover{
  transform:translateY(-3px);
  box-shadow:0 22px 60px rgba(2,8,23,.14);
  border-color:rgba(29,78,216,.25);
}

.ref-name{
  margin:0 0 8px;
  font-size:16px;
  letter-spacing:-.01em;
}
.ref-job{
  margin:0 0 6px;
  font-weight:800;
  color:var(--ref-text);
}
.ref-loc{
  margin:0;
  color:var(--ref-muted);
}

.ref-cta{
  margin-top:28px;
  padding:18px;
  border-radius:var(--ref-radius);
  border:1px solid var(--ref-line);
  background:
    radial-gradient(600px 240px at 10% 0%, rgba(14,165,233,.10), transparent 60%),
    linear-gradient(180deg,#f8fafc,#ffffff);
  box-shadow:var(--ref-shadow-soft);
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:12px;
  align-items:center;
}
.ref-cta-title{margin:0 0 6px; font-size:22px; letter-spacing:-.02em;}
.ref-cta-lead{margin:0; color:var(--ref-muted); line-height:1.8;}
.ref-cta-actions{display:flex; justify-content:flex-end; flex-wrap:wrap; gap:10px;}

.ref-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 16px;
  border-radius:16px;
  text-decoration:none;
  font-weight:900;
  transition:.15s ease;
}
.ref-btn-primary{
  color:#fff;
  background:linear-gradient(90deg,var(--ref-primary),var(--ref-accent));
  box-shadow:0 14px 30px rgba(29,78,216,.25);
}
.ref-btn:hover{transform:translateY(-1px); filter:brightness(1.02);}

/* Responsive */
@media (max-width: 980px){
  .ref-stats{grid-template-columns:1fr;}
  .ref-grid{grid-template-columns:1fr 1fr;}
  .ref-cta{grid-template-columns:1fr;}
  .ref-cta-actions{justify-content:flex-start;}
  .ref-title{font-size:34px;}
}
@media (max-width: 560px){
  .ref-grid{grid-template-columns:1fr;}
  .ref-section{padding:56px 0;}
}