/* ============================================================
   FairbanksPay — Mobile & Landscape PWA Fixes
   ============================================================
   Bu dosya, mevcut CSS kurallarını DEĞİŞTİRMEDEN, sadece
   küçük ekran + yatay mod için ek kısıtlamalar getirir.
   Her şey @media koşulları altındadır — masaüstü etkilenmez.
   ============================================================ */

/* PWA standalone modda safe-area desteği (iPhone notch/home bar) */
@supports (padding: env(safe-area-inset-top)) {
  .topbar {
    padding-top: env(safe-area-inset-top, 0) !important;
    padding-left: max(var(--space-4, 16px), env(safe-area-inset-left, 0)) !important;
    padding-right: max(var(--space-4, 16px), env(safe-area-inset-right, 0)) !important;
    height: calc(56px + env(safe-area-inset-top, 0)) !important;
    box-sizing: border-box !important;
  }
  .slide {
    top: calc(56px + env(safe-area-inset-top, 0)) !important;
    padding-bottom: env(safe-area-inset-bottom, 0) !important;
  }
  .deck {
    padding-top: calc(56px + env(safe-area-inset-top, 0)) !important;
  }
}

/* ============================================================
   1) MOBİL YATAY (LANDSCAPE) — telefon yan çevrildi
   max-height 500 → tüm modern telefonlar (iPhone Pro Max dahil)
   ============================================================ */
