:root{
  --anth:#0B0D10;
  --anth2:#11141A;
  --paper:#0F131A;
  --text:#EEF1F6;
  --muted:#A9B3C4;

  --yellow:#FFD400;
  --yellow2:#FFB800;
  --green:#25D366;

  --border: rgba(255,255,255,.10);

  --r-sm:14px;
  --r-md:18px;
  --r-lg:26px;

  --shadow: 0 22px 70px rgba(0,0,0,.45);
  --glow: 0 0 0 1px rgba(255,212,0,.10), 0 20px 80px rgba(255,212,0,.10);

  --container: 1180px;
  --ease: cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
img,video{max-width:100%;display:block}
a{color:inherit}

/* =========================
   BASE / BACKGROUND
========================= */
body{
  background:
    radial-gradient(900px 520px at 20% 0%, rgba(255,212,0,.08), transparent 60%),
    radial-gradient(900px 520px at 85% 10%, rgba(255,184,0,.06), transparent 55%),
    linear-gradient(180deg, var(--anth) 0%, var(--paper) 60%, #0C0F15 100%);
  color: var(--text);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.55;
  overflow-x:hidden;
  font-weight: 400;
  letter-spacing: 0;
}

/* =========================
   TYPOGRAPHY (Premium weights)
========================= */
.h1,.h2{
  font-family: Poppins, Inter, system-ui, sans-serif;
  font-weight: 650;
}
.h3{ font-weight: 600; }
strong{ font-weight: 650; }

.h1{
  font-size: clamp(32px, 4.2vw, 62px);
  line-height:1.02;
  letter-spacing:-.02em;
  margin:0;
}
.h2{
  font-size: clamp(22px, 2.2vw, 34px);
  margin:0;
}
.h3{font-size:18px;margin:0}

.lead{color: rgba(238,241,246,.78); max-width:72ch; font-size:16px; font-weight:400;}
.muted{color: var(--muted); font-weight:400;}

/* =========================
   LAYOUT
========================= */
.container{width:min(var(--container), calc(100% - 40px)); margin-inline:auto;}
@media (max-width:640px){ .container{width: calc(100% - 28px);} }

.section{padding: 72px 0}
.section--tight{padding: 56px 0}
@media (max-width:900px){
  .section{padding: 50px 0}
  .section--tight{padding: 44px 0}
}
.section-head{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}

/* =========================
   PILL / TAG
========================= */
.pill{
  display:inline-flex;align-items:center;gap:10px;
  width: fit-content;
  padding: 10px 12px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(238,241,246,.92);
  font-weight: 600;
}
.pill--soft{
  border-color: rgba(255,212,0,.18);
  background: rgba(255,212,0,.08);
  color: rgba(255,212,0,.95);
}

.tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 12px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: rgba(238,241,246,.86);
  font-weight: 600;
}
.tag i{color: rgba(255,212,0,.95)}

/* =========================
   BUTTONS
========================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;
  border-radius: 14px;
  border:1px solid transparent;
  text-decoration:none;
  font-weight: 650;
  transition: transform .18s var(--ease), filter .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}
.btn:active{transform: translateY(1px)}
.btn i{font-size:16px}

.btn--primary{
  background: linear-gradient(135deg, var(--yellow), var(--yellow2));
  color:#111;
  box-shadow: 0 20px 80px rgba(255,212,0,.18);
}
.btn--primary:hover{filter: brightness(1.03)}

.btn--ghost{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.14);
  color: var(--text);
}
.btn--ghost:hover{border-color: rgba(255,212,0,.30)}

.btn--whatsapp{background: var(--green); color:#fff}
.btn--whatsapp:hover{filter: brightness(1.03)}
.btn--block{width:100%}

/* =========================
   HEADER (Topbar + Main)
========================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: 80;
  background: rgba(11,13,16,.62);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.10);
}

/* Desktop Topbar */
.topbar{
  border-bottom: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
}
.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 10px 0;
}
.topbar__item{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color: rgba(238,241,246,.85);
  font-weight: 600;
}
.topbar__item i{ color: rgba(255,212,0,.95); }

.topbar__link{
  color: rgba(255,212,0,.95);
  text-decoration:none;
  font-weight: 650;
}
.topbar__link:hover{ filter: brightness(1.08); }

.topbar__right{ display:flex; gap:10px; align-items:center; }

