/* =========================================================
   Mobile Enhance — Tosconime
   Camada adicional carregada DEPOIS de style.css/watch.css.
   Objetivo: dar respiração e adaptar o layout para telas
   pequenas SEM alterar a identidade visual desktop.
   - Não muda cores, fontes, animações ou estrutura geral.
   - Só ajusta espaçamentos, alvos de toque, grids e overflow
     em telas <= 768px.
   ========================================================= */

/* Tablets e celulares */
@media (max-width: 900px) {
  :root {
    /* leve folga geral nas variáveis usadas pelo layout */
    --content-pad-x: clamp(14px, 4vw, 24px);
  }

  /* Container principal: padding lateral consistente */
  .catalog-shell,
  .browse,
  main,
  .hero,
  .hero-featured,
  .hero-layout,
  .card-detail-body,
  .comments-panel {
    padding-left: var(--content-pad-x) !important;
    padding-right: var(--content-pad-x) !important;
    box-sizing: border-box;
  }

  /* Evita scroll horizontal acidental em qualquer página */
  html, body {
    overflow-x: hidden;
  }

  /* Imagens nunca estouram a viewport.
     NÃO aplicar height:auto em iframe/video — quebra o player de vídeo
     que depende de aspect-ratio/altura controlada pelo container. */
  img {
    max-width: 100%;
    height: auto;
  }
  /* Iframes/vídeos genéricos (fora do player) só limitam largura. */
  iframe:not(.embed-player):not([class*="player"]):not([class*="vjs"]),
  video:not(.embed-player):not([class*="player"]):not([class*="vjs"]) {
    max-width: 100%;
  }
  /* Player de vídeo: garante que o wrapper ocupe 100% e o iframe preencha */
  .vjs-player,
  .embed-wrap,
  .player-wrap,
  .video-wrap {
    width: 100% !important;
    max-width: 100% !important;
  }
  .vjs-player iframe,
  .embed-player,
  .embed-wrap iframe,
  .player-wrap iframe {
    width: 100% !important;
    height: 100% !important;
    position: absolute;
    inset: 0;
    border: 0;
  }
  .vjs-player video.vjs-tech,
  .vjs-player #player {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    border: 0;
  }
}

