/* =================================================================
   ÖZBUDENT — Ağız ve Diş Sağlığı  ·  "Clinical Confidence"
   Lacivert + elektrik mavisi + beyaz · Poppins
   ================================================================= */

:root{
  --brand:        #0c5ce0;
  --brand-bright: #2b86ff;
  --cyan:         #46c6ff;
  --navy:         #0a2050;
  --navy-deep:    #06143a;
  --ink:          #0d1b34;
  --muted:        #5a6a85;
  --paper:        #f4f7fc;
  --paper-2:      #e9f0fb;
  --white:        #ffffff;
  --line:         rgba(12,32,80,.10);
  --line-strong:  rgba(12,32,80,.16);

  --shadow-sm: 0 1px 2px rgba(10,32,80,.06), 0 4px 14px rgba(10,32,80,.05);
  --shadow-md: 0 10px 30px rgba(10,32,80,.10), 0 2px 8px rgba(10,32,80,.06);
  --shadow-lg: 0 30px 70px rgba(8,28,72,.16), 0 8px 24px rgba(8,28,72,.08);
  --glow:      0 18px 50px rgba(12,92,224,.35);

  --r-sm: 12px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-xl: 40px;

  --display: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --sans: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --maxw: 1240px;
  --pad: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  letter-spacing:-0.011em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  transition:background-color .8s ease; /* drawer açılınca arka plan rengi yumuşak geçsin */
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--brand); color:#fff; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }

/* ---- Tipografi ölçekleri ---- */
.eyebrow{
  font-size:.74rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  color:var(--brand); display:inline-flex; align-items:center; gap:.6em;
}
.eyebrow::before{ content:""; width:26px; height:1.5px; background:var(--brand); display:inline-block; }
.section-no{
  font-family:var(--display); font-size:.95rem; font-weight:500; font-style:italic;
  color:var(--brand-bright); opacity:.8;
}
h1,h2,h3{ font-family:var(--display); font-weight:600; line-height:1.1; letter-spacing:-0.02em; color:var(--navy-deep); }
h2{ font-size:clamp(2rem,4.6vw,3.4rem); }
h3{ font-size:1.32rem; line-height:1.18; }
.lead{ font-size:clamp(1.05rem,1.7vw,1.22rem); color:var(--muted); font-weight:400; }
em.accent{ font-style:italic; color:var(--brand); }

/* ---- Butonlar ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  font-family:var(--sans); font-weight:600; font-size:.97rem; letter-spacing:-0.01em;
  padding:.92em 1.5em; border-radius:999px; cursor:pointer; border:1px solid transparent;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .25s, color .25s;
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:linear-gradient(135deg,var(--brand),var(--brand-bright)); color:#fff; box-shadow:var(--glow); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 24px 60px rgba(12,92,224,.45); }
.btn-ghost{ background:rgba(255,255,255,.7); color:var(--navy); border-color:var(--line-strong); backdrop-filter:blur(8px); }
.btn-ghost:hover{ transform:translateY(-3px); border-color:var(--brand); color:var(--brand); box-shadow:var(--shadow-md); }
.btn-dark{ background:var(--navy-deep); color:#fff; }
.btn-dark:hover{ transform:translateY(-3px); box-shadow:var(--shadow-lg); }
/* Form gönderim "bekleyiniz" durumu — app.js formKur() submit'te ekler (TR+EN) */
@keyframes ozbSpin{ to{ transform:rotate(360deg); } }
.btn.is-sending{ opacity:.9; cursor:progress; pointer-events:none; transform:none !important; }
.btn.is-sending:hover{ transform:none !important; }
.ozb-spin{ display:inline-block; width:1.05em; height:1.05em; border:2px solid currentColor; border-right-color:transparent; border-radius:50%; animation:ozbSpin .6s linear infinite; flex:0 0 auto; }

/* =================================================================
   ÜST BAR (topbar)
   ================================================================= */