.social{
  width:38px;height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(238,241,246,.92);
  text-decoration:none;
  transition: border-color .18s var(--ease), transform .18s var(--ease);
}
.social:hover{
  border-color: rgba(255,212,0,.30);
  transform: translateY(-1px);
}
.social i{ font-size: 15px; }

/* Main header row */
.header-main{ padding: 12px 0; }
.header-main__inner{
  display:flex;
  align-items:center;
  gap:16px;
}

/* Brand */
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color: var(--text);
}
.brand__mark{
  width:14px;height:14px;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--yellow), var(--yellow2));
  box-shadow: 0 14px 40px rgba(255,212,0,.18);
}
.brand__text{
  font-family: Poppins, Inter, sans-serif;
  font-weight: 700;
  letter-spacing: -.02em;
}

/* Desktop menu container */
.nav--desktop{ margin-left:auto; }

/* Desktop menu list */
.menu{
  list-style:none;
  display:flex;
  align-items:center;
  gap:14px;
  margin:0;
  padding:0;
  flex-wrap: nowrap;
}

.menu > li{ position: relative; }

.menu > li > a{
  display:inline-flex;
  align-items:center;
  padding: 10px 12px;
  border-radius: 14px;
  text-decoration:none;
  color: rgba(238,241,246,.92);
  font-weight: 600;
  white-space: nowrap;
  transition: background .18s var(--ease), border-color .18s var(--ease), transform .18s var(--ease);
}

.menu > li > a:hover{
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
}

/* Parent arrow indicator */
.menu > li.menu-item-has-children > a::after{
  content:"";
  width: 6px; height: 6px;
  border-right: 2px solid rgba(238,241,246,.7);
  border-bottom: 2px solid rgba(238,241,246,.7);
  transform: rotate(45deg);
  display:inline-block;
  margin-left: 10px;
  margin-top: -2px;
  opacity: .7;
}

/* Dropdown panel */
.menu .sub-menu{
  position: absolute;
  top: calc(100% + 12px);
  left: 0;

  min-width: 320px;
  padding: 10px;
  margin: 0;
  list-style: none;

  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,12,16,.84);
  backdrop-filter: blur(18px);
  box-shadow: 0 30px 90px rgba(0,0,0,.55);

  display: none;
  z-index: 999;

  transform: translateY(6px);
  opacity: 0;
  pointer-events: none;

  transition: opacity .18s var(--ease), transform .18s var(--ease);
}

.menu > li.menu-item-has-children:hover > .sub-menu,
.menu > li.menu-item-has-children:focus-within > .sub-menu{
  display: grid;
  gap: 8px;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.menu .sub-menu li a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;

  padding: 10px 12px;
  border-radius: 14px;
  text-decoration:none;

  color: rgba(238,241,246,.92);
  font-weight: 520;

  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  transition: transform .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}

.menu .sub-menu li a:hover{
  border-color: rgba(255,212,0,.26);
  background: rgba(255,212,0,.08);
  transform: translateY(-1px);
}

/* Desktop actions */
.header-actions--desktop{
  display:flex;
  gap:10px;
  align-items:center;
}

/* Mobile toggle */
.nav-toggle{
  margin-left:auto;
  width:46px;height:46px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(238,241,246,.95);
  cursor:pointer;
}
.nav-toggle:hover{ border-color: rgba(255,212,0,.30); }

/* Mobile panel */
.mobile-nav{
  padding: 10px 0 16px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.mobile-menu{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}

/* Accordion items */
.mobile-menu > li{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  border-radius: 18px;
  overflow: hidden;
}

.mobile-menu > li > a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 14px;
  border: 0;
  background: transparent;
  color: rgba(238,241,246,.92);
  text-decoration:none;
  font-weight: 600;
}

.mobile-menu a:hover{ border-color: rgba(255,212,0,.28); }

/* Submenu (hidden by JS via [hidden]) */
/* Mobile submenu: default CLOSED (JS açınca .is-open ile açılacak) */
.mobile-menu .sub-menu{
  list-style:none;
  padding: 0 10px 12px;
  margin: 0;
  display: none !important; /* <<< default kapalı */
  gap: 8px;
}

.mobile-menu > li.menu-item-has-children.is-open > .sub-menu{
  display: grid !important; /* <<< sadece açıkken */
}

