/* ============================================================
   Blue Network ® — Sahne & animasyon bileşenleri
   (style.css'ten sonra yüklenir, üzerine yazar)
   ============================================================ */

/* Sol alt bölge HUD'unu kaldır */
.zone-hud { display: none !important; }

/* ---------- Logo (bluenetwork.svg) header & footer ---------- */
.nav .logo img { height: 30px; width: auto; }
.footer-brand img { height: 44px; width: auto; }

/* ---------- Siber Güvenlik kart ikonu ---------- */
.cico--cyber::before {
  content: ""; position: absolute; left: 50%; top: 12px; transform: translateX(-50%);
  width: 30px; height: 34px; border: 2px solid var(--cyan); border-radius: 8px 8px 16px 16px;
  background: var(--grad-soft);
}
.cico--cyber::after {
  content: ""; position: absolute; left: 50%; top: 17px; transform: translateX(-50%);
  width: 12px; height: 8px; border: 2.5px solid var(--cyan); border-top: 0; border-right: 0;
  transform: translateX(-50%) rotate(-45deg); transform-origin: center;
  animation: cyberCheck 2.4s ease-in-out infinite;
}
@keyframes cyberCheck { 0%,40% { opacity: 0; transform: translateX(-50%) rotate(-45deg) scale(.4); } 55%,100% { opacity: 1; transform: translateX(-50%) rotate(-45deg) scale(1); } }

