/* ╔══════════════════════════════════════════════════════════════╗
   ║  HX DESIGN SYSTEM — LoadViser Pro (paylaşılan; index + alt sayfalar)
   ╚══════════════════════════════════════════════════════════════╝ */
.hx-root{ --hx-bg:#06101A; --hx-ink:#E7ECF1; --hx-mut:#8DA2B5; --hx-line:rgba(255,255,255,.08); --hx-cyan:#22D3EE;
  position:relative; background:var(--hx-bg); color:var(--hx-ink); font-family:'Inter',system-ui,sans-serif; overflow-x:hidden; }
.hx-root *{ box-sizing:border-box; }
.hx-wrap{ max-width:1200px; margin:0 auto; padding:0 24px; position:relative; z-index:2; }
.hx-narrow{ max-width:880px; }

@keyframes hxAur{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(6%,-4%) scale(1.12)}66%{transform:translate(-5%,5%) scale(.92)}}
@keyframes hxGrid{from{background-position:0 0}to{background-position:48px 48px}}
@keyframes hxShimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes hxUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes hxLive{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}50%{box-shadow:0 0 0 5px rgba(34,197,94,0)}}

.hx-aurora{ position:absolute; width:48vw; height:48vw; max-width:680px; max-height:680px; border-radius:9999px; filter:blur(70px); pointer-events:none; z-index:0; opacity:.6; animation:hxAur 20s ease-in-out infinite; }
.hx-a1{ background:radial-gradient(circle,rgba(10,132,255,.5),transparent 60%); top:-14%; left:-8%; }
.hx-a2{ background:radial-gradient(circle,rgba(168,85,247,.38),transparent 60%); bottom:-18%; right:-8%; animation-duration:24s; animation-delay:-5s; }
.hx-a3{ background:radial-gradient(circle,rgba(201,162,75,.26),transparent 60%); top:30%; left:45%; animation-duration:28s; animation-delay:-9s; }
.hx-a-soft{ background:radial-gradient(circle,rgba(34,211,238,.18),transparent 60%); opacity:.5; }
.hx-grid{ position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image:linear-gradient(rgba(124,179,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(124,179,255,.06) 1px,transparent 1px);
  background-size:48px 48px; animation:hxGrid 10s linear infinite;
  -webkit-mask-image:radial-gradient(120% 90% at 30% 10%,#000 30%,transparent 80%); mask-image:radial-gradient(120% 90% at 30% 10%,#000 30%,transparent 80%); }

.hx-holo{ background:linear-gradient(100deg,#0A84FF 8%,#22D3EE 34%,#C9A24B 60%,#A855F7 86%); background-size:200% auto; -webkit-background-clip:text; background-clip:text; color:transparent; animation:hxShimmer 3s linear infinite; }

/* SUBPAGE HERO */
.hx-subhero{ position:relative; overflow:hidden; padding:118px 0 56px; }
.hx-eyebrow{ display:inline-flex; align-items:center; gap:9px; font-size:12px; font-weight:700; letter-spacing:.18em; color:#CBE3FF; background:rgba(10,132,255,.1); border:1px solid rgba(10,132,255,.28); padding:7px 14px; border-radius:9999px; }
.hx-livedot{ width:8px; height:8px; border-radius:9999px; background:#22C55E; animation:hxLive 2s infinite; display:inline-block; }
.hx-subhero h1{ font-family:'Sora','Inter',sans-serif; font-weight:800; font-size:clamp(2.1rem,4.4vw,3.4rem); line-height:1.06; letter-spacing:-.02em; margin:18px 0 0; color:#fff; }
.hx-subhero .hx-lead{ color:var(--hx-mut); font-size:clamp(1rem,1.4vw,1.16rem); line-height:1.62; max-width:660px; margin:18px 0 0; }

/* BUTTONS */
.hx-cta-row{ display:flex; flex-wrap:wrap; gap:14px; margin-top:28px; }
.hx-btn{ display:inline-flex; align-items:center; gap:9px; padding:13px 24px; border-radius:12px; font-weight:700; font-size:15px; text-decoration:none; transition:transform .15s, box-shadow .2s, background .2s; cursor:pointer; border:none; }
.hx-btn-primary{ color:#fff; background:linear-gradient(135deg,#0A84FF,#0B6FD4 55%,#22D3EE); box-shadow:0 14px 34px -12px rgba(10,132,255,.7); }
.hx-btn-primary:hover{ transform:translateY(-2px); box-shadow:0 20px 44px -12px rgba(10,132,255,.85); }
.hx-btn-ghost{ color:#DCE7F2; border:1px solid var(--hx-line); background:rgba(255,255,255,.03); }
.hx-btn-ghost:hover{ border-color:rgba(10,132,255,.5); color:#fff; }

/* SECTION */
.hx-section{ position:relative; padding:60px 0; overflow:hidden; }
.hx-head{ max-width:720px; margin-bottom:36px; }
.hx-head.center{ margin:0 auto 40px; text-align:center; }
.hx-tag{ font-size:11px; font-weight:800; letter-spacing:.24em; color:var(--hx-cyan); }
.hx-head h2{ font-family:'Sora',sans-serif; font-weight:800; font-size:clamp(1.6rem,3.2vw,2.4rem); line-height:1.14; letter-spacing:-.02em; color:#fff; margin:10px 0 0; }
.hx-head p{ color:var(--hx-mut); font-size:1.02rem; line-height:1.6; margin:14px 0 0; }

.hx-reveal{ opacity:0; }
.hx-reveal.in{ animation:hxUp .7s cubic-bezier(.2,.7,.3,1) both; animation-delay:var(--d,0ms); }

/* CARD GRID (özellik/değer kartları) */
.hx-grid3{ display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:16px; }
.hx-card{ position:relative; padding:22px; border-radius:18px; border:1px solid var(--hx-line); overflow:hidden;
  background:linear-gradient(150deg,rgba(255,255,255,.045),rgba(255,255,255,.012)); transition:transform .3s, border-color .3s; }
.hx-card:hover{ transform:translateY(-5px); border-color:color-mix(in srgb,var(--accent,#0A84FF) 55%,transparent); }
.hx-card::before{ content:""; position:absolute; left:0; top:18px; bottom:18px; width:3px; border-radius:0 4px 4px 0; background:var(--accent,#0A84FF); box-shadow:0 0 16px var(--accent,#0A84FF); }
.hx-card-ico{ width:46px; height:46px; border-radius:13px; display:inline-flex; align-items:center; justify-content:center; color:#fff; font-size:20px;
  background:linear-gradient(135deg,var(--accent,#0A84FF),color-mix(in srgb,var(--accent,#0A84FF) 45%,transparent)); box-shadow:0 8px 22px -8px var(--accent,#0A84FF); }
.hx-card h3{ font-family:'Sora',sans-serif; font-weight:700; font-size:1.06rem; color:#fff; margin:14px 0 7px; }
.hx-card p{ color:var(--hx-mut); font-size:.9rem; line-height:1.55; margin:0; }

/* PROSE (yasal/içerik metin sayfaları) */
.hx-prose{ max-width:820px; color:var(--hx-mut); font-size:1.02rem; line-height:1.72; }
.hx-prose h2{ font-family:'Sora',sans-serif; color:#fff; font-weight:700; font-size:1.4rem; margin:34px 0 12px; letter-spacing:-.01em; }
.hx-prose h3{ color:#dce6f1; font-weight:700; font-size:1.12rem; margin:24px 0 8px; }
.hx-prose p{ margin:0 0 14px; }
.hx-prose a{ color:#4DA3FF; text-decoration:none; } .hx-prose a:hover{ text-decoration:underline; }
.hx-prose ul,.hx-prose ol{ margin:0 0 16px; padding-left:20px; }
.hx-prose li{ margin:6px 0; }
.hx-prose strong{ color:#dce6f1; }
.hx-prose hr{ border:none; border-top:1px solid var(--hx-line); margin:26px 0; }

/* FORM */
.hx-form{ display:flex; flex-direction:column; gap:14px; }
.hx-formcard{ position:relative; background:linear-gradient(160deg,rgba(18,30,44,.82),rgba(9,16,24,.92)); border:1px solid rgba(255,255,255,.08); border-radius:20px; padding:26px; box-shadow:0 36px 90px -34px rgba(0,0,0,.85); }
.hx-formcard::after{ content:""; position:absolute; top:0; left:0; right:0; height:2px; border-radius:20px 20px 0 0; background:linear-gradient(90deg,transparent,#0A84FF,#22D3EE,transparent); }
.hx-field label{ display:block; font-size:12px; color:#c2d0de; margin-bottom:6px; font-weight:600; }
.hx-input{ width:100%; padding:11px 13px; border-radius:11px; background:rgba(8,14,22,.7); border:1px solid rgba(255,255,255,.1); color:#fff; font-size:14px; font-family:inherit; transition:border-color .2s, box-shadow .2s; }
.hx-input:focus{ outline:none; border-color:#0A84FF; box-shadow:0 0 0 3px rgba(10,132,255,.18); }
.hx-input::placeholder{ color:#5b6e80; }

/* FAQ ACCORDION */
.hx-faq{ display:flex; flex-direction:column; gap:12px; max-width:860px; }
.hx-faq details{ border:1px solid var(--hx-line); border-radius:14px; background:rgba(255,255,255,.022); overflow:hidden; transition:border-color .25s; }
.hx-faq details[open]{ border-color:rgba(10,132,255,.4); }
.hx-faq summary{ list-style:none; cursor:pointer; padding:16px 18px; font-family:'Sora',sans-serif; font-weight:600; font-size:1.02rem; color:#fff; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.hx-faq summary::-webkit-details-marker{ display:none; }
.hx-faq summary::after{ content:"+"; font-size:1.4rem; color:var(--hx-cyan); font-weight:400; transition:transform .25s; line-height:1; }
.hx-faq details[open] summary::after{ transform:rotate(45deg); }
.hx-faq .hx-faq-a{ padding:0 18px 18px; color:var(--hx-mut); font-size:.96rem; line-height:1.65; }

/* STATS */
.hx-stats{ display:flex; flex-wrap:wrap; gap:30px; }
.hx-stat b{ display:block; font-family:'Sora',sans-serif; font-size:1.9rem; font-weight:800; color:#fff; line-height:1; background:linear-gradient(180deg,#fff,#9fc4ff); -webkit-background-clip:text; background-clip:text; }
.hx-stat span{ font-size:12px; color:var(--hx-mut); }

@media (prefers-reduced-motion: reduce){
  .hx-aurora,.hx-grid,.hx-holo,.hx-livedot{ animation:none !important; }
  .hx-reveal{ opacity:1 !important; animation:none !important; }
}

/* ── Eski .subhero kullanan sayfaları (cases/legal/features) hx görünümüne map'le ── */
.hx-root .subhero{ position:relative; overflow:hidden; padding:116px 0 52px; background:transparent; }
.hx-root .subhero::before{ content:""; position:absolute; top:-30%; left:-10%; width:48vw; height:48vw; max-width:620px; border-radius:9999px; filter:blur(70px); background:radial-gradient(circle,rgba(10,132,255,.4),transparent 60%); pointer-events:none; z-index:0; }
.hx-root .subhero::after{ content:""; position:absolute; bottom:-30%; right:-8%; width:40vw; height:40vw; max-width:520px; border-radius:9999px; filter:blur(70px); background:radial-gradient(circle,rgba(168,85,247,.3),transparent 60%); pointer-events:none; z-index:0; }
.hx-root .subhero-inner{ position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:0 24px; }
.hx-root .subhero .breadcrumb{ font-size:12px; color:var(--hx-mut); margin-bottom:14px; }
.hx-root .subhero .breadcrumb a{ color:var(--hx-mut); text-decoration:none; }
.hx-root .subhero .eyebrow{ display:inline-flex; align-items:center; font-size:12px; font-weight:700; letter-spacing:.18em; color:#CBE3FF; background:rgba(10,132,255,.1); border:1px solid rgba(10,132,255,.28); padding:7px 14px; border-radius:9999px; }
.hx-root .subhero h1{ font-family:'Sora','Inter',sans-serif; font-weight:800; font-size:clamp(2rem,4.2vw,3.2rem); line-height:1.07; letter-spacing:-.02em; margin:18px 0 0; color:#fff; }
.hx-root .subhero .lead{ color:var(--hx-mut); font-size:clamp(1rem,1.4vw,1.14rem); line-height:1.62; max-width:680px; margin:16px 0 0; }
.hx-root .section,.hx-root .section-tight{ position:relative; z-index:2; }