.mobile-menu .sub-menu a{
  border-radius: 14px;
  padding: 12px 12px;
  background: rgba(0,0,0,.20);
  border: 1px solid rgba(255,255,255,.08);
  font-weight: 520;
  text-decoration:none;
  color: rgba(238,241,246,.90);
}

/* Toggle button injected by JS */
.submenu-toggle{
  width: 44px;
  height: 44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border: 0;
  background: transparent;
  color: rgba(238,241,246,.85);
  cursor: pointer;
  margin-right: 6px;
}
.submenu-toggle i{
  transition: transform .18s var(--ease);
}
/* Buton <a> içinde olduğu için direct child değil, bu selector şart */
.menu-item-has-children.is-open .submenu-toggle i{
  transform: rotate(180deg);
}

/* Mobile meta blocks */
.mobile-cta{ margin-top: 12px; display:grid; gap:12px; }

.mobile-meta{
  border-radius: var(--r-lg);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding: 12px;
  display:grid;
  gap:12px;
}
.mobile-call{
  display:flex;
  gap:10px;
  align-items:flex-start;
}
.mobile-call i{
  color: rgba(255,212,0,.95);
  margin-top: 2px;
}
.mobile-call__title{
  font-weight: 650;
  color: rgba(238,241,246,.92);
  font-size: 13px;
}
.mobile-call__link{
  display:inline-block;
  margin-top: 2px;
  color: rgba(255,212,0,.95);
  font-weight: 650;
  text-decoration:none;
}
.mobile-call__link:hover{ filter: brightness(1.08); }

.mobile-social{ display:flex; gap:10px; flex-wrap:wrap; }
.social--mobile{ width:42px;height:42px; }

/* Responsive rules */
@media (max-width: 980px){
  .topbar--desktop{ display:none; }
  .nav--desktop{ display:none; }
  .header-actions--desktop{ display:none; }
  .header-main{ padding: 10px 0; }
  .site-header{ backdrop-filter: blur(16px); }
}
@media (min-width: 981px){
  .nav-toggle{ display:none; }
  .mobile-nav{ display:none !important; }
}

/* =========================
   HERO MEDIA SLIDER (no text)
========================= */
.hero-media{ padding-top: 16px; }

.hero-media__wrap{
  position:relative;
  height: min(72vh, 720px);
  border-radius: var(--r-lg);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow);
}

@media (max-width:900px){
  .hero-media__wrap{ height: 54vh; }
}
@media (max-width:600px){
  .hero-media__wrap{ height: 48vh; border-radius: 22px; }
}

.hero-media__slide{
  position:absolute; inset:0;
  opacity:0;
  transform: scale(1.03);
  transition: opacity .7s var(--ease), transform 1.1s var(--ease);
}
.hero-media__slide.is-active{
  opacity:1;
  transform: scale(1);
}
.hero-media__slide img{
  width:100%; height:100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(1.06) contrast(1.02);
}
.hero-media__wrap::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(700px 380px at 20% 20%, rgba(255,212,0,.22), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.45));
  pointer-events:none;
}

/* Slider arrows + dots */
.ms-arrow{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width:46px;height:46px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.22);
  color:#fff;
  cursor:pointer;
  z-index:3;
}
.ms-arrow--prev{left:12px}
.ms-arrow--next{right:12px}
.ms-arrow:hover{border-color: rgba(255,212,0,.35)}

.ms-dots{
  position:absolute;
  left:14px;
  bottom:14px;
  display:flex;
  gap:8px;
  z-index:3;
}
.ms-dots button{
  width:9px;height:9px;border-radius:99px;border:0;
  background: rgba(255,255,255,.35);
  cursor:pointer;
}
.ms-dots button[aria-current="true"]{background: var(--yellow)}

/* =========================
   HERO INTRO (below slider)
========================= */
.hero-intro{
  padding-top: 0;
  margin-top: -28px;
  position: relative;
  z-index: 3;
  padding-bottom: 12px;
}
@media (max-width:900px){
  .hero-intro{ margin-top: -18px; }
}

.hero-intro__grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:16px;
  align-items:start;
}
@media (max-width:900px){
  .hero-intro__grid{grid-template-columns:1fr;}
}

.hero-copy{
  border-radius: var(--r-lg);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  padding: 20px;
  box-shadow: var(--glow);
}

.cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.trust-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}

/* Offer card UI */
.offer-card{
  border-radius: var(--r-lg);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  padding: 18px;
  box-shadow: var(--shadow);
}
.offer-card__head{margin-bottom: 10px}
.offer-form{display:grid;gap:10px}