@media (orientation: landscape) and (max-height: 500px) {

  /* KRİTİK: Slayt'ın KENDİSİ viewport yüksekliğine sığıp kendi içinde scroll yapmalı */
  .slide {
    height: calc(100dvh - 40px) !important;
    max-height: calc(100dvh - 40px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    bottom: auto !important;
    display: none;
  }
  .slide.active { display: flex !important; }

  /* ============ COVER SLIDE ÖZEL DUZELTMELER ============ */
  /* Kapak slaytı yatayda çok büyük — tüm iç padding'leri ve gap'leri agresif düşür */
  .slide.slide-cover .cover-premium-inner {
    padding: 14px 20px 14px !important;
    gap: 8px !important;
    min-height: 0 !important;
    height: 100% !important;
  }
  .slide.slide-cover .cover-premium-top {
    padding-bottom: 6px !important;
    font-size: 8px !important;
    letter-spacing: 0.18em !important;
  }
  .slide.slide-cover .cover-premium-content {
    padding: 8px 0 !important;
    flex: 1 !important;
  }
  .slide.slide-cover .cover-premium-eyebrow {
    font-size: 9px !important;
    margin-bottom: 6px !important;
    gap: 8px !important;
  }
  .slide.slide-cover .cover-premium-eyebrow::before,
  .slide.slide-cover .cover-premium-eyebrow::after {
    width: 18px !important;
  }
  .slide.slide-cover .cover-premium-title {
    font-size: 30px !important;
    line-height: 1 !important;
    margin-bottom: 6px !important;
  }
  .slide.slide-cover .cover-premium-subtitle {
    font-size: 11px !important;
    line-height: 1.35 !important;
    margin-bottom: 10px !important;
    max-width: 100% !important;
  }
  .slide.slide-cover .cover-premium-stats {
    padding: 8px 0 !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 0 !important;
  }
  .slide.slide-cover .cover-premium-stat {
    padding: 0 8px !important;
  }
  .slide.slide-cover .cover-premium-stat-num {
    font-size: 16px !important;
    margin-bottom: 2px !important;
  }
  .slide.slide-cover .cover-premium-stat-label {
    font-size: 7.5px !important;
    letter-spacing: 0.12em !important;
  }
  .slide.slide-cover .cover-premium-bottom {
    margin-top: 10px !important;
    gap: 12px !important;
  }
  /* Dikey şeritleri yatayda gizle (CONFIDENTIAL · ANNO MMXXVI yan yazılar) */
  .slide.slide-cover .vertical-strip {
    display: none !important;
  }
  /* Footer kompakt */
  .slide.slide-cover .slide-footer-full {
    padding: 4px 16px !important;
    font-size: 8px !important;
  }


  /* Topbar daha kompakt — 56→40px, button'lar küçülsün */
  .topbar {
    height: 40px !important;
    padding: 0 10px !important;
    gap: 6px !important;
  }

  /* Topbar butonları (Dashboard, Contents, Present, PDF, Sign Out) */
  .topbar button,
  .topbar .btn,
  .topbar a.btn,
  .topbar .topbar-btn {
    height: 30px !important;
    padding: 0 8px !important;
    font-size: 10.5px !important;
    gap: 4px !important;
    border-radius: 8px !important;
  }
  .topbar button svg,
  .topbar .btn svg,
  .topbar .topbar-btn svg {
    width: 13px !important;
    height: 13px !important;
  }
  /* Sayaç (1/45) küçük */
  .slide-counter,
  .topbar .counter,
  .topbar [class*="counter"] {
    font-size: 10px !important;
  }
  /* Brand mark — sadece logo veya küçük metin */
  .topbar .brand,
  .topbar [class*="brand"] {
    flex-shrink: 1 !important;
    min-width: 0 !important;
  }
  @supports (padding: env(safe-area-inset-top)) {
    .topbar {
      height: calc(40px + env(safe-area-inset-top, 0)) !important;
    }
  }

  .topbar .brand-name,
  .topbar .brand-mark { font-size: 12px !important; }
  .topbar .brand-mark { width: 24px !important; height: 24px !important; }

  /* Slayt kapsayıcı - topbar offset güncelle */
  .slide {
    top: 40px !important;
  }
  .deck {
    padding-top: 40px !important;
    height: 100vh !important;
    height: 100dvh !important;
  }
  @supports (padding: env(safe-area-inset-top)) {
    .slide {
      top: calc(40px + env(safe-area-inset-top, 0)) !important;
    }
    .deck {
      padding-top: calc(40px + env(safe-area-inset-top, 0)) !important;
    }
  }

  /* Slayt-inner: padding'leri agresif şekilde küçült, scroll aç */
  .slide-inner {
    padding: 14px 18px 14px !important;
    gap: 8px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    max-width: 100% !important;
  }

  /* Slayt başlığı / eyebrow — yatayda yer kazan */
  .slide-title {
    font-size: 18px !important;
    line-height: 1.2 !important;
    margin: 0 0 4px !important;
  }
  .slide-eyebrow {
    font-size: 9.5px !important;
    margin: 0 0 4px !important;
  }
  .slide-subtitle {
    font-size: 11px !important;
    line-height: 1.4 !important;
    margin: 0 0 6px !important;
  }

  /* Header bloğu — gap düşür */
  .slide-header { gap: 4px !important; }

  /* Cover slide (kapak) — yatayda taşmasın */
  .slide-cover .slide-inner {
    padding: 12px 16px !important;
    justify-content: center !important;
  }
  .slide-cover .slide-title { font-size: 22px !important; }
  .slide-cover .slide-subtitle { font-size: 12px !important; }
  .slide-cover .stat-value { font-size: 18px !important; }
  .slide-cover .stat-label { font-size: 9px !important; }

  /* İçerik blokları */
  .slide-inner p,
  .slide-inner li {
    font-size: 11.5px !important;
    line-height: 1.45 !important;
  }
  .slide-inner ul, .slide-inner ol { padding-left: 16px !important; }

  /* Footer kompakt */
  .slide-footer-full,
  .slide-footer {
    padding: 4px 12px !important;
    font-size: 9px !important;
  }

  /* Slayt sayacı / progress bar — küçült */
  .slide-counter { font-size: 10px !important; }

  /* Photo card / kart kompozisyonları — yatayda yığılmasın */
  .photo-card { min-height: 90px !important; }

  /* Bullet grid'leri 2 sütunda tut, taşma olursa scroll */
  .bullet-grid {
    gap: 6px !important;
  }
  .bullet-card {
    padding: 6px 10px !important;
    min-height: 0 !important;
  }
  .bullet-card-title { font-size: 11px !important; line-height: 1.25 !important; }
  .bullet-list li { font-size: 10px !important; line-height: 1.35 !important; }

  /* Stat blokları */
  .stat-block { padding: 8px 10px !important; }
  .stat-value { font-size: 16px !important; }
  .stat-label { font-size: 9.5px !important; }

  /* Phase / timeline blokları */
  .phase-block,
  .qa-item,
  .timeline-item { padding: 6px 10px !important; }

  /* Tablolar */
  table { font-size: 10.5px !important; }
  th, td { padding: 4px 6px !important; }

  /* Callout / kutucuklar */
  .callout,
  .callout.dark { padding: 6px 10px !important; }
  .callout-text { font-size: 10.5px !important; line-height: 1.4 !important; }

  /* Erişim kontrolü kilitli kart — yatayda da düzgün */
  .fp-locked-card {
    min-height: 0 !important;
    max-width: 92vw !important;
    padding: 18px 22px !important;
  }
  .fp-locked-card .fp-locked-title {
    font-size: 18px !important;
  }
  .fp-locked-card .fp-locked-desc {
    font-size: 11.5px !important;
  }

  /* Filigran (watermark) */
  .fp-watermark {
    font-size: 8px !important;
    bottom: 4px !important;
  }

  /* Erişim seviyesi rozeti — yatayda topbar'ın altına al, topbar'ın üzerine binmesin */
  .fp-access-badge,
  #fp-access-badge {
    top: auto !important;
    bottom: 6px !important;
    right: 8px !important;
    font-size: 9px !important;
    padding: 2px 7px !important;
    z-index: 50 !important;
  }

  /* Yatay mod uyarı toast'ı yer kaplamasın — gizle, dikeyde göster */
  #fp-disclosure-toast,
  .fp-disclosure-toast {
    display: none !important;
    visibility: hidden !important;
  }

  /* iOS "Ana ekrana ekle" hint'i yatay sunum sırasında görünmesin */
  #fp-ios-hint {
    display: none !important;
  }

  /* Android install butonu yatayda küçük ve sağ altta */
  #fp-install-btn,
  [data-pwa-install] {
    bottom: 6px !important;
    right: 6px !important;
    font-size: 10.5px !important;
    padding: 6px 10px !important;
  }

  /* Ok butonları (önceki/sonraki) — küçük ve dokunmaya uygun */
  .arrow {
    width: 36px !important;
    height: 36px !important;
  }
}