.topbar{ position:relative; z-index:70; background:var(--navy-deep); color:rgba(255,255,255,.82); font-size:.84rem; }
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; min-height:42px; }
.tb-left{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.tb-left a, .tb-item{ display:inline-flex; align-items:center; gap:7px; color:rgba(255,255,255,.82); transition:color .2s; }
.tb-left a:hover{ color:#fff; }
.tb-left svg{ width:15px; height:15px; color:var(--cyan); flex:none; }
.tb-sep{ width:1px; height:14px; background:rgba(255,255,255,.18); flex:none; }
.tb-right{ display:flex; align-items:center; gap:14px; }
.tb-soc{ display:flex; align-items:center; gap:11px; }
.tb-soc a{ color:rgba(255,255,255,.7); transition:color .2s, transform .2s; }
.tb-soc a:hover{ color:#fff; transform:translateY(-2px); }
.tb-soc svg{ width:15px; height:15px; }

.tb-subeler{ position:relative; }
.tb-trigger{ display:inline-flex; align-items:center; gap:7px; background:none; border:none; cursor:pointer;
  color:#fff; font-family:var(--sans); font-size:.84rem; font-weight:600; padding:11px 0; }
.tb-trigger .pin{ width:15px; height:15px; color:var(--cyan); }
.tb-trigger .chev{ width:12px; height:12px; transition:transform .3s; }
.tb-subeler.open .tb-trigger .chev{ transform:rotate(180deg); }
@media (hover:hover){ .tb-subeler:hover .tb-trigger .chev{ transform:rotate(180deg); } }

.subeler-panel{ position:absolute; top:100%; right:0; z-index:200; padding-top:8px;
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:opacity .26s ease, transform .26s cubic-bezier(.2,.8,.2,1), visibility .26s; }
.tb-subeler.open .subeler-panel{ opacity:1; visibility:visible; transform:none; }
@media (hover:hover){
  .tb-subeler:hover .subeler-panel, .tb-subeler:focus-within .subeler-panel{ opacity:1; visibility:visible; transform:none; }
}
.sp-card{ width:min(660px, calc(100vw - 2*var(--pad))); background:#fff; border:1px solid var(--line); border-radius:20px;
  box-shadow:0 40px 80px rgba(8,28,72,.22), 0 8px 24px rgba(8,28,72,.1); overflow:hidden; }
.sp-head{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; padding:15px 22px;
  background:linear-gradient(100deg,var(--navy-deep),var(--brand)); color:#fff; }
.sp-head b{ font-family:var(--display); font-weight:600; font-size:1.05rem; }
.sp-head span{ font-size:.78rem; color:rgba(255,255,255,.74); }
.sp-grid{ display:grid; grid-template-columns:1fr 1fr; gap:2px; padding:14px; }
.sp-item{ display:flex; gap:12px; padding:13px 14px; border-radius:14px; transition:background .2s; }
.sp-item:hover{ background:var(--paper); }
.sp-item .pin{ width:38px; height:38px; flex:none; border-radius:11px; background:var(--paper-2); color:var(--brand); display:grid; place-items:center; transition:.22s; }
.sp-item:hover .pin{ background:linear-gradient(135deg,var(--brand),var(--cyan)); color:#fff; }
.sp-item .pin svg{ width:20px; height:20px; }
.sp-body{ flex:1; min-width:0; }
.sp-item b{ display:block; color:var(--navy-deep); font-size:.93rem; font-weight:600; }
.sp-item small{ display:block; color:var(--muted); font-size:.76rem; margin-top:2px; line-height:1.35; }
.sp-actions{ display:flex; gap:7px; margin-top:9px; flex-wrap:wrap; }
.sp-btn{ display:inline-flex; align-items:center; gap:6px; font-size:.76rem; font-weight:600; padding:.42em .85em; border-radius:999px; transition:transform .2s, box-shadow .2s, background .2s, border-color .2s; }
.sp-btn svg{ width:13px; height:13px; }
.sp-btn.call{ background:linear-gradient(135deg,var(--brand),var(--brand-bright)); color:#fff; }
.sp-btn.call:hover{ transform:translateY(-2px); box-shadow:0 8px 18px rgba(12,92,224,.32); }
.sp-btn.dir{ background:var(--paper-2); color:var(--brand); border:1px solid var(--line); }
.sp-btn.dir:hover{ transform:translateY(-2px); background:#fff; border-color:var(--brand); }
.sp-btn.page{ background:transparent; color:var(--navy); border:1px solid var(--line); }
.sp-btn.page:hover{ transform:translateY(-2px); color:var(--brand); border-color:var(--brand); background:#fff; }
.sp-foot{ padding:13px 22px; border-top:1px solid var(--line); text-align:center; background:var(--paper); }
.sp-foot a{ color:var(--brand); font-weight:600; font-size:.86rem; display:inline-flex; align-items:center; gap:7px; transition:gap .22s; }
.sp-foot a:hover{ gap:11px; }
.sp-foot svg{ width:15px; height:15px; }

/* Şube eylem paneli (mobil bottom sheet) */
.sheet-overlay{ position:fixed; inset:0; z-index:300; background:rgba(6,20,58,.55); backdrop-filter:blur(2px);
  display:flex; align-items:flex-end; opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s; }
.sheet-overlay.open{ opacity:1; visibility:visible; }
.sheet{ width:100%; background:#fff; border-radius:26px 26px 0 0; padding:10px 22px calc(22px + env(safe-area-inset-bottom));
  transform:translateY(100%); transition:transform .32s cubic-bezier(.2,.8,.2,1); box-shadow:0 -12px 44px rgba(8,28,72,.28); }
.sheet-overlay.open .sheet{ transform:none; }
.sheet-handle{ width:44px; height:4px; border-radius:2px; background:var(--line-strong); margin:6px auto 18px; }
.sheet-top{ display:flex; align-items:center; gap:13px; }
.sheet-top .pin{ width:44px; height:44px; flex:none; border-radius:13px; background:var(--paper-2); color:var(--brand); display:grid; place-items:center; }
.sheet-top .pin svg{ width:22px; height:22px; }
.sheet-top b{ display:block; font-family:var(--display); font-weight:600; font-size:1.22rem; color:var(--navy-deep); line-height:1.15; }
.sheet-top small{ display:block; color:var(--muted); font-size:.84rem; margin-top:3px; }
.sheet-q{ color:var(--muted); font-size:.88rem; margin:18px 0 12px; }
.sheet-actions{ display:grid; grid-template-columns:1fr 1fr; gap:11px; }
.sheet-btn{ display:flex; align-items:center; justify-content:center; gap:9px; padding:1.05em 1em; border-radius:16px; font-weight:600; font-size:.98rem; transition:transform .18s; }
.sheet-btn:active{ transform:scale(.97); }
.sheet-btn svg{ width:19px; height:19px; }
.sheet-btn.call{ background:linear-gradient(135deg,var(--brand),var(--brand-bright)); color:#fff; box-shadow:0 10px 24px rgba(12,92,224,.3); }
.sheet-btn.dir{ background:var(--paper); color:var(--brand); border:1px solid var(--line-strong); }
.sheet-btn.page{ background:#fff; color:var(--navy); border:1px solid var(--line-strong); }
.sheet-close{ width:100%; margin-top:8px; padding:.95em; background:none; border:none; color:var(--muted); font-weight:600; font-size:.92rem; cursor:pointer; }

/* =================================================================
   HEADER
   ================================================================= */
header{
  position:sticky; top:0; z-index:60;
  transition:background .35s, box-shadow .35s, border-color .35s;
  border-bottom:1px solid transparent;
}
header.scrolled{
  background:rgba(244,247,252,.82); backdrop-filter:blur(16px) saturate(140%);
  border-bottom-color:var(--line); box-shadow:0 6px 24px rgba(10,32,80,.05);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:84px; gap:24px; }
.brand{ display:flex; align-items:center; gap:13px; }
.brand .mark{
  width:48px; height:48px; border-radius:13px; overflow:hidden; flex:none;
  box-shadow:0 6px 18px rgba(12,92,224,.34); border:1.5px solid rgba(255,255,255,.6);
}
.brand .mark img{ width:100%; height:100%; object-fit:cover; }
.brand .word{ display:flex; flex-direction:column; line-height:1; }
.brand .word b{ font-family:var(--display); font-weight:600; font-size:1.32rem; color:var(--navy-deep); letter-spacing:-0.02em; }
.brand .word span{ font-size:.66rem; font-weight:600; letter-spacing:.17em; text-transform:uppercase; color:var(--muted); margin-top:4px; }

.menu{ display:flex; align-items:center; gap:6px; }
.menu > a{
  position:relative; padding:.55em .9em; font-size:.93rem; font-weight:500; color:var(--ink); border-radius:999px;
  transition:color .2s, background .2s;
}
.menu > a::after{
  content:""; position:absolute; left:50%; bottom:.32em; width:0; height:2px; background:var(--brand);
  transform:translateX(-50%); transition:width .25s; border-radius:2px;
}
.menu > a:hover{ color:var(--brand); }
.menu > a:hover::after{ width:18px; }
.nav-cta{ display:flex; align-items:center; gap:12px; }
/* Dil seçici (TR↔EN popover) — build %%LANG_CUR/URL_TR/URL_EN%% doldurur, app.js açar/kapar (basınca direkt değişmez, menü açılır) */
.lang-pick{ position:relative; display:inline-flex; }
.lang-switch{ display:inline-flex; align-items:center; gap:6px; padding:.46em .7em; border:1px solid #d8e2f2; border-radius:999px; color:var(--navy); font-weight:600; font-size:.82rem; letter-spacing:.04em; background:#fff; cursor:pointer; font-family:inherit; transition:border-color .2s, color .2s, background .2s; }
.lang-switch > svg:first-child{ width:16px; height:16px; opacity:.8; }
.lang-switch .chev{ width:13px; height:13px; opacity:.7; transition:transform .2s; }
.lang-pick.open .lang-switch .chev{ transform:rotate(180deg); }
.lang-switch:hover{ border-color:var(--brand-bright); color:var(--brand); background:#f4f8ff; }
.lang-switch span{ line-height:1; }
.lang-menu{ position:absolute; top:calc(100% + 8px); right:0; min-width:158px; background:#fff; border:1px solid #e6ecf6; border-radius:13px; box-shadow:0 16px 44px rgba(6,20,58,.18); padding:6px; display:none; z-index:1300; }
.lang-pick.open .lang-menu{ display:block; }
.lang-menu a{ display:flex; align-items:center; gap:9px; padding:9px 12px; border-radius:9px; text-decoration:none; color:var(--navy); font-weight:600; font-size:.9rem; }
.lang-menu a:hover{ background:#f2f6fd; }
.lang-menu a.on{ color:var(--brand); background:#eef4ff; }
@media (max-width:560px){ .lang-switch{ padding:.42em .56em; font-size:.78rem; } .lang-switch span{ font-size:.78rem; } }
/* Uluslararası telefon seçici — yalnız EN sayfalarda app.js ekler (.tel-cc = ülke kodu select'i) */
.tel-intl{ display:flex; gap:8px; flex-wrap:wrap; align-items:stretch; }
.tel-intl > input{ flex:2 1 150px; min-width:0; }
.tel-cc{ flex:1 1 145px; min-width:120px; border:1px solid #d8e2f2; border-radius:10px; padding:.72em .55em; background:#fff; font:inherit; font-size:.9rem; color:var(--navy); cursor:pointer; }
.tel-cc:focus{ outline:2px solid var(--brand); border-color:var(--brand); }
/* Nav telefonu — iki hat arasında döner (dur → hızlı dön → dur, JS app.js),
   tıklayınca numara seçimi (.np-pop) açılır */
.nav-phone{ position:relative; display:flex; align-items:center; }
.np-btn{ display:flex; align-items:center; gap:8px; font-family:var(--sans); font-weight:600; font-size:.92rem;
  color:var(--navy); background:none; border:none; cursor:pointer; padding:.45em .15em; }
.np-btn > svg{ width:17px; height:17px; color:var(--brand); }
.np-btn .np-chev{ width:12px; height:12px; color:var(--muted); transition:transform .3s; }
.nav-phone.open .np-chev{ transform:rotate(180deg); }
.np-roll{ display:block; height:20px; overflow:hidden; }
.np-col{ display:block; will-change:transform; }
.np-num{ display:block; height:20px; line-height:20px; white-space:nowrap; font-variant-numeric:tabular-nums; }
.np-pop{ position:absolute; top:calc(100% + 12px); right:0; min-width:256px; background:#fff;
  border:1px solid var(--line-strong); border-radius:14px; padding:8px; z-index:320;
  box-shadow:0 18px 50px rgba(6,20,58,.16); opacity:0; transform:translateY(6px); pointer-events:none;
  transition:opacity .22s, transform .22s; }
.nav-phone.open .np-pop{ opacity:1; transform:none; pointer-events:auto; }
.np-pop-head{ padding:8px 10px 6px; font-size:.78rem; font-weight:600; color:var(--muted); }
.np-opt{ display:flex; align-items:center; gap:10px; padding:9px 10px; border-radius:10px; transition:background .18s; }
.np-opt:hover{ background:var(--paper); }
.np-ic{ width:34px; height:34px; flex:none; border-radius:10px; background:rgba(12,92,224,.1); color:var(--brand); display:grid; place-items:center; }
.np-ic svg{ width:16px; height:16px; }
.np-t{ display:flex; flex-direction:column; }
.np-t b{ font-size:.85rem; font-weight:600; color:var(--navy-deep); }
.np-t small{ font-size:.8rem; color:var(--muted); }
.np-arr{ margin-left:auto; color:var(--brand); opacity:0; transform:translateX(-4px); transition:opacity .18s, transform .18s; }
.np-arr svg{ width:14px; height:14px; }
.np-opt:hover .np-arr{ opacity:1; transform:none; }

/* İçerik tel CTA'ları (footer üstü kapanış şeritleri) — app.js a.btn[href^=tel]'i
   sarmalar (.tel-sec): rulo + seçim kutusu. Kutu butonun ÜSTÜNE ortalı açılır
   (şeritler footer'a yakın — aşağı açılsa ekran dışına taşar). */
.tel-sec{ position:relative; display:inline-flex; }
.tel-sec .np-pop{ top:auto; right:auto; bottom:calc(100% + 12px); left:50%; max-width:calc(100vw - 24px);
  transform:translate(-50%,6px); text-align:left; }
.tel-sec.open .np-pop{ opacity:1; transform:translate(-50%,0); pointer-events:auto; }

.burger{ display:none; width:46px; height:46px; border-radius:12px; border:1px solid var(--line-strong); background:#fff; cursor:pointer; }
.burger span{ display:block; width:20px; height:2px; background:var(--navy-deep); margin:4px auto; border-radius:2px; transition:.3s; }

/* ---- MEGA MENÜ (Tedaviler) ---- */
.nav-item{ display:flex; align-items:center; }
.has-mega{ position:static; }
.trigger{
  position:relative;
  display:inline-flex; align-items:center; gap:6px; font-family:var(--sans); font-size:.93rem; font-weight:500;
  color:var(--ink); background:none; border:none; cursor:pointer; padding:.55em .9em; border-radius:999px;
  transition:color .2s;
}
.trigger:hover{ color:var(--brand); }
.trigger .chev{ width:13px; height:13px; transition:transform .3s; }
.has-mega.open .trigger .chev{ transform:rotate(180deg); }
@media (hover:hover){ .has-mega:hover .trigger .chev{ transform:rotate(180deg); } }
.has-mega:hover .trigger,
.has-mega.open .trigger{ color:var(--brand); }
/* Görünmez köprü: tetikleyici ile açılan kutu arasındaki minik boşluğu DOLDURUR
   (boşluğu menünün parçası sayar) → düz/yavaş inerken hover kopmaz, flicker olmaz.
   Yalnız hover/açık iken etkileşimli; kapalıyken altındaki içeriği engellemez. */
.trigger::after{
  content:""; position:absolute; left:0; right:0; top:100%; height:50px; /* boşluk ölçüldü: 45px */
  pointer-events:none;
}
@media (hover:hover){
  .has-mega:hover .trigger::after,
  .has-mega.open .trigger::after{ pointer-events:auto; }
}

.mega{
  position:absolute; left:0; right:0; top:100%; padding:12px var(--pad) 0; z-index:80;
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:opacity .26s ease, transform .26s cubic-bezier(.2,.8,.2,1), visibility .26s;
  /* Tam-genişlik sarmalayıcı: boş yan alanlar hover/tık YAKALAMASIN (sadece kart etkileşimli).
     Açılma/kapanma masaüstünde JS hover-intent ile yönetilir (app.js). */
  pointer-events:none;
}
.mega-card{ pointer-events:auto; }
.has-mega.open .mega{ opacity:1; visibility:visible; transform:none; }
@media (hover:hover){
  .has-mega:focus-within .mega{ opacity:1; visibility:visible; transform:none; }
}

.mega-card{
  max-width:var(--maxw); margin-inline:auto; background:#fff; border:1px solid var(--line);
  border-radius:24px; box-shadow:0 40px 80px rgba(8,28,72,.18), 0 8px 24px rgba(8,28,72,.08); overflow:hidden;
}
.mega-promo{
  display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
  padding:16px 30px; background:linear-gradient(100deg,var(--navy-deep),var(--brand)); color:#fff;
}
.mp-left{ display:flex; align-items:center; gap:12px; font-size:.95rem; }
.mp-left b{ font-weight:700; }
.mp-spark{ width:30px; height:30px; flex:none; border-radius:9px; background:rgba(255,255,255,.16); display:grid; place-items:center; color:var(--cyan); }
.mp-spark svg{ width:17px; height:17px; }
.mp-btn{
  display:inline-flex; align-items:center; gap:8px; background:#fff; color:var(--navy-deep); font-weight:600; font-size:.88rem;
  padding:.62em 1.1em; border-radius:999px; transition:transform .25s, box-shadow .25s; white-space:nowrap;
}
.mp-btn svg{ width:16px; height:16px; }
.mp-btn:hover{ transform:translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,.18); }

/* Split: solda ihtiyaca göre kategoriler · sağda etkileşimli önizleme */
.mega-split{ display:grid; grid-template-columns:286px 1fr; min-height:330px; }
.mega-cats{ background:var(--paper); border-right:1px solid var(--line); padding:18px; display:flex; flex-direction:column; gap:4px; }
.mega-cat{
  display:flex; align-items:center; gap:13px; width:100%; text-align:left; cursor:pointer;
  background:none; border:1px solid transparent; border-radius:15px; padding:12px 14px; font-family:var(--sans);
  text-decoration:none; color:inherit; /* <a> de <button> ile aynı görünsün */
  transition:background .22s, box-shadow .22s, border-color .22s;
}
.mc-ic{ width:42px; height:42px; flex:none; border-radius:12px; background:#fff; border:1px solid var(--line); display:grid; place-items:center; color:var(--brand); transition:.22s; }
.mc-ic svg{ width:22px; height:22px; }
.mc-txt{ flex:1; min-width:0; }
.mc-txt b{ display:block; font-weight:600; font-size:.96rem; color:var(--navy-deep); line-height:1.2; transition:color .2s; }
.mc-txt small{ display:block; font-size:.77rem; color:var(--muted); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mc-arrow{ width:16px; height:16px; flex:none; color:var(--brand); opacity:0; transform:translateX(-6px); transition:.22s; }
.mega-cat:hover{ background:#fff; box-shadow:var(--shadow-sm); }
.mega-cat.active{ background:#fff; border-color:var(--line); box-shadow:var(--shadow-md); }
.mega-cat.active .mc-ic{ background:linear-gradient(135deg,var(--brand),var(--brand-bright)); color:#fff; border-color:transparent; }
.mega-cat.active .mc-txt b{ color:var(--brand); }
.mega-cat.active .mc-arrow{ opacity:1; transform:none; }

.mega-panes{ position:relative; padding:26px 30px 24px; }
.mega-pane{ display:none; }
.mega-pane.active{ display:block; animation:paneIn .32s cubic-bezier(.2,.8,.2,1); }

/* Şubelerimiz mega — şube detayı (solda isim · sağda detay + eşit boyutlu foto) */
.branch-detail{ display:grid; grid-template-columns:360px 1fr; grid-template-rows:auto auto; column-gap:30px; row-gap:14px; align-items:start; }
/* Sol şube listesi: hepsi birden görünmesin → kaydır (sağ panelle dengeli olsun) */
.subeler-cats{ height: 385px; overflow-y:auto; min-height:0; scrollbar-width:thin; scrollbar-color:var(--line-strong) transparent; }
.subeler-cats::-webkit-scrollbar{ width:7px; }
.subeler-cats::-webkit-scrollbar-thumb{ background:var(--line-strong); border-radius:99px; }
.subeler-cats::-webkit-scrollbar-track{ background:transparent; }
.bd-photo{ grid-column:1; grid-row:1; aspect-ratio:4 / 3; border-radius:18px; overflow:hidden; background:var(--paper-2); border:1px solid var(--line); position:relative; }
.bd-photo img{ width:100%; height:100%; object-fit:cover; display:block; }
.bd-noimg{ position:absolute; inset:0; display:grid; place-content:center; justify-items:center; gap:9px; color:var(--muted); text-align:center; padding:18px; }
.bd-noimg svg{ width:38px; height:38px; color:var(--brand); opacity:.5; }
.bd-noimg small{ font-size:.78rem; line-height:1.4; }
.bd-info{ min-width:0; grid-column:2; grid-row:1 / span 2; }
.bd-info h4{ font-family:var(--display); font-weight:600; font-size:1.32rem; color:var(--navy-deep); }
.bd-yaka{ display:block; font-size:.82rem; color:var(--brand-bright); font-weight:600; margin-top:5px; }
.bd-rows{ display:flex; flex-direction:column; gap:15px; margin-top:20px; }
.bd-row{ display:flex; gap:12px; align-items:center; }
.bd-row .bd-ic{ width:36px; height:36px; flex:none; border-radius:10px; background:var(--paper-2); color:var(--brand); display:grid; place-items:center; transition:background .2s, color .2s; }
.bd-row .bd-ic svg{ width:17px; height:17px; }
a.bd-row:hover .bd-ic{ background:linear-gradient(135deg,var(--brand),var(--cyan)); color:#fff; }
.bd-t{ min-width:0; }
.bd-t span{ display:block; font-size:.68rem; color:var(--muted); text-transform:uppercase; letter-spacing:.09em; }
.bd-t b{ display:block; font-weight:600; color:var(--navy-deep); font-size:.9rem; line-height:1.3; }
a.bd-row:hover .bd-t b{ color:var(--brand); }
.bd-actions{ grid-column:1; grid-row:2; display:flex; gap:10px; align-self:start; }
.bd-actions .sp-btn{ flex:1; justify-content:center; padding:.82em 1em; font-size:.9rem; }
.sp-btn.wa{ background:#1faf54; color:#fff; }
.sp-btn.wa:hover{ transform:translateY(-2px); box-shadow:0 8px 18px rgba(31,175,84,.3); }
@keyframes paneIn{ from{ opacity:0; transform:translateX(10px); } to{ opacity:1; transform:none; } }
.mp-head{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; margin-bottom:18px; flex-wrap:wrap; }
.mp-head h4{ font-family:var(--display); font-weight:600; font-size:1.45rem; color:var(--navy-deep); }
.mp-head p{ font-size:.86rem; color:var(--muted); max-width:46ch; }
/* mp-head bir LINK olduğunda (örn. Eksik Diş → sayfa): kategori sekmesi mobilde
   pane geçişi için buton kalır, başlık ise sayfaya götürür. */
a.mp-head{ text-decoration:none; cursor:pointer; }
a.mp-head h4{ display:inline-flex; align-items:center; gap:6px; transition:color .2s; }
a.mp-head:hover h4{ color:var(--brand); }
.mp-head-arr{ width:16px; height:16px; flex:none; color:var(--brand); opacity:.65; transition:transform .2s, opacity .2s; }
a.mp-head:hover .mp-head-arr{ transform:translateX(3px); opacity:1; }
.mp-items{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.mp-item{ display:flex; gap:13px; align-items:flex-start; padding:13px 14px; border-radius:15px; border:1px solid transparent; transition:background .2s, border-color .2s, transform .2s; }
.mp-item:hover{ background:var(--paper); border-color:var(--line); transform:translateY(-2px); }
.mi-ic{ width:40px; height:40px; flex:none; border-radius:11px; background:var(--paper-2); color:var(--brand); display:grid; place-items:center; transition:.22s; }
.mi-ic svg{ width:21px; height:21px; }
.mp-item:hover .mi-ic{ background:linear-gradient(135deg,var(--brand),var(--cyan)); color:#fff; }
.mp-item b{ display:block; font-weight:600; font-size:.92rem; color:var(--navy-deep); line-height:1.25; }
.mp-item small{ display:block; font-size:.77rem; color:var(--muted); margin-top:2px; }
.mp-cta{ display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:16px; padding:14px 18px;
  border-radius:15px; background:linear-gradient(100deg,var(--navy-deep),var(--brand)); color:#fff; }
.mp-cta .t{ display:flex; align-items:center; gap:11px; font-size:.88rem; }
.mp-cta .t b{ font-weight:700; }
.mp-cta .t .badge{ width:32px; height:32px; flex:none; border-radius:9px; background:rgba(255,255,255,.16); display:grid; place-items:center; color:var(--cyan); }
.mp-cta .t .badge svg{ width:17px; height:17px; }
.mp-cta .go{ display:inline-flex; align-items:center; gap:7px; background:#fff; color:var(--navy-deep); font-weight:600; font-size:.83rem;
  padding:.55em 1em; border-radius:999px; white-space:nowrap; transition:gap .22s; }
.mp-cta .go svg{ width:15px; height:15px; }
.mp-cta:hover .go{ gap:11px; }

/* =================================================================
   HERO
   ================================================================= */
.hero{ position:relative; padding-top:clamp(40px,6vw,72px); padding-bottom:clamp(60px,8vw,110px); overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero-bg .glow{
  position:absolute; top:-12%; right:-6%; width:760px; height:760px; border-radius:50%;
  background:radial-gradient(circle at 50% 50%, rgba(70,198,255,.30), rgba(43,134,255,.16) 40%, transparent 68%);
  filter:blur(10px);
}
.hero-bg .glow.two{ top:auto; bottom:-20%; left:-10%; right:auto; width:560px; height:560px;
  background:radial-gradient(circle at 50% 50%, rgba(12,92,224,.16), transparent 65%); }
.hero-bg .grid{
  position:absolute; inset:0;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px; -webkit-mask-image:radial-gradient(circle at 70% 30%, #000, transparent 72%);
  mask-image:radial-gradient(circle at 70% 30%, #000, transparent 72%); opacity:.5;
}
.hero-inner{ position:relative; z-index:2; display:grid; grid-template-columns:1.08fr .92fr; gap:clamp(30px,4vw,64px); align-items:center; }
.hero-inner > *{ min-width:0; } /* grid item min-width:auto kilidi: uzun h1 kelimesi dar ekranda kolonu taşırmasın */

.hero-badge{
  display:inline-flex; align-items:center; gap:10px; padding:.5em .9em .5em .55em; border-radius:999px;
  background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); font-size:.84rem; font-weight:600; color:var(--navy);
}
.hero-badge .dot{ width:26px; height:26px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--cyan)); display:grid; place-items:center; color:#fff; }
.hero-badge .dot svg{ width:14px; height:14px; }
.hero h1{ font-size:clamp(2.7rem,6vw,4.7rem); margin:24px 0 0; letter-spacing:-0.03em; }
.hero p.lead{ margin:22px 0 0; max-width:33ch; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.hero-trust{ display:flex; align-items:center; gap:18px; margin-top:34px; flex-wrap:wrap; }
.hero-trust .stars{ color:#f5a623; letter-spacing:2px; font-size:1rem; }
.hero-trust small{ color:var(--muted); font-size:.86rem; }
.hero-trust b{ color:var(--navy-deep); }

/* Hero görsel — logo rozeti + yörünge + parıltı + yüzen istatistik çipleri */
.hero-visual{ position:relative; aspect-ratio:1/1; display:grid; place-items:center; }
.orbit{ position:absolute; border-radius:50%; border:1.5px dashed rgba(12,92,224,.22); }
.orbit.o1{ inset:6%; }
.orbit.o2{ inset:-4%; border-style:solid; border-color:rgba(70,198,255,.20); }
.hero-disc{
  position:relative; width:62%; aspect-ratio:1/1; border-radius:34px; overflow:hidden;
  box-shadow:0 40px 90px rgba(8,40,120,.42), inset 0 0 0 6px rgba(255,255,255,.65);
  animation:floaty 7s ease-in-out infinite;
}
.hero-disc img{ width:100%; height:100%; object-fit:cover; }
.spark{ position:absolute; color:var(--cyan); animation:twinkle 3.2s ease-in-out infinite; }
.spark svg{ width:100%; height:100%; filter:drop-shadow(0 0 6px rgba(70,198,255,.7)); }
.spark.s1{ width:30px; height:30px; top:8%; left:14%; animation-delay:.2s; }
.spark.s2{ width:18px; height:18px; top:24%; right:8%; animation-delay:1.1s; color:var(--brand-bright); }
.spark.s3{ width:24px; height:24px; bottom:14%; left:6%; animation-delay:.7s; }
.spark.s4{ width:14px; height:14px; bottom:30%; right:16%; animation-delay:1.6s; color:var(--brand-bright); }

.chip{
  position:absolute; display:flex; align-items:center; gap:10px; background:#fff; padding:.7em .95em; border-radius:16px;
  box-shadow:var(--shadow-md); border:1px solid var(--line); font-weight:600; font-size:.86rem; white-space:nowrap;
}
.chip .ic{ width:34px; height:34px; border-radius:10px; display:grid; place-items:center; background:var(--paper-2); color:var(--brand); flex:none; }
.chip .ic svg{ width:18px; height:18px; }
.chip b{ display:block; font-family:var(--display); font-weight:600; font-size:1.05rem; color:var(--navy-deep); line-height:1; }
.chip small{ color:var(--muted); font-weight:500; font-size:.74rem; }
.chip.c1{ top:6%; right:-2%; animation:floaty 6s ease-in-out infinite; }
.chip.c2{ bottom:10%; left:-6%; animation:floaty 6.6s ease-in-out infinite .8s; }
.chip.c3{ bottom:34%; right:-8%; animation:floaty 7.2s ease-in-out infinite .4s; }

/* ---- Logo şeritlerinde animasyon ---- */
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }
@keyframes twinkle{ 0%,100%{ opacity:.35; transform:scale(.7) rotate(0); } 50%{ opacity:1; transform:scale(1) rotate(20deg); } }

/* =================================================================
   GÜVEN ŞERİDİ (logos / metrics)
   ================================================================= */
.trustbar{ border-block:1px solid var(--line); background:#fff; }
.trustbar .wrap{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:24px; padding-block:28px; }
.metric{ display:flex; flex-direction:column; }
.metric b{ font-family:var(--display); font-size:clamp(1.7rem,3vw,2.4rem); font-weight:600; color:var(--navy-deep); line-height:1; }
.metric span{ font-size:.84rem; color:var(--muted); font-weight:500; margin-top:7px; letter-spacing:.01em; }
.metric .plus{ color:var(--brand); }
.trustbar .divider{ width:1px; height:42px; background:var(--line); }

/* =================================================================
   SECTION genel
   ================================================================= */
section.block{ padding-block:clamp(64px,9vw,118px); position:relative; }
.head{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; margin-bottom:54px; flex-wrap:wrap; }
.head .left{ max-width:660px; }
.head h2{ margin-top:16px; }
.head .right{ max-width:330px; color:var(--muted); font-size:.98rem; padding-bottom:6px; }

/* ---- Hizmetler ---- */
.services{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.svc{
  position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:30px 28px 28px;
  overflow:hidden; transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s, border-color .35s;
}
.svc::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:3px; background:linear-gradient(90deg,var(--brand),var(--cyan)); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.svc:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:transparent; }
.svc:hover::after{ transform:scaleX(1); }
.svc.feat{ grid-column:span 1; background:linear-gradient(160deg,var(--navy-deep),var(--navy)); color:#fff; border-color:transparent; }
.svc.feat h3,.svc.feat .svc-no{ color:#fff; }
.svc.feat p{ color:rgba(255,255,255,.74); }
.svc.feat .svc-ic{ background:rgba(255,255,255,.12); color:#fff; }
.svc-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.svc-ic{ width:54px; height:54px; border-radius:15px; display:grid; place-items:center; background:var(--paper-2); color:var(--brand); transition:.35s; }
.svc-ic svg{ width:28px; height:28px; }
.svc:hover .svc-ic{ transform:rotate(-8deg) scale(1.06); }
.svc-no{ font-family:var(--display); font-style:italic; font-size:.95rem; color:var(--muted); }
.svc h3{ margin-bottom:10px; }
.svc p{ color:var(--muted); font-size:.95rem; }
.svc .more{ display:inline-flex; align-items:center; gap:7px; margin-top:18px; font-weight:600; font-size:.9rem; color:var(--brand); }
.svc.feat .more{ color:var(--cyan); }
.svc .more svg{ width:16px; height:16px; transition:transform .25s; }
.svc:hover .more svg{ transform:translateX(4px); }

/* =================================================================
   NEDEN ÖZBUDENT — split
   ================================================================= */
.why{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(34px,5vw,72px); align-items:center; }
.why-visual{ position:relative; }
.why-card{
  background:linear-gradient(160deg,#fff,#eef4fd); border:1px solid var(--line); border-radius:var(--r-xl);
  padding:38px; box-shadow:var(--shadow-md); position:relative; overflow:hidden;
}
.why-card .ribbon{ position:absolute; top:0; right:0; width:160px; height:160px; background:radial-gradient(circle at 100% 0,rgba(70,198,255,.25),transparent 70%); }
.why-quote{ font-family:var(--display); font-size:1.5rem; line-height:1.32; color:var(--navy-deep); }
.why-quote .mark{ color:var(--brand); font-size:2.4rem; line-height:0; vertical-align:-.35em; margin-right:.1em; }
.why-sign{ display:flex; align-items:center; gap:14px; margin-top:28px; padding-top:24px; border-top:1px solid var(--line); }
.why-sign .av{ width:50px; height:50px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--cyan)); display:grid; place-items:center; color:#fff; font-weight:700; font-family:var(--display); }
.why-sign b{ display:block; color:var(--navy-deep); }
.why-sign span{ font-size:.85rem; color:var(--muted); }

.why-list{ display:grid; gap:14px; }
.feature{ display:flex; gap:18px; padding:20px 22px; border-radius:var(--r-md); background:#fff; border:1px solid var(--line); transition:transform .3s, box-shadow .3s; }
.feature:hover{ transform:translateX(6px); box-shadow:var(--shadow-md); }
.feature .fic{ width:46px; height:46px; flex:none; border-radius:13px; background:var(--paper-2); color:var(--brand); display:grid; place-items:center; }
.feature .fic svg{ width:23px; height:23px; }
.feature h3{ font-family:var(--sans); font-weight:700; font-size:1.03rem; color:var(--navy-deep); margin-bottom:4px; letter-spacing:-0.01em; }
.feature p{ font-size:.92rem; color:var(--muted); }

/* =================================================================
   ÖDEME / FİNANSMAN — koyu bant
   ================================================================= */
.finance{ background:var(--navy-deep); color:#fff; border-radius:var(--r-xl); overflow:hidden; position:relative; }
.finance::before{ content:""; position:absolute; top:-30%; right:-10%; width:540px; height:540px; border-radius:50%;
  background:radial-gradient(circle,rgba(43,134,255,.34),transparent 65%); }
.finance .inner{ position:relative; padding:clamp(40px,6vw,72px); display:grid; grid-template-columns:1fr 1.15fr; gap:48px; align-items:center; }
.finance h2{ color:#fff; }
.finance .eyebrow{ color:var(--cyan); }
.finance .eyebrow::before{ background:var(--cyan); }
.finance p{ color:rgba(255,255,255,.72); margin-top:18px; max-width:42ch; }
.pay-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.pay{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:var(--r-md); padding:24px; transition:.3s; }
.pay:hover{ background:rgba(255,255,255,.1); transform:translateY(-5px); }
.pay .pic{ width:46px; height:46px; border-radius:12px; background:linear-gradient(135deg,var(--brand),var(--cyan)); display:grid; place-items:center; margin-bottom:16px; }
.pay .pic svg{ width:24px; height:24px; color:#fff; }
.pay b{ display:block; font-family:var(--display); font-weight:600; font-size:1.18rem; }
.pay span{ font-size:.86rem; color:rgba(255,255,255,.6); }

/* =================================================================
   HEKİMLER
   ================================================================= */
.docs{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.doc{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:26px; text-align:center; transition:transform .35s, box-shadow .35s; }
.doc:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.doc .av{
  width:92px; height:92px; margin:0 auto 18px; border-radius:50%; display:grid; place-items:center;
  font-family:var(--display); font-weight:600; font-size:2rem; color:#fff; position:relative;
}
.doc .av::after{ content:""; position:absolute; inset:-6px; border-radius:50%; border:1.5px dashed rgba(12,92,224,.3); }
.doc:nth-child(1) .av{ background:linear-gradient(135deg,#0c5ce0,#46c6ff); }
.doc:nth-child(2) .av{ background:linear-gradient(135deg,#1746b8,#2b86ff); }
.doc:nth-child(3) .av{ background:linear-gradient(135deg,#0a2050,#0c5ce0); }
.doc:nth-child(4) .av{ background:linear-gradient(135deg,#1f6fef,#46c6ff); }
.doc b{ display:block; font-family:var(--display); font-weight:600; font-size:1.12rem; color:var(--navy-deep); }
.doc .role{ font-size:.85rem; color:var(--brand); font-weight:600; margin-top:5px; }
.doc .tags{ display:flex; flex-wrap:wrap; gap:6px; justify-content:center; margin-top:16px; }
.doc .tags span{ font-size:.74rem; color:var(--muted); background:var(--paper); border:1px solid var(--line); padding:.3em .7em; border-radius:999px; }
.docs-more{ margin-top:28px; text-align:center; }
.docs-more .btn svg{ width:18px; height:18px; }

/* =================================================================
   SÜREÇ
   ================================================================= */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; position:relative; }
.step{ position:relative; padding:30px 26px; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); transition:.3s; }
.step:hover{ box-shadow:var(--shadow-md); transform:translateY(-6px); }
.step .n{ font-family:var(--display); font-style:italic; font-size:2.6rem; font-weight:500; color:var(--paper-2); line-height:.8; -webkit-text-stroke:1px rgba(12,92,224,.18); }
.step h3{ font-family:var(--sans); font-weight:700; font-size:1.06rem; margin:14px 0 8px; color:var(--navy-deep); letter-spacing:-0.01em; }
.step p{ font-size:.92rem; color:var(--muted); }
.step .tick{ position:absolute; top:28px; right:26px; width:30px; height:30px; border-radius:50%; background:var(--paper-2); display:grid; place-items:center; color:var(--brand); }
.step .tick svg{ width:16px; height:16px; }

/* =================================================================
   YORUMLAR
   ================================================================= */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.review{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:30px 28px; display:flex; flex-direction:column; }
.review .stars{ color:#f5a623; letter-spacing:2px; margin-bottom:14px; }
.review p{ font-family:var(--display); font-size:1.1rem; line-height:1.45; color:var(--navy-deep); flex:1; }
.review .who{ display:flex; align-items:center; gap:13px; margin-top:22px; padding-top:20px; border-top:1px solid var(--line); }
.review .who .av{ width:44px; height:44px; border-radius:50%; display:grid; place-items:center; color:#fff; font-weight:700; background:linear-gradient(135deg,var(--brand),var(--brand-bright)); font-size:.95rem; }
.review .who b{ color:var(--navy-deep); font-size:.95rem; }
.review .who span{ font-size:.8rem; color:var(--muted); }

/* =================================================================
   RANDEVU / İLETİŞİM
   ================================================================= */
.contact{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(30px,5vw,64px); align-items:start; }
.contact > *{ min-width:0; } /* grid item min-width:auto kilidi: form içindeki select'in min-content'i dar ekranda (320) kolonu taşırmasın */
.contact-info .eyebrow{ margin-bottom:16px; }
.contact-info h2{ margin-bottom:20px; }
.info-list{ display:grid; gap:8px; margin-top:30px; }
.info{ display:flex; gap:16px; align-items:center; padding:18px 20px; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); transition:.3s; }
.info:hover{ box-shadow:var(--shadow-sm); border-color:var(--line-strong); }
.info .iic{ width:46px; height:46px; flex:none; border-radius:12px; background:var(--paper-2); color:var(--brand); display:grid; place-items:center; }
.info .iic svg{ width:22px; height:22px; }
.info span{ font-size:.8rem; color:var(--muted); display:block; }
.info b{ color:var(--navy-deep); font-size:1.02rem; }

.form{ background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); padding:clamp(28px,4vw,42px); box-shadow:var(--shadow-md); }
.form h3{ font-family:var(--display); font-size:1.5rem; margin-bottom:6px; }
.form .sub{ color:var(--muted); font-size:.92rem; margin-bottom:26px; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:.82rem; font-weight:600; color:var(--navy); margin-bottom:7px; letter-spacing:.01em; }
.field input,.field select,.field textarea{
  width:100%; font-family:var(--sans); font-size:.97rem; color:var(--ink); background:var(--paper);
  border:1px solid var(--line-strong); border-radius:13px; padding:.85em 1em; transition:.25s; outline:none;
}
.field input:focus,.field select:focus,.field textarea:focus{ border-color:var(--brand); background:#fff; box-shadow:0 0 0 4px rgba(12,92,224,.12); }
.field textarea{ resize:vertical; min-height:96px; }
.row2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form .btn-primary{ width:100%; margin-top:8px; }
.form .note{ font-size:.78rem; color:var(--muted); text-align:center; margin-top:14px; }
.form-success{ display:none; text-align:center; padding:30px 10px; }
.form-success.show{ display:block; animation:fadeUp .5s ease; }
.form-success .ok{ width:64px; height:64px; margin:0 auto 18px; border-radius:50%; background:linear-gradient(135deg,#19b36b,#0ea75f); display:grid; place-items:center; color:#fff; }
.form-success .ok svg{ width:32px; height:32px; }
.form-success h3{ color:var(--navy-deep); }
.form-success p{ color:var(--muted); margin-top:8px; }

/* =================================================================
   FOOTER
   ================================================================= */
footer{ background:var(--navy-deep); color:rgba(255,255,255,.7); padding-top:clamp(56px,7vw,88px); margin-top:clamp(40px,6vw,90px); position:relative; overflow:hidden; }
footer::before{ content:""; position:absolute; top:-40%; left:50%; transform:translateX(-50%); width:900px; height:500px; border-radius:50%; background:radial-gradient(circle,rgba(43,134,255,.16),transparent 65%); }
.foot-grid{ position:relative; display:grid; grid-template-columns:1.5fr 1fr 1fr 1.3fr; gap:40px; padding-bottom:54px; }
.foot-brand .brand .word b{ color:#fff; }
.foot-brand .brand .word span{ color:rgba(255,255,255,.55); }
.foot-brand p{ margin-top:20px; font-size:.92rem; max-width:34ch; line-height:1.7; }
.foot-soc{ display:flex; gap:10px; margin-top:22px; }
.foot-soc a{ width:42px; height:42px; border-radius:12px; background:rgba(255,255,255,.07); display:grid; place-items:center; color:#fff; transition:.3s; }
.foot-soc a:hover{ background:var(--brand); transform:translateY(-4px); }
.foot-soc svg{ width:19px; height:19px; }
.foot-col h4{ color:#fff; font-family:var(--sans); font-weight:700; font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:20px; }
.foot-col a{ display:block; padding:7px 0; font-size:.94rem; transition:.2s; }
.foot-col a:hover{ color:#fff; padding-left:6px; }
.foot-news p{ font-size:.92rem; margin-bottom:16px; }
.foot-news .nf{ display:flex; gap:8px; }
.foot-news input{ flex:1; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); border-radius:12px; padding:.75em 1em; color:#fff; font-family:var(--sans); outline:none; }
.foot-news input::placeholder{ color:rgba(255,255,255,.45); }
.foot-news input:focus{ border-color:var(--cyan); }
.foot-news button{ width:48px; border:none; border-radius:12px; background:linear-gradient(135deg,var(--brand),var(--cyan)); color:#fff; cursor:pointer; display:grid; place-items:center; }
.foot-news button svg{ width:18px; height:18px; }
/* Sağlık Bakanlığı uyum bloğu (bülten altı) — logolar koyu zeminde kaybolmasın diye beyaz kart */
.foot-uyum{ margin-top:24px; }
.fu-logos{ display:flex; align-items:stretch; gap:10px; } /* iki kart YAN YANA, eşit genişlik (kullanıcı isteği 2026-06-12; ikisi de modal tetikler) */
.fu-logos .fu-card{ flex:1 1 0; min-width:0; }
.fu-card{ background:#fff; border:1px solid rgba(255,255,255,.14); border-radius:12px; padding:10px 12px; display:grid; place-items:center;
  overflow:hidden; transition:transform .3s, box-shadow .3s; }
/* hover: büyüteç hissi — kart hafif kalkar, logo kart İÇİNDE büyür (overflow:hidden kırpar) */
.fu-card:hover{ transform:translateY(-2px) scale(1.03); box-shadow:0 16px 38px rgba(6,20,58,.5); }
.fu-card img{ display:block; height:58px; width:auto; max-width:100%; object-fit:contain; transition:transform .35s cubic-bezier(.2,.8,.3,1); }
.fu-card:hover img{ transform:scale(1.22); }
/* butonlar (yetki belgesi modali tetikleyicileri) — kart görünümünü aynen kullanır.
   ⚠️ .foot-news button kuralı (mavi gradyan + 48px) bunu eziyordu → yüksek özgüllükle beyaza sabitle. */
.foot-news .fu-card.fu-ht, .fu-card.fu-ht{ cursor:pointer; font:inherit; background:#fff; border:1px solid rgba(255,255,255,.14); border-radius:12px; padding:10px 12px; }

/* --- HealthTürkiye / Sağlık Turizmi Yetki Belgesi modali (tetik: footer logosu, app.js) --- */
.ht-modal{ position:fixed; inset:0; z-index:1400; display:grid; place-items:center; padding:18px; }
.ht-modal[hidden]{ display:none; }
.ht-arka{ position:absolute; inset:0; background:rgba(6,20,58,.72); backdrop-filter:blur(4px); opacity:0; transition:opacity .26s; }
.ht-kart{ position:relative; display:grid; grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);
  width:min(960px, 100%); max-height:min(86vh, 700px); background:#fff; border-radius:22px; overflow:hidden;
  box-shadow:0 40px 110px rgba(6,20,58,.55); opacity:0; transform:translateY(14px) scale(.97);
  transition:opacity .26s, transform .26s cubic-bezier(.2,.9,.3,1); }
.ht-modal.acik .ht-arka{ opacity:1; }
.ht-modal.acik .ht-kart{ opacity:1; transform:none; }
.ht-belge{ background:var(--paper); display:grid; place-items:center; padding:22px; overflow:auto; }
.ht-belge img{ width:100%; height:auto; max-height:100%; object-fit:contain; border-radius:10px;
  box-shadow:0 14px 40px rgba(6,20,58,.18); }
.ht-icerik{ padding:30px 30px 26px; overflow:auto; display:flex; flex-direction:column; }
.ht-icerik .ht-logo{ height:46px; width:auto; align-self:flex-start; margin-bottom:14px; }
.ht-icerik h3{ font-family:var(--display); font-weight:600; color:var(--navy-deep); font-size:1.25rem; line-height:1.25; margin-bottom:12px; }
.ht-icerik p{ font-size:.9rem; color:#46546f; line-height:1.7; margin-bottom:12px; }
.ht-kapat{ position:absolute; right:14px; top:14px; z-index:2; width:36px; height:36px; border:none; border-radius:50%;
  background:rgba(6,20,58,.08); color:var(--navy-deep); cursor:pointer; display:grid; place-items:center; transition:background .2s; }
.ht-kapat:hover{ background:rgba(6,20,58,.16); }
.ht-kapat svg{ width:16px; height:16px; }
body.ht-acik{ overflow:hidden; } /* modal açıkken arka sayfa kaymasın */
@media (max-width:760px){
  .ht-kart{ grid-template-columns:1fr; max-height:88vh; }
  .ht-belge{ padding:16px; max-height:42vh; }
  .ht-icerik{ padding:20px 18px 18px; }
}
.fu-meta{ margin-top:12px; font-size:.8rem; line-height:1.7; color:rgba(255,255,255,.55); }
.fu-meta span{ display:block; }
.fu-meta b{ color:rgba(255,255,255,.85); font-weight:600; }
.fu-meta a{ color:var(--cyan); }
.fu-meta a:hover{ color:#fff; }
.foot-bottom{ position:relative; border-top:1px solid rgba(255,255,255,.1); padding-block:26px; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.84rem; }
.foot-bottom a:hover{ color:#fff; }

/* =================================================================
   REVEAL animasyon
   ================================================================= */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s cubic-bezier(.2,.8,.2,1), transform .7s cubic-bezier(.2,.8,.2,1); }
.reveal.in{ opacity:1; transform:none; }
/* JS yoksa içerik gizli kalmasın */
.no-js .reveal, .no-js .hero .stl{ opacity:1 !important; transform:none !important; animation:none !important; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; transition:none; }
  .hero .stl{ opacity:1 !important; transform:none !important; animation:none !important; }
  .hero-disc,.chip,.spark{ animation:none !important; }
}
@keyframes fadeUp{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }

/* hero ilk yüklenme staggered */
.hero .stl{ opacity:0; transform:translateY(22px); animation:fadeUp .8s cubic-bezier(.2,.8,.2,1) forwards; }
.hero .stl.d1{ animation-delay:.05s; } .hero .stl.d2{ animation-delay:.18s; }
.hero .stl.d3{ animation-delay:.31s; } .hero .stl.d4{ animation-delay:.44s; } .hero .stl.d5{ animation-delay:.57s; }

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width:1024px){
  .hero-inner{ grid-template-columns:1fr; } .hero-visual{ max-width:480px; margin:10px auto 0; order:-1; }
  .why{ grid-template-columns:1fr; } .finance .inner{ grid-template-columns:1fr; }
  .contact{ grid-template-columns:1fr; } .docs{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); } .reviews{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  .menu,.nav-phone{ display:none; } .burger{ display:block; }

  /* Üst bar mobil */
  .topbar{ font-size:.78rem; }
  .topbar .wrap{ justify-content:space-between; gap:10px; }
  .tb-soc{ display:none; }
  .tb-right{ gap:0; }
  .tb-subeler{ position:static; }
  .subeler-panel{ left:var(--pad); right:var(--pad); }
  .sp-card{ width:auto; }
  .sp-grid{ grid-template-columns:1fr; gap:4px; }
  /* Mobilde butonlar yerine: karta dokun → eylem paneli açılır */
  .sp-actions{ display:none; }
  .sp-item{ cursor:pointer; align-items:center; position:relative; }
  .sp-item .sp-body{ padding-right:20px; }
  .sp-item::after{ content:""; position:absolute; right:13px; top:50%; width:8px; height:8px;
    border-right:2px solid var(--line-strong); border-bottom:2px solid var(--line-strong); transform:translateY(-50%) rotate(-45deg); }
  .sp-item:active{ background:var(--paper-2); }
  .menu.open{ display:flex; position:absolute; top:84px; left:var(--pad); right:var(--pad); flex-direction:column; align-items:stretch;
    background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:12px; box-shadow:var(--shadow-lg); gap:2px;
    max-height:80vh; overflow:auto; }
  .menu.open > a{ padding:.9em 1em; }

  /* Mega menü → mobil akordeon */
  .nav-item.has-mega{ flex-direction:column; align-items:stretch; }
  .trigger{ width:100%; justify-content:space-between; padding:.9em 1em; font-size:1rem; }
  .mega{ position:static; padding:0; transform:none; opacity:1; visibility:visible; display:none; }
  .has-mega.open .mega{ display:block; }
  .mega-card{ box-shadow:none; border:none; border-radius:0; margin-top:4px; }
  .mega-promo{ flex-direction:column; align-items:flex-start; gap:12px; padding:14px 14px; border-radius:14px; }
  /* Split → mobilde sekmeler üstte, içerik altta */
  .mega-split{ grid-template-columns:minmax(0,1fr); min-height:0; }
  .mega-cats{ flex-direction:row; flex-wrap:nowrap; overflow-x:auto; gap:8px; padding:12px 2px; border-right:none;
    background:none; -webkit-overflow-scrolling:touch; }
  .mega-cat{ flex:0 0 auto; flex-direction:column; align-items:flex-start; width:148px; padding:12px; border:1px solid var(--line); background:#fff; }
  .mega-cat .mc-arrow{ display:none; }
  .mc-txt small{ white-space:normal; }
  .mega-panes{ padding:6px 2px 4px; min-width:0; }
  .branch-detail{ display:flex; flex-direction:column; gap:14px; min-width:0; }
  .bd-photo{ width:100%; aspect-ratio:16 / 9; }
  .bd-info, .bd-rows, .bd-row, .bd-t{ min-width:0; }
  .subeler-cats{ height:auto; max-height:none; overflow-x:auto; overflow-y:visible; }
  .mp-items{ grid-template-columns:1fr; }
  .mp-head h4{ font-size:1.2rem; }
  .services{ grid-template-columns:1fr; } .pay-grid{ grid-template-columns:1fr; }
  .docs,.steps,.foot-grid{ grid-template-columns:1fr; } .row2{ grid-template-columns:1fr; }
  .trustbar .divider{ display:none; } .trustbar .wrap{ justify-content:center; gap:30px 40px; }
  .head{ flex-direction:column; align-items:flex-start; }
}

/* ---- Dar telefonlar: header kompakt (satır min-genişliği viewport'a sığsın —
   yatay taşmanın KÖK çözümü; maskeleme değil). Yalnız header/topbar öğeleri,
   masaüstü ve içerik butonları (.nav-cta dışı .btn) etkilenmez. ---- */
@media (max-width:480px){
  .topbar{ font-size:.76rem; }
  /* 480px'te min(2.7rem,12vw)=2.7rem (mevcutla aynı, kırılma yok); 320'ye inerken
     12vw ile küçülür → "Gülümsemeniz" gibi uzun kelime kesilmez. */
  .hero h1{ font-size:min(2.7rem,12vw); }
  .nav{ gap:10px; }
  header .brand{ gap:9px; }
  header .brand .mark{ width:40px; height:40px; border-radius:11px; }
  header .brand .word b{ font-size:1.06rem; }
  header .brand .word span{ font-size:.5rem; letter-spacing:.1em; margin-top:3px; }
  .nav-cta{ gap:7px; }
  .nav-cta .btn{ font-size:.82rem; padding:.66em 1.05em; }
  .burger{ width:40px; height:40px; border-radius:10px; }
}
/* En dar telefonlar (320–374px): marka alt yazısı bu boyutta okunaksız kalıyor → gizle;
   isim/buton/burger bir kademe daha sıkı. */
@media (max-width:374px){
  .nav{ gap:8px; }
  header .brand{ gap:8px; }
  header .brand .mark{ width:38px; height:38px; }
  header .brand .word b{ font-size:1rem; }
  header .brand .word span{ display:none; }
  .nav-cta .btn{ font-size:.78rem; padding:.6em .95em; }
  .burger{ width:38px; height:38px; }
}

/* =================================================================
   YÜZEN İLETİŞİM WIDGET'I  (FAB → Randevu drawer · WhatsApp · Ara)
   ================================================================= */
/* Sayfa gövdesi — drawer açılınca hafif geri çekilir (lacivert/mavi derinlik; GRİ gölge yok) */
#pageShell{ transition:transform .8s cubic-bezier(.22,1,.36,1), border-radius .8s ease, box-shadow .8s ease; transform-origin:center center; }
body.ozc-drawer-open{ overflow:hidden; background:var(--navy-deep); }
body.ozc-drawer-open #pageShell{ transform:scale(.955) translateX(-10px); border-radius:24px; overflow:hidden;
  box-shadow:0 40px 110px rgba(6,20,58,.55); } /* siyah değil lacivert gölge → grilik gitti */

/* --- Konteyner + FAB --- */
/* #ozc, FAB boyutuna küçülür; menü ve kartlar FAB'ın hemen üstüne absolute konumlanır
   (gizli paneller yer kaplamasın → "çok yukarıda açılma" sorunu çözülür). */
#ozc{ position:fixed; right:24px; bottom:24px; z-index:1200; width:64px; height:64px; font-family:var(--sans);
  transform:translateX(120px); pointer-events:none;  /* VARSAYILAN GİZLİ — flicker olmasın */
  transition:transform .8s cubic-bezier(.22,1,.36,1); }
.ozc-fab{ position:relative; width:64px; height:64px; flex:none; border:none; cursor:pointer; border-radius:50%;
  background:linear-gradient(135deg,var(--brand),var(--brand-bright)); color:#fff; box-shadow:var(--glow);
  display:grid; place-items:center; transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .3s; }
.ozc-fab:hover{ transform:translateY(-3px) scale(1.05); box-shadow:0 22px 55px rgba(12,92,224,.5); }
.ozc-fab svg{ width:29px; height:29px; position:absolute; transition:opacity .3s, transform .35s; }
.ozc-fab .ic-x{ opacity:0; transform:rotate(-90deg) scale(.5); }
#ozc.open .ozc-fab .ic-chat{ opacity:0; transform:rotate(90deg) scale(.5); }
#ozc.open .ozc-fab .ic-x{ opacity:1; transform:none; }
.ozc-fab::before{ content:""; position:absolute; inset:0; border-radius:50%; background:var(--brand-bright); z-index:-1; animation:ozcPulse 2.6s ease-out infinite; }
#ozc.open .ozc-fab::before{ animation:none; opacity:0; }
@keyframes ozcPulse{ 0%{ transform:scale(1); opacity:.5; } 70%{ transform:scale(1.7); opacity:0; } 100%{ opacity:0; } }

/* --- 3 seçenekli hızlı menü --- */
.ozc-menu{ position:absolute; right:0; bottom:calc(100% + 14px); display:flex; flex-direction:column; align-items:flex-end; gap:11px;
  opacity:0; visibility:hidden; transform:translateY(14px); transition:opacity .26s, transform .26s, visibility .26s; pointer-events:none; }
#ozc.menu-open .ozc-menu{ opacity:1; visibility:visible; transform:none; pointer-events:auto; }
.ozc-opt{ display:flex; align-items:center; gap:12px; background:#fff; border:1px solid var(--line); border-radius:999px;
  padding:7px 8px 7px 18px; cursor:pointer; box-shadow:var(--shadow-md); transition:transform .25s, box-shadow .25s; }
.ozc-opt:hover{ transform:translateX(-5px); box-shadow:var(--shadow-lg); }
.ozc-opt .lbl{ font-size:.92rem; font-weight:600; color:var(--navy-deep); white-space:nowrap; }
.ozc-opt .oic{ width:42px; height:42px; flex:none; border-radius:50%; display:grid; place-items:center; color:#fff; }
.ozc-opt .oic svg{ width:22px; height:22px; }
.ozc-opt.randevu .oic{ background:linear-gradient(135deg,var(--brand),var(--brand-bright)); }
.ozc-opt.wa .oic{ background:#25d366; }
.ozc-opt.ara .oic{ background:linear-gradient(135deg,var(--navy),var(--brand)); }
#ozc.menu-open .ozc-opt{ animation:ozcUp .42s both; }
#ozc.menu-open .ozc-opt:nth-child(1){ animation-delay:.03s; }
#ozc.menu-open .ozc-opt:nth-child(2){ animation-delay:.08s; }
#ozc.menu-open .ozc-opt:nth-child(3){ animation-delay:.13s; }
@keyframes ozcUp{ from{ opacity:0; transform:translateY(12px) scale(.96); } to{ opacity:1; transform:none; } }

/* --- Açılır kartlar (WhatsApp + Ara) ortak --- */
.ozc-pop{ position:absolute; right:0; bottom:calc(100% + 14px); width:340px; max-width:calc(100vw - 32px); background:#fff; border-radius:22px; overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--shadow-lg);
  opacity:0; visibility:hidden; transform:translateY(18px) scale(.95); transform-origin:bottom right;
  transition:opacity .3s, transform .36s cubic-bezier(.2,.8,.2,1), visibility .3s; pointer-events:none; }
#ozc.wa-open .ozc-wa, #ozc.call-open .ozc-call{ opacity:1; visibility:visible; transform:none; pointer-events:auto; }
.ozc-pop-x{ width:30px; height:30px; border-radius:50%; border:none; cursor:pointer; background:rgba(255,255,255,.18);
  color:#fff; display:grid; place-items:center; margin-left:auto; flex:none; transition:background .2s; }
.ozc-pop-x:hover{ background:rgba(255,255,255,.32); }
.ozc-pop-x svg{ width:16px; height:16px; }

/* --- WhatsApp kartı --- */
.ozc-wa-head{ display:flex; align-items:center; gap:12px; padding:13px 14px; background:#075e54; color:#fff; }
.ozc-wa-head .ava{ width:44px; height:44px; flex:none; border-radius:50%; background:#fff; overflow:hidden; display:grid; place-items:center; }
.ozc-wa-head .ava img{ width:100%; height:100%; object-fit:cover; }
.ozc-wa-head .who b{ font-size:.98rem; font-weight:600; line-height:1.1; }
.ozc-wa-head .who small{ font-size:.74rem; opacity:.9; display:flex; align-items:center; gap:5px; margin-top:3px; }
.ozc-wa-head .who small::before{ content:""; width:7px; height:7px; border-radius:50%; background:#5cff9d; }
.ozc-wa-thread{ background:#e5ddd5; background-image:radial-gradient(rgba(0,0,0,.035) 1px, transparent 1px); background-size:18px 18px;
  padding:16px 14px; min-height:150px; max-height:230px; overflow-y:auto; display:flex; flex-direction:column; gap:9px; }
.ozc-bubble{ max-width:86%; padding:9px 13px; font-size:.86rem; line-height:1.45; color:#111b21; box-shadow:0 1px 1px rgba(0,0,0,.07); position:relative; }
.ozc-bubble.in{ background:#fff; border-radius:2px 13px 13px 13px; align-self:flex-start; }
.ozc-bubble.out{ background:#dcf8c6; border-radius:13px 2px 13px 13px; align-self:flex-end; }
.ozc-wa-note{ font-size:.72rem; color:var(--muted); text-align:center; padding:9px 14px; background:#f6f7f9; border-top:1px solid var(--line); }
.ozc-wa-input{ display:flex; gap:8px; align-items:flex-end; padding:10px; background:#f0f2f5; }
.ozc-wa-input textarea{ flex:1; resize:none; border:1px solid var(--line); border-radius:20px; padding:10px 15px; font-family:inherit;
  font-size:.88rem; line-height:1.35; max-height:96px; background:#fff; }
.ozc-wa-input textarea:focus{ outline:none; border-color:#25d366; }
.ozc-wa-send{ width:46px; height:46px; flex:none; border-radius:50%; border:none; background:#25d366; color:#fff; cursor:pointer; display:grid; place-items:center; transition:background .2s, transform .2s; }
.ozc-wa-send:hover{ background:#1fb959; transform:scale(1.05); }
.ozc-wa-send svg{ width:21px; height:21px; }

/* --- Ara kartı --- */
.ozc-call-head{ display:flex; align-items:center; gap:11px; padding:16px 16px 15px; background:linear-gradient(120deg,var(--navy-deep),var(--brand)); color:#fff; }
.ozc-call-head .chic{ width:38px; height:38px; flex:none; border-radius:11px; background:rgba(255,255,255,.16); display:grid; place-items:center; color:#fff; }
.ozc-call-head .chic svg{ width:20px; height:20px; }
.ozc-call-head b{ font-size:1rem; font-weight:600; display:block; line-height:1.1; }
.ozc-call-head small{ font-size:.74rem; opacity:.85; }
.ozc-num{ display:flex; align-items:center; gap:13px; padding:13px 16px; border-bottom:1px solid var(--line); transition:background .2s; }
.ozc-num:last-of-type{ border-bottom:none; }
.ozc-num:hover{ background:var(--paper); }
.ozc-num .nic{ width:42px; height:42px; flex:none; border-radius:12px; background:var(--paper-2); color:var(--brand); display:grid; place-items:center; transition:.2s; }
.ozc-num:hover .nic{ background:linear-gradient(135deg,var(--brand),var(--cyan)); color:#fff; }
.ozc-num .nic svg{ width:20px; height:20px; }
.ozc-num .nt{ flex:1; min-width:0; }
.ozc-num .nt span{ display:block; font-size:.71rem; color:var(--muted); text-transform:uppercase; letter-spacing:.07em; }
.ozc-num .nt b{ display:block; font-size:1.04rem; color:var(--navy-deep); font-weight:600; }
.ozc-num .arr{ color:var(--brand); opacity:.4; transition:.2s; }
.ozc-num:hover .arr{ opacity:1; transform:translateX(3px); }
.ozc-num .arr svg{ width:18px; height:18px; }
.ozc-call-note{ font-size:.74rem; color:var(--muted); text-align:center; padding:12px 16px; background:#f6f7f9; line-height:1.5; }

/* --- Randevu drawer (sağda tam boy) --- */
.ozc-backdrop{ position:fixed; inset:0; background:linear-gradient(120deg,rgba(6,22,66,.72),rgba(12,52,116,.6));
  backdrop-filter:blur(3px); -webkit-backdrop-filter:blur(3px);
  z-index:1300; opacity:0; visibility:hidden; transition:opacity .8s ease, visibility .8s ease; }
body.ozc-drawer-open .ozc-backdrop{ opacity:1; visibility:visible; }
.ozc-drawer{ position:fixed; top:0; right:0; height:100%; height:100dvh; width:min(450px,100%); background:var(--paper); z-index:1310;
  display:flex; flex-direction:column; transform:translateX(101%);
  transition:transform .7s cubic-bezier(.22,1,.36,1), box-shadow .5s ease;
  box-shadow:none; } /* KAPALIYKEN gölge yok → ekran dışındaki drawer'ın gölgesi sağ kenarda grilik yapmaz */
body.ozc-drawer-open .ozc-drawer{ transform:none; box-shadow:-40px 0 90px rgba(6,20,58,.42); } /* gölge sadece açıkken/açılırken */
.ozc-drawer-head{ position:relative; display:flex; align-items:flex-start; justify-content:space-between; gap:14px;
  padding:22px 22px 24px; background:linear-gradient(125deg,var(--navy-deep),var(--brand)); color:#fff; overflow:hidden; }
.ozc-drawer-head::after{ content:""; position:absolute; right:-40px; top:-50px; width:180px; height:180px; border-radius:50%;
  background:radial-gradient(circle,rgba(70,198,255,.4),transparent 70%); pointer-events:none; }
.ozc-dh-badge{ display:inline-flex; align-items:center; gap:6px; font-size:.72rem; font-weight:600; letter-spacing:.04em;
  background:rgba(255,255,255,.16); padding:5px 11px; border-radius:999px; }
.ozc-dh-badge::before{ content:""; width:7px; height:7px; border-radius:50%; background:#5cff9d; }
.ozc-drawer-head h3{ font-family:var(--display); font-weight:600; font-size:1.5rem; margin-top:11px; position:relative; color:#fff; }
.ozc-dh-close{ width:38px; height:38px; flex:none; border-radius:50%; border:none; cursor:pointer; background:rgba(255,255,255,.16);
  color:#fff; display:grid; place-items:center; position:relative; z-index:2; transition:background .2s, transform .3s; }
.ozc-dh-close:hover{ background:rgba(255,255,255,.3); transform:rotate(90deg); }
.ozc-dh-close svg{ width:19px; height:19px; }
.ozc-drawer-scroll{ flex:1; overflow-y:auto; padding:22px; }
.ozc-intro h4{ font-family:var(--display); font-weight:600; font-size:1.22rem; color:var(--navy-deep); }
.ozc-intro p{ font-size:.9rem; color:var(--muted); margin-top:9px; line-height:1.6; }
.ozc-intro p b{ color:var(--navy); font-weight:600; }
.ozc-feats{ display:flex; flex-direction:column; gap:9px; margin:18px 0 6px; padding:15px 16px; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); }
.ozc-feat{ display:flex; align-items:center; gap:11px; font-size:.86rem; color:var(--navy); font-weight:500; }
.ozc-feat .fic{ width:28px; height:28px; flex:none; border-radius:9px; background:rgba(12,92,224,.1); color:var(--brand); display:grid; place-items:center; }
.ozc-feat .fic svg{ width:16px; height:16px; }
.ozc-form{ margin-top:22px; }
.ozc-kvkk{ display:flex; gap:11px; align-items:flex-start; margin:4px 0 18px; font-size:.8rem; color:var(--muted); line-height:1.5; cursor:pointer; }
.ozc-kvkk input{ margin-top:1px; width:18px; height:18px; flex:none; accent-color:var(--brand); cursor:pointer; }
.ozc-kvkk a{ color:var(--brand); font-weight:600; }
.ozc-form .btn-primary{ width:100%; }
.ozc-form .note{ font-size:.77rem; color:var(--muted); text-align:center; margin-top:14px; }
.ozc-form-ok{ display:none; text-align:center; padding:50px 16px; }
.ozc-form-ok.show{ display:block; animation:fadeUp .5s ease; }
.ozc-form-ok .ok{ width:70px; height:70px; margin:0 auto 20px; border-radius:50%; background:linear-gradient(135deg,#19b36b,#0ea75f); display:grid; place-items:center; color:#fff; box-shadow:0 16px 40px rgba(14,167,95,.35); }
.ozc-form-ok .ok svg{ width:34px; height:34px; }
.ozc-form-ok h3{ font-family:var(--display); font-weight:600; font-size:1.4rem; color:var(--navy-deep); }
.ozc-form-ok p{ color:var(--muted); margin-top:10px; font-size:.92rem; line-height:1.6; }

/* --- Acil Ara dikey sekmesi (sol kenar, kırmızı) --- */
/* VARSAYILAN GİZLİ (sola kaymış) — sayfa geçişlerinde flicker olmasın. JS görünür yapar. */
.acil-tab{ position:fixed; left:0; top:50%; transform:translate(-115%,-50%); pointer-events:none; z-index:1150;
  display:flex; flex-direction:column; align-items:center; gap:9px;
  background:linear-gradient(180deg,#ff4747,#d61f1f); color:#fff; padding:12px 9px 18px;
  border-radius:0 16px 16px 0; box-shadow:0 14px 34px rgba(214,31,31,.45);
  transition:transform .8s cubic-bezier(.22,1,.36,1), padding-left .25s, box-shadow .25s; font-family:var(--sans); }
.acil-tab:hover{ padding-left:14px; box-shadow:0 18px 46px rgba(214,31,31,.62); }
.acil-hide{ width:22px; height:22px; flex:none; border-radius:50%; display:grid; place-items:center;
  background:rgba(255,255,255,.18); color:#fff; cursor:pointer; transition:background .2s; }
.acil-hide:hover{ background:rgba(255,255,255,.42); }
.acil-hide svg{ width:12px; height:12px; }
.acil-ic{ width:36px; height:36px; flex:none; border-radius:50%; background:rgba(255,255,255,.2);
  display:grid; place-items:center; position:relative; }
.acil-ic svg{ width:20px; height:20px; }
.acil-ic::before{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid rgba(255,255,255,.55);
  animation:acilPulse 1.8s ease-out infinite; }
@keyframes acilPulse{ 0%{ transform:scale(1); opacity:.7; } 80%,100%{ transform:scale(1.75); opacity:0; } }
.acil-txt{ writing-mode:vertical-rl; transform:rotate(180deg); font-weight:700; font-size:.82rem;
  letter-spacing:.1em; text-transform:uppercase; }

/* Acil Ara — yaka seçim kartı (sekmeye tıklayınca açılır) */
.acil-pop{ position:fixed; left:64px; top:50%; transform:translate(-8px,-50%); z-index:1151;
  width:min(292px, calc(100vw - 78px)); background:#fff; border-radius:16px; padding:10px;
  box-shadow:0 22px 60px rgba(214,31,31,.28), 0 6px 18px rgba(6,20,58,.14);
  opacity:0; pointer-events:none; transition:opacity .25s, transform .25s; font-family:var(--sans); }
.acil-pop.open{ opacity:1; transform:translate(0,-50%); pointer-events:auto; }
body.nav-open .acil-pop{ opacity:0; pointer-events:none; } /* mobil menü açıkken gizle */
.acil-pop::before{ content:""; position:absolute; left:-5px; top:50%; width:12px; height:12px; background:#fff;
  transform:translateY(-50%) rotate(45deg); border-radius:2px; }
.acil-pop-head{ padding:8px 10px 10px; }
.acil-pop-head b{ display:block; font-size:.92rem; color:var(--navy-deep); }
.acil-pop-head small{ font-size:.78rem; color:var(--muted); }
.acil-opt{ display:flex; align-items:center; gap:11px; padding:10px; border-radius:12px; transition:background .18s; }
.acil-opt:hover{ background:#fdeeee; }
.acil-opt .ic{ width:38px; height:38px; flex:none; border-radius:50%; background:linear-gradient(180deg,#ff4747,#d61f1f);
  color:#fff; display:grid; place-items:center; box-shadow:0 8px 18px rgba(214,31,31,.32); }
.acil-opt .ic svg{ width:17px; height:17px; }
.acil-opt .t{ display:flex; flex-direction:column; }
.acil-opt .t b{ font-size:.9rem; font-weight:600; color:var(--navy-deep); }
.acil-opt .t small{ font-size:.8rem; color:var(--muted); }
.acil-opt .arr{ margin-left:auto; color:#d61f1f; opacity:0; transform:translateX(-4px); transition:opacity .18s, transform .18s; }
.acil-opt .arr svg{ width:15px; height:15px; }
.acil-opt:hover .arr{ opacity:1; transform:none; }

/* Acil Ara gizlendiğinde geri açma çizgisi (varsayılan gizli, sola kaymış) */
.acil-reopen{ position:fixed; left:0; top:50%; transform:translate(-100%,-50%); pointer-events:none; z-index:1150;
  width:8px; height:58px; border:none; padding:0; cursor:pointer; border-radius:0 7px 7px 0;
  background:linear-gradient(180deg,#ff4747,#d61f1f); box-shadow:0 8px 22px rgba(214,31,31,.42);
  transition:transform .8s cubic-bezier(.22,1,.36,1), width .2s; }
.acil-reopen:hover{ width:13px; }

/* --- Yüzen buton GÖRÜNÜRLÜĞÜ (varsayılan gizli; JS sınıflarla gösterir) ---
   Chat FAB (#ozc): `floats-on` = scroll bandında (tepe/dip değil) + mobil menü kapalı.
   Acil Ara: `acil-band` = TEPEDE DE görünür (acil giren ilk ekranda görsün), yalnız dipte
   gizlenir. Tab koşulu: kullanıcı gizlememiş (acil-hidden) VE 10sn ilgisizlik otomatiği
   devreye girmemiş (acil-auto). İkisinden biri varsa tab yerine ince çizgi (.acil-reopen). */
body.floats-on:not(.nav-open) #ozc{ transform:none; pointer-events:auto; }
body.acil-band:not(.nav-open):not(.acil-hidden):not(.acil-auto) .acil-tab{ transform:translateY(-50%); pointer-events:auto; }
body.acil-band:not(.nav-open).acil-hidden .acil-reopen,
body.acil-band:not(.nav-open).acil-auto:not(.acil-hidden) .acil-reopen{ transform:translateY(-50%); pointer-events:auto; }

@media (max-width:760px){
  #ozc{ right:14px; bottom:14px; }
  .ozc-drawer{ width:100%; box-shadow:none; } /* mobil tam ekran → kenar gölgesine gerek yok */
  .ozc-pop{ width:calc(100vw - 28px); }
  .acil-tab{ padding:10px 7px 15px; gap:7px; }
  .acil-pop{ left:55px; }
  .acil-ic{ width:32px; height:32px; }
  .acil-ic svg{ width:18px; height:18px; }
  .acil-txt{ font-size:.74rem; }
}

/* === Çerez onay banner'ı v2 (kategori onaylı; app.js yalnız etiket varsa gösterir) ===
   z-index 1250: TOC(1180) ve Acil(1150) üstü, FAB(1200) üstü — onay öncelikli. */
.cerez-banner{
  position:fixed; left:50%; bottom:18px; transform:translate(-50%, 16px);
  width:min(760px, calc(100vw - 28px));
  background:#fff; border:1px solid #e3eaf6; border-radius:16px;
  box-shadow:0 18px 48px rgba(6,20,58,.18), 0 4px 14px rgba(6,20,58,.08);
  padding:14px 16px; z-index:1250;
  opacity:0; pointer-events:none; transition:opacity .3s ease, transform .3s ease;
}
.cerez-banner.gorunur{ opacity:1; pointer-events:auto; transform:translate(-50%, 0); }
.cerez-banner .cb-ust{ display:flex; align-items:flex-start; gap:14px; }
.cerez-banner .cb-ic{ flex:0 0 auto; width:38px; height:38px; border-radius:11px;
  background:linear-gradient(135deg, var(--brand), var(--brand-bright)); color:#fff;
  display:flex; align-items:center; justify-content:center; }
.cerez-banner .cb-ic svg{ width:21px; height:21px; }
.cerez-banner .cb-metin{ flex:1 1 auto; min-width:0; }
.cerez-banner .cb-metin b{ display:block; font-size:.88rem; color:var(--navy); margin-bottom:2px; }
.cerez-banner .cb-metin p{ font-size:.78rem; line-height:1.45; color:#51607a; margin:0; }
.cerez-banner .cb-metin a{ color:var(--brand); text-decoration:underline; }
.cerez-banner .cb-katlar{ display:flex; gap:10px; flex-wrap:wrap; margin:11px 0 2px 52px; }
.cerez-banner .cb-kat{
  display:flex; align-items:center; gap:9px; cursor:pointer; margin:0;
  border:1px solid #e3eaf6; border-radius:11px; padding:8px 12px; background:#f9fbff;
}
.cerez-banner .cb-kat input{ width:16px; height:16px; accent-color:var(--brand); cursor:pointer; }
.cerez-banner .cb-kat b{ display:block; font-size:.8rem; color:var(--navy); line-height:1.2; }
.cerez-banner .cb-kat small{ display:block; font-size:.7rem; color:#51607a; }
.cerez-banner .cb-btnler{ display:flex; gap:8px; justify-content:flex-end; margin-top:11px; }
.cerez-banner .cb-btn{
  font-family:var(--sans); font-weight:600; font-size:.8rem; cursor:pointer;
  border-radius:10px; padding:9px 14px; border:1px solid transparent; transition:.2s;
}
.cerez-banner .cb-kabul{ background:var(--brand); color:#fff; }
.cerez-banner .cb-kabul:hover{ background:var(--brand-bright); }
.cerez-banner .cb-red{ background:#fff; color:#51607a; border-color:#dbe4f2; }
.cerez-banner .cb-red:hover{ color:var(--navy); border-color:#b9c7de; }
/* Footer'daki "Çerez Tercihleri" linki (yalnız sayfada etiket varsa görünür — app.js açar) */
.cerez-tercih{
  border:none; background:none; padding:0; cursor:pointer; font:inherit;
  color:inherit; text-decoration:underline; opacity:.85;
}
.cerez-tercih:hover{ opacity:1; }
@media (max-width:640px){
  .cerez-banner{ bottom:10px; padding:13px 14px; }
  .cerez-banner .cb-katlar{ margin-left:0; }
  .cerez-banner .cb-kat{ flex:1 1 100%; }
  .cerez-banner .cb-btn{ padding:10px 14px; }
}

/* === WP destek mesai-dışı bildirimi (FAB WhatsApp kartı; app.js saat dışında gösterir) === */
.ozc-wa-kapali{
  margin:10px 12px 0; padding:11px 13px; border-radius:12px;
  background:#fff8eb; border:1px solid #f3d9a4;
}
.ozc-wa-kapali b{ display:block; font-size:.8rem; color:#7a4d09; margin-bottom:3px; }
.ozc-wa-kapali b .saat{ font-weight:600; color:#a16207; }
.ozc-wa-kapali p{ font-size:.74rem; line-height:1.5; color:#6b5530; margin:0 0 9px; }
.ozc-wa-kapali .ara-btnler{ display:flex; gap:7px; flex-wrap:wrap; }
.ozc-wa-kapali .ozc-wk-ara{
  display:inline-flex; align-items:center; gap:6px;
  background:var(--brand); color:#fff; border-radius:9px;
  padding:7px 11px; font-size:.74rem; font-weight:600; text-decoration:none;
}
.ozc-wa-kapali .ozc-wk-ara:hover{ background:var(--brand-bright); }
.ozc-wa-kapali .ozc-wk-ara svg{ width:13px; height:13px; }
