:root{
  --bg:        oklch(0.993 0.002 255);
  --bg-2:      oklch(0.972 0.004 255);
  --ink:       oklch(0.27 0.026 260);
  --ink-2:     oklch(0.505 0.02 260);
  --line:      oklch(0.915 0.008 258);
  --line-2:    oklch(0.945 0.006 258);
  --dark:      oklch(0.235 0.03 262);
  --dark-2:    oklch(0.30 0.032 262);
  --cream:     oklch(0.975 0.008 255);
  --on-dark:   oklch(0.8 0.018 258);
  --coral:     oklch(0.59 0.175 33);
  --coral-deep:oklch(0.515 0.16 32);
  --coral-soft:oklch(0.59 0.175 33 / .10);
  --exp:cubic-bezier(.16,1,.3,1);
  --maxw:1240px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%; scroll-behavior:smooth; scroll-padding-top:78px; background:var(--bg)}
body{margin:0; background:transparent; color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,sans-serif; font-weight:400; font-size:1.01rem;
  line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility}

/* ===== Acik zemin atmosferi: animasyonlu radyal (circle) gradyan =====
   Sabit (fixed) tek katman icerigin ARKASINDA (z-1); koyu hero/footer kendi opak zemini ile orter,
   yalniz acik alanlarda gorunur. Kartlar opak -> icerik ustunde okunur. SCANLINE KALDIRILDI.
   Animasyon GPU-composited transform (background-position DEGIL) -> her karede repaint YOK, hafif. */
body::before{
  content:""; position:fixed; left:-20%; top:-20%; width:140%; height:140%; z-index:-1; pointer-events:none;
  background:
    radial-gradient(34% 34% at 22% 26%, oklch(0.94 0.006 255), transparent 70%),
    radial-gradient(40% 40% at 82% 30%, oklch(0.90 0.009 258), transparent 72%),
    radial-gradient(44% 44% at 56% 84%, oklch(0.955 0.005 255), transparent 70%);
  background-repeat:no-repeat;
  will-change:transform; animation:zeminKay 50s ease-in-out infinite;
}
@keyframes zeminKay{
  0%, 100% {transform:translate3d(0, 0, 0) scale(1)}
  50%      {transform:translate3d(-5%, 3.5%, 0) scale(1.05)}
}
@media (prefers-reduced-motion:reduce){ body::before{animation:none} }
a{color:inherit; text-decoration:none}
h1,h2,h3,h4{font-family:"Libre Franklin",system-ui,sans-serif; font-weight:700; line-height:1.08;
  letter-spacing:-.02em; margin:0; color:var(--ink)}
p{margin:0}
.wrap{max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,4vw,40px)}
.coral{color:var(--coral)}
.eg{font-family:"Hanken Grotesk",sans-serif; font-weight:600; font-size:.78rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--coral)}
main{position:relative; z-index:1}

/* ---------- NAV ---------- */
header.nav{position:fixed; inset:0 0 auto 0; z-index:60; border-bottom:1px solid transparent;
  transition:background .4s var(--exp), border-color .4s var(--exp)}
body.scrolled header.nav{background:color-mix(in oklch, var(--bg) 88%, transparent);
  backdrop-filter:saturate(1.3) blur(12px); border-bottom-color:var(--line)}
.nav-in{display:flex; align-items:center; gap:40px; height:58px}
/* ---------- RESMI LOGO KILIDI (mark + wordmark) — branding sistemiyle birebir ---------- */
.brand-link{position:relative; display:inline-flex; align-items:center; overflow:hidden; border-radius:10px}
/* hover: logonun uzerinden gecen ince diyagonal cam glint (yumusak, abartisiz) */
.brand-link::after{content:""; position:absolute; inset:0; pointer-events:none; filter:blur(1px);
  transform:translateX(-135%) skewX(-14deg);
  background:linear-gradient(90deg, transparent 44%, oklch(1 0 0 / .26) 50%, transparent 56%)}
.brand-link:hover::after{animation:brandShine .72s var(--exp)}
@keyframes brandShine{from{transform:translateX(-135%) skewX(-14deg)} to{transform:translateX(135%) skewX(-14deg)}}
@media (prefers-reduced-motion:reduce){ .brand-link:hover::after{animation:none} }
.brand{display:inline-flex; align-items:center; gap:.5em; font-size:1.4rem; line-height:1}
.brand .bmark{width:1.46em; height:1.46em; display:block; flex:none;
  /* golge SVG'nin yuvarlak alfa seklini takip eder (box-shadow kare kosesi birakirdi) */
  filter:drop-shadow(0 1px 1.5px oklch(0.3 0.06 30 / .28))}
.brand-wm{font-family:"Rajdhani",sans-serif; font-weight:700; font-size:1em; letter-spacing:.01em;
  line-height:1; color:var(--ink); white-space:nowrap}
