/* ============================================================
   nfcgoo.com — Modern Anasayfa tasarımı (hp- önekli)
   Yeşil #5E9A00 paleti. Sadece anasayfa/homepage'de yüklenir.
   Header fixed (50px) olduğu için hero üstten boşluklu.
   ============================================================ */

.hp { --hp-green:#5E9A00; --hp-green-dark:#4d8000; --hp-green-soft:#eef6e2; --hp-ink:#2f3032; --hp-muted:#80868b; --hp-line:#e8e8ea; --hp-bg:#f5f6f4; }
.hp, .hp * { box-sizing:border-box; }
.hp { color:var(--hp-ink); -webkit-font-smoothing:antialiased; font-family:"Raleway", "Helvetica", Arial, sans-serif; }
.hp-wrap { max-width:1120px; margin:0 auto; padding:0 22px; }

/* Butonlar */
.hp-btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; font-size:15px; font-weight:700; font-family:inherit; text-decoration:none; padding:14px 28px; border-radius:12px; border:1px solid transparent; cursor:pointer; transition:transform .15s, box-shadow .15s, background .15s, color .15s; }
.hp-btn svg { width:18px; height:18px; }
.hp-btn-primary { background:var(--hp-green); color:#fff; }
.hp-btn-primary:hover { background:var(--hp-green-dark); transform:translateY(-2px); box-shadow:0 12px 26px rgba(94,154,0,.28); }
.hp-btn-light { background:#fff; color:var(--hp-green-dark); }
.hp-btn-light:hover { transform:translateY(-2px); box-shadow:0 12px 26px rgba(0,0,0,.16); }
.hp-btn-outline { background:transparent; color:#fff; border-color:rgba(255,255,255,.55); }
.hp-btn-outline:hover { background:rgba(255,255,255,.12); }
.hp-btn-ghost { background:#fff; color:var(--hp-ink); border-color:var(--hp-line); }
.hp-btn-ghost:hover { background:#f4f5f3; }

/* ---------- HERO ---------- */
.hp-hero { position:relative; overflow:hidden; background:linear-gradient(135deg,#5E9A00 0%, #4d8000 55%, #3f6a00 100%); color:#fff; padding:120px 0 80px; }
.hp-hero::before { content:""; position:absolute; top:-120px; right:-120px; width:480px; height:480px; border-radius:50%; background:rgba(255,255,255,.08); }
.hp-hero::after { content:""; position:absolute; bottom:-160px; left:-100px; width:420px; height:420px; border-radius:50%; background:rgba(0,0,0,.06); }
.hp-hero-inner { position:relative; display:grid; grid-template-columns:1.1fr .9fr; gap:36px; align-items:center; }
.hp-hero-tag { display:inline-flex; align-items:center; gap:7px; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.32); font-size:12.5px; font-weight:600; padding:7px 14px; border-radius:999px; margin-bottom:18px; }
.hp-hero-tag span { width:7px; height:7px; border-radius:50%; background:#bff06a; display:inline-block; }
.hp-hero h1 { font-size:46px; line-height:1.08; font-weight:800; letter-spacing:-1px; margin:0 0 18px; }
.hp-hero p { font-size:17.5px; line-height:1.6; opacity:.94; margin:0 0 28px; max-width:520px; }
.hp-hero-cta { display:flex; gap:13px; flex-wrap:wrap; }
.hp-hero-media { text-align:center; }
.hp-hero-media img { max-height:430px; max-width:100%; filter:drop-shadow(0 30px 50px rgba(0,0,0,.35)); }

/* ---------- 3D ürün slider (hero) ---------- */
.hp3d-hero { position:relative; overflow:hidden; background:linear-gradient(135deg,#5E9A00 0%, #4d8000 55%, #3f6a00 100%); color:#fff; padding:104px 0 56px; }
.hp3d-hero::before { content:""; position:absolute; top:-140px; right:-120px; width:460px; height:460px; border-radius:50%; background:rgba(255,255,255,.07); }
.hp3d-hero::after { content:""; position:absolute; bottom:-180px; left:-120px; width:420px; height:420px; border-radius:50%; background:rgba(0,0,0,.06); }
.hp3d-top { position:relative; z-index:2; text-align:center; max-width:700px; margin:0 auto 18px; padding:0 20px; }
.hp3d-tag { display:inline-flex; align-items:center; gap:7px; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.32); font-size:12.5px; font-weight:600; padding:7px 14px; border-radius:999px; margin-bottom:16px; }
.hp3d-tag span { width:7px; height:7px; border-radius:50%; background:#bff06a; }
.hp3d-hero h1 { font-size:40px; line-height:1.1; font-weight:800; letter-spacing:-.8px; margin:0 0 12px; }
.hp3d-hero .hp3d-sub { font-size:16.5px; line-height:1.55; opacity:.92; margin:0; }

.hp3d-stage { position:relative; z-index:2; height:360px; margin:18px auto 0; max-width:1040px; perspective:1500px; touch-action:pan-y; }
.hp3d-track { position:relative; width:100%; height:100%; transform-style:preserve-3d; }
.hp3d-card { position:absolute; top:50%; left:50%; width:262px; height:300px; transform:translate(-50%,-50%); transform-origin:center center; transition:transform .55s cubic-bezier(.2,.7,.2,1), opacity .45s; background:#fff; border-radius:22px; box-shadow:0 30px 60px rgba(0,0,0,.32); overflow:hidden; cursor:pointer; will-change:transform, opacity; }
.hp3d-card.is-active { cursor:default; }
.hp3d-card-img { height:198px; display:flex; align-items:center; justify-content:center; background:linear-gradient(180deg,#fafbf8,#eef1e8); padding:22px; }
.hp3d-card-img img { max-height:150px; max-width:80%; object-fit:contain; filter:drop-shadow(0 14px 20px rgba(0,0,0,.16)); }
.hp3d-card-info { padding:16px 16px 18px; text-align:center; color:#2f3032; }
.hp3d-card-info h3 { font-size:17px; font-weight:800; margin:0 0 4px; }
.hp3d-card-info p { font-size:12.5px; color:#80868b; margin:0 0 12px; min-height:32px; }
.hp3d-card-info a { display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:700; color:#fff; background:#5E9A00; text-decoration:none; padding:9px 18px; border-radius:9px; transition:background .15s; }
.hp3d-card-info a:hover { background:#4d8000; }
.hp3d-card-info a svg { width:14px; height:14px; }

.hp3d-nav { position:absolute; top:50%; transform:translateY(-50%); z-index:200; width:46px; height:46px; border-radius:50%; border:none; background:rgba(255,255,255,.95); color:#2f3032; font-size:24px; line-height:1; cursor:pointer; box-shadow:0 10px 24px rgba(0,0,0,.25); transition:transform .15s, background .15s; display:flex; align-items:center; justify-content:center; }
.hp3d-nav:hover { background:#fff; transform:translateY(-50%) scale(1.07); }
.hp3d-nav.prev { left:8px; } .hp3d-nav.next { right:8px; }
.hp3d-dots { position:relative; z-index:2; display:flex; gap:8px; justify-content:center; margin-top:24px; }
.hp3d-dots button { width:9px; height:9px; padding:0; border:none; border-radius:50%; background:rgba(255,255,255,.45); cursor:pointer; transition:width .25s, background .25s; }
.hp3d-dots button.is-on { background:#fff; width:26px; border-radius:5px; }
.hp3d-cta { position:relative; z-index:2; display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:26px; }
.hp3d-hint { position:relative; z-index:2; text-align:center; font-size:12px; opacity:.7; margin-top:14px; }

@media (max-width:768px) {
  .hp3d-hero { padding:92px 0 48px; }
  .hp3d-hero h1 { font-size:30px; }
  .hp3d-stage { height:330px; perspective:1100px; }
  .hp3d-card { width:230px; height:280px; }
  .hp3d-card-img { height:178px; }
}
@media (max-width:560px) {
  .hp3d-hero h1 { font-size:25px; }
  .hp3d-hero .hp3d-sub { font-size:14.5px; }
  .hp3d-stage { height:320px; }
  .hp3d-card { width:210px; height:272px; }
  .hp3d-nav { width:40px; height:40px; font-size:21px; }
  .hp3d-hint { display:none; }
}

/* ---------- Güven / logolar şeridi ---------- */
.hp-trust { background:#fff; border-bottom:1px solid var(--hp-line); padding:26px 0; }
.hp-trust p { text-align:center; font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--hp-muted); margin:0 0 16px; font-weight:600; }
.hp-trust-logos { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:34px; }
.hp-trust-logos img { height:34px; opacity:.55; filter:grayscale(1); transition:opacity .2s, filter .2s; }
.hp-trust-logos img:hover { opacity:1; filter:grayscale(0); }

/* ---------- Bölüm başlığı ---------- */
.hp-section { padding:74px 0; background:var(--hp-bg); }
.hp-section.alt { background:#fff; }
.hp-head { text-align:center; max-width:640px; margin:0 auto 46px; }
.hp-head .hp-kicker { display:inline-block; font-size:13px; font-weight:700; color:var(--hp-green); text-transform:uppercase; letter-spacing:.06em; margin-bottom:10px; }
.hp-head h2 { font-size:33px; font-weight:800; letter-spacing:-.5px; margin:0 0 12px; }
.hp-head p { font-size:16px; line-height:1.6; color:var(--hp-muted); margin:0; }

/* ---------- Özellikler grid ---------- */
.hp-feat-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(250px,1fr)); gap:20px; }
.hp-feat { background:#fff; border:1px solid var(--hp-line); border-radius:16px; padding:24px; transition:transform .16s, box-shadow .16s, border-color .16s; }
.hp-feat:hover { transform:translateY(-4px); box-shadow:0 14px 34px rgba(16,24,40,.09); border-color:#dce6cc; }
.hp-feat-ico { width:50px; height:50px; border-radius:13px; background:var(--hp-green-soft); color:var(--hp-green); display:flex; align-items:center; justify-content:center; margin-bottom:15px; }
.hp-feat-ico svg { width:25px; height:25px; }
.hp-feat h3 { font-size:16.5px; font-weight:700; margin:0 0 7px; }
.hp-feat p { font-size:13.5px; line-height:1.55; color:var(--hp-muted); margin:0; }

/* ---------- Nasıl çalışır ---------- */
.hp-steps { display:grid; grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); gap:24px; counter-reset:step; }
.hp-step { position:relative; background:#fff; border:1px solid var(--hp-line); border-radius:18px; padding:32px 24px 26px; text-align:center; }
.hp-step-num { width:46px; height:46px; margin:0 auto 16px; border-radius:50%; background:var(--hp-green); color:#fff; font-size:19px; font-weight:800; display:flex; align-items:center; justify-content:center; }
.hp-step h3 { font-size:17px; font-weight:700; margin:0 0 8px; }
.hp-step p { font-size:14px; line-height:1.55; color:var(--hp-muted); margin:0; }

/* ---------- Ürünler ---------- */
.hp-prod-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(230px,1fr)); gap:22px; }
.hp-prod { display:flex; flex-direction:column; background:#fff; border:1px solid var(--hp-line); border-radius:18px; overflow:hidden; box-shadow:0 1px 2px rgba(16,24,40,.04); transition:transform .18s, box-shadow .18s; text-decoration:none; color:var(--hp-ink); }
.hp-prod:hover { transform:translateY(-5px); box-shadow:0 16px 40px rgba(16,24,40,.12); }
.hp-prod-media { height:190px; display:flex; align-items:center; justify-content:center; padding:24px; background:linear-gradient(180deg,#fafbf8,#eef1e8); }
.hp-prod-media img { max-height:138px; max-width:78%; object-fit:contain; filter:drop-shadow(0 12px 18px rgba(0,0,0,.12)); }
.hp-prod-body { padding:18px 20px 22px; text-align:center; }
.hp-prod-body h3 { font-size:16.5px; font-weight:700; margin:0 0 6px; }
.hp-prod-body p { font-size:13px; line-height:1.5; color:var(--hp-muted); margin:0 0 12px; }
.hp-prod-link { font-size:13.5px; font-weight:700; color:var(--hp-green-dark); display:inline-flex; align-items:center; gap:5px; }

/* ---------- Tek dokunuşla paylaşım showcase ---------- */
.hp-touch { background:radial-gradient(120% 120% at 80% 0%, #3a3b3d 0%, #2a2b2c 45%, #1c1d1e 100%); color:#fff; padding:78px 0; overflow:hidden; }
.hp-touch-inner { display:grid; grid-template-columns:.95fr 1.05fr; gap:44px; align-items:center; }
.hp-touch-text .hp-kicker { color:#9fe04a; }
.hp-touch-text h2 { font-size:33px; font-weight:800; letter-spacing:-.5px; margin:0 0 14px; }
.hp-touch-text > p { font-size:16px; line-height:1.6; opacity:.84; margin:0 0 24px; max-width:520px; }
.hp-touch-list { list-style:none; padding:0; margin:0 0 28px; display:grid; grid-template-columns:1fr 1fr; gap:14px 24px; }
.hp-touch-list li { display:flex; align-items:flex-start; gap:10px; font-size:14.5px; line-height:1.45; }
.hp-touch-list li svg { width:21px; height:21px; flex-shrink:0; color:#9fe04a; margin-top:1px; }

/* NFC tap görseli */
.hp-touch-visual { display:flex; align-items:center; justify-content:center; }
.hp-touch-scene { position:relative; width:300px; height:380px; display:flex; align-items:center; justify-content:center; }
.hp-touch-scene img { position:relative; z-index:2; max-height:360px; max-width:100%; filter:drop-shadow(0 26px 44px rgba(0,0,0,.5)); }
.hp-touch-glow { position:absolute; z-index:1; top:50%; left:50%; width:240px; height:240px; transform:translate(-50%,-50%); border-radius:50%; background:radial-gradient(circle, rgba(94,154,0,.55) 0%, rgba(94,154,0,0) 70%); }
.hp-wave { position:absolute; z-index:1; top:50%; left:50%; width:130px; height:130px; border:2px solid rgba(159,224,74,.65); border-radius:50%; transform:translate(-50%,-50%) scale(.4); opacity:0; animation:hpWave 2.8s cubic-bezier(.2,.6,.3,1) infinite; }
.hp-wave:nth-child(2) { animation-delay:.9s; }
.hp-wave:nth-child(3) { animation-delay:1.8s; }
@keyframes hpWave { 0% { transform:translate(-50%,-50%) scale(.4); opacity:.85; } 80% { opacity:.12; } 100% { transform:translate(-50%,-50%) scale(2.7); opacity:0; } }
@media (prefers-reduced-motion: reduce) { .hp-wave { animation:none; opacity:.25; } }
.hp-touch-badge { position:absolute; z-index:3; bottom:34px; right:-6px; background:#fff; color:#2f3032; border-radius:14px; padding:11px 14px; box-shadow:0 14px 30px rgba(0,0,0,.3); display:flex; align-items:center; gap:9px; font-size:13px; font-weight:700; }
.hp-touch-badge .hp-touch-badge-ico { width:30px; height:30px; border-radius:9px; background:var(--hp-green-soft); color:var(--hp-green); display:flex; align-items:center; justify-content:center; }
.hp-touch-badge .hp-touch-badge-ico svg { width:17px; height:17px; }
.hp-touch-badge small { display:block; font-size:11px; font-weight:500; color:var(--hp-muted); }

/* ---------- Kurumsal teaser (görsel + animasyon) ---------- */
.hp-corp { background:var(--hp-bg); padding:72px 0; }
.hp-corp-box { position:relative; overflow:hidden; padding:46px; display:grid; grid-template-columns:1.05fr .95fr; gap:36px; align-items:center; }
.hp-corp-text h2 { font-size:28px; font-weight:800; margin:6px 0 12px; letter-spacing:-.4px; }
.hp-corp-text > p { font-size:15.5px; line-height:1.6; color:var(--hp-muted); margin:0 0 20px; max-width:460px; }
.hp-corp-list { list-style:none; padding:0; margin:0 0 26px; display:flex; flex-direction:column; gap:11px; }
.hp-corp-list li { display:flex; align-items:center; gap:10px; font-size:14.5px; font-weight:500; color:var(--hp-ink); }
.hp-corp-list li svg { width:19px; height:19px; color:var(--hp-green); flex-shrink:0; }

/* Animasyonlu ekip kartları */
.hp-corp-visual { position:relative; min-height:300px; display:flex; align-items:center; justify-content:center; }
.hp-corp-cards { position:relative; width:100%; max-width:330px; display:flex; flex-direction:column; gap:16px; }
.hp-corp-card { display:flex; align-items:center; gap:14px; background:#fff; border:1px solid var(--hp-line); border-radius:16px; padding:13px 16px; box-shadow:0 12px 28px rgba(16,24,40,.10); animation:hpFloat 4s ease-in-out infinite; animation-delay:var(--d,0s); }
.hp-corp-card:nth-child(2) { margin-left:36px; }
.hp-corp-card:nth-child(3) { margin-left:16px; }
.hp-corp-ava { width:44px; height:44px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:15px; color:#fff; background:linear-gradient(135deg,#5E9A00,#4d8000); }
.hp-corp-card:nth-child(2) .hp-corp-ava { background:linear-gradient(135deg,#3d8bbd,#2f6f99); }
.hp-corp-card:nth-child(3) .hp-corp-ava { background:linear-gradient(135deg,#c9772e,#a85f1f); }
.hp-corp-meta { flex:1; min-width:0; }
.hp-corp-name { display:block; font-size:14.5px; font-weight:700; color:var(--hp-ink); }
.hp-corp-role { display:block; font-size:12.5px; color:var(--hp-muted); }
.hp-corp-nfc { width:27px; height:27px; border-radius:8px; background:var(--hp-green-soft); color:var(--hp-green); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.hp-corp-nfc svg { width:15px; height:15px; }
.hp-corp-chip { position:absolute; bottom:-4px; right:0; background:#2f3032; color:#fff; border-radius:13px; padding:10px 14px; font-size:12.5px; font-weight:700; display:flex; align-items:center; gap:8px; box-shadow:0 14px 30px rgba(0,0,0,.24); animation:hpFloat 4.6s ease-in-out infinite; animation-delay:1s; }
.hp-corp-chip svg { width:16px; height:16px; color:#9fe04a; }
@keyframes hpFloat { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-9px); } }
@media (prefers-reduced-motion: reduce) { .hp-corp-card, .hp-corp-chip { animation:none; } }

/* ---------- App ---------- */
.hp-app { background:#fff; padding:60px 0; text-align:center; }
.hp-app h2 { font-size:26px; font-weight:800; margin:0 0 10px; }
.hp-app p { font-size:15px; color:var(--hp-muted); margin:0 0 24px; }
.hp-app-badges { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.hp-app-badges a { transition:transform .15s; }
.hp-app-badges a:hover { transform:translateY(-3px); }
.hp-app-badges img { height:52px; }

/* ---------- Son CTA ---------- */
.hp-cta { background:linear-gradient(135deg,#5E9A00,#4d8000); color:#fff; text-align:center; padding:72px 22px; }
.hp-cta h2 { font-size:32px; font-weight:800; margin:0 0 12px; letter-spacing:-.5px; }
.hp-cta p { font-size:16.5px; opacity:.93; margin:0 0 26px; }

/* ---------- Responsive ---------- */
@media (max-width:880px) {
  .hp-hero-inner { grid-template-columns:1fr; text-align:center; }
  .hp-hero p { margin-left:auto; margin-right:auto; }
  .hp-hero-cta { justify-content:center; }
  .hp-hero-media { order:-1; }
  .hp-hero-media img { max-height:300px; }
  .hp-corp-box { grid-template-columns:1fr; }
  .hp-corp-text { text-align:center; }
  .hp-corp-list { max-width:290px; margin:0 auto 24px; }
  .hp-corp-cards { margin:0 auto; }
  .hp-corp-card { margin-left:0 !important; }
  .hp-corp-visual { min-height:auto; margin-top:6px; }
  .hp-corp-chip { position:static; margin:14px auto 0; width:max-content; }
  .hp-touch-inner { grid-template-columns:1fr; text-align:center; }
  .hp-touch-text > p { margin-left:auto; margin-right:auto; }
  .hp-touch-list { max-width:460px; margin-left:auto; margin-right:auto; text-align:left; }
  .hp-touch-visual { order:-1; }
}
@media (max-width:560px) {
  .hp-hero { padding:96px 0 56px; }
  .hp-hero h1 { font-size:33px; }
  .hp-hero p { font-size:15.5px; }
  .hp-section, .hp-corp { padding:52px 0; }
  .hp-head h2 { font-size:26px; }
  .hp-cta h2 { font-size:25px; }
  .hp-corp-box { padding:30px 22px; }
  .hp-trust-logos { gap:22px; }
  .hp-trust-logos img { height:26px; }
  .hp-touch-text h2 { font-size:25px; }
  .hp-touch-list { grid-template-columns:1fr; }
  .hp-touch-scene { width:240px; height:300px; }
  .hp-touch-scene img { max-height:280px; }
}

/* ============================================================
   Video hero (Apple ürün sayfası tarzı) + scroll reveal + yatay slider
   ============================================================ */
.hpv-hero { position:relative; height:100vh; height:100svh; min-height:760px; overflow:hidden; background:#0a0a0a; }
.hpv-video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; }
.hpv-overlay { position:absolute; inset:0; z-index:2; background:linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,0) 36%, rgba(0,0,0,.76) 100%); }
.hpv-content { position:absolute; z-index:3; left:0; right:0; bottom:0; color:#f5f5f7; padding:64px 0; }
.hpv-marquee { width:min(100% - 88px, 1440px); margin:0 auto; display:flex; align-items:flex-end; justify-content:space-between; gap:50px; }
.hpv-header { max-width:44em; min-width:0; }
.hpv-product { display:block; margin:0 0 14px; color:#f5f5f7; font-size:21px; line-height:1.19048; font-weight:600; letter-spacing:0; }
.hpv-content h1 { color:#f5f5f7; font-size:64px; line-height:1.0625; font-weight:600; letter-spacing:0; margin:0; }
.hpv-tag { font-size:clamp(18px, 2.4vw, 27px); font-weight:400; line-height:1.25; margin:0 0 20px; }
.hpv-links { display:flex; gap:32px; justify-content:center; flex-wrap:wrap; }
.hpv-links a { font-size:21px; font-weight:400; color:#9fe04a; text-decoration:none; display:inline-flex; align-items:center; }
.hpv-links a:hover { text-decoration:underline; }
.hpv-chev { margin-left:2px; font-weight:600; display:inline-block; transition:transform .2s; }
.hpv-links a:hover .hpv-chev { transform:translateX(3px); }
.hpv-detail { position:relative; color:#f5f5f7; padding:10px; padding-left:24px; flex:0 0 auto; max-width:520px; }
.hpv-detail::before { content:""; position:absolute; inset:0; z-index:0; border-radius:100vmax; background:rgba(66,66,69,.25); -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px); }
.hpv-detail-in { position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:34px; }
.hpv-detail p { color:#f5f5f7; font-size:17px; line-height:1.23536; font-weight:400; letter-spacing:0; margin:0; max-width:330px; }
.hpv-buy { display:inline-flex; align-items:center; justify-content:center; min-width:92px; min-height:36px; padding:8px 18px; border-radius:980px; background:#f5f5f7; color:#1d1d1f; font-size:14px; line-height:1.14286; font-weight:400; letter-spacing:0; text-decoration:none; white-space:nowrap; transition:background .18s ease, color .18s ease; }
.hpv-buy:hover { background:#fff; color:#000; text-decoration:none; }
.hpv-cta { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.hpv-scroll { position:absolute; z-index:3; bottom:26px; left:50%; transform:translateX(-50%); color:#fff; opacity:.85; text-decoration:none; font-size:12px; display:flex; flex-direction:column; align-items:center; gap:6px; letter-spacing:.04em; }
.hpv-scroll svg { width:22px; height:22px; animation:hpvBounce 1.8s infinite; }
@keyframes hpvBounce { 0%,100% { transform:translateY(0); } 50% { transform:translateY(7px); } }
@media (max-width:1068px) {
  .hpv-hero { min-height:680px; }
  .hpv-marquee { width:min(100% - 64px, 1068px); gap:32px; }
  .hpv-header { max-width:29em; }
  .hpv-content h1 { font-size:56px; line-height:1.07143; }
}
@media (max-width:734px) {
  .hpv-hero { min-height:520px; max-height:850px; }
  .hpv-content { padding:32px 0 0; }
  .hpv-marquee { width:min(100% - 44px, 734px); display:block; }
  .hpv-header { max-width:20em; }
  .hpv-product { font-size:17px; line-height:1.23536; margin-bottom:7px; }
  .hpv-content h1 { font-size:32px; line-height:1.125; }
  .hpv-detail { width:100%; max-width:none; margin-top:24px; padding:18px 0; }
  .hpv-detail::before { width:101vw; margin-left:calc(101vw / -2 + 50%); border-radius:0; }
  .hpv-detail-in { gap:28px; }
  .hpv-detail p { font-size:14px; line-height:1.28577; max-width:none; }
  .hpv-buy { min-height:32px; padding:7px 15px; font-size:13px; }
  .hpv-scroll { display:none; }
}
@media (max-width:420px) {
  .hpv-marquee { width:calc(100% - 32px); }
  .hpv-detail-in { align-items:flex-start; flex-direction:column; gap:12px; }
}

/* Scroll reveal (yalnızca JS + IntersectionObserver destekliyse aktif) */
.hp-anim .hp-section,
.hp-anim .hp-touch,
.hp-anim .hp-corp,
.hp-anim .hp-app,
.hp-anim .hp-cta,
.hp-anim .hph-section,
.hp-anim .hp-trust {
  opacity:0; transform:translateY(34px);
  transition:opacity .7s ease, transform .8s cubic-bezier(.2,.7,.2,1);
  will-change:opacity, transform;
}
.hp-anim .in-view { opacity:1 !important; transform:none !important; }
@media (prefers-reduced-motion: reduce) {
  .hp-anim .hp-section, .hp-anim .hp-touch, .hp-anim .hp-corp, .hp-anim .hp-app, .hp-anim .hp-cta, .hp-anim .hph-section, .hp-anim .hp-trust { opacity:1; transform:none; transition:none; }
  .hpv-scroll svg { animation:none; }
}

/* Yatay vurgu slider (Apple highlights) */
.hph-section { background:#fff; padding:74px 0 64px; --hph-sticky-top:92px; --hph-scroll-distance:0px; }
.hph-pin { width:100%; }
.hph-viewport { width:100%; overflow:visible; }
.hph-scroller { display:flex; gap:20px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 22px 26px; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.hph-scroller::-webkit-scrollbar { display:none; }
.hph-card { scroll-snap-align:center; flex:0 0 min(86vw, 1260px); min-height:680px; border-radius:28px; overflow:hidden; position:relative; color:#f5f5f7; display:block; padding:0; }
.hph-card .hph-bg { position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; transition:transform .6s ease; }
.hph-card:hover .hph-bg { transform:scale(1.05); }
.hph-card::after { content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(90deg, rgba(0,0,0,.58) 0%, rgba(0,0,0,.16) 48%, rgba(0,0,0,.03) 100%); }
.hph-card-in { position:absolute; z-index:2; top:50%; left:64px; transform:translateY(-50%); max-width:520px; }
.hph-k { display:none; }
.hph-card h3 { color:#f5f5f7; font-size:28px; line-height:1.14286; font-weight:600; letter-spacing:0; margin:0; }
.hph-card p { color:#f5f5f7; font-size:56px; line-height:1.1; font-weight:600; letter-spacing:0; opacity:1; margin:0; max-width:520px; }
.hph-hint { text-align:center; font-size:12.5px; color:#86868b; margin-top:6px; }
.hph-section.hph-scroll-ready { min-height:calc(100vh - var(--hph-sticky-top) + var(--hph-scroll-distance)); padding:0; }
.hph-scroll-ready .hph-pin { position:sticky; top:var(--hph-sticky-top); height:calc(100vh - var(--hph-sticky-top)); min-height:560px; display:flex; flex-direction:column; justify-content:center; overflow:hidden; padding:44px 0 36px; box-sizing:border-box; }
.hph-scroll-ready .hp-head { margin-bottom:30px; }
.hph-scroll-ready .hph-viewport { overflow:hidden; }
.hph-scroll-ready .hph-scroller { overflow:visible; scroll-snap-type:none; transform:translate3d(var(--hph-x, 0px), 0, 0); will-change:transform; }
.hph-scroll-ready .hph-card { min-height:clamp(430px, calc(100vh - var(--hph-sticky-top) - 210px), 680px); }
.hph-scroll-ready .hph-hint { margin-top:16px; }
@media (max-width:1068px) {
  .hph-card { flex-basis:min(88vw, 934px); min-height:628px; }
  .hph-card-in { top:48px; left:44px; transform:none; max-width:440px; }
  .hph-card p { font-size:34px; line-height:1.14; max-width:440px; }
  .hph-scroll-ready .hph-card { min-height:clamp(410px, calc(100vh - var(--hph-sticky-top) - 200px), 628px); }
}
@media (max-width:734px) {
  .hph-scroller { gap:14px; padding-left:16px; padding-right:16px; }
  .hph-card { flex-basis:86vw; min-height:480px; border-radius:24px; }
  .hph-card::after { background:linear-gradient(180deg, rgba(0,0,0,.54) 0%, rgba(0,0,0,.08) 64%, rgba(0,0,0,.12) 100%); }
  .hph-card-in { top:26px; left:26px; right:26px; max-width:none; }
  .hph-card p { font-size:22px; line-height:1.2; max-width:none; }
  .hph-scroll-ready .hph-pin { min-height:520px; padding:32px 0 26px; }
  .hph-scroll-ready .hp-head { margin-bottom:22px; }
  .hph-scroll-ready .hph-card { min-height:clamp(340px, calc(100vh - var(--hph-sticky-top) - 170px), 480px); }
}
