@media (max-width: 1024px) {
  .app-shell {
    padding:
      calc(16px + env(safe-area-inset-top))
      calc(16px + env(safe-area-inset-right))
      calc(16px + env(safe-area-inset-bottom))
      calc(16px + env(safe-area-inset-left));
  }

  .top-bar {
    min-height: 62px;
  }

  .timer-pill {
    font-size: clamp(1.45rem, 4.8vw, 1.9rem);
  }

  .picker-card,
  .result-panel {
    border-radius: 28px;
    padding: 22px;
  }

  .pvp-wait-panel {
    width: min(100%, 640px);
  }

  .picker-card {
    width: min(100%, 760px);
  }

  .result-panel {
    width: min(100%, 640px);
  }

  .screen-result[data-result-mode="daily-summary"] .result-panel {
    padding-left: 22px;
    padding-right: 22px;
    width: min(100%, 680px);
  }

  .preview-square {
    max-width: 520px;
    width: min(100%, 520px);
  }

  .result-compare-square {
    --result-square-size: min(100%, 390px);
  }

  .result-title {
    max-width: 16ch;
  }

  .team-result-board {
    width: min(100%, 500px);
  }

  .pvp-result-list {
    width: min(100%, 720px);
  }

  .pvp-wait-panel {
    width: min(100%, 620px);
  }

  .share-dialog {
    max-width: 520px;
    width: min(100%, 520px);
  }
}

