/*
 * IWonnaP — Mobile polish
 * Focused improvements: readability, touch targets, density,
 * calendar/dashboard/tasks layouts on small screens.
 * Loaded AFTER components.css/pages.css to override.
 */

/* ═══════════════════════════════════════════════════════
   ≤ 760px — tablet / large phone
   ══════════════════════════════════════════════════════ */

@media (max-width: 760px) {

  /* Base text — slightly larger for readability */
  html, body { font-size: 16px; line-height: 1.5; }
  h1 { font-size: 1.6rem; letter-spacing: -0.02em; }
  h2 { font-size: 1.25rem; }
  h3 { font-size: 1.05rem; }

  /* Container paddings tighter so content fills viewport */
  main.main {
    gap: var(--sp-3);
    padding: var(--sp-3) var(--sp-3) calc(var(--mobile-nav-h) + 88px);
  }

  /* Cards take less padding to maximize content */
  .dashboard-card,
  .stat-card,
  .chart-wrapper,
  .project-card,
  .idea-card,
  .auth-card,
  .thought-row,
  .bookmark-row,
  .notification-row { padding: var(--sp-3); border-radius: var(--r-md); }

  .task-list-calendar,
  .event-list-calendar,
  .mindstate-list-calendar,
  .task-log-calendar,
  .event-log-calendar,
  .mindstate-log-calendar,
  .task-list, .task-log,
  .event-list, .event-log,
  .mindstate-list, .mindstate-log {
    border-radius: var(--r-md);
    padding: var(--sp-2);
  }

  /* Touch targets everywhere ≥ 44px */
  .action-btn,
  .auth-btn,
  .btn-dark,
  input[type="submit"],
  .project-action,
  .auth-link,
  .create-cross,
  .save-btn,
  .btn-icon { min-height: 44px; }

  .icon-pc {
    flex: 0 0 40px;
    height: 40px;
    width: 40px;
    min-height: 40px;
    min-width: 40px;
    font-size: 1.05rem;
  }

  /* Hero block toned down for small screens */
  .hero { padding: var(--sp-4); }

  /* Tag chips bigger to tap */
  .tag-chip {
    font-size: var(--text-sm);
    min-height: 32px;
    padding: 5px var(--sp-2);
  }
}

/* ═══════════════════════════════════════════════════════
   ≤ 600px — phone
   ══════════════════════════════════════════════════════ */