/* ===== Mobile (≤ 768px) ===== */
@media (max-width: 768px) {

  /* ---------- Header ---------- */
  .header {
    padding: 10px var(--content-pad-x, 16px) !important;
  }
  .header-body { gap: 10px !important; }
  .header-row,
  .header-row-top {
    flex-wrap: wrap !important;
    gap: 10px !important;
    row-gap: 10px !important;
  }
  .header-right {
    flex-wrap: wrap !important;
    gap: 8px !important;
    justify-content: flex-end;
  }
  .brand-text { font-size: 1.1rem !important; }
  .brand-icon { width: 32px; height: 32px; }

  /* Tornar botões do header com alvo de toque adequado */
  .header-right button,
  .header-right .news-bell-btn,
  .header-tools-toggle,
  .btn-hide-adult,
  .discord-join-btn,
  .discord-logout-btn {
    min-width: 44px;
    min-height: 44px;
    padding: 8px 12px !important;
  }

  /* ---------- Hero ---------- */
  .hero,
  .hero-featured {
    margin-top: 14px !important;
    padding-top: 18px !important;
    padding-bottom: 22px !important;
  }
  .hero-layout {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }
  .hero-content { text-align: left; }
  .hero-featured-title,
  .hero-title {
    font-size: clamp(1.4rem, 6vw, 2rem) !important;
    line-height: 1.15 !important;
    margin-bottom: 10px !important;
  }
  .hero-featured-synopsis,
  .hero-desc {
    font-size: 0.95rem !important;
    line-height: 1.5 !important;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .hero-featured-actions,
  .hero-actions {
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin-top: 14px !important;
  }
  .btn-hero-primary,
  .btn-hero-secondary {
    flex: 1 1 calc(50% - 5px);
    min-height: 44px;
    justify-content: center;
  }
  .hero-featured-poster {
    max-width: 60%;
    margin: 0 auto;
  }

  /* ---------- Grid de animes ---------- */
  .anime-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important;
    gap: 14px !important;
    padding: 4px 0 !important;
  }
  .anime-grid > * { min-width: 0; }
  .anime-title {
    font-size: 0.9rem !important;
    line-height: 1.3;
    margin-top: 6px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .anime-meta {
    font-size: 0.75rem !important;
    opacity: .8;
  }

  /* ---------- Browse / Filtros ---------- */
  .browse-head {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 12px !important;
    margin-bottom: 14px !important;
  }
  .browse-actions,
  .browse-sort-bar {
    flex-wrap: wrap !important;
    gap: 8px !important;
  }
  .browse-actions > *,
  .browse-sort-bar > * {
    flex: 1 1 auto;
    min-height: 40px;
  }
  .browse-sub {
    font-size: 0.9rem !important;
    opacity: .85;
  }

  /* ---------- Card detail (drawer/modal) ---------- */
  .card-detail-drawer,
  .card-detail-panel {
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 18px 18px 0 0 !important;
  }
  .card-detail-hero {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    padding: 16px !important;
  }
  .card-detail-poster {
    max-width: 60%;
    margin: 0 auto;
  }
  .card-detail-title {
    font-size: 1.3rem !important;
    line-height: 1.2 !important;
  }
  .card-detail-body {
    padding: 16px !important;
  }
  .card-detail-chips {
    flex-wrap: wrap !important;
    gap: 6px !important;
  }
  .card-detail-actions {
    flex-wrap: wrap !important;
    gap: 10px !important;
  }
  .card-detail-actions > * {
    flex: 1 1 calc(50% - 5px);
    min-height: 44px;
    justify-content: center;
  }
  .card-detail-synopsis {
    font-size: 0.95rem !important;
    line-height: 1.55 !important;
  }
  .card-detail-close {
    width: 40px; height: 40px;
    top: 10px; right: 10px;
  }

  /* Recomendações: scroll horizontal com snap */
  .card-detail-recs-track {
    display: flex !important;
    gap: 12px !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px;
  }
  .card-detail-recs-track > * {
    flex: 0 0 45%;
    scroll-snap-align: start;
  }

  /* ---------- Comentários ---------- */
  .comments-panel { padding: 14px !important; }
  .comment-form { gap: 8px !important; }
  .comment-form textarea,
  .comment-form input {
    font-size: 16px !important; /* evita zoom iOS */
  }
  .btn-comment {
    min-height: 44px;
    width: 100%;
  }

  /* ---------- Painel de ferramentas (drawer lateral) ---------- */
  .header-tools-panel {
    width: min(90vw, 320px) !important;
    padding: 16px !important;
    gap: 12px !important;
  }
  .room-quick {
    flex-wrap: wrap !important;
    gap: 8px !important;
  }
  .room-quick > * {
    flex: 1 1 calc(50% - 4px);
    min-height: 40px;
  }
  .room-quick-input { min-width: 0; }

  /* ---------- News panel ---------- */
  .news-panel {
    width: min(92vw, 360px) !important;
    right: 8px !important;
    max-height: 70vh;
  }

  /* ---------- Back to top ---------- */
  .back-to-top {
    width: 46px !important;
    height: 46px !important;
    right: 14px !important;
    bottom: calc(14px + env(safe-area-inset-bottom, 0px)) !important;
  }

  /* ---------- Player (watch.css) ---------- */
  .watch-layout,
  .watch-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  .episode-list {
    max-height: 50vh;
  }
  .episode-item {
    padding: 10px 12px !important;
    min-height: 48px;
  }

  /* Inputs sempre 16px para evitar zoom iOS */
  input[type="text"],
  input[type="search"],
  input[type="email"],
  input[type="password"],
  input[type="number"],
  textarea,
  select {
    font-size: 16px !important;
  }
}

/* ===== Telas muito pequenas (≤ 420px) ===== */
@media (max-width: 420px) {
  .anime-grid {
    grid-template-columns: repeat(auto-fill, minmax(125px, 1fr)) !important;
    gap: 10px !important;
  }
  .brand-text { font-size: 1rem !important; }
  .hero-featured-actions .btn-hero-primary,
  .hero-featured-actions .btn-hero-secondary,
  .card-detail-actions > * {
    flex: 1 1 100%;
  }
  .card-detail-recs-track > * {
    flex: 0 0 60%;
  }
}

/* ===== Safe area iOS (notch) ===== */
@supports (padding: max(0px)) {
  @media (max-width: 768px) {
    .header { padding-top: max(10px, env(safe-area-inset-top)) !important; }
    body {
      padding-left: env(safe-area-inset-left);
      padding-right: env(safe-area-inset-right);
    }
  }
}