@media (max-width: 720px) {
  .app-shell {
    padding:
      calc(14px + env(safe-area-inset-top))
      calc(14px + env(safe-area-inset-right))
      calc(14px + env(safe-area-inset-bottom))
      calc(14px + env(safe-area-inset-left));
  }

  .top-bar {
    min-height: 54px;
  }

  .timer-pill {
    font-size: clamp(1.3rem, 6vw, 1.65rem);
  }

  .screen-focus {
    padding-top: clamp(20px, 5vh, 48px);
  }

  .hero-panel h1 {
    font-size: clamp(2.8rem, 16vw, 5.6rem);
  }

  .hero-description {
    font-size: 0.97rem;
    margin: -4px 0 6px;
    max-width: 29ch;
  }

  .hero-actions {
    width: 100%;
  }

  .hero-play-cluster {
    gap: 14px;
    width: min(100%, 320px);
  }

  .hero-play-button {
    height: clamp(84px, 25vw, 108px);
    margin-block: 8px 18px;
    width: clamp(84px, 25vw, 108px);
  }

  .hero-play-icon {
    height: clamp(58px, 17vw, 78px);
    margin-left: 4px;
    width: clamp(58px, 17vw, 78px);
  }

  .hero-side-button {
    height: clamp(62px, 18vw, 80px);
    width: clamp(62px, 18vw, 80px);
  }

  .hero-telegram-button {
    height: clamp(58px, 17vw, 74px);
    margin-top: 24px;
    width: clamp(58px, 17vw, 74px);
  }

  .hero-play-cluster .hero-telegram-button {
    margin-top: 0;
  }

  .hero-telegram-icon {
    height: clamp(28px, 8.2vw, 36px);
    width: clamp(28px, 8.2vw, 36px);
  }

  .hero-seo-link {
    font-size: 0.93rem;
  }

  .hero-side-icon {
    height: clamp(28px, 8vw, 34px);
    width: clamp(28px, 8vw, 34px);
  }

  .focus-text {
    font-size: clamp(1.85rem, 9.6vw, 3.15rem);
    max-width: 11ch;
  }

  .pvp-wait-step-card {
    border-radius: 22px;
    padding: 18px 16px;
  }

  .pvp-wait-step-title {
    font-size: clamp(1.45rem, 7vw, 2rem);
  }

  .pvp-wait-loading {
    font-size: clamp(1.05rem, 5.4vw, 1.45rem);
  }

  .pvp-wait-step-copy-note,
  .pvp-wait-step-detail {
    font-size: 0.96rem;
  }

  .pvp-wait-copy-button,
  .pvp-wait-cancel-primary {
    width: 100%;
  }

  .picker-card,
  .result-panel {
    border-radius: 24px;
    padding: 18px;
  }

  .screen-result:not([data-result-mode="team-summary"]):not([data-result-mode="daily-summary"]):not([data-result-mode="pvp-summary"]):not([data-result-mode="team-leaderboard"]) {
    gap: 12px;
    justify-content: center;
    padding-top: calc(8px + env(safe-area-inset-top));
    padding-bottom: calc(12px + env(safe-area-inset-bottom));
  }

  .screen-result:not([data-result-mode="team-summary"]):not([data-result-mode="daily-summary"]):not([data-result-mode="pvp-summary"]):not([data-result-mode="team-leaderboard"]) .result-panel {
    align-content: center;
    flex: 0 0 auto;
    gap: 16px;
    justify-content: center;
    margin-block: 0;
    max-height: none;
    overflow: visible;
    padding-bottom: 22px;
  }

  .screen-result:not([data-result-mode="team-summary"]):not([data-result-mode="daily-summary"]):not([data-result-mode="pvp-summary"]):not([data-result-mode="team-leaderboard"]) .result-actions {
    margin-top: 0;
  }

  .screen-result[data-result-mode="daily-round"] {
    gap: 12px;
    justify-content: center;
    padding-top: calc(8px + env(safe-area-inset-top));
    padding-bottom: calc(8px + env(safe-area-inset-bottom));
  }

  .screen-result[data-result-mode="daily-round"] .result-panel {
    align-content: center;
    gap: 18px;
    justify-content: center;
    justify-items: center;
    margin-block: auto;
    max-height: none;
    overflow: visible;
    padding-top: 22px;
    padding-bottom: 26px;
    width: min(100%, 100%);
  }

  .picker-card,
  .result-panel {
    gap: 20px;
  }

  .preview-square {
    max-width: 420px;
    width: min(100%, 420px);
  }

  .result-title {
    font-size: clamp(1.2rem, 5.8vw, 1.75rem);
    max-width: 17ch;
  }

  .screen-result:not([data-result-mode="team-summary"]):not([data-result-mode="daily-summary"]):not([data-result-mode="pvp-summary"]):not([data-result-mode="team-leaderboard"]) .result-title {
    min-height: clamp(88px, 15vh, 132px);
  }

  .result-compare-square {
    border-radius: 26px;
    --result-square-size: min(100%, 340px);
  }

  .screen-result[data-result-mode="daily-round"] .result-compare-square {
    --result-square-size: min(86vw, 380px);
  }

  .result-half::before,
  .result-half::after {
    font-size: 0.72rem;
  }

  .result-half::before {
    font-size: 0.84rem;
  }

  .result-half::before {
    max-width: 46%;
    right: 14px;
  }

  .result-half::after {
    left: 14px;
  }

  .result-half-target::before,
  .result-half-target::after {
    top: 14px;
  }

  .result-half-selected::before,
  .result-half-selected::after {
    bottom: 14px;
  }

  .result-score-pill {
    min-width: 188px;
    padding: 14px 16px;
  }

  .result-score-pill strong {
    font-size: clamp(1.05rem, 5.6vw, 1.6rem);
  }

  .team-summary-score-pill {
    min-width: 188px;
    padding: 14px 16px;
  }

  .team-summary-score-pill strong {
    font-size: clamp(1.05rem, 5.6vw, 1.6rem);
  }

  .team-summary-attempts,
  .team-result-attempts {
    gap: 8px;
  }

  .team-attempt-tile-summary {
    border-radius: 14px;
  }

  .team-attempt-tile-summary .team-attempt-score {
    font-size: clamp(0.66rem, 2.4vw, 0.82rem);
    min-width: 3.1em;
    padding: 0.34em 0.48em 0.38em;
  }

  .team-attempt-tile-compact {
    border-radius: 10px;
  }

  .team-attempt-tile-compact .team-attempt-score {
    font-size: clamp(0.5rem, 1.9vw, 0.66rem);
    min-width: 3.35em;
    padding: 0.34em 0.48em 0.38em;
  }

  .screen-result[data-result-mode="team-leaderboard"] .team-attempt-tile-compact .team-attempt-score {
    border-radius: 9px;
    font-size: clamp(0.52rem, 2vw, 0.68rem);
    min-width: 3.2em;
    padding: 0.32em 0.44em 0.36em;
  }

  .team-next-button {
    border-radius: 20px;
    height: 74px;
    margin-top: 14px;
    width: 74px;
  }

  .team-next-icon {
    height: 32px;
    width: 32px;
  }

  .result-actions {
    gap: 16px;
    grid-template-columns: 72px 96px 72px;
    padding-bottom: calc(6px + env(safe-area-inset-bottom));
  }

  .result-actions[data-mode="team-summary"] {
    grid-template-columns: 72px 96px 72px;
  }

  .result-actions[data-mode="daily-summary"] {
    grid-template-columns: 72px 72px;
  }

  .result-actions[data-mode="team-leaderboard"] {
    align-items: center;
    display: flex;
    gap: 16px;
    justify-content: center;
  }

  .result-action-button {
    height: 72px;
    width: 72px;
  }

  .result-action-button-primary {
    height: 96px;
    width: 96px;
  }

  .result-action-icon {
    height: 28px;
    width: 28px;
  }

  .result-action-icon-primary {
    height: 34px;
    width: 34px;
  }

  .team-entry-card,
  .daily-summary,
  .daily-result-board,
  .team-result-board,
  .pvp-wait-panel,
  .pvp-player-row {
    border-radius: 22px;
    width: 100%;
  }

  .team-manager-dialog {
    max-height: none;
  }

  .team-manager-scroll-area {
    max-height: calc(100svh - 32px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    padding-bottom: calc(30px + env(safe-area-inset-bottom));
    padding-right: 8px;
  }

  .team-manager-title {
    font-size: clamp(2.02rem, 8vw, 2.5rem);
  }

  .team-manager-auth-note {
    font-size: clamp(0.9rem, 4vw, 1.06rem);
    max-width: 90%;
    width: 90%;
  }

  .team-manager-section-title {
    font-size: clamp(1.42rem, 6.2vw, 1.74rem);
    margin-top: 18px;
  }

  .team-result-kicker.team-manager-section-title {
    font-size: clamp(1.72rem, 7vw, 2.04rem);
    margin: 34px 0 14px;
  }

  .team-manager-section:first-of-type .team-result-kicker.team-manager-section-title {
    margin-top: 44px;
  }

  .team-manager-section + .team-manager-section .team-result-kicker.team-manager-section-title {
    margin-top: 46px;
  }

  .team-manager-close-button-outside {
    position: fixed;
    right: calc(14px + env(safe-area-inset-right));
    top: calc(14px + env(safe-area-inset-top));
    z-index: 8;
  }

  .team-manager-card-action-row {
    gap: 12px;
  }

  .team-manager-card-icon-button {
    flex-basis: 68px;
    height: 68px;
    width: 68px;
  }

  .team-manager-card-icon-button svg {
    height: 26px;
    width: 26px;
  }

  .team-manager-show-all-button {
    font-size: 1rem;
    margin-top: 6px;
    padding: 6px 12px;
  }

  .team-entry-card.is-visible {
    margin-top: 22px;
  }

  #pvp-entry-title {
    font-size: clamp(1.08rem, 5.2vw, 1.28rem);
  }

  #pvp-entry-note {
    font-size: clamp(1.24rem, 6vw, 1.52rem);
    max-width: 90%;
    width: 90%;
  }

  .daily-summary-kicker {
    border-radius: 18px;
    gap: 8px;
    max-width: 100%;
    padding: 12px 14px;
  }

  #daily-create-form .nickname-field-label {
    font-size: clamp(1.12rem, 5.1vw, 1.28rem);
    margin: 12px 0 12px;
  }

  .daily-summary {
    gap: 26px;
  }

  .daily-summary-place {
    font-size: clamp(2.3rem, 9.2vw, 3.3rem);
    margin-top: 18px;
    margin-bottom: 12px;
  }

  .screen-result[data-result-mode="team-summary"] .result-title.place-title,
  .screen-result[data-result-mode="team-leaderboard"] .result-title.place-title,
  .daily-summary-place.place-title {
    font-size: clamp(2.05rem, 8vw, 3rem);
    max-width: min(100%, 12ch);
  }

  .daily-summary-note {
    border-radius: 16px;
    max-width: 100%;
    padding: 11px 14px;
  }

  .daily-summary .team-summary-score-pill {
    margin-bottom: 16px;
  }

  .screen-result[data-result-mode="daily-summary"] .result-panel {
    max-height: calc(100svh - 132px - env(safe-area-inset-bottom));
    padding-left: 18px;
    padding-right: 18px;
    padding-top: calc(18px + env(safe-area-inset-top));
    width: min(100%, 100%);
  }

  .screen-result[data-result-mode="team-summary"] {
    gap: 16px;
    justify-content: flex-start;
    padding-top: calc(18px + env(safe-area-inset-top));
    padding-bottom: calc(12px + env(safe-area-inset-bottom));
  }

  .screen-result[data-result-mode="team-summary"] .result-panel {
    align-content: start;
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 16px;
    justify-content: flex-start;
    max-height: calc(100svh - 136px - env(safe-area-inset-bottom));
    padding-top: 20px;
    padding-bottom: 16px;
    width: min(100%, 100%);
  }

  .screen-result[data-result-mode="team-summary"] .result-title,
  .screen-result[data-result-mode="team-leaderboard"] .result-title {
    font-size: clamp(1.55rem, 7.4vw, 2.35rem);
    max-width: 16ch;
  }

  .screen-result[data-result-mode="team-summary"] .team-series-summary {
    gap: 14px;
  }

  .screen-result[data-result-mode="team-summary"] .team-result-board {
    gap: 12px;
    padding: 16px 14px;
    width: 90%;
    max-width: 90%;
    min-width: 90%;
  }

  .screen-result[data-result-mode="team-leaderboard"] .result-panel {
    align-content: center;
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-height: calc(100svh - 136px - env(safe-area-inset-bottom));
    padding-top: 20px;
    padding-bottom: 16px;
    width: min(100%, 100%);
  }

  .screen-result[data-result-mode="team-leaderboard"] .team-result-board {
    gap: 14px;
    max-height: 70svh;
    overflow-y: auto;
    padding: 18px 16px;
    padding-right: 12px;
    width: 90%;
    max-width: 90%;
    min-width: 90%;
  }

  .screen-result[data-result-mode="daily-summary"] .daily-result-board {
    width: 90%;
  }

  .screen-result[data-result-mode="team-leaderboard"] .team-result-row {
    width: 100%;
  }

  .screen-result[data-result-mode="team-summary"] .team-result-board .team-result-kicker,
  .screen-result[data-result-mode="team-leaderboard"] .team-result-board .team-result-kicker {
    font-size: clamp(1.2rem, 5vw, 1.44rem);
  }

  .daily-result-board .team-result-kicker {
    font-size: clamp(1.48rem, 6.4vw, 1.8rem);
  }

  .daily-result-kicker-line {
    font-size: clamp(1.42rem, 6vw, 1.72rem);
  }

  .screen-result[data-result-mode="pvp-summary"] {
    gap: 14px;
    justify-content: center;
    padding-bottom: calc(18px + env(safe-area-inset-bottom));
  }

  .screen-result[data-result-mode="pvp-summary"] .result-panel {
    align-content: center;
    flex: 0 0 auto;
    justify-content: center;
    justify-items: center;
    max-height: calc(100svh - 178px - env(safe-area-inset-bottom));
    padding-bottom: 8px;
    padding-top: calc(18px + env(safe-area-inset-top));
  }

  .screen-result[data-result-mode="pvp-summary"] .result-actions {
    margin-top: 6px;
    padding-bottom: calc(22px + env(safe-area-inset-bottom));
  }

  .screen-result[data-result-mode="pvp-summary"] .pvp-summary {
    gap: 12px;
    margin-top: 0;
  }

  .screen-result[data-result-mode="pvp-summary"] .pvp-outcome {
    gap: 4px;
    padding-top: 2px;
  }

  .screen-result[data-result-mode="pvp-summary"] .pvp-result-list {
    justify-items: center;
  }

  .screen-result[data-result-mode="pvp-summary"] .pvp-player-row {
    justify-items: center;
    text-align: center;
  }

  .screen-result[data-result-mode="pvp-summary"] .pvp-player-heading {
    align-items: center;
    flex-direction: column;
    gap: 6px;
    justify-content: center;
    width: 100%;
  }

  .screen-result[data-result-mode="pvp-summary"] .pvp-player-name,
  .screen-result[data-result-mode="pvp-summary"] .pvp-player-score {
    text-align: center;
    width: 100%;
  }

  .screen-result[data-result-mode="pvp-summary"] .pvp-player-attempts {
    gap: 8px;
    grid-template-columns: repeat(var(--attempt-count, 5), minmax(0, 52px));
    justify-content: center;
    width: auto;
  }

  .screen-result[data-result-mode="pvp-summary"] .pvp-player-row {
    gap: 10px;
    padding: 12px 14px;
  }

  .pvp-outcome-title {
    font-size: clamp(1.8rem, 9vw, 2.8rem);
  }

  .pvp-rematch-actions {
    grid-template-columns: 1fr;
  }

  .team-create-modal {
    padding:
      calc(12px + env(safe-area-inset-top))
      calc(12px + env(safe-area-inset-right))
      calc(12px + env(safe-area-inset-bottom))
      calc(12px + env(safe-area-inset-left));
  }

  .team-create-dialog {
    border-radius: 24px;
    gap: 14px;
    max-height: calc(100svh - 24px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    padding: 18px;
    width: min(100%, 100%);
  }

  .team-create-scroll-area {
    padding-right: 8px;
  }

  .team-create-close-button-outside {
    right: 12px;
    top: -52px;
  }

  .audio-settings-dialog,
  .faq-dialog {
    width: min(100%, 100%);
  }

  .faq-dialog {
    max-height: calc(100svh - 24px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    overflow: hidden;
    padding-top: 22px;
  }

  .faq-scroll-area {
    max-height: calc(100svh - 132px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    overflow: auto;
    padding-right: 8px;
  }

  .faq-intro,
  .faq-section-title {
    width: 100%;
  }

  .faq-section-title {
    font-size: clamp(1.24rem, 5.6vw, 1.5rem);
  }

  .faq-close-button-outside {
    right: 12px;
    top: 12px;
  }

  .team-invite-input {
    font-size: 0.86rem;
  }

  .team-invite-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .team-copy-button {
    min-width: 0;
    width: 100%;
  }

  .team-create-link {
    font-size: 0.86rem;
  }

  .team-create-question-title,
  .team-create-custom-title {
    font-size: 1rem;
  }

  .team-create-choice-grid,
  .team-create-choice-grid-rounds {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .team-create-choice-grid-rounds .team-create-choice-button:last-child {
    grid-column: span 2;
  }

  .team-create-choice-button-wide {
    min-height: 84px;
  }

  .team-create-custom-header {
    grid-template-columns: minmax(0, 1fr);
  }

  .team-create-custom-preview {
    min-width: 0;
    width: 100%;
  }

  .team-create-colors-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .team-result-row {
    padding: 11px 12px;
  }

  .team-result-row-body {
    gap: 10px;
  }

  .team-result-score {
    font-size: 0.95rem;
  }

  .team-progress-indicator {
    bottom: calc(12px + env(safe-area-inset-bottom));
    font-size: 0.94rem;
  }

  .confirm-button {
    height: 64px;
    width: 64px;
  }

  .share-modal {
    padding:
      calc(12px + env(safe-area-inset-top))
      calc(12px + env(safe-area-inset-right))
      calc(12px + env(safe-area-inset-bottom))
      calc(12px + env(safe-area-inset-left));
  }

  .share-dialog {
    border-radius: 24px;
    gap: 16px;
    padding: 58px 18px 18px;
    width: min(100%, 100%);
  }

  .share-preview-frame {
    min-height: 230px;
    padding: 10px;
  }

  .share-action-grid {
    grid-template-columns: 1fr;
  }

  .share-action-button {
    padding: 14px 16px;
  }

  body.keyboard-open .screen-start {
    align-items: flex-start;
    overflow-y: auto;
    padding-bottom: calc(18px + env(safe-area-inset-bottom) + var(--keyboard-shift));
    padding-top: calc(8px + env(safe-area-inset-top));
  }

  body.keyboard-open .hero-panel {
    gap: 10px;
    padding-top: 6px;
    transform: translateY(calc(-1 * var(--keyboard-panel-lift)));
    transition: transform 220ms ease;
    width: 100%;
  }

  body.keyboard-open .hero-kicker {
    font-size: 0.78rem;
    letter-spacing: 0.16em;
  }

  body.keyboard-open .hero-panel h1 {
    font-size: clamp(2.25rem, 12vw, 4.4rem);
  }

  body.keyboard-open .team-entry-card {
    margin-top: 4px;
    scroll-margin-bottom: calc(24px + var(--keyboard-shift));
    transition: margin-top 220ms ease;
  }

  body.keyboard-open .team-create-modal {
    align-items: end;
    padding-bottom: calc(10px + env(safe-area-inset-bottom) + var(--keyboard-shift));
    padding-top: calc(10px + env(safe-area-inset-top));
  }

  body.keyboard-open .team-create-dialog {
    margin-top: auto;
    max-height: calc(100svh - 16px - env(safe-area-inset-top) - var(--keyboard-shift));
    scroll-margin-bottom: calc(20px + var(--keyboard-shift));
    transform: translateY(calc(-1 * var(--keyboard-panel-lift)));
    transition: transform 220ms ease;
  }

  body.keyboard-open .team-create-scroll-area {
    max-height: calc(100svh - 124px - env(safe-area-inset-top) - var(--keyboard-shift));
  }
}

@media (min-width: 721px) and (max-width: 1024px) {
  .picker-card {
    gap: 22px;
    width: min(100%, 760px);
  }

  .preview-square {
    max-width: 500px;
    width: min(100%, 500px);
  }

  .result-panel {
    gap: 24px;
  }
}

@media (max-height: 760px) {
  .result-panel {
    gap: 18px;
    max-height: calc(100svh - 118px);
    padding-bottom: 22px;
  }

  .result-compare-square {
    --result-square-size: min(100%, 320px);
  }

  .screen-result[data-result-mode="daily-round"] .result-panel {
    margin-block: auto;
    padding-top: 18px;
    padding-bottom: 22px;
  }

  .screen-result[data-result-mode="daily-round"] .result-compare-square {
    --result-square-size: min(82vw, 340px);
  }

  .team-next-button {
    height: 70px;
    margin-top: 16px;
    width: 70px;
  }
}