.brand-wm b{font-weight:700; color:inherit}
.brand-wm span{color:var(--coral); font-weight:700}
.brand.on-dark .brand-wm{color:#fff}
.nav-links{display:flex; gap:30px; margin-left:8px}
.nav-links{align-self:stretch; align-items:center} /* tam header yuksekligi -> panel cubuga bitisir */
/* ust menu linki + mega tetikleyici ortak gorunum (button reset dahil) */
.nav-links > a, .nav-trigger{position:relative; display:inline-flex; align-items:center;
  font-family:inherit; font-weight:500; font-size:.93rem; color:var(--ink-2); transition:color .2s;
  cursor:pointer; background:none; border:0; padding:0}
.nav-links > a:hover, .nav-trigger:hover, .nav-item:hover .nav-trigger{color:var(--ink)}
/* hover: metin altinda soldan saga dolan coral cizgi (marka turuncusu) */
.nav-links > a::after, .nav-trigger::after{content:""; position:absolute; left:0; bottom:-6px; width:100%; height:2px;
  border-radius:2px; background:var(--coral); transform:scaleX(0); transform-origin:left center;
  transition:transform .32s var(--exp)}
.nav-links > a:hover::after, .nav-trigger:hover::after, .nav-item:hover .nav-trigger::after{transform:scaleX(1)}
@media (prefers-reduced-motion:reduce){ .nav-links > a::after, .nav-trigger::after{transition:none} }

/* ---------- MEGA MENU (Moduller / Cozumler) — koyu, cubuga tumlesik ---------- */
.nav-item{position:relative; display:flex; align-items:center; align-self:stretch} /* tam header yuksekligi */
.nav-chev{width:14px; height:14px; margin-left:4px; opacity:.6}
.nav-trigger > .nav-chev{transition:transform .25s var(--exp)}
.nav-item:hover .nav-trigger > .nav-chev{transform:rotate(180deg)}
/* yalniz hover ile acilir: fare cekilince / baska menuye gecince / bosluga gidince kendiliginden kapanir.
   nav-item tam yukseklik oldugu icin panel header altina BITISIR (top:100% = cubuk alti), bosluk yok. */
.mega{position:absolute; top:100%; left:-16px; z-index:70;
  opacity:0; visibility:hidden; transform:translateY(8px);
  transition:opacity .22s var(--exp), transform .22s var(--exp), visibility 0s linear .22s}
.nav-item:hover .mega{opacity:1; visibility:visible; transform:translateY(0);
  transition:opacity .26s var(--exp), transform .26s var(--exp)}
/* tumlesik panel: cubuktan asagi buyur -> ust kose DUZ + ust kenarlik YOK, alt yuvarlak */
.mega-grid{position:relative; overflow:hidden;
  background:linear-gradient(180deg, var(--dark-2), var(--dark));
  border:1px solid color-mix(in oklch, var(--cream) 11%, transparent); border-top:0;
  border-radius:0 0 12px 12px;
  box-shadow:0 30px 70px -28px oklch(0.12 0.02 262 / .85), 0 10px 30px -18px #000;
  padding:15px 14px 14px; display:grid; gap:4px}
.mega-mod .mega-grid{grid-template-columns:1fr 1fr; width:608px}
.mega-coz .mega-grid{grid-template-columns:1fr; width:392px}
.mega-card{display:grid; grid-template-columns:auto 1fr; gap:14px; align-items:start;
  padding:12px 13px; border-radius:9px; border:1px solid transparent;
  transition:background .18s var(--exp), border-color .18s var(--exp)}
.mega-card:hover{background:color-mix(in oklch, var(--cream) 6%, transparent);
  border-color:color-mix(in oklch, var(--cream) 9%, transparent)}
.mega-ic{flex:none; width:42px; height:42px; border-radius:9px; display:grid; place-items:center;
  background:color-mix(in oklch, var(--cream) 8%, transparent); color:oklch(0.78 0.13 40);
  transition:background .18s var(--exp), color .18s var(--exp), transform .18s var(--exp)}
.mega-card:hover .mega-ic{background:var(--coral); color:#fff; transform:translateY(-1px);
  box-shadow:0 8px 18px -8px var(--coral)}
.mega-ic svg{width:20px; height:20px}
.mega-tx{display:flex; flex-direction:column; gap:2px; min-width:0}
.mega-tx b{font-family:"Libre Franklin",sans-serif; font-weight:700; font-size:.95rem; color:var(--cream); letter-spacing:-.01em}
.mega-tx span{font-size:.83rem; color:var(--on-dark); line-height:1.42}
.mega-foot{display:inline-flex; align-items:center; gap:5px; margin:8px 2px 1px; padding:9px 13px;
  font-weight:600; font-size:.88rem; color:oklch(0.8 0.12 42); border-radius:8px;
  transition:background .18s var(--exp), gap .18s var(--exp)}
.mega-foot:hover{background:color-mix(in oklch, var(--cream) 6%, transparent); gap:8px}
.mega-foot .nav-chev{width:13px; height:13px; opacity:1; margin-left:0; transform:rotate(-90deg)}
/* hesap menusu (giris yapilmis) */
.acc-item{position:relative}
.acc-trigger{display:inline-flex; align-items:center; gap:8px; font-family:"Hanken Grotesk",sans-serif; font-weight:600;
  font-size:.92rem; color:var(--ink); background:none; border:0; cursor:pointer; padding:.35rem .2rem}
body.dark-hero .acc-trigger{color:#fff}
.acc-trigger .nav-chev{width:13px; height:13px}
.acc-av{width:30px; height:30px; border-radius:50%; display:grid; place-items:center; flex:none; overflow:hidden;
  background:var(--coral); color:#fff; font-weight:800; font-size:.9rem; font-family:"Libre Franklin",sans-serif}
.acc-av img{width:100%; height:100%; object-fit:cover; display:block}
.acc-name{max-width:118px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.mega-acc{left:auto; right:-8px; min-width:208px; padding:8px;
  background:linear-gradient(180deg, var(--dark-2), var(--dark));
  border:1px solid color-mix(in oklch, var(--cream) 11%, transparent); border-top:0; border-radius:0 0 12px 12px;
  box-shadow:0 30px 70px -28px oklch(0.12 0.02 262 / .85), 0 10px 30px -18px #000}
.acc-link{display:flex; align-items:center; gap:10px; width:100%; padding:10px 12px; border-radius:8px; border:0;
  background:none; cursor:pointer; font-family:"Hanken Grotesk",sans-serif; font-weight:600; font-size:.9rem;
  color:var(--cream); text-align:left; transition:background .18s var(--exp)}
.acc-link:hover{background:color-mix(in oklch, var(--cream) 7%, transparent)}
.acc-link svg{width:17px; height:17px; color:oklch(0.8 0.12 42)}
.acc-cikis{color:#ff9b86}
.acc-cikis svg{color:#ff9b86}
/* align-self:stretch -> hesap menusu (acc-item) tam header yuksekligine uzar; mega-acc top:100% = cubuk alti (tumlesik) */
.nav-cta{margin-left:auto; display:flex; align-items:center; align-self:stretch; gap:20px}
/* Giris yap: koyu header'da cam-buton (arka planli) */
.nav-cta .login{font-family:"Hanken Grotesk",sans-serif; font-weight:600; font-size:.92rem; color:var(--ink);
  padding:.55rem 1.2rem; border-radius:9px; border:1px solid var(--line); background:var(--bg-2);
  transition:background .2s var(--exp), border-color .2s var(--exp), color .2s var(--exp)}
.nav-cta .login:hover{border-color:var(--ink)}
body.dark-hero .nav-cta .login{color:#fff; background:color-mix(in oklch, var(--cream) 9%, transparent);
  border-color:color-mix(in oklch, var(--cream) 24%, transparent)}
body.dark-hero .nav-cta .login:hover{background:color-mix(in oklch, var(--cream) 15%, transparent);
  border-color:color-mix(in oklch, var(--cream) 42%, transparent)}
.btn{font-family:"Hanken Grotesk",sans-serif; font-weight:600; font-size:.95rem; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; border:0; border-radius:9px;
  padding:.7rem 1.25rem; background:var(--coral); color:#fff; box-shadow:0 8px 20px -10px var(--coral);
  transition:background .2s var(--exp), transform .2s var(--exp)}
.btn:hover{background:var(--coral-deep)}
.btn.lg{padding:.92rem 1.7rem; font-size:1rem; border-radius:10px}
.btn.ghost{background:transparent; color:var(--ink); border:1px solid var(--line); box-shadow:none}
.btn.ghost:hover{border-color:var(--ink); background:transparent}

/* ---------- HERO ---------- */
.hero{padding:clamp(108px,13vh,150px) 0 clamp(40px,6vh,72px); position:relative; isolation:isolate}
.hero-grid{display:grid; grid-template-columns:0.92fr 1.08fr; gap:clamp(28px,4vw,60px); align-items:center; position:relative; z-index:1}

/* ---------- HERO AURORA (suzulen renk alanlari, dekoratif zemin) ---------- */
.hero-aurora{position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none;
  /* boyamayi izole et: scroll sirasinda sayfanin geri kalanini repaint'e zorlamaz */
  contain:layout paint style;
  /* kenarlardan ve alttan yumusakca erir: metin + alt seride tasmaz */
  -webkit-mask-image:radial-gradient(135% 115% at 62% 26%, #000 0%, #000 42%, transparent 82%);
  mask-image:radial-gradient(135% 115% at 62% 26%, #000 0%, #000 42%, transparent 82%)}
.hero-aurora .a{position:absolute; border-radius:50%; filter:blur(34px); will-change:transform,opacity}
/* her alan farkli sure/yon ile suzulur -> hicbir zaman senkron olmaz (organik his) */
.hero-aurora .a1{width:48vw; height:48vw; top:-14vw; right:-9vw;
  background:radial-gradient(circle at 50% 50%, oklch(0.64 0.16 33 / .22), transparent 64%);
  animation:auroraDrift1 13s ease-in-out infinite}
.hero-aurora .a2{width:44vw; height:44vw; top:10%; left:-12vw;
  background:radial-gradient(circle at 50% 50%, oklch(0.64 0.13 250 / .22), transparent 64%);
  animation:auroraDrift2 16s ease-in-out infinite}
.hero-aurora .a3{width:44vw; height:44vw; top:34%; left:26%;
  background:radial-gradient(circle at 50% 50%, oklch(0.68 0.13 300 / .19), transparent 64%);
  animation:auroraDrift3 11s ease-in-out infinite}
.hero-aurora .a4{width:30vw; height:30vw; top:-9vw; left:7%;
  background:radial-gradient(circle at 50% 50%, oklch(0.80 0.10 62 / .14), transparent 64%);
  animation:auroraDrift4 18s ease-in-out infinite}
/* ince tane: genis yumusak gecislerde olusan bant/banding'i kirar (premium dokunus) */
.hero-aurora::after{content:""; position:absolute; inset:0; opacity:.10; mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px}
/* transform + opacity = compositor'da calisir (repaint yok) -> gorunur hareket ama scroll'u takmaz.
   ust uste binen farkli-renk bloblari acilip-kapanarak aurora'nin renk kaymasi hissini ucuza verir. */
/* "Merakli uzay gemisi" gezinmesi: SCALE YOK (scale + 34px blur = GPU tavan); yalniz translate + opacity
   -> blur bir kez cache'lenir, compositor'da ucuzca gezer. Cok-noktali + her blob farkli yol/sure
   -> organik, asla senkron olmayan, surekli sola-saga-bir oraya-bir buraya dolasan isiklar. */
@keyframes auroraDrift1{
  0%{transform:translate(0,0); opacity:.8}
  20%{transform:translate(26%,14%); opacity:1}
  45%{transform:translate(12%,30%); opacity:.8}
  70%{transform:translate(-20%,18%); opacity:1}
  88%{transform:translate(-8%,-10%); opacity:.9}
  100%{transform:translate(0,0); opacity:.8}}
@keyframes auroraDrift2{
  0%{transform:translate(0,0); opacity:.66}
  25%{transform:translate(-24%,16%); opacity:.95}
  50%{transform:translate(22%,-18%); opacity:1}
  75%{transform:translate(30%,12%); opacity:.8}
  100%{transform:translate(0,0); opacity:.66}}
@keyframes auroraDrift3{
  0%{transform:translate(0,0); opacity:.7}
  30%{transform:translate(-30%,-22%); opacity:1}
  55%{transform:translate(-10%,18%); opacity:.75}
  80%{transform:translate(24%,-14%); opacity:1}
  100%{transform:translate(0,0); opacity:.7}}
@keyframes auroraDrift4{
  0%{transform:translate(0,0); opacity:.55}
  22%{transform:translate(22%,24%); opacity:.95}
  48%{transform:translate(-18%,10%); opacity:1}
  72%{transform:translate(10%,-26%); opacity:.8}
  100%{transform:translate(0,0); opacity:.55}}
.hero .cs-title{font-size:clamp(2.4rem,4.6vw,3.7rem); font-weight:800; letter-spacing:-.03em; margin-top:18px}
.hero-sub{font-size:clamp(1.05rem,1.4vw,1.2rem); color:var(--ink-2); max-width:44ch; margin-top:20px}
.hero-actions{display:flex; gap:14px; margin-top:30px; flex-wrap:wrap}
.trust{display:flex; gap:22px; margin-top:30px; flex-wrap:wrap; color:var(--ink-2); font-size:.88rem; font-weight:500}
.trust span{position:relative; padding-left:16px}
.trust span::before{content:""; position:absolute; left:0; top:.52em; width:7px; height:7px; border-radius:2px; background:var(--coral)}
.shot{position:relative; will-change:transform}
.frame{border-radius:13px; overflow:hidden; background:#fff; border:1px solid var(--line);
  box-shadow:0 2px 4px oklch(0.3 0.03 260/.05), 0 36px 70px -34px oklch(0.25 0.05 262/.4), 0 14px 32px -22px oklch(0.25 0.05 262/.28)}
.frame .bar{display:flex; align-items:center; gap:.5rem; height:42px; padding:0 14px; border-bottom:1px solid var(--line-2);
  background:var(--bg-2)}
.frame .bar i{width:10px; height:10px; border-radius:50%; background:var(--line); display:block}
.frame .bar .addr{margin-inline:auto; font-size:.78rem; color:var(--ink-2); background:var(--bg);
  border:1px solid var(--line-2); padding:.24rem 1rem; border-radius:6px; transform:translateX(-18px)}
.frame img{display:block; width:100%; height:auto}

/* ---------- HERO SLIDER ---------- */
.hero-copy{position:relative}
.cslider{position:relative; min-height:300px}
.cslide{position:absolute; inset:0; opacity:0; pointer-events:none; transition:opacity .5s var(--exp)}
.cslide.active{opacity:1; pointer-events:auto}
.cslide .eg,.cslide .cs-title,.cslide .hero-sub{opacity:0; transform:translateY(24px); filter:blur(7px);
  transition:opacity .72s var(--exp), transform .72s var(--exp), filter .72s var(--exp)}
.cslide.active .eg{opacity:1; transform:none; filter:blur(0); transition-delay:.06s}
.cslide.active .cs-title{opacity:1; transform:none; filter:blur(0); transition-delay:.17s}
.cslide.active .hero-sub{opacity:1; transform:none; filter:blur(0); transition-delay:.30s}
/* TV glitch: yazi girisinden sonra slayt basina BIR kez (.glitch JS ekler/kaldirir).
   ::before cyan + ::after magenta dilimli RGB-ayrismasi + ana metin titremesi. */
.cs-title{position:relative}
.cs-title::before,.cs-title::after{content:attr(data-text); position:absolute; left:0; top:0; width:100%;
  opacity:0; pointer-events:none; color:var(--cream)}
.cs-title.glitch{animation:glMain .5s steps(2,jump-none) both}
.cs-title.glitch::before{animation:glA .5s steps(2,jump-none) both; color:#69f7ff; text-shadow:1px 0 #69f7ff}
.cs-title.glitch::after{animation:glB .5s steps(2,jump-none) both; color:#ff5b8e; text-shadow:-1px 0 #ff2d6a}
@keyframes glMain{0%,100%{transform:none}18%{transform:translate(-2px,1px)}36%{transform:translate(2px,-1px)}58%{transform:translate(-1px,0)}80%{transform:translate(1px,1px)}}
@keyframes glA{0%,100%{opacity:0;transform:none;clip-path:inset(0 0 100% 0)}12%{opacity:.9;transform:translate(-5px,-1px);clip-path:inset(2% 0 74% 0)}34%{opacity:.85;transform:translate(5px,1px);clip-path:inset(34% 0 40% 0)}56%{opacity:.9;transform:translate(-6px,0);clip-path:inset(56% 0 20% 0)}78%{opacity:.75;transform:translate(4px,-1px);clip-path:inset(22% 0 60% 0)}92%{opacity:.5;transform:translate(-2px,1px);clip-path:inset(80% 0 6% 0)}}
@keyframes glB{0%,100%{opacity:0;transform:none;clip-path:inset(100% 0 0 0)}12%{opacity:.9;transform:translate(5px,1px);clip-path:inset(70% 0 8% 0)}34%{opacity:.85;transform:translate(-5px,-1px);clip-path:inset(40% 0 36% 0)}56%{opacity:.9;transform:translate(6px,0);clip-path:inset(18% 0 58% 0)}78%{opacity:.75;transform:translate(-4px,1px);clip-path:inset(60% 0 22% 0)}92%{opacity:.5;transform:translate(2px,-1px);clip-path:inset(6% 0 82% 0)}}
@media (prefers-reduced-motion:reduce){
  .cs-title.glitch,.cs-title.glitch::before,.cs-title.glitch::after{animation:none}
  .cs-title::before,.cs-title::after{display:none}}
.hero-media{position:relative; min-height:clamp(320px,36vw,470px)}
/* gelen ekran: hafif buyukten oturur + yukselir (premium zoom-settle; blur YOK -> periyodik takilma olmaz) */
.mslide{position:absolute; inset:0; opacity:0; transform:scale(1.04) translateY(16px);
  pointer-events:none; transition:opacity .7s var(--exp), transform .8s var(--exp)}
.mslide.active{opacity:1; transform:none; pointer-events:auto}
/* aktif urun ekrani yavasca suzulur (canlilik) */
/* hero gorselleri tam ve okunakli gosterilir; kirpma yok */
.hero-dots{display:flex; gap:9px; margin-top:30px}
.hero-dots .dot{width:38px; height:4px; padding:0; border:0; border-radius:3px; cursor:pointer;
  background:var(--line); position:relative; overflow:hidden; transition:background .3s var(--exp)}
.hero-dots .dot.active{background:color-mix(in oklch, var(--coral) 28%, var(--line))}
.hero-dots .dot span{position:absolute; left:0; top:0; bottom:0; width:0; background:var(--coral)}
.hero-dots .dot.active span{width:100%; transition:width 5.3s linear}

/* ---------- ANA SAYFA HERO — KOYU VARYANT (slider + ekranlar korunur; alt sayfa hero diliyle ayni) ---------- */
.hero{background:var(--dark); color:var(--cream)}
/* TV scanline (CRT tarama cizgisi): aurora/globe uzerinde, icerigin altinda (z-0, ::after sonra boyanir).
   mix-blend YOK: animasyonlu globe uzerinde blend her kare yeniden besteler -> agir; duz alfa ucuz. */
.hero::after{content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:repeating-linear-gradient(to bottom,
    transparent 0, transparent 2px, oklch(0.03 0.01 250 / .5) 2px, oklch(0.03 0.01 250 / .5) 3px);
  opacity:.5}
.hero .eg{color:oklch(0.8 0.12 42)}
.hero .cs-title{color:var(--cream)}
.hero .hero-sub{color:var(--on-dark)}
.hero .trust{color:var(--on-dark)}
.hero .btn.ghost{color:var(--cream); border-color:color-mix(in oklch, var(--cream) 26%, transparent)}
.hero .btn.ghost:hover{border-color:var(--cream); background:color-mix(in oklch, var(--cream) 8%, transparent)}
.hero .hero-dots .dot{background:color-mix(in oklch, var(--cream) 18%, transparent)}
.hero .hero-dots .dot.active{background:color-mix(in oklch, var(--coral) 45%, var(--cream))}

/* anchor (menu) hedefleri sabit nav altinda kalmasin (scroll-snap KALDIRILDI: akici serbest scroll) */
section[id]{scroll-margin-top:78px}

/* ---------- LOGO/VALUE STRIP ---------- */
.strip{border-block:1px solid var(--line); background:var(--bg-2)}
.strip-in{display:flex; flex-wrap:wrap; justify-content:space-between; gap:18px 30px; padding:26px 0}
.strip-in div{display:flex; flex-direction:column}
.strip-in .k{font-family:"Libre Franklin",sans-serif; font-weight:800; font-size:1.5rem; color:var(--ink); letter-spacing:-.02em}
.strip-in .l{font-size:.85rem; color:var(--ink-2); margin-top:2px}
/* ikonlu varyant: ikon solda, baslik+alt metin sagda (yalniz .strip-feat) */
.strip-feat .strip-in > div{flex-direction:row; align-items:center; gap:14px}
.strip-feat .ic{flex:none; width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  background:var(--coral-soft); color:var(--coral)}
.strip-feat .ic svg{width:22px; height:22px; display:block}
.strip-feat .tx{display:flex; flex-direction:column; min-width:0}
.strip-feat .strip-in .k{font-size:1.18rem}

/* ---------- MARQUEE ---------- */
.marquee{overflow:hidden; padding:16px 0; border-bottom:1px solid var(--line);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.mq{display:flex; width:max-content; white-space:nowrap; animation:marq 70s linear infinite}
.mq span{font-weight:600; font-size:1rem; color:var(--ink-2); letter-spacing:.01em; margin-right:46px}
@keyframes marq{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){ .mq{animation:none} }

/* ---------- FEATURE SECTIONS ---------- */
.feat{padding:clamp(70px,10vh,116px) 0; overflow-x:clip} /* yatay reveal slide'i yatay tasma yaratmasin */
.feat-grid{display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,72px); align-items:center}
.feat.rev .feat-grid{direction:rtl}
.feat.rev .feat-grid > *{direction:ltr}
.feat h2{font-size:clamp(1.8rem,3.2vw,2.6rem); font-weight:800; margin-top:14px}
.feat p{color:var(--ink-2); margin-top:16px; font-size:1.08rem; max-width:40ch}
.flist{margin-top:24px; display:flex; flex-direction:column; gap:12px}
.flist div{display:grid; grid-template-columns:auto 1fr; gap:12px; align-items:start}
.flist b{font-weight:700; color:var(--ink)}
.flist .mk{width:20px; height:20px; border-radius:6px; background:var(--coral-soft); position:relative; margin-top:2px}
.flist .mk::after{content:""; position:absolute; inset:6px; border-radius:2px; background:var(--coral)}
.flist span{color:var(--ink-2)}

/* ---------- MODULE MATRIX ---------- */
.mods{padding:clamp(70px,10vh,116px) 0; background:var(--bg-2); border-block:1px solid var(--line)}
.mods .head{max-width:36ch; margin-bottom:clamp(34px,5vh,52px)}
.mods h2{font-size:clamp(1.9rem,3.4vw,2.7rem); font-weight:800}
.mods .head p{color:var(--ink-2); margin-top:14px; font-size:1.06rem}
/* alt sayfa yetenek bolumu: baslik dar kolona hapsolmasin, genis nefes alsin */
#yetenekler .head{max-width:800px}
#yetenekler .head p{max-width:58ch}
.matrix{display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:12px; overflow:hidden}
.cell{background:var(--bg); padding:24px clamp(20px,2.4vw,30px); display:grid; grid-template-columns:auto 1fr; gap:18px;
  transition:background .3s var(--exp)}
.cell:hover{background:var(--coral-soft)}
.cell .n{font-family:"Libre Franklin",sans-serif; font-weight:800; font-size:.92rem; color:var(--coral); padding-top:.2rem}
.cell h3{font-family:"Libre Franklin",sans-serif; font-size:1.18rem; font-weight:700}
.cell p{color:var(--ink-2); margin-top:5px; font-size:.96rem}

/* ---------- ANA SAYFA MODULLER (ikon kartlari, 2-kolon baslik) ---------- */
.mods-head{display:grid; grid-template-columns:1.5fr 1fr; gap:clamp(20px,4vw,56px); align-items:end;
  margin-bottom:clamp(34px,5vh,56px)}
.mods-head h2{font-size:clamp(2rem,3.8vw,3rem); font-weight:800; margin-top:12px; letter-spacing:-.02em; line-height:1.08}
.mods-head > p{color:var(--ink-2); font-size:1.07rem; line-height:1.6; max-width:40ch; padding-bottom:6px}
/* interaktif kesif: sol liste + sag canli onizleme */
.explorer{display:grid; grid-template-columns:296px 1fr; gap:clamp(24px,3vw,48px); align-items:stretch}
/* sol liste */
/* liste sag kart yuksekligine esitlenir; ogeler bosluğu esit paylasir (nizami) */
.ex-list{display:flex; flex-direction:column; justify-content:space-between; gap:2px}
.ex-item{display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:12px; width:100%;
  font-family:inherit; text-align:left; cursor:pointer; background:none; border:0; border-radius:12px;
  padding:10px 13px; color:var(--ink-2);
  transition:background .2s var(--exp), color .2s var(--exp), box-shadow .2s var(--exp)}
.ex-item:hover{background:var(--bg); color:var(--ink)}
.ex-item.active{background:var(--bg); color:var(--ink); box-shadow:0 16px 38px -24px oklch(0.25 0.05 262 / .55)}
.ex-ic{flex:none; width:36px; height:36px; border-radius:10px; display:grid; place-items:center;
  background:var(--coral-soft); color:var(--coral); transition:background .2s var(--exp), color .2s var(--exp)}
.ex-item.active .ex-ic{background:var(--coral); color:#fff; box-shadow:0 10px 22px -10px var(--coral)}
.ex-ic svg{width:19px; height:19px}
.ex-name{font-family:"Libre Franklin",sans-serif; font-weight:600; font-size:.98rem; color:inherit; letter-spacing:-.01em}
.ex-item.active .ex-name{font-weight:700}
.ex-arrow{width:17px; height:17px; color:var(--coral); opacity:0; transform:translateX(-4px);
  transition:opacity .2s var(--exp), transform .2s var(--exp)}
.ex-item.active .ex-arrow{opacity:1; transform:none}
/* sol liste: soldan saga (sirayla) belirir - explorer gorunur olunca tetiklenir */
html.js .explorer{transform:none} /* blok kendi kaymasin, yalniz ogeler sirali gelsin */
html.js .ex-item{opacity:0}
.explorer.in .ex-item{animation:exItemIn .5s var(--exp) forwards; animation-delay:calc(var(--d,0) * .05s)}
@keyframes exItemIn{from{opacity:0; transform:translateX(-22px)} to{opacity:1; transform:none}}

.ex-item:focus-visible{outline:2px solid var(--coral); outline-offset:2px}

/* sag: detay KARTI — 2 kolon (sol metin+CTA, sag mini onizleme); liste ile YUKSEKLIK ESIT */
.ex-stage{position:relative; display:flex; flex-direction:column}
.ex-panel{display:none}
.ex-panel.active{display:flex; flex-direction:column; flex:1; animation:exIn .28s var(--exp)}
@keyframes exIn{from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:none}}
.ex-card{flex:1; display:grid; grid-template-columns:1fr .92fr; gap:clamp(20px,2.4vw,32px);
  background:var(--bg); border:1px solid var(--line); border-radius:18px; padding:clamp(22px,2.6vw,32px);
  box-shadow:0 2px 6px oklch(0.3 0.03 260/.04), 0 30px 64px -38px oklch(0.25 0.05 262/.4)}
/* sol kolon */
.ex-card-l{min-width:0}
.ex-bigic{display:inline-grid; place-items:center; width:56px; height:56px; border-radius:15px;
  background:var(--coral); color:#fff; box-shadow:0 16px 34px -14px var(--coral)}
.ex-bigic svg{width:28px; height:28px}
.ex-h{font-family:"Libre Franklin",sans-serif; font-size:clamp(1.5rem,2.4vw,2rem); font-weight:800; letter-spacing:-.02em; margin-top:16px}
.ex-lead{color:var(--ink-2); margin-top:9px; font-size:1.04rem; line-height:1.55}
.ex-eg{display:block; font-family:"Hanken Grotesk",sans-serif; font-weight:600; font-size:.72rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--coral); margin-top:22px}
.ex-benefits{list-style:none; margin:12px 0 0; padding:0; display:flex; flex-direction:column; gap:12px}
.ex-benefits li{display:grid; grid-template-columns:auto 1fr; gap:12px; align-items:start}
.ex-benefits li svg{flex:none; width:24px; height:24px; padding:4px; box-sizing:border-box; margin-top:1px;
  color:var(--coral); background:var(--coral-soft); border-radius:7px}
.ex-benefits li span{font-size:1rem; color:var(--ink); line-height:1.45; font-weight:500}
.ex-tags{display:flex; flex-wrap:wrap; gap:7px; margin-top:18px}
.ex-tags span{font-size:.8rem; font-weight:600; color:var(--ink-2); background:var(--bg-2);
  border:1px solid var(--line); border-radius:999px; padding:.34rem .72rem}
.ex-cta{margin-top:22px; gap:8px}
.ex-cta svg{width:18px; height:18px; transition:transform .2s var(--exp)}
.ex-cta:hover svg{transform:translateX(3px)}
/* sag kolon: mini urun onizlemesi */
.ex-card-r{min-width:0; display:flex}
.ex-prev{flex:1; display:flex; flex-direction:column; gap:14px;
  background:linear-gradient(180deg, var(--bg-2), var(--bg)); border:1px solid var(--line);
  border-radius:14px; padding:clamp(15px,1.7vw,19px)}
.ex-prev-top{display:flex; align-items:center; justify-content:space-between}
.ex-prev-label{font-family:"Libre Franklin",sans-serif; font-weight:700; font-size:.96rem; color:var(--ink)}
.ex-prev-live{display:inline-flex; align-items:center; gap:6px; font-size:.72rem; font-weight:600; color:var(--ink-2)}
.ex-prev-live i{width:7px; height:7px; border-radius:50%; background:oklch(0.65 0.16 150); box-shadow:0 0 0 3px oklch(0.65 0.16 150/.18)}
.ex-stats{display:grid; grid-template-columns:repeat(3,1fr); gap:8px}
.ex-stat{background:var(--bg); border:1px solid var(--line-2); border-radius:10px; padding:11px 12px; min-width:0}
.ex-stat b{display:block; font-family:"Libre Franklin",sans-serif; font-weight:800; font-size:1.1rem; color:var(--ink); letter-spacing:-.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.ex-stat span{display:block; font-size:.73rem; color:var(--ink-2); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.ex-rows{display:flex; flex-direction:column; gap:11px; margin-top:auto}
.ex-row-head{display:flex; align-items:center; justify-content:space-between; font-size:.84rem; margin-bottom:6px}
.ex-row-head span{color:var(--ink-2)}
.ex-row-head b{color:var(--ink); font-weight:700}
.ex-bar{height:7px; border-radius:99px; background:var(--line); overflow:hidden}
.ex-bar i{display:block; height:100%; border-radius:99px; width:var(--w);
  background:linear-gradient(90deg, var(--coral), var(--coral-deep))}
.ex-panel.active .ex-bar i{animation:barGrow .7s var(--exp) backwards}
@keyframes barGrow{from{width:0} to{width:var(--w)}}
@media (prefers-reduced-motion:reduce){
  .ex-panel.active,.ex-panel.active *{animation:none !important}
  html.js .ex-item{opacity:1}
}
@media (max-width:860px){
  .mods-head{grid-template-columns:1fr; gap:12px; align-items:start}
  .mods-head > p{padding-bottom:0}
  .explorer{grid-template-columns:1fr; gap:18px}
  /* mobil: liste yatay kayan pill seridi */
  .ex-list{flex-direction:row; overflow-x:auto; gap:8px; padding-bottom:4px; scrollbar-width:thin}
  .ex-item{grid-template-columns:auto auto; width:auto; flex:none; padding:9px 13px}
  .ex-item .ex-name{font-size:.92rem; white-space:nowrap}
  .ex-arrow{display:none}
  /* kart tek kolona duser, onizleme metnin altina iner */
  .ex-card{grid-template-columns:1fr; gap:18px}
}

/* ---------- DARK ARCHITECTURE ---------- */
.arch{background:var(--dark); color:var(--cream); position:relative; overflow:hidden}
/* ana sayfa hero'sundaki gibi belli belirsiz TV scanline (CRT tarama cizgisi); icerigin altinda (z-0) */
.arch::after{content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:repeating-linear-gradient(to bottom,
    transparent 0, transparent 2px, oklch(0.03 0.01 250 / .5) 2px, oklch(0.03 0.01 250 / .5) 3px);
  opacity:.45}
.arch .wrap{padding-block:clamp(76px,12vh,128px); position:relative; z-index:1}
.arch-grid{display:grid; grid-template-columns:1.25fr .75fr; gap:clamp(30px,4vw,60px); align-items:center}
.arch .eg{color:oklch(0.74 0.1 38)}
.arch h2{color:var(--cream); font-size:clamp(1.9rem,3.6vw,2.9rem); font-weight:800; margin-top:14px; max-width:18ch; line-height:1.08}
.arch h2 em{font-style:normal; color:var(--on-dark)}
/* mevzuat uyum notu: editoryel, sol mercan cizgi; pill/dolgu/nokta yok */
.uyum{display:flex; gap:16px; margin-top:24px; max-width:33rem}
.uyum::before{content:""; flex:0 0 2px; align-self:stretch; border-radius:2px;
  background:linear-gradient(180deg, var(--coral), color-mix(in oklch, var(--coral) 0%, transparent))}
.uyum p{margin:0; color:var(--on-dark); font-size:1.04rem; line-height:1.55; letter-spacing:.1px}
.uyum .yer{color:var(--cream); font-weight:600; white-space:nowrap;
  border-bottom:1px solid color-mix(in oklch, var(--coral) 55%, transparent); padding-bottom:1px}
.uyum b{color:var(--coral); font-weight:700}
html.js .arch-copy .uyum{opacity:0}
.arch-copy.in .uyum{animation:archInUp .55s var(--exp) both; animation-delay:.18s}
.pillars{margin-top:clamp(40px,6vh,60px);
  border-top:1px solid color-mix(in oklch, var(--cream) 22%, transparent); padding-top:clamp(28px,4vh,44px)}
/* slider: tum slaytlar ayni grid hucresinde ust uste; en uzunu yuksekligi belirler (ziplama yok) */
.pstack{display:grid}
.pslide{grid-area:1/1; opacity:0; transform:translateY(10px); visibility:hidden;
  transition:opacity .5s var(--exp), transform .5s var(--exp); pointer-events:none}
.pslide.active{opacity:1; transform:none; visibility:visible; pointer-events:auto}
.pillars h3{font-family:"Libre Franklin",sans-serif; color:var(--cream); font-size:1.18rem; font-weight:700}
.pillars p{color:var(--on-dark); margin-top:8px; font-size:1rem; max-width:42ch}
.pdots{display:flex; gap:9px; margin-top:22px}
.pdot{width:22px; height:5px; border-radius:999px; border:0; padding:0; cursor:pointer;
  background:color-mix(in oklch, var(--cream) 22%, transparent); transition:background .3s, width .3s}
.pdot:hover{background:color-mix(in oklch, var(--cream) 40%, transparent)}
.pdot.active{width:34px; background:var(--coral)}
.arch-art{position:relative; height:clamp(240px,26vw,360px)}
.arch-art canvas{position:absolute; inset:0; width:100%; height:100%}
/* GIRIS ANIMASYONU: baslik soldan-saga hizli; 3 sutun asagidan-yukari sirayla.
   Sol kolon yalniz tetikleyici (kendi kaymaz); icindekiler .in ile animasyona girer. */
html.js .arch-copy[data-reveal]{opacity:1; transform:none}
html.js .arch-copy .eg, html.js .arch-copy h2{opacity:0}
.arch-copy.in .eg{animation:archInLeft .5s var(--exp) .05s both}
.arch-copy.in h2{animation:archInLeft .6s var(--exp) .14s both}
@keyframes archInLeft{from{opacity:0; transform:translateX(-46px)} to{opacity:1; transform:none}}
html.js .arch-copy .pillars{opacity:0}
.arch-copy.in .pillars{animation:archInUp .55s var(--exp) both; animation-delay:.3s}
@keyframes archInUp{from{opacity:0; transform:translateY(28px)} to{opacity:1; transform:none}}
@media (prefers-reduced-motion:reduce){
  html.js .arch-copy .eg, html.js .arch-copy h2, html.js .arch-copy .uyum, html.js .arch-copy .pillars{opacity:1; animation:none}
}

/* ---------- CTA ---------- */
.cta{padding:clamp(76px,11vh,128px) 0; text-align:center}
.cta h2{font-size:clamp(2rem,4.4vw,3.2rem); font-weight:800; max-width:20ch; margin-inline:auto}
.cta p{color:var(--ink-2); margin:16px auto 0; max-width:46ch; font-size:1.08rem}
.cta .row{display:flex; gap:14px; justify-content:center; margin-top:32px; flex-wrap:wrap}

/* ---------- INNER PAGES (alt sayfa sablonu) ---------- */
.page-hero{position:relative; isolation:isolate; overflow:hidden; border-bottom:1px solid var(--line);
  padding:clamp(122px,16vh,178px) 0 clamp(50px,7vh,76px); text-align:center}
/* cizgi-ag arka plani (particles.js); aurora'nin uzerinde, icerigin altinda, kenarlardan erir */
.hero-lines{position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden;
  -webkit-mask-image:radial-gradient(125% 108% at 50% 36%, #000 0%, #000 50%, transparent 86%);
  mask-image:radial-gradient(125% 108% at 50% 36%, #000 0%, #000 50%, transparent 86%)}
.hero-lines canvas{display:block}
@media (prefers-reduced-motion:reduce){ .hero-lines{display:none} }
@media (max-width:720px){ .hero-lines{display:none} } /* mobilde kapali (yogunluk + pil) */

/* ---------- ALT SAYFA KOYU HERO (hero-sp: metin sol + donen ucgen-globe sag) ---------- */
.hero-sp{position:relative; isolation:isolate; overflow:hidden; background:var(--dark); color:var(--cream);
  padding:clamp(108px,13vh,146px) 0 clamp(44px,6vh,66px)}
/* KATMAN 1 (en alt): yumusak coral + mavi parilti (derinlik, globe arkasi sicak nokta) */
.hero-sp::before{content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(46% 62% at 82% 42%, oklch(0.6 0.16 33 / .28), transparent 70%),
    radial-gradient(52% 60% at 12% 24%, oklch(0.5 0.1 250 / .20), transparent 72%)}
/* KATMAN 2 (renk uzerinde, icerigin altinda): belli belirsiz TV scanline (CRT tarama cizgisi).
   mix-blend YOK (animasyonlu globe uzerinde pahali); duz alfa ile ayni his, ucuz. */
.hero-sp::after{content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:repeating-linear-gradient(to bottom,
    transparent 0, transparent 2px, oklch(0.03 0.01 250 / .5) 2px, oklch(0.03 0.01 250 / .5) 3px);
  opacity:.5}
.hero-sp-grid{position:relative; z-index:1; display:grid; grid-template-columns:1.18fr .82fr;
  gap:clamp(24px,3vw,48px); align-items:center}
.hero-sp-copy{text-align:left; max-width:34rem}
/* ortali varyant (kurumsal sayfalar — globe yok, metin ortali) */
.hero-sp.center .hero-sp-grid{grid-template-columns:1fr}
.hero-sp.center .hero-sp-copy{max-width:760px; margin-inline:auto; text-align:center}
.hero-sp.center .hero-sp-copy .lead{margin-inline:auto}
.hero-sp.center .hero-actions{justify-content:center}
/* modul sayfasi hero onizlemesi (koyu zeminde acik kart) */
.hero-sp-prev{position:relative; z-index:1}
.hero-sp-prev .ex-prev{box-shadow:0 36px 80px -36px #000, 0 12px 30px -22px #000; animation:exIn .5s var(--exp)}
.hero-sp-prev .ex-bar i{animation:barGrow .85s var(--exp) .35s backwards}
/* modul sayfasi buyuk ikon (kazanc bolumu gorseli) */
.modul-bigic{display:grid; place-items:center; aspect-ratio:4/3; max-width:420px; margin-inline:auto; border-radius:18px;
  background:radial-gradient(120% 120% at 72% 12%, var(--coral-soft), transparent 60%), var(--bg-2);
  border:1px solid var(--line); color:var(--coral)}
.modul-bigic svg{width:34%; height:34%}
.hero-sp .eg{color:oklch(0.8 0.12 42)}
.hero-sp h1{color:var(--cream); font-size:clamp(2.3rem,4.7vw,3.6rem); font-weight:800;
  letter-spacing:-.03em; line-height:1.06; margin-top:16px}
.hero-sp h1 em{font-style:normal; color:oklch(0.82 0.1 40)}
.hero-sp .lead{color:var(--on-dark); font-size:clamp(1.08rem,1.5vw,1.25rem); margin-top:18px; max-width:52ch}
.hero-sp .hero-actions{margin-top:30px}
.hero-sp .btn.ghost{color:var(--cream); border-color:color-mix(in oklch, var(--cream) 26%, transparent)}
.hero-sp .btn.ghost:hover{border-color:var(--cream); background:color-mix(in oklch, var(--cream) 8%, transparent)}
.hero-sp-art{position:relative; height:clamp(278px,33vw,404px)}
.hero-sp-art canvas{position:absolute; inset:0; width:100%; height:100%}

/* globe sarmalayici yumusakca belirir (globe three.js'te buyuyerek+donerek girer) */
html.js .hero-sp-art{opacity:0; animation:spArtIn 1s var(--exp) .12s forwards}
@keyframes spArtIn{from{opacity:0} to{opacity:1}}
/* metin girisi (kademeli: blur + asagidan yukari) */
@keyframes spTextIn{from{opacity:0; transform:translateY(28px); filter:blur(7px)} to{opacity:1; transform:none; filter:blur(0)}}
html.js .hero-sp .eg{opacity:0; animation:spTextIn .8s var(--exp) .08s forwards}
html.js .hero-sp h1{opacity:0; animation:spTextIn .9s var(--exp) .2s forwards}
html.js .hero-sp .lead{opacity:0; animation:spTextIn .9s var(--exp) .36s forwards}
html.js .hero-sp .hero-actions{opacity:0; animation:spTextIn .9s var(--exp) .5s forwards}

/* ---------- KOMPAKT ALT-SAYFA BASLIGI (yardimci/uygulama sayfalari: profil, hesabim, dogrulama) ----------
   hero-sp'nin buyuk hero'su yerine kisa, duzenli, sol-hizali koyu baslik seridi. */
.page-head{position:relative; isolation:isolate; overflow:hidden; background:var(--dark); color:var(--cream);
  padding:clamp(82px,9vh,94px) 0 clamp(16px,2.6vh,26px)}
.page-head::before{content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(60% 120% at 90% 0%, oklch(0.6 0.16 33 / .16), transparent 70%)}
/* ana sayfa hero'sundaki gibi belli belirsiz TV scanline (CRT tarama cizgisi) */
.page-head::after{content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:repeating-linear-gradient(to bottom,
    transparent 0, transparent 2px, oklch(0.03 0.01 250 / .5) 2px, oklch(0.03 0.01 250 / .5) 3px);
  opacity:.5}
.page-head .wrap{position:relative; z-index:1}
.page-head .eg{color:oklch(0.8 0.12 42)}
.page-head h1{color:var(--cream); font-size:clamp(1.55rem,2.8vw,2.05rem); font-weight:800;
  letter-spacing:-.02em; line-height:1.12; margin-top:7px}
.page-head h1 em{font-style:normal; color:oklch(0.82 0.1 40)}
.page-head p{color:var(--on-dark); font-size:1rem; line-height:1.5; margin-top:8px; max-width:58ch}
/* baslik seridinin hemen altindaki form/icerik bolumu fazla bosluk birakmasin */
.page-head + .section{padding-top:clamp(28px,4vh,44px)}

/* App sayfalari (panel/profil/hesabim/bildirimler): page-head YOK.
   Header daima koyu (seffaf degil -> beyaz nav yazisi acik icerik uzerinde kalmaz),
   ilk icerik bolumu sabit header'i (59px) temizler + modest ust bosluk. */
body.app-shell header.nav{background:var(--dark); border-bottom-color:color-mix(in oklch, var(--cream) 8%, transparent)}
body.app-shell main > .section{padding-top:calc(59px + 22px)}
/* daktilo (typewriter) imleci: yanip sonen dikdortgen blok (hesabim karsilamasi) */
.tw-cursor{display:inline-block; width:.5em; height:1.02em; margin-left:.06em; vertical-align:-0.13em;
  background:var(--coral); border-radius:1px; animation:twBlink 1.05s steps(1,end) infinite}
@keyframes twBlink{0%,49%{opacity:1} 50%,100%{opacity:0}}
@media (prefers-reduced-motion:reduce){ .tw-cursor{animation:none} }

/* koyu hero ustunde (henuz kaydirilmamis) sabit nav acik renge doner */
/* dark-hero sayfalarda header KAYDIRINCA DA koyu kalir (acik temaya donmez).
   backdrop-filter blur YOK: scroll'da arka plani her kare yeniden bulanik. yapip takiyordu;
   neredeyse opak koyu zemin gorsel olarak ayni, cok daha ucuz. */
body.dark-hero.scrolled header.nav{background:color-mix(in oklch, var(--dark) 95%, transparent);
  backdrop-filter:none;
  border-bottom-color:color-mix(in oklch, var(--cream) 12%, transparent)}
/* mega menu acikken: header tek parca koyu yuzey + alt cizgi yok -> panel ile kaynasir (tumlesik) */
header.nav:has(.has-mega:hover),
header.nav:has(.hdr-bell-pop:not([hidden])){background:color-mix(in oklch, var(--dark) 97%, transparent);
  backdrop-filter:none; border-bottom-color:transparent}
/* header daima koyu oldugu icin nav metni daima acik renk */
body.dark-hero .nav-links > a,
body.dark-hero .nav-trigger{color:var(--on-dark)}
body.dark-hero .nav-links > a:hover,
body.dark-hero .nav-trigger:hover,
body.dark-hero .nav-item:hover .nav-trigger{color:#fff}
body.dark-hero .brand-wm{color:#fff}

@media (max-width:920px){
  .hero-sp-grid{grid-template-columns:1fr; gap:12px}
  .hero-sp-copy{max-width:none}
  .hero-sp-art{order:-1; height:clamp(220px,52vw,300px)}
}
@media (prefers-reduced-motion:reduce){
  html.js .hero-sp .eg,html.js .hero-sp h1,html.js .hero-sp .lead,html.js .hero-sp .hero-actions,
  html.js .hero-sp-art{opacity:1; animation:none; filter:none; transform:none}
}
.page-hero-in{position:relative; z-index:1; max-width:880px; margin-inline:auto}
.page-hero h1{font-size:clamp(2.3rem,4.7vw,3.5rem); font-weight:800; letter-spacing:-.03em; margin-top:16px;
  max-width:16ch; margin-inline:auto}
.crumbs{display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:8px;
  font-size:.86rem; color:var(--ink-2); margin-bottom:4px}
.crumbs a{color:var(--ink-2); transition:color .2s}
.crumbs a:hover{color:var(--coral)}
.crumbs span[aria-current]{color:var(--ink); font-weight:600}
.lead{font-size:clamp(1.08rem,1.5vw,1.25rem); color:var(--ink-2); margin:20px auto 0; max-width:60ch}
.page-hero .hero-actions{margin-top:30px; justify-content:center}

/* SSS (details/summary - JS'siz, erisilebilir) */
.faq{padding:clamp(64px,9vh,104px) 0}
.faq-wrap{max-width:840px}
.faq-list{margin-top:clamp(24px,4vh,36px); display:flex; flex-direction:column; gap:12px}
.faq-item{border:1px solid var(--line); border-radius:12px; background:var(--bg); overflow:hidden;
  transition:border-color .25s var(--exp), background .25s var(--exp)}
.faq-item[open]{border-color:color-mix(in oklch, var(--coral) 40%, var(--line)); background:var(--bg-2)}
.faq-item summary{list-style:none; cursor:pointer; padding:18px 22px; display:flex; align-items:center; gap:14px;
  font-family:"Libre Franklin",sans-serif; font-weight:700; font-size:1.04rem; color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:focus-visible{outline:2px solid var(--coral); outline-offset:-2px; border-radius:10px}
.faq-item summary::after{content:""; margin-left:auto; flex:none; width:10px; height:10px; margin-right:2px;
  border-right:2px solid var(--ink-2); border-bottom:2px solid var(--ink-2); transform:rotate(45deg);
  transition:transform .25s var(--exp)}
.faq-item[open] summary::after{transform:rotate(-135deg)}
.faq-a{padding:0 22px 20px; color:var(--ink-2); font-size:1rem; line-height:1.65; max-width:66ch}
@media (max-width:920px){ .page-hero-in,.lead{max-width:none} }

/* ---------- ILETISIM SAYFASI ---------- */
.iletisim{padding:clamp(46px,7vh,80px) 0 clamp(64px,10vh,104px)}
.iletisim-grid{display:grid; grid-template-columns:1.25fr .75fr; gap:clamp(28px,4vw,48px); align-items:start}

.ilet-form-card{background:var(--bg); border:1px solid var(--line); border-radius:16px;
  padding:clamp(24px,3vw,40px);
  box-shadow:0 1px 3px oklch(0.3 0.03 260/.04), 0 24px 50px -36px oklch(0.25 0.05 262/.3)}
.ilet-form-card h2{font-size:clamp(1.4rem,2.2vw,1.8rem); font-weight:800}
.ilet-form-sub{color:var(--ink-2); margin-top:8px; font-size:.98rem}
.ilet-form-card form{margin-top:22px; display:flex; flex-direction:column; gap:16px}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.field{display:flex; flex-direction:column; gap:7px; min-width:0}
.field label{font-weight:600; font-size:.9rem; color:var(--ink)}
.field .req{color:var(--coral)}
.field input,.field select,.field textarea{font-family:inherit; font-size:1rem; color:var(--ink);
  background:var(--bg-2); border:1px solid var(--line); border-radius:10px; padding:.72rem .85rem; width:100%;
  transition:border-color .2s var(--exp), background .2s var(--exp), box-shadow .2s var(--exp)}
.field textarea{resize:vertical; min-height:120px; line-height:1.55}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--coral);
  background:var(--bg); box-shadow:0 0 0 3px var(--coral-soft)}
.field [aria-invalid="true"]{border-color:var(--coral-deep)}
.field-err{color:var(--coral-deep); font-size:.82rem; font-weight:500}
.field-check .check{display:grid; grid-template-columns:auto 1fr; gap:10px; align-items:start; cursor:pointer}
.field-check .check input{width:18px; height:18px; margin-top:2px; accent-color:var(--coral)}
.field-check .check span{font-size:.9rem; color:var(--ink-2); font-weight:400; line-height:1.5}
.field-check .check a{color:var(--coral); text-decoration:underline}
.ilet-form-card button[type=submit]{align-self:flex-start; margin-top:4px}
.ilet-hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}

.ilet-err{background:var(--coral-soft); color:var(--coral-deep); margin-top:18px;
  border:1px solid color-mix(in oklch,var(--coral) 30%,var(--line));
  border-radius:10px; padding:.7rem .9rem; font-size:.9rem; font-weight:500}
.ilet-ok{display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:start}
.ilet-ok-ic{flex:none; width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  background:var(--coral-soft); color:var(--coral)}
.ilet-ok-ic svg{width:24px; height:24px}
.ilet-ok h2{font-size:clamp(1.3rem,2vw,1.6rem); font-weight:800}
.ilet-ok p{color:var(--ink-2); margin-top:10px; font-size:1rem; max-width:46ch}
.ilet-ok .btn{margin-top:18px}

.ilet-info{position:sticky; top:92px}
.ilet-info-h{font-size:1.1rem; font-weight:800; margin-bottom:6px}
.ilet-item{display:grid; grid-template-columns:auto 1fr; gap:14px; align-items:center;
  padding:14px 0; border-bottom:1px solid var(--line-2)}
.ilet-item:last-of-type{border-bottom:0}
a.ilet-item:hover .ilet-ic{background:var(--coral); color:#fff}
.ilet-ic{flex:none; width:42px; height:42px; border-radius:11px; display:grid; place-items:center;
  background:var(--coral-soft); color:var(--coral); transition:background .2s var(--exp), color .2s var(--exp)}
.ilet-ic svg{width:20px; height:20px}
.ilet-tx{display:flex; flex-direction:column; min-width:0}
.ilet-tx b{font-weight:700; font-size:.82rem; color:var(--ink-2); letter-spacing:.01em}
.ilet-tx span{font-size:1rem; color:var(--ink); font-weight:600; overflow-wrap:anywhere}
.ilet-bayi{margin-top:22px; padding:20px; background:var(--bg-2); border:1px solid var(--line); border-radius:14px}
.ilet-bayi h3{font-size:1.02rem; font-weight:800}
.ilet-bayi p{color:var(--ink-2); margin-top:6px; font-size:.9rem}
.ilet-bayi .btn{margin-top:14px}
.btn.sm{padding:.55rem 1.1rem; font-size:.9rem}

/* demo basvuru formu: grup basligi + adim/perk listesi */
.form-group-h{font-family:"Libre Franklin",sans-serif; font-size:.78rem; font-weight:700; letter-spacing:.08em;
  text-transform:uppercase; color:var(--coral); margin:22px 0 2px}
.ilet-form-card form > .form-group-h:first-of-type{margin-top:8px}
.demo-steps{display:flex; flex-direction:column; gap:14px; margin:4px 0 22px}
.demo-step{display:grid; grid-template-columns:auto 1fr; gap:13px; align-items:start}
.demo-step-n{flex:none; width:30px; height:30px; border-radius:50%; display:grid; place-items:center;
  background:var(--coral); color:#fff; font-family:"Libre Franklin",sans-serif; font-weight:800; font-size:.92rem}
.demo-step b{display:block; font-weight:700; font-size:.96rem; color:var(--ink)}
.demo-step span{display:block; color:var(--ink-2); font-size:.88rem; margin-top:2px; line-height:1.45}
.demo-perks{list-style:none; margin:0 0 6px; padding:0; display:flex; flex-direction:column; gap:9px}
.demo-perks li{position:relative; padding-left:26px; font-size:.92rem; color:var(--ink)}
.demo-perks li::before{content:""; position:absolute; left:0; top:2px; width:17px; height:17px; border-radius:50%;
  background:var(--coral-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23d05040' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/12px no-repeat}

@media (max-width:920px){
  .iletisim-grid{grid-template-columns:1fr; gap:28px}
  .ilet-info{position:static}
}
@media (max-width:560px){ .form-row{grid-template-columns:1fr} }

/* ---------- GENEL SAYFA BILESENLERI (kurumsal sayfalar) ---------- */
.section{padding:clamp(58px,9vh,104px) 0}
.section.alt{background:var(--bg-2); border-block:1px solid var(--line)}
.section-head{max-width:760px; margin-bottom:clamp(28px,5vh,46px)}
.section-head h2{font-size:clamp(1.8rem,3.4vw,2.6rem); font-weight:800; margin-top:12px; letter-spacing:-.02em; line-height:1.1}
.section-head p{color:var(--ink-2); margin-top:14px; font-size:1.08rem; line-height:1.6}
.section-head.center{margin-inline:auto; text-align:center}
/* ikon kart izgarasi */
.cards{display:grid; grid-template-columns:repeat(auto-fill, minmax(290px,1fr)); gap:16px}
.card{background:var(--bg); border:1px solid var(--line); border-radius:14px; padding:clamp(22px,2.4vw,28px);
  transition:border-color .2s var(--exp), box-shadow .2s var(--exp)}
.card:hover{border-color:color-mix(in oklch, var(--coral) 42%, var(--line));
  box-shadow:0 20px 44px -28px oklch(0.25 0.05 262 / .4)}
.card .c-ic{display:grid; place-items:center; width:48px; height:48px; border-radius:12px;
  background:var(--coral-soft); color:var(--coral); margin-bottom:16px}
.card .c-ic svg{width:24px; height:24px}
.card h3{font-family:"Libre Franklin",sans-serif; font-size:1.18rem; font-weight:700; color:var(--ink)}
.card p{color:var(--ink-2); margin-top:8px; font-size:.98rem; line-height:1.55}
/* numarali adimlar */
.steps{display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:clamp(18px,2.4vw,30px); counter-reset:s}
.step{position:relative; padding-top:8px}
.step::before{counter-increment:s; content:counter(s,decimal-leading-zero);
  font-family:"Libre Franklin",sans-serif; font-weight:800; font-size:1.1rem; color:var(--coral);
  display:inline-grid; place-items:center; width:42px; height:42px; border-radius:11px;
  background:var(--coral-soft); margin-bottom:14px}
.step h3{font-family:"Libre Franklin",sans-serif; font-size:1.1rem; font-weight:700}
.step p{color:var(--ink-2); margin-top:7px; font-size:.97rem; line-height:1.55}
/* tikli fayda listesi */
.checklist{list-style:none; margin:0; padding:0; display:grid; gap:14px}
.checklist li{display:grid; grid-template-columns:auto 1fr; gap:13px; align-items:start}
.checklist li svg{flex:none; width:26px; height:26px; padding:4px; box-sizing:border-box; margin-top:1px;
  color:var(--coral); background:var(--coral-soft); border-radius:8px}
.checklist li b{font-weight:700; color:var(--ink)}
.checklist li span{color:var(--ink-2); line-height:1.55}
.checklist li span b{color:var(--ink)}
/* acik pozisyon / liste satiri */
.poslist{display:grid; gap:12px; margin-top:8px}
.posrow{display:grid; grid-template-columns:1fr auto; align-items:center; gap:16px;
  background:var(--bg); border:1px solid var(--line); border-radius:12px; padding:18px clamp(18px,2vw,24px);
  transition:border-color .2s var(--exp), background .2s var(--exp)}
.posrow:hover{border-color:color-mix(in oklch, var(--coral) 40%, var(--line))}
.posrow h3{font-family:"Libre Franklin",sans-serif; font-size:1.08rem; font-weight:700}
.posrow .pos-meta{color:var(--ink-2); font-size:.9rem; margin-top:3px}
.posrow .btn{flex:none}
@media (max-width:560px){ .posrow{grid-template-columns:1fr; gap:12px} .posrow .btn{justify-self:start} }

/* ---------- LIGHTBOX (ekran goruntusu buyutme) ---------- */
.shot .frame{cursor:zoom-in}
.lightbox{position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center;
  padding:clamp(18px,5vw,64px); cursor:zoom-out;
  background:oklch(0.2 0.03 262 / .84); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px)}
.lightbox.open{display:flex}
html.js .lightbox.open{animation:lbFade .26s var(--exp)}
.lightbox img{max-width:100%; max-height:100%; border-radius:13px; border:1px solid oklch(1 0 0 / .12);
  box-shadow:0 50px 120px -30px #000}
html.js .lightbox.open img{animation:lbZoom .3s var(--exp)}
.lightbox-close{position:absolute; top:clamp(14px,2vw,24px); right:clamp(14px,2vw,26px); width:44px; height:44px;
  display:grid; place-items:center; border-radius:50%; cursor:pointer; color:#fff;
  background:oklch(1 0 0 / .12); border:1px solid oklch(1 0 0 / .2); transition:background .2s var(--exp)}
.lightbox-close:hover{background:oklch(1 0 0 / .22)}
.lightbox-close svg{width:22px; height:22px}
@keyframes lbFade{from{opacity:0} to{opacity:1}}
@keyframes lbZoom{from{opacity:0; transform:scale(.94)} to{opacity:1; transform:none}}
@media (prefers-reduced-motion:reduce){ html.js .lightbox.open,html.js .lightbox.open img{animation:none} }

/* ---------- GIRIS / KAYIT / SIFIRLAMA MODALI (iki kolon, kompakt) ---------- */
.nav-cta .login{cursor:pointer; font-family:"Hanken Grotesk",sans-serif}
.auth-modal{position:fixed; inset:0; z-index:300; display:flex; align-items:center; justify-content:center;
  padding:clamp(14px,4vw,30px); background:oklch(0.2 0.03 262 / .55);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px)}
.auth-modal[hidden]{display:none}
html.js .auth-modal:not([hidden]){animation:lbFade .2s var(--exp)}
.auth-card{position:relative; width:100%; max-width:740px; max-height:calc(100dvh - 28px); overflow:hidden;
  display:grid; grid-template-columns:.8fr 1fr;
  background:var(--bg); border:1px solid var(--line); border-radius:18px;
  box-shadow:0 44px 120px -34px oklch(0.2 0.04 262 / .6)}
html.js .auth-modal:not([hidden]) .auth-card{animation:authPop .28s var(--exp)}
@keyframes authPop{from{opacity:0; transform:translateY(12px) scale(.985)} to{opacity:1; transform:none}}
.auth-close{position:absolute; top:11px; right:11px; z-index:3; width:33px; height:33px; display:grid; place-items:center;
  border:0; background:oklch(1 0 0 / .16); color:#fff; border-radius:50%; cursor:pointer; transition:background .2s var(--exp)}
.auth-close:hover{background:oklch(1 0 0 / .3)}
.auth-close svg{width:16px; height:16px}
/* SOL marka paneli */
.auth-aside{position:relative; overflow:hidden; padding:clamp(22px,2.4vw,30px); color:#fff;
  display:flex; flex-direction:column;
  background:linear-gradient(158deg, var(--coral), var(--coral-deep) 68%, oklch(0.4 0.13 30))}
.auth-aside::after{content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(120% 80% at 105% -5%, oklch(1 0 0 / .2), transparent 55%)}
.auth-aside > *{position:relative; z-index:1}
/* globe yerine: hero'daki gibi surekli gezinen iki BEYAZ isik (yalniz translate + opacity -> blur bir kez
   cache'lenir, compositor'da ucuzca gezer; WebGL/GPU yuku YOK). scanline'in altinda, metnin arkasinda. */
.auth-aura{position:absolute; z-index:0; border-radius:50%; filter:blur(32px); pointer-events:none;
  background:radial-gradient(circle at 50% 50%, oklch(1 0 0 / .55), transparent 66%)}
.auth-aura-1{width:64%; height:50%; top:-10%; right:-12%; animation:auroraDrift1 14s ease-in-out infinite}
.auth-aura-2{width:58%; height:46%; bottom:-12%; left:-14%; opacity:.85; animation:auroraDrift2 18s ease-in-out infinite}
.auth-scan{position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.4;
  background-image:repeating-linear-gradient(to bottom,
    transparent 0, transparent 2px, oklch(0.22 0.06 30 / .5) 2px, oklch(0.22 0.06 30 / .5) 3px)}
.auth-aside-logo{display:inline-flex; align-items:center; gap:8px; font-family:"Rajdhani",sans-serif; font-weight:700; font-size:1.16rem}
.auth-aside-logo .bmark{width:30px; height:30px}
.auth-aside-logo b{color:#fff}
.auth-aside h3{font-size:1.5rem; font-weight:800; letter-spacing:-.02em; line-height:1.12; margin-top:auto}
.auth-aside p{color:oklch(1 0 0 / .86); font-size:.9rem; line-height:1.5; margin-top:10px}
.auth-aside-list{list-style:none; margin:18px 0 0; padding:0; display:flex; flex-direction:column; gap:9px}
.auth-aside-list li{position:relative; padding-left:25px; font-size:.88rem; color:oklch(1 0 0 / .92)}
.auth-aside-list li::before{content:"✓"; position:absolute; left:0; top:0; width:18px; height:18px; line-height:18px;
  text-align:center; font-size:11px; font-weight:800; border-radius:50%; background:oklch(1 0 0 / .22)}
/* SAG form alani */
.auth-main{padding:clamp(22px,2.5vw,30px); overflow-y:auto; max-height:calc(100dvh - 28px)}
.auth-back{display:inline-flex; align-items:center; gap:4px; background:none; border:0; cursor:pointer; color:var(--ink-2);
  font-family:inherit; font-weight:600; font-size:.85rem; padding:0; margin-bottom:13px; transition:color .2s var(--exp)}
.auth-back[hidden]{display:none}
.auth-back:hover{color:var(--coral)}
.auth-back svg{width:16px; height:16px}
.auth-head{margin-bottom:15px}
.auth-head h2{font-size:1.3rem; font-weight:800; letter-spacing:-.02em}
/* form-ustu bildirim (hata/basari) */
.auth-note{font-size:.85rem; font-weight:500; line-height:1.45; padding:9px 12px; border-radius:9px; margin-bottom:13px}
.auth-note[hidden]{display:none}
.auth-note.err{background:var(--coral-soft); color:var(--coral-deep); border:1px solid color-mix(in oklch, var(--coral) 28%, transparent)}
.auth-note.ok{background:oklch(0.95 0.04 150); color:oklch(0.40 0.11 150); border:1px solid oklch(0.80 0.10 150)}
.auth-note .auth-link{font-size:inherit}
/* hesap portali rozet */
.hesap-rozet{display:inline-block; margin:8px 6px 0 0; padding:3px 10px; border-radius:20px; font-size:.76rem; font-weight:600;
  background:var(--bg-2); color:var(--ink-2); border:1px solid var(--line)}
.hesap-rozet.ok{background:oklch(0.95 0.04 150); color:oklch(0.40 0.11 150); border-color:oklch(0.82 0.09 150)}
/* ---------- PROFIL SAYFASI (tam genislik, 2-kolon, detayli) ---------- */
.profil-grid{display:grid; grid-template-columns:312px 1fr; gap:26px; align-items:start}
/* SOL ozet kart (yapiskan) */
.profil-yan{position:sticky; top:90px}
.profil-yan-kart{background:var(--bg); border:1px solid var(--line); border-radius:12px; padding:24px 22px; text-align:center}
.profil-av{border-radius:50%; flex:none; overflow:hidden; display:grid; place-items:center;
  background:var(--coral); color:#fff; font-weight:800; font-family:"Libre Franklin",sans-serif}
.profil-av img{width:100%; height:100%; object-fit:cover; display:block}
.profil-av-lg{width:96px; height:96px; font-size:2.3rem; margin:0 auto 14px}
.profil-yan-ad{font-size:1.18rem; font-weight:800; letter-spacing:-.01em; line-height:1.2}
.profil-yan-eposta{color:var(--ink-2); font-size:.9rem; margin-top:3px; overflow-wrap:anywhere}
.profil-yan-rozet{display:flex; flex-wrap:wrap; gap:6px; justify-content:center; margin:14px 0 4px}
.profil-yan-rozet .hesap-rozet{margin:0}
.profil-av-akt{display:flex; flex-direction:column; gap:8px; align-items:center; margin-top:16px; padding-top:16px; border-top:1px solid var(--line-2)}
.profil-av-ip{font-size:.78rem; color:var(--ink-2); margin:2px 0 0}
/* SAG detay kartlari */
.profil-ana{display:flex; flex-direction:column; gap:18px; min-width:0}
/* form de flex (icindeki kartlar + alt aksiyon ayni 18px ile esit araliklansin; yapisik 0px degil) */
.profil-ana > [data-profil-form]{display:flex; flex-direction:column; gap:18px}
.profil-ana > [data-profil-form] > .profil-foot{margin-top:0}
.profil-kart{background:var(--bg); border:1px solid var(--line); border-radius:12px; padding:22px 24px}
.profil-kart > h2{font-size:1.05rem; font-weight:800; letter-spacing:-.01em; margin:0 0 4px}
.profil-kart-alt{color:var(--ink-2); font-size:.9rem; line-height:1.5; margin:0 0 16px}
.profil-kart h2 + .form-row, .profil-kart h2 + .field{margin-top:16px}
.profil-kart .form-row{margin-bottom:14px}
.profil-kart .form-row:last-child, .profil-kart .field:last-child{margin-bottom:0}
.profil-kart textarea{font-family:inherit; font-size:.96rem; color:var(--ink); background:var(--bg-2);
  border:1px solid var(--line); border-radius:10px; padding:.7rem .85rem; resize:vertical; min-height:64px}
.profil-kart textarea:focus{outline:none; border-color:var(--coral); background:var(--bg); box-shadow:0 0 0 3px var(--coral-soft)}
/* bireysel/kurumsal segment secici */
.profil-seg{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:6px}
.profil-seg-opt{position:relative; cursor:pointer}
.profil-seg-opt input{position:absolute; opacity:0; inset:0; cursor:pointer}
.profil-seg-opt span{display:flex; flex-direction:column; gap:1px; padding:13px 16px; border-radius:11px;
  border:1.5px solid var(--line); background:var(--bg-2); transition:border-color .18s var(--exp), background .18s var(--exp)}
.profil-seg-opt b{font-weight:700; font-size:.96rem}
.profil-seg-opt small{color:var(--ink-2); font-size:.82rem}
.profil-seg-opt input:checked + span{border-color:var(--coral); background:var(--coral-soft)}
.profil-seg-opt input:focus-visible + span{box-shadow:0 0 0 3px var(--coral-soft)}
/* ===== Tema-uyumlu combobox: native <select.sel> gizli, stilli .csel onun yerine ===== */
select.sel{display:none !important}
.csel{position:relative; width:100%}
.csel-btn{display:flex; align-items:center; justify-content:space-between; gap:10px; width:100%;
  font-family:inherit; font-size:.96rem; color:var(--ink); background:var(--bg-2); text-align:left;
  border:1px solid var(--line); border-radius:10px; padding:.62rem .8rem; cursor:pointer;
  transition:border-color .15s var(--exp), box-shadow .15s var(--exp), background .15s var(--exp)}
.csel-btn:hover{border-color:color-mix(in oklch, var(--coral) 40%, var(--line))}
.csel-btn:focus-visible, .csel.acik .csel-btn{outline:none; border-color:var(--coral); background:var(--bg); box-shadow:0 0 0 3px var(--coral-soft)}
.csel-btn:disabled{opacity:.55; cursor:not-allowed}
.csel-val{overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.csel-val.bos{color:var(--ink-2)}
.csel-ok{flex:none; width:16px; height:16px; stroke:var(--ink-2); fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; transition:transform .2s var(--exp)}
.csel.acik .csel-ok{transform:rotate(180deg)}
.csel-pop{position:absolute; z-index:30; top:calc(100% + 6px); left:0; right:0; background:var(--bg);
  border:1px solid var(--line); border-radius:12px; padding:6px;
  box-shadow:0 18px 44px -22px oklch(0.25 0.05 262 / .5)}
.csel-pop[hidden]{display:none}
.csel-ara{width:100%; font-family:inherit; font-size:.9rem; color:var(--ink); background:var(--bg-2);
  border:1px solid var(--line); border-radius:8px; padding:.46rem .6rem; margin-bottom:6px}
.csel-ara:focus{outline:none; border-color:var(--coral); box-shadow:0 0 0 3px var(--coral-soft)}
.csel-liste{list-style:none; margin:0; padding:0; max-height:240px; overflow-y:auto}
.csel-opt{padding:.5rem .65rem; border-radius:8px; font-size:.94rem; cursor:pointer; color:var(--ink); display:flex; align-items:center}
.csel-opt:hover, .csel-opt.vurgu{background:var(--coral-soft)}
.csel-opt[aria-selected]{color:var(--coral-deep); font-weight:600}
.csel-opt[aria-selected]::after{content:"✓"; margin-left:auto; color:var(--coral)}
.csel-bos{padding:.6rem .65rem; color:var(--ink-2); font-size:.9rem}

/* profil turu kilit/gecis notu */
.profil-kilit-not, .profil-gecis-not{display:flex; align-items:flex-start; gap:8px; margin:12px 0 0; font-size:.86rem; line-height:1.45; color:var(--ink-2)}
.profil-kilit-not[hidden], .profil-gecis-not[hidden]{display:none}
.profil-kilit-not svg, .profil-gecis-not svg{flex:none; width:16px; height:16px; margin-top:1px; stroke:var(--coral); fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round}
.profil-seg.kilitli .profil-seg-opt input:disabled + span{opacity:.5; cursor:not-allowed}

/* ===== Rol-bazli panel (/panel) ===== */
.panel-grid{display:grid; grid-template-columns:236px 1fr; gap:26px; align-items:start}
.panel-nav{position:sticky; top:84px; display:flex; flex-direction:column; gap:1px; overflow:hidden;
  background:var(--bg); border:1px solid var(--line); border-radius:12px; padding:8px}
.panel-nav-grup{font-size:.68rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase;
  color:var(--ink-2); opacity:.65; padding:13px 10px 5px}
.panel-nav-grup:first-child{padding-top:5px}
.panel-nav-it{display:flex; align-items:center; gap:10px; padding:.5rem .6rem; border-radius:8px;
  font-weight:500; font-size:.9rem; color:var(--ink-2); text-decoration:none;
  transition:background .15s var(--exp), color .15s var(--exp)}
.panel-nav-it:hover{background:var(--bg-2); color:var(--ink)}
.panel-nav-it.aktif{background:var(--coral-soft); color:var(--coral-deep); font-weight:600}
.panel-nav-ic{flex:none; font-size:18px; line-height:1; opacity:.8}
.panel-nav-it.aktif .panel-nav-ic{opacity:1}
.panel-nav-ad{flex:1 1 auto; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.panel-nav-dis{flex:none; margin-left:auto; font-size:14px; opacity:.45}
.panel-ana{min-width:0; display:flex; flex-direction:column; gap:18px}
.panel-kart{background:var(--bg); border:1px solid var(--line); border-radius:12px; padding:22px 24px; overflow:hidden}
/* === Ortak panel KART BASLIGI (card title) — coral bar, beyaz yazi. TUM panel kartlari + sol menu.
   Tek yerden yonetilir; ileride degisiklik tek seferde uygulanir. === */
.panel-kart-bas{display:flex; align-items:center; gap:9px; min-height:40px; padding:8px 16px;
  background:linear-gradient(180deg, color-mix(in oklch, var(--coral), white 7%), var(--coral));
  border-radius:12px 12px 0 0}
.panel-kart-bas-ic{flex:none; font-size:16px; line-height:1; color:#fff; opacity:.92}
.panel-kart-bas h2{margin:0; color:#fff; font-size:.9rem; font-weight:600; letter-spacing:.005em; line-height:1.2}
.panel-kart > .panel-kart-bas{margin:-22px -24px 18px}   /* sag kart: kart kenarina flush */
.panel-nav  > .panel-kart-bas{margin:-8px -8px 8px}      /* sol menu: flush */
.panel-kart-bas .btn{margin-left:auto; background:rgba(255,255,255,.16); color:#fff;
  border:1px solid rgba(255,255,255,.34)}
.panel-kart-bas .btn:hover{background:rgba(255,255,255,.26)}
.panel-bos{padding:26px 4px; text-align:center}
.panel-bos p{font-weight:700; color:var(--ink); margin:0 0 4px}
.panel-bos span{color:var(--ink-2); font-size:.9rem}

/* lisans karti */
.lisans-kart{border:1px solid var(--line); border-radius:12px; padding:18px 20px; background:var(--bg-2)}
.lisans-ust{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap}
.lisans-paket{font-size:1.18rem; font-weight:800; letter-spacing:-.01em}
.lisans-edition{margin-left:8px; font-size:.8rem; font-weight:700; color:var(--ink-2);
  background:var(--bg); border:1px solid var(--line); border-radius:20px; padding:2px 10px}
.lisans-durum{font-size:.76rem; font-weight:700; padding:3px 11px; border-radius:20px}
.lisans-durum.ok{background:oklch(0.95 0.04 150); color:oklch(0.40 0.11 150); border:1px solid oklch(0.82 0.09 150)}
.lisans-durum.uyari{background:var(--coral-soft); color:var(--coral-deep); border:1px solid color-mix(in oklch, var(--coral) 30%, transparent)}
.lisans-eklenti{margin-top:16px}
.lisans-eklenti-bas, .lisans-et{display:block; font-size:.76rem; font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; color:var(--ink-2); margin-bottom:7px}
.lisans-cipler{display:flex; flex-wrap:wrap; gap:7px}
.lisans-cip{font-size:.85rem; font-weight:600; color:var(--ink); background:var(--bg);
  border:1px solid var(--line); border-radius:8px; padding:5px 11px}
.lisans-bilgi{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:18px;
  border-top:1px solid var(--line); padding-top:16px}
.lisans-bilgi-it b{font-size:1rem; font-weight:700}
.lisans-bilgi-it .lisans-et{margin-bottom:4px}
.lisans-uyari{margin-top:16px; font-size:.88rem; line-height:1.45; padding:10px 13px; border-radius:10px}
.lisans-uyari.warn{background:oklch(0.96 0.05 85); color:oklch(0.45 0.12 75); border:1px solid oklch(0.85 0.10 85)}
.lisans-uyari.err{background:var(--coral-soft); color:var(--coral-deep); border:1px solid color-mix(in oklch, var(--coral) 28%, transparent)}
@media (max-width:840px){ .panel-grid{grid-template-columns:1fr} .panel-nav{position:static; flex-direction:row; overflow-x:auto} .panel-nav > .panel-kart-bas{display:none} .lisans-bilgi{grid-template-columns:1fr 1fr} }
.panel-ana.panel-yukleniyor{opacity:.5; pointer-events:none; transition:opacity .15s}

/* Header bildirim zili — header top menu (mega) ile AYNI stil: koyu tumlesik panel, cream metin */
.hdr-bildirim{position:relative; display:flex; align-items:center; align-self:stretch}
.hdr-bell{position:relative; width:38px; height:38px; border-radius:9px; display:grid; place-items:center;
  background:none; border:0; color:var(--ink); cursor:pointer; transition:background .18s var(--exp)}
body.dark-hero .hdr-bell{color:#fff}
.hdr-bell:hover{background:color-mix(in oklch, currentColor 9%, transparent)}
.hdr-bell svg{width:20px; height:20px}
.hdr-bell-say{position:absolute; top:2px; right:1px; min-width:16px; height:16px; padding:0 4px; border-radius:8px;
  background:var(--coral); color:#fff; font-size:.66rem; font-weight:700; display:grid; place-items:center; line-height:1}
.hdr-bell-say[hidden]{display:none}
.hdr-bell-pop{position:absolute; right:-8px; top:100%; width:max-content; min-width:236px; max-width:min(320px,86vw); z-index:70; overflow:hidden;
  background:color-mix(in oklch, var(--dark) 97%, transparent); /* acik-header ile BIREBIR ayni renk */
  border:1px solid color-mix(in oklch, var(--cream) 12%, transparent); border-top:0; border-radius:0 0 12px 12px;
  box-shadow:0 16px 36px -18px oklch(0.1 0.02 262 / .7); padding:7px}
.hdr-bell-pop[hidden]{display:none}
.hdr-bell-bas{display:flex; align-items:center; justify-content:space-between; gap:10px; padding:9px 11px 7px}
.hdr-bell-bas > span{font-size:.72rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--on-dark)}
.hdr-bell-oku{font-family:inherit; font-size:.74rem; font-weight:600; color:oklch(0.8 0.12 42); background:none; border:0; cursor:pointer; padding:0}
.hdr-bell-oku[hidden]{display:none}
.hdr-bell-oku:hover{color:var(--coral)}
.hdr-bell-bos{display:flex; flex-direction:column; align-items:center; gap:7px; padding:16px 12px 14px; color:var(--on-dark); font-size:.85rem; text-align:center}
.hdr-bell-bos svg{width:22px; height:22px; opacity:.55}
.hdr-bell-it{display:flex; align-items:flex-start; gap:10px; padding:10px 11px; border-radius:8px;
  font-size:.89rem; line-height:1.42; color:var(--cream); transition:background .18s var(--exp)}
.hdr-bell-it::before{content:""; flex:none; width:7px; height:7px; border-radius:50%; margin-top:5px; background:var(--coral)}
.hdr-bell-it.warn::before{background:oklch(0.8 0.13 70)}
.hdr-bell-it.err::before{background:var(--coral)}
.hdr-bell-it.okunmus{color:var(--on-dark)}
.hdr-bell-it.okunmus::before{background:color-mix(in oklch, var(--cream) 22%, transparent)}
.hdr-bell-it:hover{background:color-mix(in oklch, var(--cream) 6%, transparent)}
.hdr-bell-gov{min-width:0}
.hdr-bell-zaman{display:block; font-size:.74rem; color:var(--on-dark); margin-top:2px; opacity:.85}
.hdr-bell-tum{display:block; text-align:center; padding:9px; margin-top:4px; border-top:1px solid color-mix(in oklch, var(--cream) 9%, transparent);
  font-size:.83rem; font-weight:600; color:oklch(0.8 0.12 42); transition:color .15s}
.hdr-bell-tum:hover{color:var(--coral)}

/* Kart-ici inline form (Yeni musteri / Yeni talep - modal DEGIL) */
.kart-form{border:1px solid var(--line); border-radius:10px; background:var(--bg-2); padding:18px 20px; margin-bottom:18px}
.kart-form[hidden]{display:none}
.kart-form-bas{font-size:1rem; font-weight:800; letter-spacing:-.01em; margin:0 0 3px}
.kart-form-alt{color:var(--ink-2); font-size:.86rem; line-height:1.45; margin:0 0 14px}
.kart-form .form-row{margin-bottom:14px}
.kart-form .field:last-of-type, .kart-form .form-row:last-of-type{margin-bottom:0}

/* CRM "Musterilerim" */
.crm-bas{gap:9px}
.crm-bas h2{margin:0}
.crm-filtre{display:flex; flex-wrap:wrap; gap:7px; margin:0 0 16px}
.crm-cip{font-family:inherit; font-size:.84rem; font-weight:600; color:var(--ink-2); background:var(--bg-2);
  border:1px solid var(--line); border-radius:8px; padding:5px 13px; cursor:pointer; transition:background .15s, color .15s, border-color .15s}
.crm-cip:hover{border-color:color-mix(in oklch, var(--coral) 40%, var(--line))}
.crm-cip.aktif{background:var(--coral-soft); color:var(--coral-deep); border-color:color-mix(in oklch, var(--coral) 35%, transparent)}
.crm-liste{overflow-x:auto}
.crm-tablo{width:100%; border-collapse:collapse; font-size:.92rem}
.crm-tablo th{text-align:left; font-size:.74rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase;
  color:var(--ink-2); padding:0 12px 10px; border-bottom:1px solid var(--line)}
.crm-tablo td{padding:12px; border-bottom:1px solid var(--line-2); vertical-align:middle}
.crm-tablo tbody tr:last-child td{border-bottom:0}
.crm-tablo b{font-weight:700}
.crm-firma{display:block; color:var(--ink-2); font-size:.84rem; margin-top:2px}
.crm-iletisim span{display:block; line-height:1.4}
.crm-iletisim .crm-ep{color:var(--ink-2); font-size:.85rem}
.crm-bos-i{color:var(--ink-2)}
.crm-asama-sel{font-family:inherit; font-size:.85rem; color:var(--ink); background:var(--bg);
  border:1px solid var(--line); border-radius:8px; padding:5px 9px; cursor:pointer}
.crm-asama-sel:focus{outline:none; border-color:var(--coral); box-shadow:0 0 0 3px var(--coral-soft)}
.crm-koruma{font-size:.74rem; font-weight:700; padding:3px 10px; border-radius:20px; white-space:nowrap}
.crm-koruma.ok{background:oklch(0.95 0.04 150); color:oklch(0.40 0.11 150); border:1px solid oklch(0.82 0.09 150)}
.crm-koruma.cakisma{background:var(--coral-soft); color:var(--coral-deep); border:1px solid color-mix(in oklch, var(--coral) 30%, transparent)}
.crm-aksiyon{text-align:right}
.tbtn{font-family:inherit; font-size:.82rem; font-weight:600; color:var(--ink-2); background:var(--bg);
  border:1px solid var(--line); border-radius:8px; padding:5px 11px; cursor:pointer; transition:border-color .15s, color .15s}
.tbtn:hover{border-color:var(--coral); color:var(--coral-deep)}

/* Alt Bayilerim (bolge) — flat, hairline ayraclar */
.ab-liste{display:flex; flex-direction:column; gap:10px}
.ab-item{border:1px solid var(--line); border-radius:10px; overflow:hidden}
.ab-item[open]{border-color:color-mix(in oklch, var(--coral) 30%, var(--line))}
.ab-bas{display:flex; align-items:center; gap:14px; padding:14px 16px; cursor:pointer; list-style:none}
.ab-bas::-webkit-details-marker{display:none}
.ab-ok{flex:none; width:18px; height:18px; color:var(--ink-2); transition:transform .2s var(--exp)}
.ab-item[open] .ab-ok{transform:rotate(90deg)}
.ab-ok svg{width:18px; height:18px}
.ab-ad{flex:1 1 auto; min-width:0}
.ab-ad b{font-weight:700}
.ab-kod{display:block; color:var(--ink-2); font-size:.84rem; margin-top:1px}
.ab-prog{color:var(--coral-deep); font-weight:600}
.ab-metr{display:flex; gap:18px; flex:none; flex-wrap:wrap}
.ab-metr span{font-size:.85rem; color:var(--ink-2)}
.ab-metr b{color:var(--ink); font-weight:700}
.ab-metr .uyari, .ab-metr .uyari b{color:var(--coral-deep)}
.ab-det{padding:2px 16px 14px; border-top:1px solid var(--line-2); background:var(--bg-2)}
.ab-bos-i{color:var(--ink-2); font-size:.9rem; padding:12px 0; margin:0}
.ab-tablo{width:100%; border-collapse:collapse; font-size:.9rem; margin-top:10px}
.ab-tablo th{text-align:left; font-size:.72rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-2); padding:8px 10px 8px}
.ab-tablo td{padding:9px 10px; border-top:1px solid var(--line)}
.ab-tablo td.uyari{color:var(--coral-deep); font-weight:600}
.ab-tablo td.err{color:var(--coral-deep); font-weight:700}
@media (max-width:560px){ .ab-bas{flex-wrap:wrap} .ab-metr{gap:12px} }
.ab-ok iconify-icon{font-size:18px; display:block}

/* Bayi Agi (yonetici) — ozet + tip/program/durum rozetleri */
.ag-ozet{display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:18px}
.ag-stat{border:1px solid var(--line); border-radius:10px; padding:13px 15px; background:var(--bg-2)}
.ag-stat-d{display:block; font-size:1.5rem; font-weight:800; letter-spacing:-.02em; line-height:1.1}
.ag-stat-e{display:block; font-size:.78rem; font-weight:600; color:var(--ink-2); margin-top:3px}
.ag-stat.uyari .ag-stat-d{color:var(--coral-deep)}
.ag-tip{display:inline-block; font-size:.72rem; font-weight:700; padding:2px 8px; border-radius:20px; letter-spacing:.01em}
.ag-tip.t-bolge{background:var(--coral-soft); color:var(--coral-deep)}
.ag-tip.t-tali{background:var(--bg); color:var(--ink-2); border:1px solid var(--line)}
.ag-tablo td .ag-kod{display:block; color:var(--ink-2); font-size:.8rem; margin-top:1px}
.ag-prog{color:var(--coral-deep); font-weight:600; font-size:.85rem}
.ag-yok{color:var(--ink-2)}
.ag-durum{font-size:.76rem; font-weight:600; padding:2px 8px; border-radius:6px; white-space:nowrap}
.ag-durum.ok{background:oklch(0.95 0.04 150); color:oklch(0.40 0.11 150)}
.ag-durum.pasif{background:var(--bg); color:var(--ink-2); border:1px solid var(--line)}
@media (max-width:680px){ .ag-ozet{grid-template-columns:repeat(2,1fr)} }

/* Lisanslar (yonetici) tablo */
.lis-tablo .lc-paket{width:130px} .lis-tablo .lc-bayi{width:176px} .lis-tablo .lc-durum{width:96px} .lis-tablo .lc-bitis{width:118px} .lis-tablo .lc-kalan{width:92px}
.lis-bayi{display:block; font-weight:600} .lis-bayi-kod{display:block; color:var(--ink-2); font-size:.8rem; margin-top:1px}
.lis-tablo td.uyari{color:var(--coral-deep); font-weight:600}
.lis-tablo td.err{color:var(--coral-deep); font-weight:700}

/* Destek (ticket) */
.destek-oncelik-not{font-size:.88rem; color:var(--ink-2); margin:0 0 14px; padding:9px 13px; border-radius:10px;
  background:var(--coral-soft); border:1px solid color-mix(in oklch, var(--coral) 22%, transparent)}
.destek-oncelik-not b{color:var(--coral-deep)}
.destek-liste{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px}
.destek-it{border:1px solid var(--line); border-radius:10px; padding:13px 15px; cursor:pointer; transition:border-color .15s, background .15s}
.destek-it:hover{border-color:color-mix(in oklch, var(--coral) 35%, var(--line)); background:var(--bg-2)}
.destek-it:focus-visible{outline:none; border-color:var(--coral); box-shadow:0 0 0 3px var(--coral-soft)}
.destek-it-bas{display:flex; align-items:center; justify-content:space-between; gap:10px}
.destek-it-bas b{font-weight:700}
.destek-it-alt{display:flex; flex-wrap:wrap; gap:12px; margin-top:5px; font-size:.83rem; color:var(--ink-2)}
.destek-oncelik{color:var(--coral-deep); font-weight:600}
.destek-tarih{margin-left:auto}
.dyon-musteri{color:var(--ink); font-weight:600}
.destek-durum{font-size:.74rem; font-weight:700; padding:3px 10px; border-radius:20px; white-space:nowrap}
.destek-durum.d-acik{background:oklch(0.96 0.05 85); color:oklch(0.45 0.12 75); border:1px solid oklch(0.85 0.10 85)}
.destek-durum.d-yanitlandi{background:oklch(0.95 0.04 150); color:oklch(0.40 0.11 150); border:1px solid oklch(0.82 0.09 150)}
.destek-durum.d-kapali{background:var(--bg-2); color:var(--ink-2); border:1px solid var(--line)}
.destek-detay-bas{display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:8px}
.destek-detay-konu{font-size:1.1rem; font-weight:800; margin:0}
.destek-detay-meta{color:var(--ink-2); font-size:.85rem; margin-top:2px}
.destek-thread{display:flex; flex-direction:column; gap:10px; margin:16px 0}
.destek-msg{max-width:80%; padding:10px 13px; border-radius:12px; font-size:.92rem; line-height:1.5}
.destek-msg-kim{font-size:.74rem; color:var(--ink-2); margin-bottom:3px}
.destek-msg.ben{align-self:flex-end; background:var(--coral-soft); border:1px solid color-mix(in oklch, var(--coral) 20%, transparent)}
.destek-msg.dst{align-self:flex-start; background:var(--bg-2); border:1px solid var(--line)}
.destek-msg-govde{white-space:pre-wrap; overflow-wrap:anywhere}
.destek-yanit{display:flex; flex-direction:column; gap:8px; border-top:1px solid var(--line); padding-top:14px}
.destek-yanit textarea{font-family:inherit; font-size:.95rem; color:var(--ink); background:var(--bg-2); border:1px solid var(--line); border-radius:10px; padding:.6rem .8rem; resize:vertical; min-height:54px}
.destek-yanit textarea:focus{outline:none; border-color:var(--coral); background:var(--bg); box-shadow:0 0 0 3px var(--coral-soft)}
.destek-yanit-foot{display:flex; align-items:center; justify-content:space-between; gap:10px}
.destek-kapali-not{color:var(--ink-2); font-size:.88rem; border-top:1px solid var(--line); padding-top:14px; margin:14px 0 0}

/* Kazançlarım (hakediş) */
.hak-ozet{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:6px}
.hak-ozet-it{border:1px solid var(--line); border-radius:10px; padding:14px 16px; background:var(--bg-2)}
.hak-ozet-it span{display:block; font-size:.76rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-2); margin-bottom:6px}
.hak-ozet-it b{font-size:1.3rem; font-weight:800; letter-spacing:-.01em}
.hak-ozet-it.bekle b{color:var(--coral-deep)}
.hak-not{color:var(--ink-2); font-size:.84rem; line-height:1.45; margin:12px 0 16px}
.hak-tablo .hak-sag{text-align:right}
.hak-neg{color:var(--coral-deep); font-weight:700}
.hak-tip{font-size:.76rem; font-weight:700; padding:2px 8px; border-radius:6px}
.hak-tip.t-tahakkuk{background:oklch(0.95 0.04 150); color:oklch(0.40 0.11 150)}
.hak-tip.t-odeme{background:var(--bg-2); color:var(--ink-2); border:1px solid var(--line)}
.hak-tip.t-clawback{background:var(--coral-soft); color:var(--coral-deep)}
@media (max-width:560px){ .hak-ozet{grid-template-columns:1fr} }

/* Sertifikalarım */
.sert-program{display:flex; align-items:center; gap:12px; padding:14px 16px; border:1px solid var(--line); border-radius:10px; background:var(--bg-2); margin-bottom:4px}
.sert-program-et{font-size:.85rem; color:var(--ink-2); font-weight:600}
.sert-program-rozet{font-size:.9rem; font-weight:700; color:var(--coral-deep); background:var(--coral-soft); border:1px solid color-mix(in oklch, var(--coral) 28%, transparent); padding:4px 12px; border-radius:8px}
.sert-program-yok{color:var(--ink-2); font-size:.9rem}
.sert-durum{font-size:.76rem; font-weight:700; padding:3px 10px; border-radius:6px}
.sert-durum.sd-aktif{background:oklch(0.95 0.04 150); color:oklch(0.40 0.11 150); border:1px solid oklch(0.82 0.09 150)}
.sert-durum.sd-suresi-doldu{background:oklch(0.96 0.05 85); color:oklch(0.45 0.12 75); border:1px solid oklch(0.85 0.10 85)}
.sert-durum.sd-iptal{background:var(--bg-2); color:var(--ink-2); border:1px solid var(--line)}

/* Yonetici - Kullanici Yonetimi */
/* Kullanici Yonetimi filtre toolbar (arama + kategori) — nizami hizali */
.kull-filtre{display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin:0 0 18px}
.kull-ara-sar{position:relative; flex:1 1 280px; min-width:200px; max-width:400px}
.kull-ara-ic{position:absolute; left:11px; top:50%; transform:translateY(-50%); font-size:16px; color:var(--ink-2); pointer-events:none}
.kull-ara{width:100%; font-family:inherit; font-size:.9rem; color:var(--ink); background:var(--bg-2);
  border:1px solid var(--line); border-radius:9px; padding:.55rem .8rem .55rem 2.15rem; transition:border-color .15s, box-shadow .15s, background .15s}
.kull-ara:focus{outline:none; border-color:var(--coral); box-shadow:0 0 0 3px var(--coral-soft); background:var(--bg)}
.kull-kat-filtre{flex:none; font-family:inherit; font-size:.9rem; color:var(--ink); background:var(--bg-2);
  border:1px solid var(--line); border-radius:9px; padding:.55rem 2rem .55rem .8rem; cursor:pointer; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23667085' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right .6rem center; background-size:15px}
.kull-kat-filtre:focus{outline:none; border-color:var(--coral); box-shadow:0 0 0 3px var(--coral-soft)}
/* tablo kolon hizasi (colgroup) */
.kull-tablo .kc-kat{width:176px} .kull-tablo .kc-profil{width:104px} .kull-tablo .kc-durum{width:92px} .kull-tablo .kc-islem{width:108px}
.kull-tablo td.crm-aksiyon, .kull-tablo th:last-child{text-align:right}
.kull-kat{font-size:.78rem; font-weight:600; padding:3px 9px; border-radius:6px; white-space:nowrap}
.kull-kat.g-dis{background:var(--bg-2); color:var(--ink); border:1px solid var(--line)}
.kull-kat.g-ic{background:var(--coral-soft); color:var(--coral-deep); border:1px solid color-mix(in oklch, var(--coral) 25%, transparent)}
.kull-kanal-not{font-size:.83rem; color:var(--ink-2); margin:6px 0 12px; padding:8px 11px; background:var(--bg-2); border-radius:8px}

/* Bildirimler sayfasi (/bildirimler) — kart header/wrap genisliginde */
.bil-bas{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-bottom:6px}
.bil-filtre{display:flex; gap:7px; flex-wrap:wrap}
.bil-liste{list-style:none; margin:8px 0 0; padding:0; display:flex; flex-direction:column}
.bil-it{display:flex; align-items:flex-start; gap:12px; padding:14px 4px; border-top:1px solid var(--line-2)}
.bil-it:first-child{border-top:0}
.bil-it[hidden]{display:none}
.bil-dot{flex:none; width:9px; height:9px; border-radius:50%; margin-top:5px; background:var(--coral)}
.bil-it.t-warn .bil-dot{background:oklch(0.72 0.14 70)}
.bil-it.okunmus .bil-dot{background:var(--line)}
.bil-gov{flex:1 1 auto; min-width:0}
.bil-baslik{display:block; font-weight:700; font-size:.95rem}
.bil-metin{display:block; color:var(--ink); font-size:.92rem; line-height:1.45; margin-top:1px}
.bil-it.okunmus .bil-baslik, .bil-it.okunmus .bil-metin{color:var(--ink-2)}
.bil-zaman{display:block; color:var(--ink-2); font-size:.8rem; margin-top:3px}
.bil-oku-btn{flex:none; align-self:center}

/* ===== Sticky footer: footer her zaman sayfanin EN ALTINA dayanir (kisa sayfada bile) ===== */
body{min-height:100dvh; display:flex; flex-direction:column}
body > main{flex:1 0 auto}
body > footer{flex-shrink:0}

/* App sayfalari (panel/profil/hesabim/bildirimler): ilk ekran viewport'u doldurur ->
   normal mega-footer FOLD'un altinda kalir, asagi kaydirinca cikar. */
body.app-shell > main{min-height:100svh}

/* App sabit alt bar: ekranin altina SABIT tek satir; solda logo, sagda telefon.
   Ilk yuklemede gorunur; mega-footer gorununce main.js IntersectionObserver ile gizlenir. */
.app-bar{position:fixed; left:0; right:0; bottom:0; z-index:60; background:var(--dark);
  border-top:1px solid color-mix(in oklch, var(--cream) 9%, transparent);
  transition:transform .28s ease, opacity .28s ease}
.app-bar.gizli{transform:translateY(110%); opacity:0; pointer-events:none}
.app-bar-in{display:flex; align-items:center; justify-content:space-between; gap:14px;
  min-height:52px; padding-top:6px; padding-bottom:6px}
.app-bar-marka{display:inline-flex; align-items:center}
.app-bar-marka .brand{transform:scale(.92); transform-origin:left center}
.app-bar-tel{display:inline-flex; align-items:center; gap:9px; font-weight:600; font-size:.95rem;
  color:#fff; white-space:nowrap; transition:color .15s ease}
.app-bar-tel svg{width:18px; height:18px; color:var(--coral); flex:none}
.app-bar-tel:hover{color:var(--coral)}

/* form alt aksiyon cubugu: ana eylem SAGDA (Form & Buton standardi) */
.form-foot{display:flex; justify-content:flex-end; align-items:center; gap:10px; margin-top:16px}
.profil-foot{margin-top:18px}
.kurumsal-only[hidden]{display:none}

/* --- Guvenlik bolumu: ayar satirlari (sifre + 2FA ...) --- */
.guv-liste{display:flex; flex-direction:column}
.guv-satir{display:flex; align-items:center; gap:14px; padding:16px 0; border-top:1px solid var(--line-2)}
.guv-satir:first-child{border-top:0; padding-top:4px}
.guv-ikon{flex:none; width:38px; height:38px; border-radius:10px; display:grid; place-items:center;
  background:var(--bg-2); border:1px solid var(--line); color:var(--ink-2)}
.guv-ikon svg{width:19px; height:19px; stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round}
.guv-org{flex:1 1 auto; min-width:0; display:flex; flex-direction:column; gap:2px}
.guv-org b{font-size:.96rem; font-weight:700}
.guv-org small{color:var(--ink-2); font-size:.85rem; line-height:1.45}
.guv-durum{flex:none; font-size:.74rem; font-weight:700; padding:3px 9px; border-radius:20px; letter-spacing:.02em}
.guv-durum.kapali{background:var(--bg-2); color:var(--ink-2); border:1px solid var(--line)}
.guv-durum.acik{background:oklch(0.95 0.04 150); color:oklch(0.40 0.11 150); border:1px solid oklch(0.82 0.09 150)}
.guv-satir .btn{flex:none}
.guv-panel{padding:4px 0 18px; border-top:1px dashed var(--line-2); margin-top:-1px}
.guv-panel[hidden]{display:none}
.guv-panel > .form-row:first-child, .guv-panel > .field:first-child{margin-top:14px}

/* --- Foto kirpma modali (istemci-tarafi kare kirpma + zoom + surukle) --- */
.kirp-ortu{position:fixed; inset:0; z-index:120; display:none; align-items:center; justify-content:center;
  background:oklch(0.18 0.03 262 / .62); backdrop-filter:blur(3px); padding:20px}
.kirp-ortu.acik{display:flex}
.kirp-kutu{background:var(--bg); border:1px solid var(--line); border-radius:18px; width:min(380px,100%);
  padding:22px; box-shadow:0 30px 80px -30px oklch(0.2 0.05 262 / .55)}
.kirp-kutu h3{font-size:1.05rem; font-weight:800; margin:0 0 3px}
.kirp-kutu p{color:var(--ink-2); font-size:.85rem; margin:0 0 16px}
.kirp-sahne{position:relative; width:280px; height:280px; max-width:100%; margin:0 auto; border-radius:50%;
  overflow:hidden; background:var(--bg-2); touch-action:none; cursor:grab}
.kirp-sahne:active{cursor:grabbing}
.kirp-tuval{display:block; width:100%; height:100%}
.kirp-zoom{display:flex; align-items:center; gap:10px; margin:16px 2px 4px; color:var(--ink-2)}
.kirp-zoom input[type=range]{flex:1; accent-color:var(--coral)}
.kirp-zoom svg{width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:2; flex:none}
.kirp-foot{display:flex; gap:10px; justify-content:flex-end; margin-top:14px}
@media (max-width:900px){
  .profil-grid{grid-template-columns:1fr; gap:18px}
  .profil-yan{position:static}
}
.auth-head p{color:var(--ink-2); margin-top:5px; font-size:.88rem; line-height:1.45}
.auth-tabs{display:grid; grid-template-columns:1fr 1fr; gap:3px; background:var(--bg-2); border:1px solid var(--line);
  border-radius:10px; padding:3px; margin-bottom:14px}
.auth-tabs[hidden]{display:none}
.auth-tab{font-family:inherit; font-weight:600; font-size:.88rem; padding:.48rem; border:0; border-radius:8px;
  background:none; color:var(--ink-2); cursor:pointer; transition:background .2s var(--exp), color .2s var(--exp), box-shadow .2s var(--exp)}
.auth-tab.active{background:var(--bg); color:var(--ink); box-shadow:0 3px 10px -5px oklch(0.25 0.05 262 / .4)}
.auth-google{display:flex; align-items:center; justify-content:center; gap:9px; width:100%; font-family:inherit;
  font-weight:600; font-size:.9rem; color:var(--ink); background:var(--bg); border:1px solid var(--line);
  border-radius:9px; padding:.6rem; cursor:pointer; transition:background .2s var(--exp), border-color .2s var(--exp)}
.auth-google:hover{background:var(--bg-2); border-color:var(--ink-2)}
.auth-google[hidden]{display:none}
.auth-or{display:flex; align-items:center; gap:10px; margin:13px 0; color:var(--ink-2); font-size:.78rem}
.auth-or[hidden]{display:none}
.auth-or::before,.auth-or::after{content:""; flex:1; height:1px; background:var(--line)}
.auth-form{display:flex; flex-direction:column; gap:11px}
.auth-form[hidden]{display:none}
.auth-form .field{display:flex; flex-direction:column; gap:5px}
.auth-form label{font-weight:600; font-size:.83rem; color:var(--ink)}
.auth-form input[type=email],.auth-form input[type=password],.auth-form input[type=text]{
  font-family:inherit; font-size:.94rem; color:var(--ink); background:var(--bg-2); border:1px solid var(--line);
  border-radius:9px; padding:.58rem .72rem;
  transition:border-color .2s var(--exp), background .2s var(--exp), box-shadow .2s var(--exp)}
.auth-form input:focus{outline:none; border-color:var(--coral); background:var(--bg); box-shadow:0 0 0 3px var(--coral-soft)}
.auth-form input[aria-invalid=true]{border-color:var(--coral-deep)}
.auth-form .field-err{color:var(--coral-deep); font-size:.78rem; font-weight:500; display:none}
.auth-form .field-err.show{display:block}
.auth-form .field-check .check{display:grid; grid-template-columns:auto 1fr; gap:9px; align-items:start; cursor:pointer}
.auth-form .field-check .check input{width:16px; height:16px; margin-top:2px; accent-color:var(--coral)}
.auth-form .field-check .check span{font-size:.84rem; color:var(--ink-2); font-weight:400; line-height:1.5}
.auth-row{display:flex; align-items:center; justify-content:space-between; gap:10px; font-size:.84rem; flex-wrap:wrap}
.auth-remember{display:inline-flex; align-items:center; gap:7px; cursor:pointer; color:var(--ink-2)}
.auth-remember input{width:15px; height:15px; accent-color:var(--coral)}
.auth-link{color:var(--coral); font-weight:600; background:none; border:0; cursor:pointer; font:inherit; padding:0; text-decoration:none}
.auth-link:hover{text-decoration:underline}
.btn.auth-submit{width:100%; margin-top:3px; padding:.66rem 1.2rem; font-size:.94rem}
.auth-mini{text-align:center; font-size:.83rem; color:var(--ink-2); margin-top:0}
.auth-switch{text-align:center; margin-top:13px; font-size:.85rem; color:var(--ink-2)}
.auth-switch[hidden]{display:none}
/* OTP — 6 haneli kod kutulari */
.otp{display:grid; grid-template-columns:repeat(6,1fr); gap:7px}
.otp input{text-align:center; font-family:"Libre Franklin",sans-serif; font-weight:800;
  font-size:1.2rem; padding:.5rem 0; width:100%}
/* basari */
.auth-done{align-items:center; text-align:center; gap:13px; padding-top:6px}
.auth-done-ic{display:grid; place-items:center; width:52px; height:52px; border-radius:50%; background:var(--coral-soft); color:var(--coral)}
.auth-done-ic svg{width:27px; height:27px}
.auth-done p{color:var(--ink-2); font-size:.94rem; line-height:1.5; max-width:34ch}
@media (max-width:620px){
  .auth-card{grid-template-columns:1fr; max-width:412px}
  .auth-aside{display:none}
}
@media (prefers-reduced-motion:reduce){ html.js .auth-modal:not([hidden]),html.js .auth-modal:not([hidden]) .auth-card,.auth-aura{animation:none} }

/* ---------- FOOTER ---------- */
footer{background:var(--dark); color:var(--on-dark); padding:clamp(56px,8vh,80px) 0 40px}
.foot-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr 1.15fr; gap:36px}
.foot-col.foot-bayi{justify-content:flex-start}
.foot-bayi .btn-bayi{display:inline-flex; align-items:center; gap:8px; width:auto;
  font-family:"Hanken Grotesk",sans-serif; font-weight:700; font-size:.92rem;
  color:#fff; background:var(--coral); border:1px solid var(--coral); border-radius:10px;
  padding:.66rem 1.25rem; box-shadow:0 12px 30px -12px oklch(0.5 0.16 33 / .7);
  transition:transform .2s var(--exp), background .25s var(--exp), box-shadow .25s var(--exp)}
.foot-bayi .btn-bayi svg{width:17px; height:17px}
.foot-bayi .btn-bayi:hover{background:var(--coral-deep); box-shadow:0 16px 38px -12px oklch(0.5 0.16 33 / .85); transform:translateY(-1px); color:#fff}
.foot-grid .brand{font-size:1.32rem}
.foot-blurb{margin-top:14px; max-width:34ch; font-size:.92rem; color:var(--on-dark)}
.foot-tel{display:inline-flex; align-items:center; gap:9px; margin-top:16px; font-weight:600;
  font-size:.98rem; color:#fff; transition:color .15s ease}
.foot-tel svg{width:18px; height:18px; color:var(--coral); flex:none}
.foot-tel:hover{color:var(--coral)}
.foot-col h4{font-family:"Libre Franklin",sans-serif; color:#fff; font-size:.82rem; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase; margin-bottom:16px}
.foot-col a{display:block; color:var(--on-dark); font-size:.92rem; padding:5px 0; transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{border-top:1px solid color-mix(in oklch, var(--cream) 16%, transparent); margin-top:clamp(40px,6vh,60px);
  padding-top:26px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:.86rem; color:var(--on-dark)}

/* ---------- reveal + a11y ---------- */
html.js [data-reveal]{opacity:0; transform:translateY(24px); transition:opacity .85s var(--exp), transform .85s var(--exp)}
html.js [data-reveal].in{opacity:1; transform:none}
html.js [data-reveal][data-d="1"]{transition-delay:.08s}
html.js [data-reveal][data-d="2"]{transition-delay:.16s}
html.js [data-reveal][data-d="3"]{transition-delay:.24s}
html.js [data-reveal][data-d="4"]{transition-delay:.32s}
/* yatay reveal (ozellik bloklari: metin bir yandan, gorsel diger yandan kayarak gelir) — yalniz 2-kolon masaustunde */
@media (min-width:921px){
  html.js [data-reveal="left"]{transform:translateX(-54px)}
  html.js [data-reveal="right"]{transform:translateX(54px)}
}
:where(a,button):focus-visible{outline:2px solid var(--coral); outline-offset:3px; border-radius:6px}

@media (max-width:920px){
  .nav-links{display:none}
  .hero-grid,.feat-grid,.arch-grid{grid-template-columns:1fr; gap:34px}
  .feat .shot{order:2}
  .hero-media{order:-1; min-height:clamp(220px,58vw,300px)}
  .cslider{min-height:336px}
  .feat.rev .feat-grid{direction:ltr}
  .matrix{grid-template-columns:1fr}
  .pillars{grid-template-columns:1fr; gap:24px}
  .foot-grid{grid-template-columns:1fr 1fr; gap:30px}
  .arch-art{display:none}
  html{scroll-snap-type:none}
}
@media (max-width:560px){ .strip-in{gap:18px 22px} .strip-in > div{flex:1 1 40%; min-width:0} .strip-in .k{font-size:1.25rem} .foot-grid{grid-template-columns:1fr} }
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto; scroll-snap-type:none}
  html.js [data-reveal]{opacity:1; transform:none; transition:none}
  .mq{animation:none}
  .hero-aurora .a{animation:none}
  .cslide,.cslide *,.mslide{transition:none; filter:none}
  .cslide:not(.active){display:none}
  .hero-media .mslide.active .frame{animation:none}
  .hero-dots .dot.active span{transition:none; width:100%}
}

/* ====================================================================
   MOBIL NAVIGASYON — hamburger + sag cekmece (off-canvas), yalniz <=920px.
   Masaustu .nav-links gizlenince (@media 920) tek erisim noktasi budur.
   Gruplar native <details>/<summary> ile acilir (JS'siz); panel ac/kapat main.js.
   ==================================================================== */
.nav-burger{display:none; align-items:center; justify-content:center; width:42px; height:42px;
  border:0; background:none; color:var(--ink); cursor:pointer; border-radius:9px;
  transition:background .18s var(--exp)}
body.dark-hero .nav-burger{color:#fff}
.nav-burger:hover{background:color-mix(in oklch, currentColor 10%, transparent)}
.nav-burger svg{width:25px; height:25px}

.mnav{position:fixed; inset:0; z-index:200; overflow:hidden; visibility:hidden; transition:visibility 0s linear .34s}
.mnav.acik{visibility:visible; transition:visibility 0s}
.mnav-ortu{position:absolute; inset:0; background:oklch(0.2 0.03 262 / .5);
  -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px); opacity:0; transition:opacity .34s var(--exp)}
.mnav.acik .mnav-ortu{opacity:1}
.mnav-panel{position:absolute; top:0; right:0; bottom:0; width:min(87vw,360px);
  display:flex; flex-direction:column; overflow-y:auto; overscroll-behavior:contain;
  background:linear-gradient(180deg, var(--dark-2), var(--dark)); color:var(--cream);
  box-shadow:-24px 0 70px -24px #000; transform:translateX(100%); transition:transform .34s var(--exp)}
.mnav.acik .mnav-panel{transform:none}
.mnav-bas{display:flex; align-items:center; justify-content:space-between; gap:12px; flex:none;
  padding:13px 18px; border-bottom:1px solid color-mix(in oklch, var(--cream) 10%, transparent)}
.mnav-bas .brand-wm, .mnav-bas .brand-wm b{color:#fff}
.mnav-kapat{display:grid; place-items:center; width:38px; height:38px; flex:none; border:0; cursor:pointer;
  border-radius:9px; background:color-mix(in oklch, var(--cream) 8%, transparent); color:var(--cream);
  transition:background .18s var(--exp)}
.mnav-kapat:hover{background:color-mix(in oklch, var(--cream) 16%, transparent)}
.mnav-kapat svg{width:19px; height:19px}
.mnav-icerik{flex:1 1 auto; padding:8px 12px}
.mnav-grup{border-bottom:1px solid color-mix(in oklch, var(--cream) 8%, transparent)}
.mnav-grup > summary{list-style:none; cursor:pointer; display:flex; align-items:center; gap:8px;
  padding:15px 10px; font-family:"Libre Franklin",sans-serif; font-weight:700; font-size:1.02rem; color:#fff}
.mnav-grup > summary::-webkit-details-marker{display:none}
.mnav-grup > summary .nav-chev{margin-left:auto; width:16px; height:16px; opacity:.65; transition:transform .25s var(--exp)}
.mnav-grup[open] > summary .nav-chev{transform:rotate(180deg)}
.mnav-alt{display:flex; flex-direction:column; padding:0 0 10px}
.mnav-alt a{display:flex; align-items:center; gap:12px; padding:10px; border-radius:9px;
  color:var(--on-dark); font-size:.95rem; transition:background .15s var(--exp), color .15s var(--exp)}
.mnav-alt a:hover, .mnav-alt a:active{background:color-mix(in oklch, var(--cream) 7%, transparent); color:#fff}
.mnav-ic{flex:none; width:34px; height:34px; border-radius:9px; display:grid; place-items:center;
  background:color-mix(in oklch, var(--cream) 8%, transparent); color:oklch(0.8 0.12 42)}
.mnav-ic svg{width:18px; height:18px}
.mnav-link{display:flex; align-items:center; padding:16px 10px; font-family:"Libre Franklin",sans-serif;
  font-weight:700; font-size:1.02rem; color:#fff;
  border-bottom:1px solid color-mix(in oklch, var(--cream) 8%, transparent)}
.mnav-link:last-child{border-bottom:0}
.mnav-link:hover, .mnav-link:active{color:oklch(0.82 0.12 42)}
.mnav-foot{display:flex; flex-direction:column; gap:9px; flex:none; padding:16px 18px 22px;
  border-top:1px solid color-mix(in oklch, var(--cream) 10%, transparent)}
.mnav-foot .btn{width:100%; padding:.82rem 1.2rem}
.mnav-foot .btn.ghost{color:#fff; border-color:color-mix(in oklch, var(--cream) 26%, transparent)}
.mnav-foot-link{display:flex; align-items:center; gap:11px; padding:11px 4px;
  color:var(--cream); font-weight:600; font-size:.98rem}
.mnav-foot-link svg{width:18px; height:18px; color:oklch(0.8 0.12 42)}
.mnav-foot-link:hover{color:oklch(0.82 0.12 42)}
.mnav-cikis{margin-top:4px; color:#ff9b86 !important; border-color:color-mix(in oklch,#ff9b86 36%,transparent) !important}

@media (max-width:920px){
  .nav-burger{display:inline-flex}
  /* login + hesap menusu cekmeceye tasinir; ust-bar sade kalir (logo + zil + hamburger) */
  .nav-cta .login, .nav-cta .acc-item{display:none}
  .nav-cta{gap:4px}
}
@media (min-width:921px){ .mnav{display:none} }   /* masaustunde DOM disi */
@media (prefers-reduced-motion:reduce){ .mnav-ortu, .mnav-panel{transition:none} }

/* ====================================================================
   MOBIL DENEYIM CILASI (kapsamli) — <=680px ve <=430px
   Masaustu tasarim mobilde "alt alta dizilmis" kaliyordu. Bu blok mobile
   ozel: (1) dikey ritim, (2) baslik/metin oranlari, (3) tasan-kirpik metni
   keser (bolum overflow:hidden ile yarim kalmasin), (4) tam-genislik buton +
   rahat dokunma, (5) sikisik bilesenleri ferahlatir.
   ==================================================================== */
@media (max-width:680px){
  /* 1) Dikey ritim — bolum bosluklari mobile gore kisalir (dev bosluk hissi gider) */
  .feat{padding-block:clamp(42px,7vh,60px)}
  .mods{padding-block:clamp(42px,7vh,60px)}
  .cta{padding-block:clamp(46px,8vh,66px)}
  .section{padding-block:clamp(38px,6vh,58px)}
  .arch .wrap{padding-block:clamp(46px,8vh,66px)}
  .hero{padding-top:clamp(90px,16vh,118px); padding-bottom:clamp(30px,5vh,46px)}
  .feat-grid,.hero-grid,.arch-grid{gap:24px}
  .feat .flist{margin-top:18px}

  /* 2) Baslik/metin oranlari — asiri buyuk minimumlar mobile iner, daha dengeli */
  .hero .cs-title{font-size:clamp(1.95rem,8.4vw,2.5rem); line-height:1.12}
  .hero-sub{font-size:1.02rem; max-width:none}
  .feat h2{font-size:clamp(1.55rem,6.6vw,2rem)}
  .feat p{font-size:1rem; max-width:none}
  .mods h2{font-size:clamp(1.6rem,6.8vw,2.05rem)}
  .mods-head h2{font-size:clamp(1.7rem,7vw,2.2rem)}
  .mods-head>p{font-size:1rem; max-width:none}
  .arch h2{font-size:clamp(1.6rem,6.6vw,2.05rem); max-width:none}
  .cta h2{font-size:clamp(1.7rem,7vw,2.25rem); max-width:none}
  .cta p{max-width:none}
  .section-head h2{font-size:clamp(1.55rem,6.4vw,2rem)}
  .ex-h{font-size:clamp(1.4rem,6vw,1.8rem)}
  .page-hero h1,.hero-sp h1{font-size:clamp(1.9rem,8vw,2.5rem)}

  /* 3) Uzun kelime/metin tasmasini KES — bolum overflow:hidden icinde yarim kalmasin */
  .uyum p,.feat p,.mods .head p,.mods-head>p,.hero-sub,.lead,.ex-lead,.cta p,
  .section-head p,.ex-benefits li span,.flist span,.flist b,.cell p,.cell h3,
  .card p,.step p{overflow-wrap:anywhere}
  .uyum{max-width:none}

  /* 4) Butonlar tam-genislik + rahat dokunma (44px+) */
  .hero-actions,.cta .row{flex-direction:column; align-items:stretch}
  .hero-actions .btn,.cta .row>.btn{width:100%; justify-content:center}
  .btn.lg{padding:.95rem 1.35rem; font-size:1rem}

  /* 5) Sikisik bilesenler ferahlar + modul karti TASMASI giderilir
     (1fr grid/flex ogeleri icerige gore sismesin -> min-width:0; istatistik grid'i kuculsun -> minmax(0,1fr)) */
  .explorer,.ex-stage,.ex-panel,.ex-card,.ex-card-l,.ex-card-r,.ex-prev{min-width:0}
  .ex-card{padding:20px}
  .ex-stats{grid-template-columns:repeat(3,minmax(0,1fr)); gap:6px}
  .ex-stat{padding:9px 8px; min-width:0}
  .ex-stat b{font-size:.96rem}
  .matrix .cell{padding:20px}
  /* ekran goruntusu cercevesi: mobilde "buyutmek icin dokun" ipucu */
  .shot .frame{position:relative}
  .shot .frame::after{content:"Büyütmek için dokunun"; position:absolute; right:8px; bottom:8px; z-index:2;
    font-family:"Hanken Grotesk",sans-serif; font-size:.7rem; font-weight:600; color:#fff; pointer-events:none;
    background:oklch(0.25 0.03 262 / .72); padding:4px 9px; border-radius:7px; -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px)}
}
@media (max-width:430px){
  .wrap{padding-inline:18px}
  .hero .cs-title{font-size:clamp(1.8rem,8.2vw,2.2rem)}
  .hero-actions{margin-top:24px}
}

/* ====================================================================
   MOBIL ANA SAYFA KURGUSU (<=680px) — "masaustu dizilmis" degil, mobile ozel.
   Header/menu AYNI; govde icerigi cep icin yeniden kurgulanir.
   Ortak yardimci: .yalniz-mobil (cepte gorunur) / .yalniz-masaustu (cepte gizli).
   ==================================================================== */
.yalniz-mobil{display:none}
.k-ic{display:none}   /* deger serisi ikonu yalniz mobil kartta gorunur */
@media (max-width:680px){
  .yalniz-masaustu{display:none !important}
  .yalniz-mobil{display:block}

  /* --- HERO: yogun masaustu urun ekranini KALDIR; sade, net, metin+CTA odakli --- */
  .hero-media{display:none}
  .hero{padding-top:clamp(94px,16vh,118px); padding-bottom:clamp(34px,6vh,50px)}
  .hero-grid{display:block}
  .cslider{min-height:0; margin-bottom:4px}
  .cslide{position:relative; inset:auto}            /* tek slayt akista; mutlak konum kalksin */
  .cslide:not(.active){display:none}                /* sadece aktif slayt yer kaplasin (ziplama yok) */
  .hero-dots{margin-top:22px}
  .trust{flex-direction:column; gap:11px; margin-top:24px}
  .trust span{font-size:.92rem}

  /* --- DEGER SERIDI: sitenin masaustu dili (bg-2 panel + guclu rakam) -> mobilde 2x2 hairline stat izgarasi.
     Panel arka plani + ust/alt cizgi KORUNUR (base .strip); ic hairline'lar hucreleri ayirir. --- */
  .strip:not(.strip-feat) .strip-in{display:grid; grid-template-columns:1fr 1fr; gap:0; padding:0; max-width:none}
  .strip:not(.strip-feat) .strip-in > div{min-width:0; padding:22px 18px;
    border-bottom:1px solid var(--line); border-right:1px solid var(--line)}
  .strip:not(.strip-feat) .strip-in > div:nth-child(2n){border-right:0}
  .strip:not(.strip-feat) .strip-in > div:nth-last-child(-n+2){border-bottom:0}
  .strip:not(.strip-feat) .k-ic{display:none}
  .strip:not(.strip-feat) .strip-in .k{display:block; font-family:"Libre Franklin",sans-serif;
    font-weight:800; font-size:1.16rem; letter-spacing:-.01em; line-height:1.2; color:var(--ink)}
  .strip:not(.strip-feat) .strip-in .l{display:block; font-size:.83rem; color:var(--ink-2); margin-top:6px; line-height:1.45}

  /* --- OZELLIK BOLUMLERI: okunaksiz ekrani KALDIR; metni temiz karta al --- */
  .feat .shot{display:none}
  .feat-grid{display:block}
  /* ozellik blogu: kutu/golge degil — ust mercan ince cizgi + ferah bosluk (editoryel) */
  .feat .feat-grid > div[data-reveal]{background:transparent; border:0; border-top:2px solid var(--coral);
    border-radius:0; padding:22px 0 0; box-shadow:none}
  .feat .feat-grid > div[data-reveal] > .eg{display:block}
  .feat h2{margin-top:10px}
  .feat p{margin-top:12px}
  .feat{padding-block:clamp(34px,6vh,52px)}

  /* --- MODULLER: editoryel/tipografik liste (ikon-rozet YOK, ince ayrac + ince ok) --- */
  .mod-mobil{display:block}
  .mod-mobil-kart{display:grid; grid-template-columns:1fr auto; align-items:center; gap:12px;
    padding:16px 2px; border-top:1px solid var(--line-2); background:transparent}
  .mod-mobil-kart:first-child{border-top:0}
  .mod-mobil-ic{display:none}
  .mod-mobil-tx{display:flex; flex-direction:column; gap:3px; min-width:0}
  .mod-mobil-tx b{font-family:"Libre Franklin",sans-serif; font-weight:800; font-size:1.05rem; color:var(--ink); letter-spacing:-.01em}
  .mod-mobil-tx span{font-size:.88rem; color:var(--ink-2); line-height:1.45}
  .mod-mobil-ok{flex:none; width:17px; height:17px; color:var(--ink-2); opacity:.4}
  .mod-mobil-kart:active .mod-mobil-tx b{color:var(--coral-deep)}
  .mods-head{margin-bottom:18px}

  /* --- MIMARI (koyu) + CTA: ferah ve hizali --- */
  .pillars{margin-top:28px; padding-top:24px}
  .arch h2{max-width:none}
}