.field span{
  display:block;
  font-size:12px;
  color: rgba(238,241,246,.72);
  font-weight:600;
  margin-bottom:6px
}
.field input,.field select{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  color: var(--text);
  outline:none;
}
.field input::placeholder{color: rgba(238,241,246,.40)}
.field input:focus,.field select:focus{border-color: rgba(255,212,0,.45)}

.offer-mini{
  display:flex;flex-wrap:wrap;gap:10px;
  color: rgba(238,241,246,.74);
  font-weight:600;
  font-size:13px;
}
.offer-mini i{color: var(--yellow)}

/* =========================
   SERVICES UI
========================= */
.grid{display:grid;gap:14px}
.grid--3{grid-template-columns: repeat(3, minmax(0,1fr))}
@media (max-width:900px){ .grid--3{grid-template-columns: repeat(2, minmax(0,1fr))} }
@media (max-width:640px){ .grid--3{grid-template-columns: 1fr} }

.svc{
  border-radius: var(--r-lg);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.28);
  transition: transform .18s var(--ease), border-color .18s var(--ease);
}
.svc:hover{
  transform: translateY(-2px);
  border-color: rgba(255,212,0,.24);
}
.svc__icon{
  width:46px;height:46px;
  border-radius: 16px;
  display:flex;align-items:center;justify-content:center;
  background: rgba(255,212,0,.10);
  border:1px solid rgba(255,212,0,.18);
  margin-bottom: 10px;
  box-shadow: 0 18px 70px rgba(255,212,0,.08);
}
.svc__icon i{color: var(--yellow)}
.svc__link{
  display:inline-flex;align-items:center;gap:10px;
  margin-top: 8px;
  font-weight: 650;
  color: rgba(255,212,0,.95);
  text-decoration:none;
}
.svc__link:hover{filter: brightness(1.08)}

/* =========================
   MARQUEE (Testimonials)
========================= */
.marquee{
  border-radius: var(--r-lg);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding: 12px;
  overflow:hidden;
}
.marquee::-webkit-scrollbar{display:none}
.marquee__track{
  display:flex;
  gap:14px;
  width:max-content;
  align-items:stretch;
}
.tcard{
  width: 340px;
  border-radius: var(--r-lg);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  overflow:hidden;
  flex:0 0 auto;
  box-shadow: 0 18px 70px rgba(0,0,0,.28);
}
.tcard__img{height: 210px; position:relative;}
.tcard__img img{width:100%;height:100%;object-fit: cover;}
.tcard__img::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.62));
}
.tcard__body{
  padding: 14px;
  margin-top: -42px;
  position:relative;
}
.quote{
  background: rgba(15,19,26,.78);
  border:1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  padding: 12px;
}
.quote p{margin:0;color: rgba(238,241,246,.92);font-weight:600;line-height:1.45}
.quote .who{margin-top:8px;color: rgba(255,212,0,.92);font-size:13px;font-weight:650}
.marquee.is-dragging{cursor: grabbing}

/* =========================
   REELS
========================= */
.reels{
  display:flex;
  gap: 14px;
  overflow:auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 6px;
}
.reels::-webkit-scrollbar{display:none}
.reel{
  flex: 0 0 auto;
  width: 280px;
  border-radius: var(--r-lg);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  overflow:hidden;
  position:relative;
  scroll-snap-align: start;
  box-shadow: 0 22px 70px rgba(0,0,0,.30);
}
.reel__video{
  width:100%;
  height: 460px;
  object-fit: cover;
  background:#000;
}
@media (max-width:640px){
  .reel{width: 72vw}
  .reel__video{height: 58vh}
}
.reel__play{
  position:absolute;
  left:12px; top:12px;
  width:46px;height:46px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.25);
  color:#fff;
  cursor:pointer;
  z-index:2;
}
.reel__play:hover{border-color: rgba(255,212,0,.35)}
.reel__meta{
  position:absolute;
  left:12px; right:12px; bottom:12px;
  padding: 12px;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
}

/* =========================================================
   FORCE DESKTOP DROPDOWN (override everything)
   (Bu blok, başka CSS ezse bile dropdown'u kesin düzeltir)
========================================================= */
.nav--desktop .menu{ list-style:none !important; margin:0 !important; padding:0 !important; display:flex !important; gap:14px !important; }
.nav--desktop .menu > li{ position:relative !important; }
.nav--desktop .menu > li > a{ display:inline-flex !important; align-items:center !important; padding:10px 12px !important; border-radius:14px !important; text-decoration:none !important; }

