html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  overflow-x: hidden;
}

.standalone-app body {
  padding-top: env(safe-area-inset-top);
}

button,
input,
select,
textarea {
  font-size: 16px;
}

button,
.nav-link,
.rating-btn,
.drag-item {
  touch-action: manipulation;
}

.app-install-prompt {
  position: fixed;
  z-index: 1000;
  left: max(1rem, env(safe-area-inset-left));
  right: max(1rem, env(safe-area-inset-right));
  bottom: max(1rem, env(safe-area-inset-bottom));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .85rem;
  max-width: 560px;
  margin: 0 auto;
  padding: .85rem;
  background: #1e1e2e;
  color: #fff;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 10px;
  box-shadow: 0 14px 34px rgba(0,0,0,.28);
}

.app-install-copy {
  display: grid;
  gap: .12rem;
  min-width: 0;
}

.app-install-copy strong {
  font-size: .92rem;
  line-height: 1.2;
}

.app-install-copy span {
  color: rgba(255,255,255,.72);
  font-size: .8rem;
  line-height: 1.3;
}

.app-install-actions {
  display: flex;
  align-items: center;
  gap: .45rem;
  flex: 0 0 auto;
}

.app-install-button,
.app-install-dismiss {
  width: auto;
  min-height: 38px;
  border-radius: 8px;
}

.app-install-button {
  background: #fff;
  color: #1e1e2e;
  padding: .55rem .8rem;
}

.app-install-dismiss {
  display: grid;
  place-items: center;
  min-width: 38px;
  padding: 0;
  background: rgba(255,255,255,.12);
  color: #fff;
  font-size: 1.25rem;
  line-height: 1;
}

@media (max-width: 700px) {
  .page-header {
    padding: 1rem 1rem 0;
  }

  .page-header h1 {
    font-size: 1.25rem;
  }

  .main-nav {
    justify-content: flex-start;
    flex-wrap: nowrap;
    gap: .5rem;
    overflow-x: auto;
    margin-left: -1rem;
    margin-right: -1rem;
    padding: .65rem 1rem .85rem;
    scroll-snap-type: x proximity;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .main-nav::-webkit-scrollbar {
    display: none;
  }

  .nav-link {
    display: flex;
    flex: 0 0 auto;
    align-items: center;
    min-height: 38px;
    padding: .45rem .65rem;
    white-space: nowrap;
    scroll-snap-align: start;
  }

  .container {
    width: 100%;
    padding: 1.25rem .85rem 5.5rem;
  }

  .page-intro {
    margin-bottom: 1.25rem;
  }

  .page-intro h2 {
    font-size: 1.15rem;
  }

  .question-card,
  .commitment-card,
  .item-card,
  .generate-card,
  .intake-panel,
  .context-panel,
  #plan-output,
  #roadmap-output,
  #synthesis-output,
  .profile-rendered,
  .direction-card,
  .commitment-work-card {
    border-radius: 8px;
    padding: 1rem;
  }

  textarea {
    min-height: 112px;
  }

  button {
    width: 100%;
    min-height: 44px;
    padding: .78rem 1rem;
  }

  .submit-row,
  .submit-bar,
  .save-bar,
  .feedback-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .rating-buttons {
    flex-direction: column;
  }

  .rating-btn {
    min-height: 44px;
  }

  .progress-row {
    align-items: stretch;
    flex-direction: column;
    gap: .45rem;
  }

  .progress-label {
    min-width: 0;
  }

  .app-install-prompt {
    align-items: stretch;
  }

  .app-install-actions {
    align-self: center;
  }
}