/* ============================================================
   2) MOBİL DİKEY (PORTRAIT) — küçük ekran, ek temizlik
   ============================================================ */
@media (orientation: portrait) and (max-width: 500px) {
  /* Topbar dar ekranda kompakt */
  .topbar {
    height: 50px !important;
    padding: 0 8px !important;
    gap: 4px !important;
  }
  .topbar button,
  .topbar .btn,
  .topbar a.btn {
    padding: 0 8px !important;
    font-size: 11px !important;
    height: 32px !important;
    gap: 3px !important;
  }
  /* Sayaç (1/45) küçük */
  .slide-counter,
  .topbar [class*="counter"] {
    font-size: 10px !important;
  }

  .slide-inner {
    padding: 16px 16px 18px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .slide-title { font-size: 20px !important; line-height: 1.2 !important; }
  .slide-subtitle { font-size: 12px !important; }
  .slide-eyebrow { font-size: 10px !important; }
  .slide-inner p, .slide-inner li { font-size: 12.5px !important; line-height: 1.5 !important; }

  /* Bullet grid mobilde tek sütun */
  .bullet-grid { grid-template-columns: 1fr !important; }

  /* Topbar markası küçük */
  .topbar { height: 52px !important; }
  .slide { top: 52px !important; }
  .deck { padding-top: 52px !important; height: 100dvh !important; }

  /* Erişim kontrolü kilitli kart mobil dikeyde */
  .fp-locked-card {
    max-width: 92vw !important;
    padding: 22px 18px !important;
    min-height: 0 !important;
  }
}

/* ============================================================
   3) GENEL: Her küçük ekranda overflow problemini önle
   ============================================================ */
@media (max-width: 900px) {
  .slide-inner > * {
    max-width: 100% !important;
  }
  /* Yatayda body scroll lock istemiyoruz - slayt-inner kendi scroll yapsın */
  body { overscroll-behavior: contain; }
}