/* Submenu default hidden */
.nav--desktop .menu > li > .sub-menu{
  position:absolute !important;
  top: calc(100% + 12px) !important;
  left: 0 !important;

  display: none !important;
  opacity: 0 !important;
  transform: translateY(8px) !important;
  pointer-events: none !important;

  min-width: 320px !important;
  padding: 10px !important;
  margin: 0 !important;
  list-style: none !important;

  border-radius: 18px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  background: rgba(10,12,16,.84) !important;
  backdrop-filter: blur(18px) !important;
  box-shadow: 0 30px 90px rgba(0,0,0,.55) !important;

  z-index: 9999 !important;
}

/* Show on hover/focus */
.nav--desktop .menu > li.menu-item-has-children:hover > .sub-menu,
.nav--desktop .menu > li.menu-item-has-children:focus-within > .sub-menu{
  display: grid !important;
  gap: 8px !important;
  opacity: 1 !important;
  transform: translateY(0) !important;
  pointer-events: auto !important;
}

/* Submenu links */
.nav--desktop .menu > li > .sub-menu a{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;

  padding:10px 12px !important;
  border-radius:14px !important;

  border: 1px solid rgba(255,255,255,.10) !important;
  background: rgba(255,255,255,.03) !important;

  text-decoration:none !important;
  color: rgba(238,241,246,.92) !important;
  font-weight: 520 !important;
}
.nav--desktop .menu > li > .sub-menu a:hover{
  border-color: rgba(255,212,0,.26) !important;
  background: rgba(255,212,0,.08) !important;
  transform: translateY(-1px) !important;
}
/* =========================
   DROPDOWN HOVER FIX
   (hover gap + clickable submenu)
========================= */

/* Parent LI hover alanını büyüt: imleç aşağı inerken kopmasın */
.nav--desktop .menu > li.menu-item-has-children{
  padding-bottom: 14px; /* gap bridge */
}

/* Submenu üst boşluğunu kaldır veya çok azalt */
.nav--desktop .menu > li > .sub-menu{
  top: calc(100% + 4px) !important; /* 12px yerine 4px */
}

/* Submenu hover olunca da açık kalsın (ekstra güvenlik) */
.nav--desktop .menu > li.menu-item-has-children:hover > .sub-menu,
.nav--desktop .menu > li.menu-item-has-children:focus-within > .sub-menu,
.nav--desktop .menu > li.menu-item-has-children > .sub-menu:hover{
  display: grid !important;
  opacity: 1 !important;
  transform: translateY(0) !important;
  pointer-events: auto !important;
}

/* Hover bridge: li ile submenu arasında görünmez bir köprü */
.nav--desktop .menu > li.menu-item-has-children > .sub-menu::before{
  content:"";
  position:absolute;
  left: 0;
  right: 0;
  top: -12px;     /* submenu ile parent arasını kapat */
  height: 12px;
}
/* Mobile submenu items full width */
.mobile-menu .sub-menu a{
  width: 100%;
  display: flex;
}
/* =========================
   MOBILE NAV SCROLL LOCK
========================= */
body.is-nav-open{
  overflow: hidden;
  touch-action: none;
}