/* ---------- Siber Güvenlik detay sahnesi (.scy) ---------- */
.scy { position: absolute; inset: 0; overflow: hidden; }
.scy__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(47,230,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(47,230,255,.05) 1px, transparent 1px); background-size: 26px 26px; mask-image: radial-gradient(circle at 50% 50%, #000, transparent 78%); }
.scy__shield { position: absolute; top: 50%; left: 50%; width: 120px; height: 134px; transform: translate(-50%,-50%); }
.scy__shield::before { content: ""; position: absolute; inset: 0; border: 2px solid var(--cyan); border-radius: 22px 22px 60px 60px / 22px 22px 90px 90px; background: radial-gradient(circle at 50% 35%, rgba(47,230,255,.2), transparent 65%); box-shadow: 0 0 30px rgba(47,230,255,.3); }
.scy__shield::after { content: ""; position: absolute; left: 50%; top: 44%; width: 26px; height: 16px; border: 4px solid var(--cyan); border-top: 0; border-right: 0; transform: translate(-50%,-50%) rotate(-45deg); animation: cyberCheck 3s ease-in-out infinite; }
.scy__ring { position: absolute; top: 50%; left: 50%; border-radius: 50%; border: 1px dashed var(--stroke-strong); transform: translate(-50%,-50%); }
.scy__ring.a { width: 230px; height: 230px; animation: spin360 16s linear infinite; }
.scy__ring.b { width: 310px; height: 310px; border-color: rgba(47,230,255,.25); animation: spin360 26s linear infinite reverse; }
.scy__sweep { position: absolute; top: 50%; left: 50%; width: 150px; height: 4px; transform-origin: left center; background: linear-gradient(90deg, rgba(47,230,255,.6), transparent); animation: spin360 3.4s linear infinite; }
.scy__threat { position: absolute; width: 9px; height: 9px; border-radius: 50%; background: #ff3b5c; box-shadow: 0 0 8px #ff3b5c; animation: threatBlock 3.6s ease-in-out infinite; }
.scy__threat.t1 { top: 22%; left: 18%; } .scy__threat.t2 { top: 70%; left: 24%; animation-delay: 1.2s; } .scy__threat.t3 { top: 30%; right: 16%; animation-delay: 2.2s; } .scy__threat.t4 { bottom: 18%; right: 22%; animation-delay: .6s; }
@keyframes threatBlock { 0%,50% { background: #ff3b5c; box-shadow: 0 0 8px #ff3b5c; transform: scale(1); } 65%,100% { background: #4ade80; box-shadow: 0 0 8px #4ade80; transform: scale(.7); } }

/* ---------- Blue Network hakkında kartı ---------- */
.about-sec { padding: 70px 0 30px; }
.about-card {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 0;
  border: 1px solid var(--stroke-strong);
  border-radius: 26px;
  overflow: hidden;
  background: rgba(8, 12, 26, 0.72);
  backdrop-filter: blur(16px);
  box-shadow: 0 40px 90px rgba(0, 0, 0, 0.5);
}
.about-card__media {
  position: relative;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 26px;
  padding: 44px;
  background:
    radial-gradient(circle at 50% 40%, rgba(20,143,206,.22), transparent 65%),
    linear-gradient(160deg, rgba(47,230,255,.08), rgba(99,102,241,.1));
  border-right: 1px solid var(--stroke);
}
.about-card__media img { width: 76%; max-width: 260px; filter: drop-shadow(0 0 26px rgba(47,230,255,.35)); }
.about-card__badges { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.about-card__badges span { font-size: 12.5px; padding: 6px 13px; border-radius: 100px; border: 1px solid var(--stroke-strong); color: var(--muted); background: rgba(255,255,255,.03); }
.about-card__body { padding: 46px 44px; }
.about-card__body h2 { font-size: clamp(26px, 3.2vw, 38px); line-height: 1.12; margin: 14px 0 16px; letter-spacing: -.5px; }
.about-card__body > p { color: var(--muted); font-size: 15.5px; margin-bottom: 14px; }
.about-stats { display: flex; gap: 30px; margin: 22px 0 26px; flex-wrap: wrap; }
.about-stats strong { font-size: 32px; background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; display: block; }
.about-stats span { font-size: 13px; color: var(--muted); }
.about-actions { display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 860px) {
  .about-card { grid-template-columns: 1fr; }
  .about-card__media { border-right: 0; border-bottom: 1px solid var(--stroke); padding: 36px; }
  .about-card__body { padding: 34px 26px; }
}

/* ---------- 10 Oda bölümü (alt alta açıklamalı kartlar) ---------- */
.rooms-intro { text-align: center; padding: 70px 0 10px; }
.room-sec {
  min-height: 86vh;
  display: flex;
  align-items: center;
  position: relative;
}
.room-sec .container { width: 100%; }
.room-card {
  max-width: 480px;
  padding: 38px;
  border-radius: 22px;
  border: 1px solid var(--stroke-strong);
  background: rgba(8, 12, 26, 0.72);
  backdrop-filter: blur(14px);
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.5);
}
.room-sec:nth-child(even) .room-card { margin-left: auto; }
.room-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: "JetBrains Mono", monospace; font-size: 12.5px; letter-spacing: 1.5px;
  color: var(--room-c, var(--cyan)); padding: 7px 14px; border-radius: 100px;
  border: 1px solid color-mix(in srgb, var(--room-c, var(--cyan)) 45%, transparent);
  background: color-mix(in srgb, var(--room-c, var(--cyan)) 12%, transparent);
  margin-bottom: 18px;
}
.room-tag::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--room-c, var(--cyan)); box-shadow: 0 0 10px var(--room-c, var(--cyan)); }
.room-card h2 { font-size: clamp(26px, 3.4vw, 38px); line-height: 1.1; margin-bottom: 12px; letter-spacing: -.5px; }
.room-card > p { color: var(--muted); font-size: 16px; margin-bottom: 20px; }
.room-list { display: grid; gap: 11px; margin-bottom: 26px; }
.room-list li { display: flex; gap: 12px; align-items: flex-start; font-size: 15px; color: var(--text); }
.room-list li::before {
  content: ""; flex-shrink: 0; width: 18px; height: 18px; margin-top: 2px; border-radius: 6px;
  background: color-mix(in srgb, var(--room-c, var(--cyan)) 22%, transparent);
  border: 1px solid var(--room-c, var(--cyan));
  background-image: linear-gradient(135deg, transparent 45%, var(--room-c, var(--cyan)) 45%, var(--room-c, var(--cyan)) 55%, transparent 55%);
}
.room-card .btn { background: var(--room-c, var(--cyan)); color: #04101f; }
.room-progress {
  position: fixed; top: 50%; right: 22px; transform: translateY(-50%);
  display: flex; flex-direction: column; gap: 10px; z-index: 30;
}
.room-progress button {
  width: 11px; height: 11px; border-radius: 50%; border: 1px solid var(--stroke-strong);
  background: transparent; cursor: pointer; padding: 0; transition: .25s; position: relative;
}
.room-progress button.active { background: var(--cyan); border-color: var(--cyan); box-shadow: 0 0 10px var(--cyan); transform: scale(1.3); }
.room-progress button:hover::after {
  content: attr(data-label); position: absolute; right: 22px; top: 50%; transform: translateY(-50%);
  white-space: nowrap; font-size: 12px; font-family: "JetBrains Mono", monospace; color: var(--text);
  background: rgba(8,12,26,.9); border: 1px solid var(--stroke); padding: 5px 10px; border-radius: 8px;
}
@media (max-width: 920px) {
  .room-progress { display: none; }
  .room-sec { min-height: auto; padding: 50px 0; }
  .room-sec:nth-child(even) .room-card { margin-left: 0; }
  .room-card { max-width: 100%; }
}

/* ---------- İletişim sayfası animasyonları ---------- */
.contact-aurora { position: fixed; inset: 0; z-index: -1; overflow: hidden; pointer-events: none; }
.contact-aurora span { position: absolute; border-radius: 50%; filter: blur(80px); }
.contact-aurora span:nth-child(1) { width: 460px; height: 460px; background: rgba(47,230,255,.32); top: -140px; left: -90px; animation: caFloat 15s ease-in-out infinite; }
.contact-aurora span:nth-child(2) { width: 520px; height: 520px; background: rgba(99,102,241,.3); bottom: -180px; right: -120px; animation: caFloat 19s ease-in-out infinite reverse; }
.contact-aurora span:nth-child(3) { width: 380px; height: 380px; background: rgba(244,114,182,.2); top: 42%; left: 52%; animation: caFloat 17s ease-in-out infinite; }
@keyframes caFloat { 0%,100% { transform: translate(0,0) scale(1); } 33% { transform: translate(70px,-46px) scale(1.12); } 66% { transform: translate(-46px,56px) scale(.94); } }

.contact-hero h1 { animation: heroGlow 3.2s ease-in-out infinite alternate; }
@keyframes heroGlow { from { text-shadow: 0 0 0 transparent; } to { text-shadow: 0 0 26px rgba(47,230,255,.3); } }

.contact-info .ci { transition: transform .3s, border-color .3s, background .3s; }
.contact-info .ci:hover { transform: translateY(-4px) translateX(4px); border-color: var(--cyan); background: var(--grad-soft); }
.contact-info .ci-ico { position: relative; }
.contact-info .ci-ico::after { content: ""; position: absolute; inset: -5px; border-radius: 14px; border: 1.5px solid var(--cyan); opacity: 0; animation: ciPulse 2.6s ease-out infinite; }
.contact-info .ci:nth-child(2) .ci-ico::after { animation-delay: .65s; }
.contact-info .ci:nth-child(3) .ci-ico::after { animation-delay: 1.3s; }
.contact-info .ci:nth-child(4) .ci-ico::after { animation-delay: 1.95s; }
@keyframes ciPulse { 0% { transform: scale(.85); opacity: .7; } 100% { transform: scale(1.55); opacity: 0; } }

.contact-form-card { position: relative; overflow: hidden; }
.contact-form-card::before { content: ""; position: absolute; top: 0; left: -35%; width: 35%; height: 3px; background: linear-gradient(90deg, transparent, var(--cyan), transparent); animation: cfSweep 4.5s linear infinite; }
@keyframes cfSweep { 0% { left: -35%; } 100% { left: 100%; } }
.contact-form-card .field input, .contact-form-card .field textarea, .contact-form-card .field select { transition: border-color .25s, box-shadow .25s, transform .25s; }
.contact-form-card .field input:focus, .contact-form-card .field textarea:focus, .contact-form-card .field select:focus { transform: translateY(-1px); }

/* ---------- Footer slogan ---------- */
.footer-brand .footer-slogan {
  font-size: 14.5px; font-weight: 600; line-height: 1.3; white-space: nowrap;
  color: var(--text); margin-top: 8px; letter-spacing: -.2px;
}
.footer-brand .footer-slogan::after { content: ""; display: block; width: 42px; height: 3px; border-radius: 3px; background: var(--grad); margin-top: 12px; }
@media (max-width: 420px) { .footer-brand .footer-slogan { white-space: normal; } }

/* ---------- Footer social (SVG ikon, çerçevesiz) ---------- */
.footer-social { display: flex; gap: 14px; margin-top: 14px; }
.footer-social a {
  width: auto !important; height: auto !important;
  border: 0 !important; background: none !important; border-radius: 0 !important;
  padding: 2px; color: var(--muted); display: inline-flex;
}
.footer-social a::before { display: none !important; }
.footer-social a svg { position: relative; z-index: 1; width: 24px; height: 24px; display: block; transition: transform .3s; }
.footer-social a:hover { color: var(--cyan); transform: none; }
.footer-social a:hover svg { color: var(--cyan); transform: translateY(-3px) scale(1.08); }

/* ---------- Oda HUD: sadece odalar (1-11) görünürken aktif, sonra freeze/gizli ---------- */
.room-progress { opacity: 0; visibility: hidden; transition: opacity .45s ease, visibility .45s ease; }
.room-progress.show { opacity: 1; visibility: visible; }

/* ---------- Global animasyonlu arka plan ---------- */
body::before { animation: bgFloatA 26s ease-in-out infinite; }
body::after { animation: bgFloatB 34s linear infinite; }
@keyframes bgFloatA { 0%,100% { transform: translate3d(0,0,0) scale(1); } 50% { transform: translate3d(-2%,2.5%,0) scale(1.05); } }
@keyframes bgFloatB { 0% { background-position: 0 0; } 100% { background-position: 56px 56px; } }
/* Yüzen ışık zerrecikleri (sayfa geneli, hafif) */
.bg-orbs { position: fixed; inset: 0; z-index: -1; overflow: hidden; pointer-events: none; }
.bg-orbs span { position: absolute; border-radius: 50%; filter: blur(70px); opacity: .22; }
.bg-orbs span:nth-child(1) { width: 360px; height: 360px; background: #2fe6ff; top: -120px; left: -60px; animation: orbDrift 22s ease-in-out infinite; }
.bg-orbs span:nth-child(2) { width: 420px; height: 420px; background: #6366f1; bottom: -160px; right: -80px; animation: orbDrift 28s ease-in-out infinite reverse; }
@keyframes orbDrift { 0%,100% { transform: translate(0,0); } 50% { transform: translate(60px,-40px); } }

/* ---------- Marka belgesi — büyütme (lightbox) ---------- */
.belge-trigger { display: block; width: 100%; border: 0; padding: 0; background: none; cursor: zoom-in; position: relative; border-radius: 12px; overflow: hidden; }
.belge-trigger img { width: 100%; display: block; border-radius: 12px; transition: transform .4s; }
.belge-trigger:hover img { transform: scale(1.03); }
.belge-zoom { position: absolute; right: 12px; bottom: 12px; padding: 7px 13px; border-radius: 100px; background: rgba(8,12,26,.82); border: 1px solid var(--stroke-strong); color: var(--cyan); font-size: 13px; backdrop-filter: blur(6px); opacity: 0; transform: translateY(6px); transition: .3s; pointer-events: none; }
.belge-trigger:hover .belge-zoom { opacity: 1; transform: translateY(0); }
.img-lightbox { position: fixed; inset: 0; z-index: 200; background: rgba(3,6,15,.92); backdrop-filter: blur(8px); display: flex; align-items: center; justify-content: center; padding: 40px; opacity: 0; visibility: hidden; transition: opacity .3s, visibility .3s; }
.img-lightbox.open { opacity: 1; visibility: visible; }
.img-lightbox img { max-width: 92%; max-height: 90vh; border-radius: 12px; border: 1px solid var(--stroke-strong); box-shadow: 0 30px 80px rgba(0,0,0,.6); transform: scale(.92); transition: transform .35s; }
.img-lightbox.open img { transform: scale(1); }
.img-lightbox__close { position: absolute; top: 24px; right: 30px; width: 46px; height: 46px; border-radius: 12px; border: 1px solid var(--stroke-strong); background: rgba(8,12,26,.7); color: var(--text); font-size: 26px; cursor: pointer; transition: .25s; }
.img-lightbox__close:hover { border-color: var(--cyan); color: var(--cyan); }

/* ---------- İletişim formu — sade buton ---------- */
.btn-send {
  display: inline-flex; align-items: center; gap: 9px;
  width: 100%; justify-content: center;
  padding: 15px 26px; margin-top: 6px;
  border: 0; border-radius: 14px; cursor: pointer;
  font-family: var(--font); font-weight: 600; font-size: 15.5px;
  color: #04101f; background: var(--cyan);
  transition: background .25s, transform .25s, box-shadow .25s;
}
.btn-send:hover { background: #66f0ff; transform: translateY(-2px); box-shadow: 0 14px 30px rgba(47,230,255,.3); }
.btn-send:disabled { opacity: .7; cursor: default; transform: none; }
.btn-send .arrow { transition: transform .25s; }
.btn-send:hover .arrow { transform: translateX(4px); }
.form-note { margin-top: 14px; color: #4ade80; font-size: 14px; }
.contact-form-card .field label { font-size: 13px; letter-spacing: .3px; text-transform: uppercase; color: var(--muted-2); }
.contact-form-card .field input, .contact-form-card .field textarea, .contact-form-card .field select { border-radius: 12px; }

/* ============================================================
   iPhone 17 Pro Max görünümlü mobil sahne (.iphone)
   ============================================================ */
.iphone { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); height: 88%; aspect-ratio: 9 / 19.5; border-radius: 44px; padding: 7px; background: linear-gradient(150deg, #3a4150, #0c1018); box-shadow: 0 30px 70px rgba(0,0,0,.6), inset 0 0 0 1.5px rgba(255,255,255,.1); animation: ipFloat 6s ease-in-out infinite; }
@keyframes ipFloat { 0%,100% { transform: translate(-50%,-50%); } 50% { transform: translate(-50%,-54%); } }
.iphone__screen { position: relative; width: 100%; height: 100%; border-radius: 38px; overflow: hidden; background: #070d1c; }
.iphone__island { position: absolute; top: 11px; left: 50%; transform: translateX(-50%); width: 36%; height: 19px; border-radius: 12px; background: #000; z-index: 6; }
.iphone__island::after { content: ""; position: absolute; right: 9px; top: 50%; transform: translateY(-50%); width: 7px; height: 7px; border-radius: 50%; background: #16324a; }
.iphone__status { position: absolute; top: 13px; left: 18px; font: 700 11px sans-serif; color: #cbd5e1; z-index: 4; }
.iphone__status::after { content: ""; position: absolute; right: -150px; top: 1px; width: 16px; height: 9px; border: 1.5px solid #cbd5e1; border-radius: 3px; }
.iphone__app { position: absolute; inset: 44px 16px 78px; }
.iphone__hero { height: 30%; border-radius: 18px; background: linear-gradient(150deg, #1f6dff, #6366f1); position: relative; overflow: hidden; }
.iphone__hero::before { content: ""; position: absolute; left: 16px; top: 18px; width: 60%; height: 12px; border-radius: 6px; background: rgba(255,255,255,.85); box-shadow: 0 22px 0 rgba(255,255,255,.5); }
.iphone__hero::after { content: ""; position: absolute; left: 16px; bottom: 16px; width: 42%; height: 22px; border-radius: 11px; background: rgba(255,255,255,.9); }
.iphone__cards { display: flex; gap: 11px; margin-top: 14px; }
.iphone__cards i { flex: 1; height: 72px; border-radius: 16px; background: #101a32; position: relative; }
.iphone__cards i::before { content: ""; position: absolute; top: 14px; left: 14px; width: 28px; height: 28px; border-radius: 9px; }
.iphone__cards i:nth-child(1)::before { background: #2fe6ff; } .iphone__cards i:nth-child(2)::before { background: #4ade80; }
.iphone__cards i::after { content: ""; position: absolute; left: 14px; bottom: 14px; right: 14px; height: 8px; border-radius: 4px; background: #24304f; }
.iphone__rows { margin-top: 14px; }
.iphone__rows i { display: block; height: 38px; border-radius: 12px; background: #101a32; margin-bottom: 9px; position: relative; }
.iphone__rows i::before { content: ""; position: absolute; left: 12px; top: 50%; transform: translateY(-50%); width: 22px; height: 22px; border-radius: 50%; background: #1f2b48; }
.iphone__notif { position: absolute; top: 46px; left: 16px; right: 16px; height: 50px; border-radius: 16px; background: rgba(18,28,52,.97); border: 1px solid var(--stroke-strong); z-index: 7; box-shadow: 0 10px 24px rgba(0,0,0,.4); animation: ipNotif 5.5s ease-in-out infinite; }
.iphone__notif::before { content: ""; position: absolute; left: 12px; top: 50%; transform: translateY(-50%); width: 26px; height: 26px; border-radius: 8px; background: var(--grad); }
.iphone__notif::after { content: ""; position: absolute; left: 50px; right: 14px; top: 14px; height: 8px; border-radius: 4px; background: rgba(255,255,255,.45); box-shadow: 0 16px 0 rgba(255,255,255,.25); }
@keyframes ipNotif { 0%,60% { transform: translateY(-72px); opacity: 0; } 70%,90% { transform: translateY(0); opacity: 1; } 100% { transform: translateY(-72px); opacity: 0; } }
.iphone__tab { position: absolute; bottom: 14px; left: 16px; right: 16px; height: 52px; border-radius: 20px; background: #0b1326; border: 1px solid var(--stroke); display: flex; align-items: center; justify-content: space-around; z-index: 4; }
.iphone__tab b { width: 24px; height: 24px; border-radius: 8px; background: #2a3650; animation: ipTab 6s infinite; }
.iphone__tab b:nth-child(2) { animation-delay: 1.5s; } .iphone__tab b:nth-child(3) { animation-delay: 3s; } .iphone__tab b:nth-child(4) { animation-delay: 4.5s; }
@keyframes ipTab { 0%,16% { background: var(--cyan); box-shadow: 0 0 12px rgba(47,230,255,.6); } 24%,100% { background: #2a3650; box-shadow: none; } }

/* ============================================================
   Siber Güvenlik (.cyberfw) — firewall paket engelleme
   ============================================================ */
.cyberfw { position: absolute; inset: 0; overflow: hidden; }
.cyberfw__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(47,230,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(47,230,255,.05) 1px, transparent 1px); background-size: 30px 30px; mask-image: radial-gradient(circle at 50% 50%, #000, transparent 85%); }
.cyberfw__wall { position: absolute; top: 14%; bottom: 14%; left: 50%; transform: translateX(-50%); width: 6px; border-radius: 6px; background: linear-gradient(180deg, #2fe6ff, #6366f1); box-shadow: 0 0 24px rgba(47,230,255,.55); }
.cyberfw__wall::before, .cyberfw__wall::after { content: ""; position: absolute; left: 50%; transform: translateX(-50%); width: 22px; height: 2px; background: rgba(47,230,255,.4); }
.cyberfw__wall::before { top: 30%; } .cyberfw__wall::after { bottom: 30%; }
.cyberfw__shield { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 66px; height: 74px; z-index: 4; }
.cyberfw__shield::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 50% 35%, rgba(47,230,255,.28), rgba(8,14,30,.9) 70%); border: 2px solid #2fe6ff; border-radius: 16px 16px 50px 50px / 16px 16px 80px 80px; box-shadow: 0 0 28px rgba(47,230,255,.4); }
.cyberfw__shield::after { content: ""; position: absolute; left: 50%; top: 42%; width: 22px; height: 13px; border: 3.5px solid #4ade80; border-top: 0; border-right: 0; transform: translate(-50%,-50%) rotate(-45deg); animation: cyberCheck 2.6s ease-in-out infinite; }
.cyberfw__pkt { position: absolute; width: 11px; height: 11px; border-radius: 50%; background: #ff3b5c; box-shadow: 0 0 9px #ff3b5c; left: -8%; animation: pktFly 2.6s linear infinite; }
.cyberfw__pkt.p1 { top: 26%; } .cyberfw__pkt.p2 { top: 42%; animation-delay: .5s; } .cyberfw__pkt.p3 { top: 58%; animation-delay: 1s; } .cyberfw__pkt.p4 { top: 72%; animation-delay: 1.5s; } .cyberfw__pkt.p5 { top: 34%; animation-delay: 2s; }
@keyframes pktFly { 0% { left: -8%; opacity: 0; background: #ff3b5c; box-shadow: 0 0 9px #ff3b5c; } 10% { opacity: 1; } 44% { left: 44%; background: #ff3b5c; } 50% { left: 47%; background: #4ade80; box-shadow: 0 0 16px #4ade80; transform: scale(1.5); } 56% { left: 47%; opacity: 0; transform: scale(.4); } 100% { left: 47%; opacity: 0; } }
.cyberfw__lock { position: absolute; right: 12%; width: 26px; height: 22px; border-radius: 4px; background: rgba(74,222,128,.18); border: 2px solid #4ade80; }
.cyberfw__lock::before { content: ""; position: absolute; left: 50%; top: -10px; transform: translateX(-50%); width: 14px; height: 14px; border: 2px solid #4ade80; border-bottom: 0; border-radius: 7px 7px 0 0; }
.cyberfw__lock.l1 { top: 30%; animation: floatY 3s ease-in-out infinite; } .cyberfw__lock.l2 { top: 56%; animation: floatY 3.4s ease-in-out infinite .5s; }

/* ============================================================
   Akıllı Ev (.shome) — kapsamlı otomasyon sahnesi
   ============================================================ */
.shome { position: absolute; inset: 0; overflow: hidden; }
.shome__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(56,189,248,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(56,189,248,.05) 1px, transparent 1px); background-size: 30px 30px; mask-image: radial-gradient(circle at 50% 60%, #000, transparent 85%); }
.shome__house { position: absolute; left: 50%; top: 52%; transform: translate(-50%,-50%); width: 180px; height: 130px; }
.shome__roof { position: absolute; top: -2px; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-left: 96px solid transparent; border-right: 96px solid transparent; border-bottom: 50px solid rgba(56,189,248,.25); }
.shome__body { position: absolute; bottom: 0; left: 12px; right: 12px; height: 82px; border: 1px solid #38bdf8; border-radius: 5px; background: rgba(6,12,26,.7); display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; padding: 10px; }
.shome__body i { border-radius: 5px; background: rgba(255,255,255,.05); animation: winLight 2.8s ease-in-out infinite; }
.shome__body i:nth-child(2){animation-delay:.5s;} .shome__body i:nth-child(3){animation-delay:1s;} .shome__body i:nth-child(4){animation-delay:1.5s;} .shome__body i:nth-child(5){animation-delay:2s;} .shome__body i:nth-child(6){animation-delay:2.5s;}
.shome__wifi { position: absolute; top: -34px; left: 50%; transform: translateX(-50%); width: 60px; height: 60px; }
.shome__wifi span { position: absolute; left: 50%; bottom: 0; transform: translateX(-50%); border: 2px solid #38bdf8; border-bottom: 0; border-radius: 50% 50% 0 0; opacity: 0; animation: wifi 2.4s ease-out infinite; }
.shome__wifi span:nth-child(1){ width: 16px; height: 8px; } .shome__wifi span:nth-child(2){ width: 36px; height: 18px; animation-delay: .3s; } .shome__wifi span:nth-child(3){ width: 56px; height: 28px; animation-delay: .6s; }
.shome__dev { position: absolute; display: flex; align-items: center; gap: 7px; padding: 8px 12px; border-radius: 100px; background: rgba(8,14,30,.85); border: 1px solid var(--stroke-strong); font-family: "JetBrains Mono", monospace; font-size: 12px; color: #cbd5e1; animation: floatY 3.4s ease-in-out infinite; }
.shome__dev b { width: 9px; height: 9px; border-radius: 50%; animation: blink2 1.6s infinite; }
.shome__dev.d1 { top: 16%; left: 8%; } .shome__dev.d1 b { background: #fec02e; box-shadow: 0 0 8px #fec02e; }
.shome__dev.d2 { top: 12%; right: 8%; animation-delay: .6s; } .shome__dev.d2 b { background: #4ade80; box-shadow: 0 0 8px #4ade80; animation-delay: .4s; }
.shome__dev.d3 { bottom: 16%; left: 7%; animation-delay: 1s; } .shome__dev.d3 b { background: #2fe6ff; box-shadow: 0 0 8px #2fe6ff; animation-delay: .8s; }
.shome__dev.d4 { bottom: 12%; right: 7%; animation-delay: 1.4s; } .shome__dev.d4 b { background: #f472b6; box-shadow: 0 0 8px #f472b6; animation-delay: 1.2s; }
.shome__phone { position: absolute; right: 16%; bottom: 18%; width: 42px; height: 84px; border-radius: 10px; border: 2px solid var(--stroke-strong); background: linear-gradient(160deg, rgba(56,189,248,.25), #0a1020); animation: floatY 3.8s ease-in-out infinite; }
.shome__phone::after { content: ""; position: absolute; inset: 8px; border-radius: 5px; background: repeating-linear-gradient(180deg, rgba(56,189,248,.4) 0 4px, transparent 4px 12px); opacity: .6; }

/* ============================================================
   Hakkımızda (.aboutsys) — entegre operasyon panosu
   ============================================================ */
.aboutsys { position: relative; min-height: 380px; border: 1px solid var(--stroke); border-radius: var(--radius-lg); background: radial-gradient(circle at 75% 0%, rgba(47,230,255,.09), transparent 60%), var(--panel); overflow: hidden; padding: 26px 26px 24px; display: flex; flex-direction: column; gap: 20px; }
.aboutsys::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(120,160,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(120,160,255,.05) 1px, transparent 1px); background-size: 30px 30px; -webkit-mask-image: radial-gradient(circle at 65% 25%, #000, transparent 86%); mask-image: radial-gradient(circle at 65% 25%, #000, transparent 86%); pointer-events: none; }
/* başlık */
.aboutsys__head { position: relative; display: flex; align-items: center; gap: 14px; padding-bottom: 18px; border-bottom: 1px solid var(--stroke); animation: abIn .6s ease both; }
.aboutsys__logo { width: 54px; height: 54px; border-radius: 15px; background: var(--grad-soft); border: 1px solid var(--stroke-strong); display: grid; place-items: center; flex-shrink: 0; box-shadow: 0 0 26px rgba(47,230,255,.18); }
.aboutsys__logo img { width: 60%; filter: drop-shadow(0 0 12px rgba(47,230,255,.4)); }
.aboutsys__id b { display: block; font-size: 16px; color: var(--text); }
.aboutsys__id span { font-family: "JetBrains Mono", monospace; font-size: 11.5px; color: var(--muted); }
.aboutsys__live { margin-left: auto; width: 10px; height: 10px; border-radius: 50%; background: #4ade80; box-shadow: 0 0 0 0 rgba(74,222,128,.5); animation: abLive 1.6s ease-in-out infinite; }
@keyframes abLive { 0%, 100% { box-shadow: 0 0 0 0 rgba(74,222,128,.55); } 50% { box-shadow: 0 0 0 6px rgba(74,222,128,0); } }
/* yetenek satırları */
.aboutsys__rows { position: relative; display: flex; flex-direction: column; gap: 15px; }
.aboutsys__row { display: grid; grid-template-columns: 28px 84px 1fr; align-items: center; gap: 12px; opacity: 0; transform: translateX(16px); animation: abRow .55s ease forwards; }
.aboutsys__row:nth-child(1) { animation-delay: .15s; } .aboutsys__row:nth-child(2) { animation-delay: .3s; }
.aboutsys__row:nth-child(3) { animation-delay: .45s; } .aboutsys__row:nth-child(4) { animation-delay: .6s; }
.aboutsys__row .ic { width: 28px; height: 28px; border-radius: 9px; display: grid; place-items: center; font-size: 14px; background: rgba(47,230,255,.1); border: 1px solid var(--stroke-strong); color: var(--cyan); }
.aboutsys__row .lb { font-size: 13.5px; color: #dbe6ff; }
.aboutsys__row .bar { position: relative; height: 8px; border-radius: 100px; background: rgba(120,150,220,.14); overflow: hidden; }
.aboutsys__row .bar b { position: absolute; inset: 0 auto 0 0; width: 0; border-radius: 100px; background: var(--grad); animation: abFill 1.1s cubic-bezier(.3,.1,.2,1) both; }
.aboutsys__row:nth-child(1) .bar b { animation-delay: .4s; } .aboutsys__row:nth-child(2) .bar b { animation-delay: .55s; }
.aboutsys__row:nth-child(3) .bar b { animation-delay: .7s; } .aboutsys__row:nth-child(4) .bar b { animation-delay: .85s; }
.aboutsys__row .bar::after { content: ""; position: absolute; top: 0; left: 0; height: 100%; width: 42px; background: linear-gradient(90deg, transparent, rgba(255,255,255,.28), transparent); animation: abShimmer 2.6s ease-in-out infinite; }
@keyframes abIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@keyframes abRow { to { opacity: 1; transform: none; } }
@keyframes abFill { to { width: var(--w, 90%); } }
@keyframes abShimmer { 0% { transform: translateX(-60px); } 60%, 100% { transform: translateX(360px); } }
/* alt durum */
.aboutsys__foot { position: relative; margin-top: auto; display: flex; align-items: center; gap: 9px; padding: 12px 14px; border-radius: 12px; background: rgba(8,14,30,.55); border: 1px solid var(--stroke); font-family: "JetBrains Mono", monospace; font-size: 11.5px; color: #9fb4dd; }
.aboutsys__foot i { width: 8px; height: 8px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 8px var(--cyan); animation: blink2 1.4s infinite; flex-shrink: 0; }
@media (prefers-reduced-motion: reduce) {
  .aboutsys__head, .aboutsys__row, .aboutsys__live, .aboutsys__foot i, .aboutsys__row .bar::after { animation: none; }
  .aboutsys__row { opacity: 1; transform: none; }
  .aboutsys__row .bar b { width: var(--w, 90%); animation: none; }
}

/* ============================================================
   Footer — modern & animasyonlu
   ============================================================ */
footer.site { position: relative; overflow: hidden; }
footer.site::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, #2fe6ff, #6366f1, #f472b6, transparent); background-size: 200% 100%; animation: footBar 6s linear infinite; }
@keyframes footBar { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
footer.site::after { content: ""; position: absolute; bottom: -160px; left: 50%; transform: translateX(-50%); width: 600px; height: 320px; background: radial-gradient(circle, rgba(47,230,255,.1), transparent 70%); pointer-events: none; animation: footGlow 8s ease-in-out infinite; }
@keyframes footGlow { 0%,100% { opacity: .5; } 50% { opacity: 1; } }
footer.site .fcol a { position: relative; width: fit-content; }
footer.site .fcol a::after { content: ""; position: absolute; left: 0; bottom: 2px; width: 0; height: 1px; background: var(--cyan); transition: width .3s; }
footer.site .fcol a:hover::after { width: 100%; }
footer.site .fcol a:hover { padding-left: 4px; }
.footer-brand img { transition: transform .4s, filter .4s; }
.footer-brand:hover img { transform: scale(1.04); filter: drop-shadow(0 0 18px rgba(47,230,255,.4)); }
.footer-social a { position: relative; overflow: hidden; }
.footer-social a::before { content: ""; position: absolute; inset: 0; background: var(--grad); opacity: 0; transition: opacity .3s; }
.footer-social a:hover::before { opacity: .25; }
.footer-social a:hover { transform: translateY(-4px) rotate(-6deg); }
.footer-badges span { transition: border-color .3s, color .3s, transform .3s; }
.footer-badges span:hover { border-color: var(--cyan); color: var(--text); transform: translateY(-2px); }

/* ---------- Projeler & Referanslar kartları (alt alta) ---------- */
.pr-stack { display: grid; gap: 22px; }
.pr-card { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: 34px; align-items: center; padding: 38px; }
.pr-card__head h2 { font-size: clamp(23px, 2.8vw, 32px); margin: 12px 0 10px; line-height: 1.15; }
.pr-card__head p { color: var(--muted); margin-bottom: 22px; }
.pr-card__logos { display: flex; gap: 16px; flex-wrap: wrap; }
.pr-logo { flex: 1; min-width: 170px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; padding: 26px 20px; border: 1px solid var(--stroke); border-radius: 16px; background: var(--panel); transition: transform .3s, border-color .3s; text-align: center; }
.pr-logo:hover { border-color: var(--stroke-strong); transform: translateY(-5px); }
.pr-logo img { height: 48px; max-width: 80%; object-fit: contain; filter: brightness(1.08); }
.pr-logo span { font-size: 12.5px; color: var(--muted); }
@media (max-width: 860px) { .pr-card { grid-template-columns: 1fr; gap: 24px; padding: 28px; } }

/* ---------- Sosyal Medya (.smscene) — post + yükselen beğeniler ---------- */
.smscene { position: absolute; inset: 0; overflow: hidden; display: grid; place-items: center; }
.smscene__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(249,115,22,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(249,115,22,.05) 1px, transparent 1px); background-size: 30px 30px; mask-image: radial-gradient(circle at 50% 50%, #000, transparent 82%); }
.smscene__post { position: relative; z-index: 3; width: 62%; max-width: 256px; background: rgba(10,16,34,.96); border: 1px solid var(--stroke-strong); border-radius: 18px; overflow: hidden; box-shadow: 0 24px 56px rgba(0,0,0,.5); }
.smscene__post .top { display: flex; align-items: center; gap: 9px; padding: 12px; }
.smscene__post .av { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, #f97316, #fb7185); flex-shrink: 0; }
.smscene__post .nm { font-size: 13px; font-weight: 600; color: #eef4ff; line-height: 1.2; }
.smscene__post .nm span { display: block; font-size: 10px; color: var(--muted); font-weight: 400; }
.smscene__post .img { height: 124px; background: linear-gradient(135deg, #1f6dff, #a855f7, #f97316, #1f6dff); background-size: 300% 300%; animation: smGrad 8s ease infinite; position: relative; }
@keyframes smGrad { 0%,100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }
.smscene__post .img::after { content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-46%,-50%); border-left: 18px solid rgba(255,255,255,.92); border-top: 12px solid transparent; border-bottom: 12px solid transparent; }
.smscene__post .img::before { content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 54px; height: 54px; border-radius: 50%; background: rgba(255,255,255,.14); }
.smscene__post .act { display: flex; align-items: center; gap: 12px; padding: 12px 14px 2px; font-size: 19px; line-height: 1; }
.smscene__post .act .hh { color: #ff5a7a; animation: smBeat 1.4s ease-in-out infinite; }
.smscene__post .act .c { color: #6c7aa0; font-size: 16px; }
@keyframes smBeat { 0%,100% { transform: scale(1); } 30% { transform: scale(1.25); } }
.smscene__post .likes { padding: 6px 14px 14px; font-size: 13px; color: #eef4ff; font-weight: 600; }
.smscene__heart { position: absolute; bottom: 16%; color: #ff5a7a; font-size: 22px; opacity: 0; animation: smRise 4s linear infinite; text-shadow: 0 0 10px rgba(255,90,122,.5); }
.smscene__heart.h1 { left: 32%; } .smscene__heart.h2 { left: 50%; font-size: 28px; animation-delay: 1.3s; } .smscene__heart.h3 { left: 64%; animation-delay: 2.5s; } .smscene__heart.h4 { left: 42%; font-size: 18px; animation-delay: 3.3s; }
@keyframes smRise { 0% { transform: translateY(0) scale(.5); opacity: 0; } 15% { opacity: 1; } 100% { transform: translateY(-210px) scale(1.2) rotate(8deg); opacity: 0; } }
.smscene__chip { position: absolute; padding: 7px 13px; border-radius: 100px; background: rgba(8,14,30,.85); border: 1px solid var(--stroke-strong); font-family: "JetBrains Mono", monospace; font-size: 12px; color: #cbd5e1; animation: floatY 3.4s ease-in-out infinite; }
.smscene__chip b { color: #f97316; }
.smscene__chip.c1 { top: 13%; left: 7%; } .smscene__chip.c2 { top: 19%; right: 7%; animation-delay: .6s; } .smscene__chip.c3 { bottom: 15%; left: 6%; animation-delay: 1.1s; } .smscene__chip.c4 { bottom: 11%; right: 7%; animation-delay: 1.6s; }
.smscene__heart.h5 { left: 56%; font-size: 24px; animation-delay: 1.9s; } .smscene__heart.h6 { left: 38%; font-size: 20px; animation-delay: 3.0s; }

/* sonar pulse behind the post */
.smscene__pulse { position: absolute; z-index: 2; top: 50%; left: 50%; width: 200px; height: 200px; margin: -100px 0 0 -100px; border-radius: 50%; }
.smscene__pulse::before, .smscene__pulse::after { content: ""; position: absolute; inset: 0; border-radius: 50%; border: 2px solid rgba(249,115,22,.45); opacity: 0; animation: smPulse 3s ease-out infinite; }
.smscene__pulse::after { animation-delay: 1.5s; border-color: rgba(168,85,247,.45); }
@keyframes smPulse { 0% { transform: scale(.45); opacity: .9; } 100% { transform: scale(1.7); opacity: 0; } }

/* live badge */
.smscene__live { margin-left: auto; display: inline-flex; align-items: center; gap: 5px; font-size: 9px; font-weight: 700; letter-spacing: .08em; color: #ff5a7a; padding: 3px 8px; border-radius: 100px; background: rgba(255,90,122,.12); border: 1px solid rgba(255,90,122,.35); }
.smscene__live i { width: 6px; height: 6px; border-radius: 50%; background: #ff5a7a; animation: smBlink 1.1s ease-in-out infinite; }
@keyframes smBlink { 0%,100% { opacity: 1; box-shadow: 0 0 0 0 rgba(255,90,122,.6); } 50% { opacity: .35; box-shadow: 0 0 0 4px rgba(255,90,122,0); } }

/* orbiting social-action icons */
.smscene__orbit { position: absolute; z-index: 4; top: 50%; left: 50%; width: 320px; height: 320px; margin: -160px 0 0 -160px; animation: smSpin 16s linear infinite; pointer-events: none; }
.smscene__orbit .ob { position: absolute; width: 38px; height: 38px; display: grid; place-items: center; border-radius: 50%; font-size: 17px; color: #fff; background: rgba(10,16,34,.92); border: 1px solid var(--stroke-strong); box-shadow: 0 8px 20px rgba(0,0,0,.45); animation: smSpinR 16s linear infinite; }
.smscene__orbit .ob1 { top: -19px; left: 50%; margin-left: -19px; color: #ff5a7a; }
.smscene__orbit .ob2 { top: 50%; right: -19px; margin-top: -19px; color: #2fe6ff; }
.smscene__orbit .ob3 { bottom: -19px; left: 50%; margin-left: -19px; color: #4ade80; }
.smscene__orbit .ob4 { top: 50%; left: -19px; margin-top: -19px; color: #f97316; }
@keyframes smSpin { to { transform: rotate(360deg); } }
@keyframes smSpinR { to { transform: rotate(-360deg); } }

@media (prefers-reduced-motion: reduce) {
  .smscene__orbit, .smscene__pulse::before, .smscene__pulse::after, .smscene__post .img, .smscene__live i { animation: none; }
}

/* ---------- Gösterişli CTA ---------- */
.cta-fancy {
  position: relative; border-radius: 28px; padding: 66px 56px; overflow: hidden;
  text-align: center; isolation: isolate;
}
.cta-fancy::before {
  content: ""; position: absolute; inset: -2px; border-radius: 30px; z-index: -2;
  background: conic-gradient(from 0deg, #2fe6ff, #6366f1, #f472b6, #4ade80, #fec02e, #2fe6ff);
  animation: spin360 7s linear infinite; filter: saturate(1.2);
}
.cta-fancy::after {
  content: ""; position: absolute; inset: 1.5px; border-radius: 27px; z-index: -1;
  background: radial-gradient(120% 120% at 72% -10%, rgba(59,130,246,.28), transparent 55%), #080d1e;
}
.cta-fancy .cta-orb { position: absolute; border-radius: 50%; filter: blur(34px); opacity: .5; z-index: -1; pointer-events: none; }
.cta-fancy .cta-orb.o1 { width: 220px; height: 220px; background: rgba(47,230,255,.5); top: -80px; left: -40px; animation: orbFloat 9s ease-in-out infinite; }
.cta-fancy .cta-orb.o2 { width: 260px; height: 260px; background: rgba(99,102,241,.45); bottom: -110px; right: -50px; animation: orbFloat 11s ease-in-out infinite reverse; }
@keyframes orbFloat { 0%,100% { transform: translate(0,0); } 50% { transform: translate(30px,-24px); } }
.cta-fancy .cta-shine { position: absolute; top: 0; left: -60%; width: 50%; height: 100%; z-index: -1; background: linear-gradient(100deg, transparent, rgba(255,255,255,.06), transparent); animation: ctaShine 5s ease-in-out infinite; }
@keyframes ctaShine { 0% { left: -60%; } 60%,100% { left: 120%; } }
.cta-fancy h2 { font-size: clamp(28px,3.6vw,42px); margin-bottom: 14px; max-width: 760px; margin-inline: auto; }
.cta-fancy p { color: var(--muted); margin-bottom: 26px; }
.cta-steps { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-bottom: 30px; }
.cta-steps span { display: inline-flex; align-items: center; gap: 8px; font-family: "JetBrains Mono", monospace; font-size: 13px; padding: 9px 16px; border-radius: 100px; border: 1px solid var(--stroke-strong); background: rgba(255,255,255,.03); position: relative; }
.cta-steps span::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 8px var(--cyan); animation: pulse2 1.8s infinite; }
.cta-steps span:nth-child(2)::before { animation-delay: .4s; background: var(--indigo); box-shadow: 0 0 8px var(--indigo); }
.cta-steps span:nth-child(3)::before { animation-delay: .8s; background: #4ade80; box-shadow: 0 0 8px #4ade80; }

/* 3D üzerindeki metinlerin okunabilirliği için yumuşak koyu degrade */
.has-journey .hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(95deg, rgba(5,8,19,.9) 0%, rgba(5,8,19,.62) 40%, rgba(5,8,19,.12) 70%, transparent 100%);
}
.has-journey .hero .container { position: relative; z-index: 2; }
/* Yolculuk bölümlerindeki metin blokları için hafif okunabilirlik zemini */
.has-journey .split > div { position: relative; }
.has-journey .section-head h2,
.has-journey .feature-list { text-shadow: 0 2px 20px rgba(5,8,19,.6); }

/* ---------- Header: sade animasyonlu İletişim butonu ---------- */
.btn-contact {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 11px 22px;
  border-radius: 100px;
  font-family: var(--font);
  font-weight: 600;
  font-size: 15px;
  color: var(--text);
  border: 1px solid var(--stroke-strong);
  background: rgba(255, 255, 255, 0.03);
  overflow: hidden;
  isolation: isolate;
  transition: color .35s ease, border-color .35s ease;
}
.btn-contact::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--cyan);
  transform: translateX(-101%);
  transition: transform .4s cubic-bezier(.4, 0, .2, 1);
}
.btn-contact:hover { color: #04101f; border-color: var(--cyan); }
.btn-contact:hover::before { transform: translateX(0); }
.btn-contact .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--cyan); box-shadow: 0 0 8px var(--cyan);
  transition: background .35s, box-shadow .35s;
}
.btn-contact:hover .dot { background: #04101f; box-shadow: none; }
.btn-contact .arrow { transition: transform .3s; }
.btn-contact:hover .arrow { transform: translateX(4px); }

/* Mobil menü başlıkları */
.mobile-menu .mm-h {
  display: block;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cyan);
  padding: 18px 4px 6px;
  border: 0;
}

/* ---------- İstatistik / metrik tipografi düzeltmesi ---------- */
.stat strong,
.hero-metrics .m strong,
.detail-metrics .dm strong {
  font-size: clamp(26px, 3vw, 34px) !important;
  line-height: 1.1;
  font-weight: 700;
  word-break: keep-all;
  white-space: nowrap;
  letter-spacing: -.5px;
}
.stat span,
.hero-metrics .m span,
.detail-metrics .dm span {
  font-size: 14px !important;
  color: var(--muted);
  line-height: 1.3;
}
.stat { display: flex; flex-direction: column; gap: 6px; justify-content: center; min-height: 130px; }
.hero-metrics .m { display: flex; flex-direction: column; gap: 4px; justify-content: center; }

/* Hero metrik sayıları: hepsi eşit boyut + gradient (10 · 40+ · 360°) */
.hero-metrics .m strong,
.hero-metrics .m strong > span {
  font-size: clamp(34px, 3.4vw, 44px) !important;
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -1px;
  background: var(--grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  white-space: nowrap;
}

/* ============================================================
   Ana sayfa kart ikonları (alana özel mini animasyonlar)
   ============================================================ */
.cico {
  width: 60px; height: 60px;
  border-radius: 14px;
  position: relative;
  overflow: hidden;
  background: var(--grad-soft);
  border: 1px solid var(--stroke-strong);
  margin-bottom: 20px;
  flex-shrink: 0;
}
.cico::before, .cico::after { content: ""; position: absolute; }

@keyframes scanY { 0% { top: -12%; } 100% { top: 112%; } }
@keyframes blink2 { 0%, 100% { opacity: 1; } 50% { opacity: .2; } }
@keyframes ping2 { 0% { transform: scale(.6); opacity: 1; } 70% { box-shadow: 0 0 0 9px rgba(255,95,87,0); } 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(255,95,87,0); } }
@keyframes pulse2 { 50% { transform: scale(1.35); } }
@keyframes spin360 { to { transform: rotate(360deg); } }
@keyframes curMove { 0%,100% { transform: translate(0,0); } 50% { transform: translate(20px,18px); } }

/* web — tarayıcı + tarama çizgisi */
.cico--web::before { left: 9px; right: 9px; top: 12px; height: 7px; border-radius: 2px; background: rgba(255,255,255,.14); box-shadow: 0 12px 0 rgba(255,255,255,.09), 0 23px 0 rgba(255,255,255,.06); }
.cico--web::after { left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--cyan), transparent); animation: scanY 2.2s linear infinite; }

/* mobil — telefon + bildirim (ortalanmış) */
.cico--mobile::before { left: 50%; transform: translateX(-50%); top: 11px; width: 20px; height: 38px; border: 2px solid var(--cyan); border-radius: 6px; opacity: .9; }
.cico--mobile::after { left: 50%; margin-left: 4px; top: 8px; width: 9px; height: 9px; border-radius: 50%; background: #ff5f57; animation: ping2 1.7s ease-out infinite; }

/* sunucu — yanıp sönen LED satırları */
.cico--server i { position: absolute; left: 9px; right: 9px; height: 9px; border-radius: 2px; background: rgba(255,255,255,.08); }
.cico--server i:nth-child(1) { top: 12px; } .cico--server i:nth-child(2) { top: 26px; } .cico--server i:nth-child(3) { top: 40px; }
.cico--server i::after { content: ""; position: absolute; right: 5px; top: 2px; width: 5px; height: 5px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 6px var(--cyan); animation: blink2 1.2s infinite; }
.cico--server i:nth-child(2)::after { background: #4ade80; box-shadow: 0 0 6px #4ade80; animation-delay: .4s; }
.cico--server i:nth-child(3)::after { background: var(--indigo); box-shadow: 0 0 6px var(--indigo); animation-delay: .8s; }

/* ui — çerçeve + hareketli imleç */
.cico--ui::before { left: 12px; top: 12px; right: 12px; bottom: 12px; border: 1.5px dashed var(--stroke-strong); border-radius: 6px; }
.cico--ui::after { left: 16px; top: 16px; width: 12px; height: 12px; background: var(--cyan); clip-path: polygon(0 0, 100% 45%, 45% 55%, 55% 100%); animation: curMove 3s ease-in-out infinite; }

/* brand — nabız atan renk noktaları */
.cico--brand i { position: absolute; width: 13px; height: 13px; border-radius: 50%; top: 24px; animation: pulse2 1.8s infinite; }
.cico--brand i:nth-child(1) { left: 11px; background: var(--cyan); }
.cico--brand i:nth-child(2) { left: 25px; background: var(--blue); animation-delay: .3s; }
.cico--brand i:nth-child(3) { left: 39px; background: var(--indigo); animation-delay: .6s; }

/* logo — dönen halka + merkez */
.cico--logo::before { content: ""; position: absolute; inset: 13px; border: 2px dashed var(--cyan); border-radius: 50%; animation: spin360 5s linear infinite; }
.cico--logo::after { content: ""; position: absolute; left: 50%; top: 50%; width: 16px; height: 16px; margin: -8px 0 0 -8px; border-radius: 50%; background: var(--grad); box-shadow: 0 0 10px rgba(47,230,255,.5); }

/* home — ev + pencere ışığı */
.cico--home::before { content: ""; position: absolute; left: 50%; top: 13px; transform: translateX(-50%); width: 0; height: 0; border-left: 19px solid transparent; border-right: 19px solid transparent; border-bottom: 15px solid var(--cyan); opacity: .85; }
.cico--home::after { content: ""; position: absolute; left: 50%; top: 28px; transform: translateX(-50%); width: 26px; height: 19px; border: 2px solid var(--cyan); border-top: 0; background: rgba(47,230,255,.15); animation: winLight 2.4s ease-in-out infinite; }

/* fiber — ışık darbesi hatları */
.cico--fiber::before { content: ""; position: absolute; left: 8px; right: 8px; top: 50%; height: 2px; background: var(--stroke-strong); box-shadow: 0 -11px 0 var(--stroke-strong), 0 11px 0 var(--stroke-strong); }
.cico--fiber::after { content: ""; position: absolute; top: calc(50% - 2px); left: 0; width: 20px; height: 5px; border-radius: 5px; background: linear-gradient(90deg, transparent, #fff, var(--cyan), transparent); animation: pulseX 1.8s linear infinite; }

/* security — radar süpürme */
.cico--security::before { left: 11px; top: 11px; right: 11px; bottom: 11px; border-radius: 50%; border: 1.5px solid var(--stroke-strong); }
.cico--security::after { left: 50%; top: 50%; width: 20px; height: 2px; background: linear-gradient(90deg, var(--cyan), transparent); transform-origin: left center; animation: spin360 2s linear infinite; box-shadow: -2px -1px 0 2px rgba(47,230,255,.25); }

/* ============================================================
   Hero terminal — 3D perspektif + büyütme
   ============================================================ */
.hero-visual { perspective: 1400px; perspective-origin: 50% 40%; }
.hero-visual .terminal {
  max-width: 520px;
  transform: rotateY(-13deg) rotateX(6deg);
  transform-style: preserve-3d;
  transition: transform .4s ease;
  border: 1px solid rgba(47,230,255,.28);
  box-shadow:
    0 40px 90px rgba(0,0,0,.6),
    0 0 0 1px rgba(47,230,255,.08),
    -30px 30px 60px rgba(20,143,206,.18);
  animation: termFloat 6s ease-in-out infinite;
}
.hero-visual .terminal::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(47,230,255,.10), transparent 40%);
  pointer-events: none;
  z-index: 5;
}
.hero-visual .terminal::after {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(0deg, rgba(47,230,255,.04) 0px, rgba(47,230,255,.04) 1px, transparent 1px, transparent 3px);
  pointer-events: none;
  z-index: 4;
  opacity: .5;
}
@keyframes termFloat { 0%,100% { transform: rotateY(-13deg) rotateX(6deg) translateY(0); } 50% { transform: rotateY(-13deg) rotateX(6deg) translateY(-12px); } }
.hero-visual .terminal-body { min-height: 320px; font-size: 13.5px; }
/* JS fare etkileşimi devredeyken float'ı kapat */
.hero-visual.tilt-active .terminal { animation: none; }
.term-progress { margin-top: 6px; height: 7px; border-radius: 4px; background: rgba(255,255,255,.06); overflow: hidden; position: relative; }
.term-progress > span { position: absolute; inset: 0; width: 0%; background: var(--grad); border-radius: 4px; transition: width .2s linear; }
.term-progress > em { position: absolute; right: 6px; top: -19px; font-size: 11px; color: var(--cyan); font-style: normal; }

@media (max-width: 1080px) {
  .hero-visual .terminal { transform: none; animation: none; max-width: 460px; }
  .hero-visual .terminal::before, .hero-visual .terminal::after { display: none; }
}

/* ============================================================
   Hero arka plan logosu — scroll ile zoom-in
   ============================================================ */
.hero-logo-zoom {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: grid;
  place-items: center;
  overflow: hidden;
  pointer-events: none;
}
.hero-logo-zoom img {
  width: 58%;
  max-width: 620px;
  opacity: .08;
  transform: scale(1);
  transform-origin: center center;
  filter: drop-shadow(0 0 40px rgba(47,230,255,.35));
  will-change: transform, opacity;
}
.has-journey .hero .container { position: relative; z-index: 2; }

/* ============================================================
   Ana sayfa hero — Blue Network logo animasyonu (kullanım dışı)
   ============================================================ */
.logo-stage {
  position: relative;
  min-height: 410px;
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  background: radial-gradient(circle at 50% 45%, rgba(20,143,206,.16), transparent 62%), var(--panel);
  backdrop-filter: blur(10px);
  overflow: hidden;
  display: grid;
  place-items: center;
  box-shadow: 0 30px 80px rgba(0,0,0,.5);
}
.logo-stage__glow {
  position: absolute; width: 72%; height: 56%; left: 14%; top: 22%;
  background: radial-gradient(circle, rgba(47,230,255,.24), transparent 70%);
  filter: blur(22px);
  animation: glowPulse 4.2s ease-in-out infinite;
}
@keyframes glowPulse { 0%,100% { opacity: .45; transform: scale(.94); } 50% { opacity: 1; transform: scale(1.06); } }
.logo-stage__lines { position: absolute; inset: 0; }
.logo-stage__lines i { position: absolute; left: -10%; right: -10%; height: 1px; background: var(--stroke-strong); }
.logo-stage__lines i:nth-child(1) { top: 30%; }
.logo-stage__lines i:nth-child(2) { top: 50%; }
.logo-stage__lines i:nth-child(3) { top: 70%; }
.logo-stage__lines i::after {
  content: ""; position: absolute; top: -2px; left: 0; width: 64px; height: 4px; border-radius: 4px;
  background: linear-gradient(90deg, transparent, var(--cyan), #fff, var(--cyan), transparent);
  filter: blur(.4px); animation: pulseX 3s linear infinite;
}
.logo-stage__lines i:nth-child(2)::after { background: linear-gradient(90deg, transparent, #148FCE, #fff, #148FCE, transparent); animation-delay: 1s; }
.logo-stage__lines i:nth-child(3)::after { background: linear-gradient(90deg, transparent, #E52227, #fff, #E52227, transparent); animation-delay: 2s; }
.logo-stage__nodes span {
  position: absolute; width: 7px; height: 7px; border-radius: 50%;
  background: var(--cyan); box-shadow: 0 0 9px var(--cyan); animation: pulse2 2.4s infinite;
}
.logo-stage__mark {
  position: relative; z-index: 3; width: 76%; max-width: 380px;
  filter: drop-shadow(0 0 26px rgba(47,230,255,.4));
  animation: floatY 5s ease-in-out infinite;
}
.logo-stage__scan {
  position: absolute; left: 0; right: 0; height: 2px; top: 0;
  background: linear-gradient(90deg, transparent, rgba(47,230,255,.55), transparent);
  animation: scanY 4.5s linear infinite;
}
.logo-stage__ring {
  position: absolute; border: 1px dashed var(--stroke-strong); border-radius: 50%;
}
.logo-stage__ring.a { width: 300px; height: 300px; animation: spin360 26s linear infinite; }
.logo-stage__ring.b { width: 210px; height: 210px; border-color: rgba(47,230,255,.28); animation: spin360 18s linear infinite reverse; }

/* ============================================================
   Hizmet detay sahneleri (her hizmete özel büyük animasyon)
   ============================================================ */
.svc-stage {
  position: relative;
  aspect-ratio: 1 / 1;
  min-height: 360px;
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  background: radial-gradient(circle at 50% 35%, rgba(47,230,255,.08), transparent 60%), var(--panel);
  overflow: hidden;
  backdrop-filter: blur(8px);
}
.svc-stage .badge {
  position: absolute; z-index: 5; top: 18px; left: 18px;
  font-family: "JetBrains Mono", monospace; font-size: 12px;
  padding: 7px 13px; border-radius: 100px;
  background: rgba(8,12,28,.7); border: 1px solid var(--stroke-strong); color: var(--cyan);
}
.svc-stage .badge.r { left: auto; right: 18px; top: auto; bottom: 18px; color: #4ade80; }

/* --- WEB: kod editörü --- */
.sw { position: absolute; inset: 16% 14%; border: 1px solid var(--stroke-strong); border-radius: 12px; background: rgba(6,10,24,.7); overflow: hidden; }
.sw__bar { height: 30px; border-bottom: 1px solid var(--stroke); display: flex; align-items: center; gap: 6px; padding: 0 12px; }
.sw__bar i { width: 9px; height: 9px; border-radius: 50%; background: var(--muted-2); }
.sw__bar i:nth-child(1) { background: #ff5f57; } .sw__bar i:nth-child(2) { background: #febc2e; } .sw__bar i:nth-child(3) { background: #28c840; }
.sw__code { padding: 16px; font-family: "JetBrains Mono", monospace; font-size: 12px; line-height: 2; }
.sw__code span { display: block; height: 9px; border-radius: 3px; background: linear-gradient(90deg, var(--cyan), transparent); opacity: .5; animation: lineGrow 2.6s ease-in-out infinite; transform-origin: left; }
.sw__code span:nth-child(1) { width: 70%; } .sw__code span:nth-child(2) { width: 45%; background: linear-gradient(90deg, var(--indigo), transparent); animation-delay: .3s; }
.sw__code span:nth-child(3) { width: 85%; animation-delay: .6s; } .sw__code span:nth-child(4) { width: 35%; background: linear-gradient(90deg, #4ade80, transparent); animation-delay: .9s; }
.sw__code span:nth-child(5) { width: 60%; animation-delay: 1.2s; }
@keyframes lineGrow { 0%, 100% { transform: scaleX(.4); opacity: .25; } 50% { transform: scaleX(1); opacity: .7; } }
.sw__scan { position: absolute; left: 0; right: 0; height: 30px; top: 0; background: linear-gradient(180deg, rgba(47,230,255,.18), transparent); animation: scanY 3s linear infinite; }

/* --- WEB (yeni): 3D full-stack katmanları + veri akışı --- */
.wstack { position: absolute; inset: 12%; perspective: 1000px; display: grid; place-items: center; }
.wstack__layer {
  position: absolute; width: 78%; height: 54px; border-radius: 12px;
  border: 1px solid var(--stroke-strong); background: rgba(8,14,30,.9);
  display: flex; align-items: center; gap: 10px; padding: 0 16px;
  box-shadow: 0 20px 44px rgba(0,0,0,.45);
}
.wstack__layer b { font-family: "JetBrains Mono", monospace; font-size: 13px; width: 32px; flex-shrink: 0; }
.wstack__layer i { height: 8px; border-radius: 3px; flex: 1; opacity: .55; animation: lineGrow 2.6s ease-in-out infinite; }
.wstack .w-ui { transform: rotateX(54deg) rotateZ(-1deg) translateY(-78px); }
.wstack .w-api { transform: rotateX(54deg) rotateZ(-1deg); }
.wstack .w-db { transform: rotateX(54deg) rotateZ(-1deg) translateY(78px); }
.w-ui b { color: var(--cyan); } .w-ui i { background: linear-gradient(90deg, var(--cyan), transparent); }
.w-api b { color: var(--indigo); } .w-api i { background: linear-gradient(90deg, var(--indigo), transparent); animation-delay: .4s; }
.w-db b { color: #4ade80; } .w-db i { background: linear-gradient(90deg, #4ade80, transparent); animation-delay: .8s; }
.wstack__pkt { position: absolute; left: 50%; width: 11px; height: 11px; margin-left: -5px; border-radius: 50%; background: #fff; box-shadow: 0 0 12px var(--cyan); animation: pktMove 2.4s linear infinite; }
.wstack__pkt.p2 { animation-delay: .8s; margin-left: 28px; box-shadow: 0 0 12px var(--indigo); }
.wstack__pkt.p3 { animation-delay: 1.6s; margin-left: -38px; box-shadow: 0 0 12px #4ade80; }
@keyframes pktMove { 0% { top: 26%; opacity: 0; } 12% { opacity: 1; } 50% { top: 50%; } 88% { opacity: 1; } 100% { top: 74%; opacity: 0; } }

/* --- MOBİL (yeni): kayan ekranlar + bildirim + sekmeler --- */
.phone3 { position: absolute; top: 11%; left: 50%; transform: translateX(-50%); width: 162px; height: 78%; border: 3px solid var(--stroke-strong); border-radius: 28px; background: #070d1c; overflow: hidden; box-shadow: 0 26px 60px rgba(0,0,0,.55); }
.phone3__cam { position: absolute; top: 9px; left: 50%; transform: translateX(-50%); width: 44px; height: 6px; border-radius: 4px; background: var(--stroke-strong); z-index: 6; }
.phone3__view { position: absolute; inset: 26px 10px 44px; border-radius: 12px; overflow: hidden; border: 1px solid var(--stroke); }
.phone3__track { display: flex; width: 300%; height: 100%; animation: scSlide 7s ease-in-out infinite; }
.phone3__track > span { flex: 1; height: 100%; position: relative; }
.phone3__track > span::before { content: ""; position: absolute; left: 12px; right: 12px; top: 16px; height: 10px; border-radius: 4px; background: rgba(255,255,255,.25); box-shadow: 0 20px 0 rgba(255,255,255,.12), 0 38px 0 rgba(255,255,255,.08); }
.sc1 { background: linear-gradient(160deg, rgba(47,230,255,.3), rgba(8,14,30,.7)); }
.sc2 { background: linear-gradient(160deg, rgba(99,102,241,.32), rgba(8,14,30,.7)); }
.sc3 { background: linear-gradient(160deg, rgba(74,222,128,.26), rgba(8,14,30,.7)); }
@keyframes scSlide { 0%,26% { transform: translateX(0); } 33%,59% { transform: translateX(-33.33%); } 66%,92% { transform: translateX(-66.66%); } 100% { transform: translateX(0); } }
.phone3__notif { position: absolute; top: 30px; left: 14px; right: 14px; height: 26px; border-radius: 9px; background: rgba(20,30,56,.95); border: 1px solid var(--stroke-strong); z-index: 7; animation: notifDrop 5.5s ease-in-out infinite; }
.phone3__notif::before { content: ""; position: absolute; left: 9px; top: 50%; transform: translateY(-50%); width: 9px; height: 9px; border-radius: 50%; background: #ff5f57; box-shadow: 0 0 8px #ff5f57; }
.phone3__notif::after { content: ""; position: absolute; left: 28px; right: 12px; top: 50%; transform: translateY(-50%); height: 5px; border-radius: 3px; background: rgba(255,255,255,.3); }
@keyframes notifDrop { 0%,66% { transform: translateY(-44px); opacity: 0; } 74%,90% { transform: translateY(0); opacity: 1; } 100% { transform: translateY(-44px); opacity: 0; } }
.phone3__tabs { position: absolute; bottom: 13px; left: 0; right: 0; display: flex; justify-content: center; gap: 15px; z-index: 6; }
.phone3__tabs i { width: 9px; height: 9px; border-radius: 50%; background: var(--stroke-strong); animation: tabHi 7s infinite; }
.phone3__tabs i:nth-child(2) { animation-delay: 1.75s; }
.phone3__tabs i:nth-child(3) { animation-delay: 3.5s; }
.phone3__tabs i:nth-child(4) { animation-delay: 5.25s; }
@keyframes tabHi { 0%,16% { background: var(--cyan); box-shadow: 0 0 8px var(--cyan); } 22%,100% { background: var(--stroke-strong); box-shadow: none; } }

/* --- MOBİL (eski): telefon + kayan ekranlar --- */
.sp { position: absolute; top: 12%; left: 50%; transform: translateX(-50%); width: 150px; height: 76%; border: 3px solid var(--stroke-strong); border-radius: 26px; background: rgba(6,10,24,.8); overflow: hidden; box-shadow: 0 20px 50px rgba(0,0,0,.5); }
.sp::before { content: ""; position: absolute; top: 10px; left: 50%; transform: translateX(-50%); width: 40px; height: 5px; border-radius: 3px; background: var(--stroke-strong); z-index: 3; }
.sp__screen { position: absolute; inset: 26px 12px 40px; }
.sp__screen i { position: absolute; left: 0; right: 0; height: 26px; border-radius: 8px; background: var(--grad-soft); border: 1px solid var(--stroke); animation: cardUp 3.2s ease-in-out infinite; }
.sp__screen i:nth-child(1) { top: 0; } .sp__screen i:nth-child(2) { top: 34px; animation-delay: .4s; } .sp__screen i:nth-child(3) { top: 68px; animation-delay: .8s; }
@keyframes cardUp { 0%, 100% { transform: translateY(6px); opacity: .4; } 50% { transform: translateY(0); opacity: 1; } }
.sp__dot { position: absolute; top: 16px; right: 18px; width: 10px; height: 10px; border-radius: 50%; background: #ff5f57; animation: ping2 1.7s ease-out infinite; z-index: 4; }
.sp__nav { position: absolute; bottom: 12px; left: 0; right: 0; display: flex; justify-content: center; gap: 10px; }
.sp__nav span { width: 8px; height: 8px; border-radius: 50%; background: var(--stroke-strong); }
.sp__nav span:first-child { background: var(--cyan); }

/* --- SUNUCU: rack + LED'ler --- */
.sr { position: absolute; top: 12%; left: 50%; transform: translateX(-50%); width: 56%; height: 76%; border: 1px solid var(--stroke-strong); border-radius: 12px; background: rgba(6,10,24,.7); padding: 12px; display: flex; flex-direction: column; gap: 7px; }
.sr__u { flex: 1; border-radius: 5px; background: rgba(255,255,255,.05); border: 1px solid var(--stroke); position: relative; display: flex; align-items: center; padding-left: 10px; gap: 5px; }
.sr__u b { width: 6px; height: 6px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 6px var(--cyan); animation: blink2 1.4s infinite; }
.sr__u b:nth-child(2) { background: #4ade80; box-shadow: 0 0 6px #4ade80; animation-delay: .3s; }
.sr__u b:nth-child(3) { background: var(--indigo); box-shadow: 0 0 6px var(--indigo); animation-delay: .6s; }
.sr__u::after { content: ""; position: absolute; right: 10px; width: 36%; height: 4px; border-radius: 2px; background: var(--stroke-strong); }
.sr__ring { position: absolute; right: 16px; bottom: 16px; width: 54px; height: 54px; border-radius: 50%; border: 3px solid var(--stroke); border-top-color: var(--cyan); animation: spin360 1.6s linear infinite; }

/* --- UI/UX: tasarım tuvali --- */
.sd { position: absolute; inset: 16%; border: 1px solid var(--stroke-strong); border-radius: 12px; background: rgba(6,10,24,.6); }
.sd__shape { position: absolute; animation: floatY 3.4s ease-in-out infinite; }
.sd__shape.c1 { top: 18%; left: 16%; width: 46px; height: 46px; border-radius: 50%; background: var(--grad-soft); border: 1px solid var(--cyan); }
.sd__shape.c2 { top: 22%; right: 18%; width: 40px; height: 40px; border-radius: 10px; background: rgba(99,102,241,.2); border: 1px solid var(--indigo); animation-delay: .5s; }
.sd__shape.c3 { bottom: 20%; left: 30%; width: 64px; height: 16px; border-radius: 8px; background: var(--grad); animation-delay: 1s; }
@keyframes floatY { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
.sd__cursor { position: absolute; width: 14px; height: 14px; background: #fff; clip-path: polygon(0 0, 100% 45%, 45% 55%, 55% 100%); animation: curMove2 4s ease-in-out infinite; z-index: 3; }
@keyframes curMove2 { 0% { left: 24%; top: 28%; } 33% { left: 64%; top: 32%; } 66% { left: 44%; top: 66%; } 100% { left: 24%; top: 28%; } }

/* --- KURUMSAL KİMLİK: marka panosu --- */
.sb { position: absolute; inset: 16%; display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 10px; }
.sb > div { border-radius: 10px; border: 1px solid var(--stroke); display: grid; place-items: center; font-family: "JetBrains Mono", monospace; }
.sb__logo { background: var(--grad-soft); }
.sb__logo img { width: 46px; }
.sb__type { font-size: 30px; font-weight: 700; color: var(--text); }
.sb__pal { display: flex !important; gap: 0 !important; padding: 0; overflow: hidden; }
.sb__pal i { flex: 1; height: 100%; animation: swatch 3s ease-in-out infinite; }
.sb__pal i:nth-child(1) { background: var(--cyan); } .sb__pal i:nth-child(2) { background: var(--blue); animation-delay: .3s; }
.sb__pal i:nth-child(3) { background: var(--indigo); animation-delay: .6s; } .sb__pal i:nth-child(4) { background: #4ade80; animation-delay: .9s; }
@keyframes swatch { 50% { opacity: .45; } }
.sb__grid { color: var(--cyan); font-size: 13px; letter-spacing: 1px; }

/* --- LOGO: geometrik dönüş --- */
/* ---------- Logo Tasarımı (.lgc) — logo yapım ızgarası / blueprint ---------- */
.lgc { position: absolute; inset: 0; display: grid; place-items: center; overflow: hidden; }
/* blueprint ızgara */
.lgc__grid {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(120,160,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(120,160,255,.08) 1px, transparent 1px);
  background-size: 26px 26px;
  -webkit-mask-image: radial-gradient(circle at 50% 50%, #000 56%, transparent 88%);
  mask-image: radial-gradient(circle at 50% 50%, #000 56%, transparent 88%);
  animation: lgcFade 1s ease both;
}
@keyframes lgcFade { from { opacity: 0; } to { opacity: 1; } }
/* merkez kılavuz çizgileri (artı) */
.lgc__guide { position: absolute; z-index: 2; }
.lgc__guide.v { left: 50%; top: 8%; width: 1px; height: 84%; margin-left: -.5px; background: linear-gradient(180deg, transparent, rgba(47,230,255,.5) 22%, rgba(47,230,255,.5) 78%, transparent); animation: lgcGuide 4s ease-in-out infinite; }
.lgc__guide.h { top: 50%; left: 8%; height: 1px; width: 84%; margin-top: -.5px; background: linear-gradient(90deg, transparent, rgba(47,230,255,.5) 22%, rgba(47,230,255,.5) 78%, transparent); animation: lgcGuide 4s ease-in-out infinite .4s; }
@keyframes lgcGuide { 0%, 100% { opacity: .35; } 50% { opacity: .85; } }
/* altın oran inşa çemberleri */
.lgc__circle { position: absolute; top: 50%; left: 50%; border-radius: 50%; }
.lgc__circle.c1 { width: 192px; height: 192px; margin: -96px 0 0 -96px; border: 1.5px solid rgba(120,160,255,.4); animation: lgcDraw .8s cubic-bezier(.2,.8,.2,1) both, lgcBreath 7s ease-in-out 1s infinite; }
.lgc__circle.c2 { width: 124px; height: 124px; margin: -62px 0 0 -95px; border: 1.5px solid rgba(47,230,255,.42); animation: lgcDraw .8s cubic-bezier(.2,.8,.2,1) .15s both, lgcBreath 7s ease-in-out 1.1s infinite; }
.lgc__circle.c3 { width: 124px; height: 124px; margin: -62px 0 0 -29px; border: 1.5px solid rgba(99,130,255,.42); animation: lgcDraw .8s cubic-bezier(.2,.8,.2,1) .3s both, lgcBreath 7s ease-in-out 1.2s infinite; }
@keyframes lgcDraw { from { opacity: 0; transform: scale(.55); } to { opacity: 1; transform: scale(1); } }
@keyframes lgcBreath { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.035); } }
/* çapa (anchor) noktaları */
.lgc__node { position: absolute; z-index: 3; top: 50%; left: 50%; width: 9px; height: 9px; margin: -4.5px 0 0 -4.5px; border: 1.5px solid var(--cyan); background: #0a1326; animation: lgcNode 2.6s ease-in-out infinite; }
.lgc__node.n1 { margin-top: -100.5px; } .lgc__node.n2 { margin-top: 91.5px; animation-delay: .65s; }
.lgc__node.n3 { margin-left: -100.5px; animation-delay: 1.3s; } .lgc__node.n4 { margin-left: 91.5px; animation-delay: 1.95s; }
@keyframes lgcNode { 0%, 100% { opacity: .4; box-shadow: 0 0 0 0 rgba(47,230,255,.5); } 50% { opacity: 1; box-shadow: 0 0 0 5px rgba(47,230,255,0); } }
/* merkez logo işareti */
.lgc__mark { position: relative; z-index: 5; width: 90px; height: 90px; border-radius: 20px; background: var(--grad-soft); border: 1px solid var(--stroke-strong); display: grid; place-items: center; box-shadow: 0 14px 36px rgba(0,0,0,.45); animation: lgcMark 6s ease-in-out infinite; }
.lgc__mark img { width: 48px; }
@keyframes lgcMark { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.045); } }
/* renk paleti */
.lgc__swatches { position: absolute; z-index: 6; bottom: 8%; left: 50%; transform: translateX(-50%); display: flex; gap: 9px; }
.lgc__swatches i { width: 22px; height: 22px; border-radius: 7px; border: 1px solid rgba(255,255,255,.14); opacity: 0; transform: translateY(8px); animation: lgcSw .6s ease forwards; }
.lgc__swatches i:nth-child(1) { background: #2fe6ff; animation-delay: 1.2s; }
.lgc__swatches i:nth-child(2) { background: #3b82f6; animation-delay: 1.4s; }
.lgc__swatches i:nth-child(3) { background: #6366f1; animation-delay: 1.6s; }
.lgc__swatches i:nth-child(4) { background: #0b1430; animation-delay: 1.8s; }
@keyframes lgcSw { to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) {
  .lgc__grid, .lgc__guide, .lgc__circle, .lgc__node, .lgc__mark, .lgc__swatches i { animation: none; }
  .lgc__swatches i { opacity: 1; transform: none; }
}

/* --- GÜVENLİK KAMERASI: CCTV tarama --- */
.sc { position: absolute; inset: 0; }
.sc__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(47,230,255,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(47,230,255,.06) 1px, transparent 1px); background-size: 30px 30px; }
.sc__cam { position: absolute; top: 16%; left: 50%; transform: translateX(-50%); width: 70px; height: 40px; border-radius: 40px 40px 8px 8px; background: linear-gradient(180deg, #1a2444, #0c1430); border: 1px solid var(--stroke-strong); }
.sc__cam::after { content: ""; position: absolute; bottom: 7px; left: 14px; width: 16px; height: 16px; border-radius: 50%; background: #04101f; border: 2px solid var(--cyan); box-shadow: 0 0 10px var(--cyan); }
.sc__cone { position: absolute; top: 30%; left: 50%; width: 4px; height: 60%; background: linear-gradient(180deg, rgba(47,230,255,.4), transparent); transform-origin: top center; animation: sweep 3.4s ease-in-out infinite; filter: blur(1px); }
@keyframes sweep { 0%, 100% { transform: rotate(-32deg); } 50% { transform: rotate(32deg); } }
.sc__rec { position: absolute; top: 18px; right: 18px; display: flex; align-items: center; gap: 6px; font-family: "JetBrains Mono", monospace; font-size: 11px; color: #ff5f57; }
.sc__rec b { width: 8px; height: 8px; border-radius: 50%; background: #ff5f57; animation: blink2 1s infinite; }

/* --- GÜVENLİK KAMERASI (.cctv): profesyonel CCTV izleme ekranı --- */
.cctv { position: absolute; inset: 0; overflow: hidden; font-family: "JetBrains Mono", monospace; }
/* tarama çizgileri (CCTV/CRT dokusu) */
.cctv::before { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .4; background: repeating-linear-gradient(0deg, rgba(0,0,0,.18) 0 1px, transparent 1px 3px); }
.cctv__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(74,222,128,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(74,222,128,.06) 1px, transparent 1px); background-size: 34px 34px; -webkit-mask-image: radial-gradient(circle at 50% 50%, #000 72%, transparent 100%); mask-image: radial-gradient(circle at 50% 50%, #000 72%, transparent 100%); }
.cctv__scan { position: absolute; left: 0; right: 0; top: -70px; height: 70px; background: linear-gradient(180deg, rgba(74,222,128,.13), transparent); animation: cctvScan 4.5s linear infinite; }
@keyframes cctvScan { to { top: 100%; } }
/* HUD köşeleri */
.cctv__hud { position: absolute; z-index: 5; font-size: 11px; letter-spacing: .12em; display: flex; align-items: center; gap: 7px; }
.cctv__hud.tl { top: 17px; left: 42px; color: #ff7a7a; }
.cctv__hud.tr { top: 17px; right: 42px; color: #84e0ad; }
.cctv__hud .rec { width: 9px; height: 9px; border-radius: 50%; background: #ff5f57; box-shadow: 0 0 8px #ff5f57; animation: blink2 1.2s infinite; }
.cctv__hud .live { width: 7px; height: 7px; border-radius: 50%; background: #4ade80; box-shadow: 0 0 8px #4ade80; }
/* takip edilen özne + kilit çerçevesi */
.cctv__track { position: absolute; z-index: 3; bottom: 26%; left: 50%; width: 76px; height: 108px; transform: translateX(-50%); animation: cctvWalk 8s ease-in-out infinite; }
.cctv__subject::before { content: ""; position: absolute; bottom: 52px; left: 50%; transform: translateX(-50%); width: 20px; height: 20px; border-radius: 50%; background: #3a4a68; }
.cctv__subject::after { content: ""; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 30px; height: 50px; border-radius: 16px 16px 7px 7px; background: #3a4a68; }
.cctv__lock { position: absolute; inset: 0; animation: cctvLock 8s ease-in-out infinite; }
.cctv__lock i { position: absolute; width: 16px; height: 16px; border: 2px solid #4ade80; }
.cctv__lock i:nth-child(1) { top: 0; left: 0; border-right: 0; border-bottom: 0; }
.cctv__lock i:nth-child(2) { top: 0; right: 0; border-left: 0; border-bottom: 0; }
.cctv__lock i:nth-child(3) { bottom: 0; left: 0; border-right: 0; border-top: 0; }
.cctv__lock i:nth-child(4) { bottom: 0; right: 0; border-left: 0; border-top: 0; }
.cctv__lock em { position: absolute; top: -17px; left: 0; font-size: 9.5px; font-style: normal; letter-spacing: .1em; color: #4ade80; }
@keyframes cctvWalk { 0%, 100% { left: 36%; } 50% { left: 64%; } }
@keyframes cctvLock { 0%, 100% { opacity: .8; transform: scale(1); } 50% { opacity: 1; transform: scale(1.06); } }
/* alt durum çubuğu (tek satır, çakışmasız) */
.cctv__bar { position: absolute; z-index: 5; left: 42px; right: 42px; bottom: 16px; display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.cctv__bar .ts { font-size: 11px; color: #8ea0c4; letter-spacing: .04em; }
.cctv__chips { display: flex; gap: 8px; }
.cctv__chips b { font-size: 10px; letter-spacing: .08em; padding: 4px 9px; border-radius: 6px; border: 1px solid; }
.cctv__chips b.armed { color: #4ade80; border-color: rgba(74,222,128,.45); background: rgba(74,222,128,.1); }
.cctv__chips b.motion { color: #fec02e; border-color: rgba(254,192,46,.45); background: rgba(254,192,46,.1); animation: blink2 1.6s infinite; }
/* viewfinder köşe çerçeveleri */
.cctv__frame { position: absolute; inset: 14px; z-index: 4; pointer-events: none; }
.cctv__frame span { position: absolute; width: 20px; height: 20px; border: 2px solid rgba(74,222,128,.45); }
.cctv__frame span:nth-child(1) { top: 0; left: 0; border-right: 0; border-bottom: 0; }
.cctv__frame span:nth-child(2) { top: 0; right: 0; border-left: 0; border-bottom: 0; }
.cctv__frame span:nth-child(3) { bottom: 0; left: 0; border-right: 0; border-top: 0; }
.cctv__frame span:nth-child(4) { bottom: 0; right: 0; border-left: 0; border-top: 0; }
/* üstte hafifçe pan yapan dome kamera */
.cctv__cam { position: absolute; z-index: 4; top: 13px; left: 50%; width: 50px; height: 22px; transform: translateX(-50%); transform-origin: 50% 0; animation: cctvPan 6.5s ease-in-out infinite; }
.cctv__cam::before { content: ""; position: absolute; inset: 0; border-radius: 22px 22px 6px 6px; background: linear-gradient(180deg, #1a2444, #0c1430); border: 1px solid var(--stroke-strong); }
.cctv__cam i { position: absolute; z-index: 1; bottom: 4px; left: 50%; transform: translateX(-50%); width: 12px; height: 12px; border-radius: 50%; background: #04101f; border: 2px solid #4ade80; box-shadow: 0 0 8px #4ade80; }
@keyframes cctvPan { 0%, 100% { transform: translateX(-50%) rotate(-8deg); } 50% { transform: translateX(-50%) rotate(8deg); } }
/* özneden yayılan tespit halkası (ping) */
.cctv__ping { position: absolute; z-index: 2; left: 50%; top: 50%; width: 24px; height: 24px; margin: -12px 0 0 -12px; border-radius: 50%; border: 2px solid rgba(74,222,128,.6); opacity: 0; animation: cctvPing 4s ease-out infinite; }
@keyframes cctvPing { 0% { opacity: 0; transform: scale(.4); } 12% { opacity: .8; } 60% { opacity: 0; transform: scale(3.4); } 100% { opacity: 0; } }
@media (prefers-reduced-motion: reduce) {
  .cctv__scan, .cctv__track, .cctv__lock, .cctv__hud .rec, .cctv__chips b.motion, .cctv__cam, .cctv__ping { animation: none; }
}

/* --- AI ÇÖZÜMLERİ (.aiscene): chatbot + nöral ağ --- */
.aiscene { position: absolute; inset: 0; overflow: hidden; display: grid; place-items: center; }
.aiscene__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(168,85,247,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(168,85,247,.05) 1px, transparent 1px); background-size: 30px 30px; mask-image: radial-gradient(circle at 50% 50%, #000, transparent 82%); }
.aiscene__ring { position: absolute; border-radius: 50%; border: 1px dashed rgba(168,85,247,.4); }
.aiscene__ring.a { width: 290px; height: 290px; animation: spin360 22s linear infinite; }
.aiscene__ring.b { width: 380px; height: 380px; border-color: rgba(99,102,241,.22); animation: spin360 32s linear infinite reverse; }
.aiscene__node { position: absolute; width: 9px; height: 9px; border-radius: 50%; background: #a855f7; box-shadow: 0 0 9px #a855f7; animation: pulse2 2.4s infinite; }
.aiscene__chat { position: relative; z-index: 3; width: 70%; max-width: 290px; background: rgba(10,16,34,.95); border: 1px solid var(--stroke-strong); border-radius: 16px; padding: 14px; box-shadow: 0 24px 56px rgba(0,0,0,.5); }
.aiscene__chat .head { display: flex; align-items: center; gap: 9px; padding-bottom: 11px; border-bottom: 1px solid var(--stroke); }
.aiscene__chat .av { width: 28px; height: 28px; border-radius: 50%; background: linear-gradient(135deg, #a855f7, #6366f1); position: relative; flex-shrink: 0; }
.aiscene__chat .av::before { content: "AI"; position: absolute; inset: 0; display: grid; place-items: center; font: 700 11px sans-serif; color: #fff; }
.aiscene__chat .av::after { content: ""; position: absolute; right: -1px; bottom: -1px; width: 9px; height: 9px; border-radius: 50%; background: #4ade80; border: 2px solid #0a1022; }
.aiscene__chat .name { font-size: 13.5px; font-weight: 600; color: #eef4ff; line-height: 1.2; }
.aiscene__chat .name span { display: block; font-size: 10px; color: #4ade80; font-weight: 400; }
.aiscene__msg { margin-top: 11px; max-width: 82%; padding: 9px 12px; border-radius: 13px; font-size: 12px; line-height: 1.35; }
.aiscene__msg.bot { background: #16203c; color: #cbd5e1; border-bottom-left-radius: 4px; animation: aiMsg .5s ease both; }
.aiscene__msg.user { background: linear-gradient(135deg, #a855f7, #6366f1); color: #fff; margin-left: auto; border-bottom-right-radius: 4px; animation: aiMsg .5s ease .5s both; }
@keyframes aiMsg { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.aiscene__typing { margin-top: 11px; display: inline-flex; gap: 5px; padding: 12px 14px; background: #16203c; border-radius: 13px; border-bottom-left-radius: 4px; animation: aiMsg .4s ease 1s both; }
.aiscene__typing b { width: 7px; height: 7px; border-radius: 50%; background: #9fb3d8; animation: aiTyping 1.2s infinite; }
.aiscene__typing b:nth-child(2) { animation-delay: .2s; } .aiscene__typing b:nth-child(3) { animation-delay: .4s; }
@keyframes aiTyping { 0%,60%,100% { opacity: .3; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-4px); } }


/* --- UI/UX detay: tasarım aracı (Figma benzeri) .uitool --- */
.uitool { position: absolute; inset: 8%; border-radius: 14px; border: 1px solid var(--stroke-strong); background: #0b1124; overflow: hidden; box-shadow: 0 24px 56px rgba(0,0,0,.45); }
.uitool__bar { height: 36px; display: flex; align-items: center; gap: 7px; padding: 0 14px; border-bottom: 1px solid var(--stroke); }
.uitool__bar i { width: 11px; height: 11px; border-radius: 50%; }
.uitool__bar i:nth-child(1) { background: #ff5f57; } .uitool__bar i:nth-child(2) { background: #febc2e; } .uitool__bar i:nth-child(3) { background: #28c840; }
.uitool__bar span { margin-left: auto; font-family: "JetBrains Mono", monospace; font-size: 12px; color: var(--muted); }
.uitool__body { display: flex; height: calc(100% - 36px); }
.uitool__left { width: 50px; border-right: 1px solid var(--stroke); display: flex; flex-direction: column; align-items: center; gap: 11px; padding: 14px 0; }
.uitool__left i { width: 26px; height: 26px; border-radius: 8px; background: #2a3a5e; }
.uitool__left i.on { background: #a78bfa; box-shadow: 0 0 12px rgba(167,139,250,.5); }
.uitool__canvas { flex: 1; position: relative; padding: 18px; }
.uitool__art { position: relative; width: 100%; height: 100%; border-radius: 10px; background: #070d1c; overflow: hidden; }
.uitool__art .nav { position: absolute; top: 14px; left: 16px; width: 60px; height: 12px; border-radius: 6px; background: #2fe6ff; }
.uitool__art .navi { position: absolute; top: 15px; right: 16px; width: 90px; height: 10px; border-radius: 5px; background: #1c2742; }
.uitool__art .hero { position: absolute; top: 40px; left: 16px; right: 16px; height: 42%; border-radius: 12px; background: linear-gradient(150deg, #1f6dff, #6366f1); }
.uitool__art .hero::after { content: ""; position: absolute; left: 16px; bottom: 16px; width: 46%; height: 14px; border-radius: 7px; background: rgba(255,255,255,.85); }
.uitool__art .c { position: absolute; bottom: 16px; height: 26%; border-radius: 10px; background: #101a32; }
.uitool__art .c1 { left: 16px; width: 44%; } .uitool__art .c2 { right: 16px; width: 44%; }
.uitool__sel { position: absolute; top: 36px; left: 12px; right: 12px; height: calc(42% + 8px); border: 1.5px dashed #a78bfa; border-radius: 12px; animation: uiSel 4s ease-in-out infinite; }
.uitool__sel b { position: absolute; width: 7px; height: 7px; background: #a78bfa; border-radius: 1px; }
.uitool__sel b:nth-child(1){ top:-4px;left:-4px; } .uitool__sel b:nth-child(2){ top:-4px;right:-4px; } .uitool__sel b:nth-child(3){ bottom:-4px;left:-4px; } .uitool__sel b:nth-child(4){ bottom:-4px;right:-4px; }
@keyframes uiSel { 0%,100% { opacity: .5; } 50% { opacity: 1; } }
.uitool__cursor { position: absolute; width: 16px; height: 16px; z-index: 5; background: #fff; clip-path: polygon(0 0, 100% 45%, 45% 55%, 55% 100%); filter: drop-shadow(0 2px 3px rgba(0,0,0,.5)); animation: uiCur 5s ease-in-out infinite; }
@keyframes uiCur { 0% { left: 30%; top: 30%; } 30% { left: 60%; top: 40%; } 55% { left: 45%; top: 70%; } 80% { left: 35%; top: 50%; } 100% { left: 30%; top: 30%; } }
.uitool__right { width: 128px; border-left: 1px solid var(--stroke); padding: 14px; display: flex; flex-direction: column; gap: 12px; }
.uitool__sw { display: flex; gap: 8px; }
.uitool__sw i { width: 26px; height: 26px; border-radius: 7px; }
.uitool__sw i:nth-child(1){ background:#2fe6ff; } .uitool__sw i:nth-child(2){ background:#a78bfa; } .uitool__sw i:nth-child(3){ background:#4ade80; }
.uitool__right .row { height: 10px; border-radius: 5px; background: #1c2742; position: relative; overflow: hidden; }
.uitool__right .row::after { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 40%; background: #a78bfa; border-radius: 5px; animation: uiRow 3s ease-in-out infinite; }
.uitool__right .row:nth-child(3)::after { animation-delay: .5s; width: 65%; } .uitool__right .row:nth-child(4)::after { animation-delay: 1s; width: 30%; }
@keyframes uiRow { 0%,100% { transform: translateX(-12%); } 50% { transform: translateX(0); } }
@media (max-width: 760px) { .uitool__right { display: none; } }

/* --- AKILLI EV: ışıklar + wifi --- */
.sh { position: absolute; inset: 0; display: grid; place-items: center; }
.sh__house { position: relative; width: 150px; height: 120px; }
.sh__roof { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-left: 80px solid transparent; border-right: 80px solid transparent; border-bottom: 46px solid rgba(47,230,255,.18); }
.sh__body { position: absolute; bottom: 0; left: 15px; right: 15px; height: 74px; border: 1px solid var(--stroke-strong); border-radius: 4px; background: rgba(6,10,24,.6); display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding: 10px; }
.sh__body i { border-radius: 4px; background: rgba(255,255,255,.06); animation: winLight 2.6s ease-in-out infinite; }
.sh__body i:nth-child(2) { animation-delay: .6s; } .sh__body i:nth-child(3) { animation-delay: 1.2s; } .sh__body i:nth-child(4) { animation-delay: 1.8s; }
@keyframes winLight { 0%, 100% { background: rgba(255,255,255,.06); } 50% { background: rgba(254,188,46,.55); box-shadow: 0 0 12px rgba(254,188,46,.4); } }
.sh__wifi { position: absolute; top: -38px; left: 50%; transform: translateX(-50%); width: 60px; height: 60px; }
.sh__wifi span { position: absolute; left: 50%; bottom: 0; transform: translateX(-50%); border: 2px solid var(--cyan); border-bottom: 0; border-radius: 50% 50% 0 0; opacity: 0; animation: wifi 2.4s ease-out infinite; }
.sh__wifi span:nth-child(1) { width: 16px; height: 8px; } .sh__wifi span:nth-child(2) { width: 34px; height: 17px; animation-delay: .3s; } .sh__wifi span:nth-child(3) { width: 54px; height: 27px; animation-delay: .6s; }
@keyframes wifi { 0% { opacity: 0; } 50% { opacity: 1; } 100% { opacity: 0; } }

/* --- FİBER: ışık darbeleri --- */
.sf { position: absolute; inset: 0; overflow: hidden; }
.sf__line { position: absolute; left: -10%; right: -10%; height: 2px; background: var(--stroke-strong); }
.sf__line:nth-child(1) { top: 30%; transform: rotate(-8deg); } .sf__line:nth-child(2) { top: 50%; } .sf__line:nth-child(3) { top: 70%; transform: rotate(8deg); }
.sf__line::after { content: ""; position: absolute; top: -2px; left: 0; width: 50px; height: 6px; border-radius: 6px; background: linear-gradient(90deg, transparent, var(--cyan), #fff, var(--cyan), transparent); filter: blur(.5px); animation: pulseX 2.4s linear infinite; }
.sf__line:nth-child(2)::after { animation-delay: .8s; background: linear-gradient(90deg, transparent, var(--indigo), #fff, var(--indigo), transparent); }
.sf__line:nth-child(3)::after { animation-delay: 1.5s; background: linear-gradient(90deg, transparent, #4ade80, #fff, #4ade80, transparent); }
@keyframes pulseX { 0% { left: -15%; } 100% { left: 100%; } }
.sf__core { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 70px; height: 70px; border-radius: 50%; background: var(--grad-soft); border: 1px solid var(--stroke-strong); display: grid; place-items: center; font-family: "JetBrains Mono", monospace; color: var(--cyan); font-size: 13px; z-index: 3; }

@media (max-width: 760px) {
  .stat strong, .hero-metrics .m strong, .detail-metrics .dm strong { white-space: normal; }
}