@media (max-width: 600px) {

  /* ─── HEADER ───────────────────────────────────────
     Hide username + dropdown nav (we have bottom-nav).
     Compact avatar + brand + theme toggle.
     ────────────────────────────────────────────────── */
  header.header {
    gap: var(--sp-2);
    padding: var(--sp-2) var(--sp-3);
    min-height: 52px;
  }
  .center-buttons.main-nav { display: none; }
  .username { display: none; }
  .user-round-photo { height: 30px; width: 30px; }
  .theme-toggle-btn { height: 36px; min-width: 36px; padding: 0 var(--sp-2); }
  .theme-toggle-btn [data-theme-label] { display: none; }
  .auth-link { padding: 6px var(--sp-2); }
  .auth-link img { display: none; }

  /* ─── NOTIFICATIONS ──────────────────────────────── */
  #notification-container {
    left: var(--sp-2);
    right: var(--sp-2);
    top: calc(52px + var(--sp-1));
    transform: none;
    width: auto;
    max-width: none;
  }
  .notification-banner {
    padding: var(--sp-2) var(--sp-3);
    font-size: var(--text-sm);
  }

  /* ─── ROWS (task/event/mindstate) ───────────────────
     Two-line layout: name on top, badge+actions below.
     Far more readable than squished single line.
     ────────────────────────────────────────────────── */
  .pc-item {
    align-items: stretch;
    border-radius: var(--r-md);
    display: grid;
    gap: var(--sp-1);
    grid-template-columns: auto 1fr;
    padding: var(--sp-2) var(--sp-2);
    min-height: 56px;
  }
  .pc-item .priority-badge,
  .pc-item .priority-1,
  .pc-item .priority-2,
  .pc-item .priority-3,
  .pc-item .priority-4 {
    align-self: center;
    grid-column: 1;
    grid-row: 1 / span 2;
  }
  .pc-item .taskName {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    font-size: 0.95rem;
    font-weight: 500;
    gap: var(--sp-1);
    grid-column: 2;
    grid-row: 1;
    line-height: 1.3;
    overflow: hidden;
    padding: 0;
    text-overflow: ellipsis;
    white-space: normal;
    /* Cap to 2 lines */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
  .pc-item .task-date {
    color: var(--muted);
    font-size: 11px;
    margin-left: auto;
  }
  .pc-item .pc-actions {
    flex-wrap: wrap;
    gap: 6px;
    grid-column: 2;
    grid-row: 2;
    justify-content: flex-end;
    margin: 0;
  }
  .pc-item .running-label {
    font-size: 10px;
    grid-column: 2;
    grid-row: 2;
    justify-self: flex-start;
    padding: 2px 8px;
  }
  .pc-item .tag-chip {
    font-size: 11px;
    grid-column: 2;
    grid-row: 2;
    justify-self: flex-start;
  }

  /* Task/event row hover off — touch device */
  .pc-item:hover { transform: none; }

  /* ─── BUTTONS ─────────────────────────────────────── */
  .action-btn,
  .auth-btn,
  .btn-dark,
  input[type="submit"] {
    padding: 10px var(--sp-3);
    font-size: 0.95rem;
  }

  /* Stacking pair: primary + cancel — equal widths */
  .modal-footer { flex-direction: column-reverse; gap: var(--sp-2); padding: var(--sp-3); }
  .modal-footer .action-btn,
  .modal-footer button {
    flex: 1 1 100%;
    width: 100%;
  }

  /* ─── FORMS ──────────────────────────────────────── */
  input, select, textarea, .form-control, .form-select {
    font-size: 16px; /* Prevents iOS zoom on focus */
    min-height: 44px;
    padding: 10px 12px;
  }
  textarea { min-height: 96px; }
  label { font-size: 0.9rem; }

  .field-row {
    grid-template-columns: 1fr;
    gap: var(--sp-1);
  }
  .field-row label { padding-top: 0; }

  /* Range slider — bigger thumb area */
  .state-score-control {
    grid-template-columns: 1fr;
    gap: var(--sp-2);
    padding: var(--sp-3);
  }
  .state-score-slider { height: 48px; }
  .state-score-number { font-size: 1.2rem; min-height: 48px; }

  /* ─── MODAL → bottom sheet ─────────────────────── */
  .modal-overlay { align-items: flex-end; padding: 0; }
  .modal {
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    max-height: 92dvh;
    max-width: 100vw;
    width: 100vw;
    margin: 0;
  }
  .modal-header {
    padding: var(--sp-4) var(--sp-4) var(--sp-3);
    padding-top: calc(var(--sp-5) + 4px); /* drag-handle space */
  }
  .modal-header h2, .modal-header h3 { font-size: 1.05rem; }
  .modal-body { padding: var(--sp-3) var(--sp-4); }
  .modal::after {
    background: var(--line-strong);
    border-radius: var(--r-full);
    content: "";
    height: 4px;
    left: 50%;
    position: absolute;
    top: 10px;
    transform: translateX(-50%);
    width: 40px;
  }

  /* Quick-create tiles — single column for clarity */
  .quick-create-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-2);
  }
  .quick-create-tile { padding: var(--sp-3); }
  .quick-create-tile .qc-icon { font-size: 24px; }
  .quick-create-tile .qc-title { font-size: 0.95rem; }
  .quick-create-tile .qc-sub { font-size: 11px; }

  /* ─── CALENDAR GRID ──────────────────────────────── */
  .calendar-container { padding: var(--sp-2); border-radius: var(--r-md); }
  .calendar-month-nav { font-size: 0.95rem; padding: var(--sp-2) 0; }
  .calendar-day {
    border-radius: 8px;
    font-size: 11px;
    min-height: 44px;
    padding: 3px;
  }
  .calendar-day .day-number { font-size: 13px; font-weight: 600; }
  .calendar-day .day-progress { height: 4px; }
  .calendar-day .day-events { display: none; }  /* dot-only on small screens */
  .calendar-day::after {
    background: var(--accent);
    border-radius: 50%;
    content: "";
    height: 5px;
    margin: 1px auto 0;
    width: 5px;
    display: block;
  }
  .calendar-day:empty::after, .calendar-day.empty::after { display: none; }

  /* Day-details — when a day is opened on mobile */
  .day-details-container { padding: var(--sp-2); border-radius: var(--r-md); }

  /* Calendar task tabs — single column */
  .calendar-task-tabs { grid-template-columns: 1fr; gap: var(--sp-1); }
  .calendar-task-tabs > label { min-height: 44px; }

  /* ─── DASHBOARD / STATS ──────────────────────────── */
  .dashboard, .statistics, .idea-grid, .project-grid, .persons-grid,
  .statistics-charts {
    grid-template-columns: 1fr !important;
    gap: var(--sp-3);
  }
  .stat-card .stat-num { font-size: 1.5rem; }

  /* ─── TASK TREE ──────────────────────────────────── */
  .task-tree-children {
    margin-left: var(--sp-1);
    padding-left: var(--sp-2);
  }
  .task-tree-summary { padding: var(--sp-1); min-height: 36px; }
  .task-tree-summary-title { font-size: 0.9rem; }

  /* ─── PAGINATION ─────────────────────────────────── */
  .pagination { gap: 4px; padding: var(--sp-3) 0; }
  .pagination a, .pagination span {
    min-height: 40px;
    min-width: 40px;
    font-size: 0.9rem;
  }

  /* ─── TASK EDIT ──────────────────────────────────── */
  .task-edit-container { padding: var(--sp-3); border-radius: var(--r-md); }

  /* ─── BOTTOM NAV — refine spacing ────────────────── */
  .mobile-nav { height: 60px; }
  .mobile-nav a {
    font-size: 10px;
    letter-spacing: -0.01em;
  }
  .mobile-nav a .icon { font-size: 18px; }

  /* ─── FAB — position above bottom-nav, smaller ───── */
  .fab {
    bottom: calc(60px + var(--sp-3));
    height: 52px;
    width: 52px;
    font-size: 22px;
    right: var(--sp-3);
  }

  /* ─── SIDEBAR HIDDEN — already hidden in layout.css */
  /* But re-assert for safety */
  .left-sidebar, .right-sidebar, .sidebar { display: none !important; }

  /* ─── FOOTER ─────────────────────────────────────── */
  footer.footer { font-size: 10px; padding: var(--sp-2); }
}