/* Mobile nav panel kendi içinde scroll */
@media (max-width: 980px){
  .mobile-nav{
    max-height: calc(100vh - 74px); /* header yüksekliğine göre */
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
  }
}
/* Desktop: 3 reel yan yana, scroll yok */
@media (min-width: 981px){
  .reels{
    overflow: visible;
  }
  .reel{
    width: auto;
    flex: 1 1 0;
    max-width: 380px;
  }
}
/* =========================
   DISTRICTS (internal links)
========================= */
.districts{
  display:grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap:10px;
}
@media (max-width: 980px){
  .districts{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
.district{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding: 12px 14px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  text-decoration:none;
  transition: transform .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}
.district:hover{
  transform: translateY(-1px);
  border-color: rgba(255,212,0,.22);
  background: rgba(255,212,0,.06);
}
.district i{ color: rgba(255,212,0,.95); }

/* =========================
   FAQ (details/summary)
========================= */
.faq{
  display:grid;
  gap:10px;
}
.faq__item{
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  overflow:hidden;
}
.faq__q{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 14px 14px;
  font-weight: 650;
  color: rgba(238,241,246,.92);
}
.faq__q::-webkit-details-marker{ display:none; }
.faq__q i{
  transition: transform .18s var(--ease);
  opacity: .9;
}
.faq__item[open] .faq__q i{
  transform: rotate(180deg);
}
.faq__a{
  padding: 0 14px 14px;
  border-top: 1px solid rgba(255,255,255,.08);
}
/* =========================
   CONTACT PAGE
========================= */
.contact-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 16px;
  align-items:start;
}
@media (max-width: 980px){
  .contact-grid{ grid-template-columns: 1fr; }
}

.contact-cards{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 640px){
  .contact-cards{ grid-template-columns: 1fr; }
}

.contact-right{
  display:grid;
  gap: 14px;
}

.contact-map .map-embed{
  margin-top: 12px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
}
.contact-map iframe{
  width: 100%;
  height: 320px;
  border: 0;
  display:block;
}
@media (max-width: 640px){
  .contact-map iframe{ height: 280px; }
}

/* CF7 wrap: tema stiline uyum */
.cf7-wrap :is(input, select, textarea){
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  color: var(--text);
  outline:none;
}
.cf7-wrap textarea{ min-height: 120px; resize: vertical; }
.cf7-wrap :is(input, select, textarea):focus{ border-color: rgba(255,212,0,.45); }
.cf7-wrap .wpcf7-submit{
  width:100%;
  cursor:pointer;
  border:0;
  border-radius: 14px;
  padding: 12px 16px;
  font-weight: 650;
  background: linear-gradient(135deg, var(--yellow), var(--yellow2));
  color:#111;
  box-shadow: 0 20px 80px rgba(255,212,0,.18);
}
.cf7-wrap .wpcf7-not-valid-tip{ color: rgba(255,212,0,.95); }

/* CF7'yi offer-card düzenine uydur */
.offer-form--cf7 .wpcf7 form,
.offer-form--cf7 .wpcf7-form{
  display: grid;
  gap: 10px;
}

.offer-form--cf7 .wpcf7 p{ margin: 0; }

.offer-form--cf7 .wpcf7 input,
.offer-form--cf7 .wpcf7 select,
.offer-form--cf7 .wpcf7 textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  color: var(--text);
  outline: none;
}

.offer-form--cf7 .wpcf7 input:focus,
.offer-form--cf7 .wpcf7 select:focus,
.offer-form--cf7 .wpcf7 textarea:focus{
  border-color: rgba(255,212,0,.45);
}

.offer-form--cf7 .wpcf7-submit{
  width: 100%;
}
/* =========================
   FOOTER (Premium)
========================= */
.site-footer{ padding: 38px 0 28px; }

.footer-card{
  border-radius: var(--r-lg);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  box-shadow: 0 22px 70px rgba(0,0,0,.28);
  overflow: hidden;
}

.footer-grid{
  display:grid;
  grid-template-columns: 1.25fr 1fr 1fr .95fr;
  gap: 18px;
  padding: 22px;
}

@media (max-width: 980px){
  .footer-grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px){
  .footer-grid{ grid-template-columns: 1fr; padding: 18px; }
}

.footer-col .h3{ margin-bottom: 10px; }

.footer-actions{ display:flex; gap:10px; flex-wrap:wrap; }

.footer-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap: 10px;
}

.footer-list a{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  text-decoration:none;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  color: rgba(238,241,246,.92);
  transition: transform .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}
.footer-list a:hover{
  transform: translateY(-1px);
  border-color: rgba(255,212,0,.22);
  background: rgba(255,212,0,.06);
}
.footer-list a i{ color: rgba(255,212,0,.95); }

/* wp_nav_menu ul'lerini de footer-list gibi göster */
.footer-menu ul{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap: 10px;
}
.footer-menu a{
  display:flex;
  align-items:center;
  padding: 10px 12px;
  border-radius: 14px;
  text-decoration:none;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  color: rgba(238,241,246,.92);
}
.footer-menu a:hover{
  border-color: rgba(255,212,0,.22);
  background: rgba(255,212,0,.06);
}

.footer-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 14px 22px;
  border-top: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.14);
}

@media (max-width: 640px){
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
}

.small{ font-size: 13px; }