/* ═══════════════════════════════════════════════════════
   ≤ 380px — compact phone (iPhone SE et al.)
   ══════════════════════════════════════════════════════ */

@media (max-width: 380px) {
  main.main { padding: var(--sp-2) var(--sp-2) calc(var(--mobile-nav-h) + 80px); }
  .hero { padding: var(--sp-3); }
  .hero h1 { font-size: 1.4rem; }

  .pc-item { padding: var(--sp-2) 6px; min-height: 52px; }
  .pc-item .icon-pc { flex: 0 0 36px; height: 36px; width: 36px; }

  .quick-create-grid { grid-template-columns: 1fr; }

  .mobile-nav a { font-size: 9px; }
  .mobile-nav a .icon { font-size: 17px; }

  .stat-card .stat-num { font-size: 1.3rem; }
}

/* ═══════════════════════════════════════════════════════
   Landscape phone — reclaim vertical space
   ══════════════════════════════════════════════════════ */

@media (max-width: 900px) and (orientation: landscape) and (max-height: 500px) {
  header.header { min-height: 44px; padding: 4px var(--sp-3); }
  .mobile-nav { height: 48px; }
  .mobile-nav a { font-size: 9px; }
  .mobile-nav a .icon { font-size: 15px; }
  .fab { bottom: 56px; height: 44px; width: 44px; font-size: 18px; }
  main.main { padding-bottom: calc(48px + var(--sp-3)); }
}

/* ═══════════════════════════════════════════════════════
   Touch-only refinements
   Hover effects are useless and can stick; disable.
   ══════════════════════════════════════════════════════ */

@media (hover: none) and (pointer: coarse) {
  .hover-lift:hover,
  .pc-item:hover,
  .stat-card:hover,
  .dashboard-card:hover,
  .project-card:hover,
  .idea-card:hover,
  .wishlist-card:hover {
    transform: none;
    box-shadow: var(--shadow);
  }
  .action-btn:hover,
  .btn-icon:hover,
  .icon-pc:hover { transform: none; }
  .icon-pc:active { transform: scale(0.92); background: var(--accent-muted); }
  .pc-item:active { background: var(--surface-soft); }

  /* Tap highlight color tuned to accent */
  * { -webkit-tap-highlight-color: rgba(40, 200, 210, .15); }
}

/* ═══════════════════════════════════════════════════════
   Safe-area insets for notched devices
   ══════════════════════════════════════════════════════ */

@supports (padding: max(0px)) {
  header.header   { padding-left: max(var(--sp-3), env(safe-area-inset-left)); padding-right: max(var(--sp-3), env(safe-area-inset-right)); }
  main.main       { padding-left: max(var(--sp-3), env(safe-area-inset-left)); padding-right: max(var(--sp-3), env(safe-area-inset-right)); }
  .mobile-nav     { padding-bottom: env(safe-area-inset-bottom); }
  .fab            { bottom: calc(60px + var(--sp-3) + env(safe-area-inset-bottom)); }
}

/* ═══════════════════════════════════════════════════════
   Mobile mirror of right-sidebar quick widget (Phase 26 hotfix)
   Wrapper hidden by default; shown only on narrow screens.
   ══════════════════════════════════════════════════════ */
.rs-quick-mobile-wrap {
  display: none;
}
.rs-quick-mobile-wrap .rs-quick {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--sp-3);
  padding: var(--sp-2);
}
@media (max-width: 1100px) {
  .rs-quick-mobile-wrap { display: block; }
  .calendar-container ~ .emoji-bar,
  .main-block > .emoji-bar { display: none; }
}
