/* ============================================================================
   HugoFamily — Component styles
   ----------------------------------------------------------------------------
   Every visual value here comes from a SEMANTIC TOKEN defined in tokens.css
   (--surface-*, --btn-*, --nav-*, --color-*, --space-*, --radius-*,
   --shadow-*, --focus-ring, …). No hard-coded brand colours, radii, or shadows
   live in this file, so a different [data-skin] / [data-theme] re-skins the
   whole app without touching component CSS.

   Hybrid brand model in effect:
     • ORANGE (--color-primary)  → create / CTA / add / FAB / Hugo / active nav
     • SAGE   (--color-success)  → done / bought / approved / success / trust
   ========================================================================== */

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-body);
  font-size: var(--text-body);
  line-height: 1.5;
  background: var(--surface-page);
  color: var(--text-primary);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  -webkit-text-size-adjust: 100%;
}

/* ── Global focus-visible: a single, high-visibility ring everywhere (A11Y) ── */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible,
[tabindex]:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ── App shell ────────────────────────────────────────────────────────────── */
.app-shell {
  width: min(100%, var(--shell-max));
  margin: 0 auto;
  min-height: 100vh;
  padding: var(--space-4) var(--space-4) calc(7rem + env(safe-area-inset-bottom));
}

/* ── Typography ───────────────────────────────────────────────────────────── */
h1, h2, h3 {
  font-family: var(--font-heading);
  color: var(--text-primary);
  overflow-wrap: break-word;
}
h1 { margin: 0 0 var(--space-2); font-size: clamp(1.75rem, 8vw, 2.4rem); line-height: 1.08; font-weight: var(--weight-heavy); letter-spacing: -0.01em; }
h2 { font-weight: var(--weight-bold); }
p { color: var(--text-secondary); line-height: 1.55; overflow-wrap: break-word; }
.muted { color: var(--text-secondary); }
.eyebrow {
  margin: 0 0 var(--space-1);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: var(--text-eyebrow);
  font-weight: var(--weight-heavy);
  color: var(--color-primary-text);
}

/* ── Hero / cards ─────────────────────────────────────────────────────────── */
.hero {
  background: linear-gradient(135deg, var(--hero-from), var(--hero-to));
  border: 1px solid var(--hairline);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  box-shadow: var(--shadow-md);
}
.quick-grid { display: grid; gap: var(--space-3); margin-top: var(--space-4); }
.card {
  background: var(--surface-card);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
}

/* ── Bottom navigation ────────────────────────────────────────────────────── */
.bottom-nav {
  position: fixed;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: min(100%, var(--shell-max));
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-1);
  padding: var(--space-2) var(--space-2) calc(var(--space-2) + env(safe-area-inset-bottom));
  background: color-mix(in srgb, var(--nav-bg) 92%, transparent);
  border-top: 1px solid var(--hairline);
  backdrop-filter: blur(10px);
  z-index: 20;
}
.bottom-nav a {
  min-height: var(--tap-min);
  display: grid;
  place-items: center;
  color: var(--nav-item);
  text-decoration: none;
  font-weight: var(--weight-bold);
  font-size: var(--text-small);
  border-radius: var(--radius-pill);
  transition: background var(--dur-press) var(--ease), color var(--dur-press) var(--ease);
}
.bottom-nav a.active {
  background: var(--nav-item-active-bg);
  color: var(--nav-item-active-text);
}

/* ── Forms ────────────────────────────────────────────────────────────────── */
.stack-form { display: grid; gap: var(--space-3); }
label { display: grid; gap: var(--space-1); font-weight: var(--weight-bold); }
input, textarea, select {
  width: 100%;
  min-height: var(--tap-min);
  border: 1px solid var(--input-border);
  border-radius: var(--radius-md);
  padding: .85rem;
  font: inherit;
  background: var(--input-bg);
  color: var(--input-text);
  transition: border-color var(--dur-press) var(--ease), box-shadow var(--dur-press) var(--ease);
}
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--input-border-focus);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--input-border-focus) 30%, transparent);
}
input[type="checkbox"], input[type="radio"] { width: auto; min-width: 1.15rem; min-height: 1.15rem; accent-color: var(--color-primary); }
textarea { min-height: 6rem; }
fieldset { border: 1px solid var(--hairline); border-radius: var(--radius-md); padding: var(--space-3); margin: 0; }
legend { padding: 0 var(--space-1); font-weight: var(--weight-heavy); }
.store-picker { display: grid; grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr)); gap: var(--space-2); }
.store-picker legend { grid-column: 1 / -1; }
.store-picker label { display: flex; align-items: center; gap: .45rem; font-weight: var(--weight-bold); background: var(--surface-inset); border-radius: var(--radius-sm); padding: .55rem; }
.required, .error { color: var(--danger-text); }
.error { margin: 0; font-weight: var(--weight-heavy); }
.field-block { display: grid; gap: var(--space-1); margin-top: .85rem; }
.field-block > span.field-label { font-weight: var(--weight-heavy); }
select.lang-select { background: var(--input-bg); }

/* ── Buttons ──────────────────────────────────────────────────────────────── */
button, .button, .button-link, .secondary-link, .auth-primary-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--tap-min);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  padding: .8rem 1.1rem;
  background: var(--btn-primary-bg);
  color: var(--btn-primary-text);
  font-family: var(--font-heading);
  font-weight: var(--weight-heavy);
  font-size: var(--text-button);
  line-height: 1.2;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--dur-press) var(--ease), transform var(--dur-press) var(--ease);
}
button:hover, .button:hover, .button-link:hover, .auth-primary-btn:hover { background: var(--btn-primary-bg-hover); }
button:active, .button:active, .button-link:active, .auth-primary-btn:active { transform: translateY(1px); }
button.secondary, .secondary, .secondary-link {
  background: var(--btn-secondary-bg);
  color: var(--btn-secondary-text);
  border-color: var(--btn-secondary-border);
}
button.secondary:hover, .secondary:hover, .secondary-link:hover { background: var(--surface-inset); }
button:disabled, .button:disabled, button[disabled], .is-loading {
  background: var(--btn-disabled-bg);
  color: var(--btn-disabled-text);
  border-color: transparent;
  cursor: not-allowed;
  transform: none;
}
.is-loading { position: relative; pointer-events: none; }
.link-danger, button.link-danger {
  background: transparent;
  border: 0;
  min-height: var(--tap-min);
  padding: .5rem .65rem;
  color: var(--danger-text);
  font-weight: var(--weight-heavy);
  cursor: pointer;
}
.link-danger:hover { text-decoration: underline; }
.compact-danger { background: var(--btn-danger-bg); color: var(--btn-danger-text); padding: .6rem .75rem; font-size: var(--text-meta); }
.compact-danger:hover { background: var(--btn-danger-bg-hover); }
.pk-danger { background: var(--btn-danger-bg); border-color: var(--btn-danger-bg); color: var(--btn-danger-text); }

/* ── Lists / shopping & task rows ─────────────────────────────────────────── */
.item-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .45rem; }
.shopping-item { border-top: 1px solid var(--hairline); padding-top: var(--space-3); }
.shopping-item:first-child { border-top: 0; padding-top: 0; }
.compact-row { position: relative; overflow: visible; border-radius: var(--radius-md); background: var(--surface-inset); touch-action: pan-y; }
.compact-row .item-main { min-height: 3.35rem; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: .45rem; align-items: center; padding: .55rem .65rem; background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-md); transition: transform var(--dur-base) var(--ease); position: relative; z-index: 2; }
.compact-row strong { min-width: 0; overflow-wrap: anywhere; }
.item-meta { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: .25rem .55rem; color: var(--text-secondary); font-size: var(--text-small); line-height: 1.2; }
.quantity { color: var(--text-secondary); font-weight: var(--weight-bold); white-space: nowrap; }
.price-chip { display: inline-flex; align-items: center; padding: .1rem .4rem; border-radius: var(--radius-pill); font-size: .72rem; font-weight: var(--weight-bold); background: var(--color-primary-soft); color: var(--color-primary-text); white-space: nowrap; }
.item-aside { grid-column: 2; display: inline-flex; align-items: center; gap: .4rem; }
.shopping-item.bought { opacity: .72; }

/* Overflow (⋯) action menu — always-available, accessible alternative to swipe */
.item-actions-menu { display: none; position: relative; }
.item-actions-menu summary { list-style: none; min-height: 2.15rem; display: grid; place-items: center; border: 1px solid var(--hairline); border-radius: var(--radius-pill); padding: .35rem .65rem; background: var(--surface-inset); color: var(--text-secondary); font-size: var(--text-small); font-weight: 900; cursor: pointer; }
.item-actions-menu summary::-webkit-details-marker { display: none; }
.item-actions-panel { position: absolute; right: 0; top: calc(100% + .25rem); z-index: 50; min-width: 8.4rem; display: grid; gap: .3rem; padding: .35rem; border: 1px solid var(--hairline); border-radius: var(--radius-md); background: var(--surface-card); box-shadow: var(--shadow-md); }
.item-actions-panel form { display: grid; }
.compact-action { width: 100%; min-height: 2.35rem; display: grid; place-items: center; border-radius: var(--radius-sm); padding: .45rem .65rem; font-size: var(--text-meta); font-weight: var(--weight-bold); text-decoration: none; white-space: nowrap; border: 0; }
.compact-action-edit { background: var(--action-edit-bg); color: var(--action-edit-text); }
.compact-action-bought { background: var(--action-done-bg); color: var(--action-done-text); }
.compact-action-restore { background: var(--action-restore-bg); color: var(--action-restore-text); }
.compact-action-delete { background: var(--action-delete-bg); color: var(--action-delete-text); }

/* Swipe-to-reveal rails (paired with the overflow menu above) */
.swipe-actions { opacity: 0; pointer-events: none; position: absolute; top: .05rem; bottom: .05rem; z-index: 1; display: flex; align-items: stretch; gap: .25rem; padding: .25rem; transition: opacity .12s ease; }
.swipe-actions-left { left: .05rem; justify-content: flex-start; }
.swipe-actions-right { right: .05rem; justify-content: flex-end; }
.swipe-actions form { display: flex; }
.swipe-actions button, .swipe-actions a { min-width: 4.8rem; display: grid; place-items: center; padding: .55rem .7rem; border-radius: var(--radius-sm); font-size: var(--text-meta); font-weight: var(--weight-bold); text-decoration: none; border: 0; min-height: auto; }
.swipe-action-edit { background: var(--action-edit-bg); color: var(--action-edit-text); }
.swipe-action-bought { background: var(--action-done-bg); color: var(--action-done-text); }
.swipe-action-restore { background: var(--action-restore-bg); color: var(--action-restore-text); }
.swipe-action-delete { background: var(--action-delete-bg); color: var(--action-delete-text); }
.swipe-action-done { background: var(--action-done-bg); color: var(--action-done-text); }
.swipe-row.is-swiped-left .item-main { transform: translateX(var(--swipe-left-offset)); }
.swipe-row.is-swiped-right .item-main { transform: translateX(var(--swipe-right-offset)); }
.swipe-row.is-swiped-left .swipe-actions-right, .swipe-row.is-swiped-right .swipe-actions-left { opacity: 1; pointer-events: auto; }
.swipe-hint { margin: .35rem 0 0; font-size: var(--text-small); color: var(--text-secondary); }
.actions { display: grid; gap: .4rem; min-width: 6.5rem; }
.suggestions ul { margin: .4rem 0 0; padding-left: 1.2rem; color: var(--text-secondary); }

/* ── Member rows / status pills ───────────────────────────────────────────── */
.member-list { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; gap: .55rem; }
.member-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: .5rem; align-items: stretch; background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-md); padding: 0; overflow: hidden; }
.member-row-link { display: block; min-width: 0; padding: .7rem; color: var(--text-primary); text-decoration: none; border-radius: var(--radius-md); }
.member-row-link:focus-visible { outline: 3px solid var(--focus-ring); outline-offset: -3px; }
.member-row-action { display: grid; align-items: center; padding: .7rem .7rem .7rem 0; }
.member-row p { margin: .2rem 0 0; font-size: var(--text-meta); }
.member-row-link.with-avatar { display: flex; align-items: center; gap: .65rem; }
.member-row-avatar { flex-shrink: 0; }
.member-row-text { min-width: 0; }
.member-row-text strong { display: block; overflow-wrap: anywhere; }
.status-pill { display: inline-flex; align-items: center; border-radius: var(--radius-pill); padding: .2rem .5rem; background: var(--success-bg); color: var(--success-text); font-size: var(--text-small); font-weight: var(--weight-heavy); }
.status-pill.waiting { background: var(--warning-bg); color: var(--warning-text); }
.status-pill.invited { background: var(--info-bg); color: var(--info-text); }
.action-note { margin: .35rem 0 0; font-size: var(--text-small); color: var(--text-secondary); }

/* ── Pairing / QR ─────────────────────────────────────────────────────────── */
.pair-code { margin: .5rem 0; font-size: 2.1rem; font-weight: 900; letter-spacing: .22em; color: var(--color-primary-text); text-align: center; }
.pair-qr-wrap { display: grid; place-items: center; margin: .25rem auto .5rem; }
.pair-qr-wrap svg.pair-qr { width: min(15rem, 70vw); height: auto; background: #fff; border-radius: var(--radius-md); padding: .5rem; box-shadow: var(--shadow-sm); }
.header-actions { display: flex; gap: .4rem; flex-wrap: wrap; margin: .35rem 0 0; }

/* ── Service tokens ───────────────────────────────────────────────────────── */
.token-reveal { border-color: var(--color-success); background: var(--success-bg); }
.token-reveal-warning { color: var(--danger-text); font-weight: var(--weight-heavy); margin: 0 0 .5rem; }
.token-reveal-value { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; }
.token-reveal-value code { flex: 1 1 14rem; min-width: 0; overflow-wrap: anywhere; padding: .6rem .7rem; border-radius: var(--radius-sm); background: var(--surface-card); border: 1px solid var(--hairline); font-size: var(--text-meta); }
.token-row { border-top: 1px solid var(--hairline); padding-top: var(--space-3); }
.token-row:first-child { border-top: 0; padding-top: 0; }
.token-row-head { display: flex; align-items: center; gap: .5rem; }
.token-row-head strong { min-width: 0; overflow-wrap: anywhere; }
.token-row-meta { margin: .25rem 0 0; font-size: var(--text-small); }
.token-row form { margin-top: .5rem; }

/* ── PWA install banner + iOS guide modal ─────────────────────────────────── */
.pwa-banner { position: fixed; left: .75rem; right: .75rem; bottom: calc(5rem + env(safe-area-inset-bottom)); z-index: 30; display: flex; align-items: center; gap: .6rem; padding: .75rem .9rem; background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.pwa-banner-text { flex: 1; min-width: 0; font-weight: var(--weight-bold); font-size: var(--text-meta); }
.pwa-banner-actions { display: flex; gap: .4rem; flex-shrink: 0; }
.pwa-banner-actions .button { padding: .5rem .7rem; font-size: var(--text-meta); min-height: auto; }
.pwa-modal { position: fixed; inset: 0; z-index: 40; display: grid; place-items: center; background: var(--overlay); padding: var(--space-4); }
.pwa-modal-card { width: min(100%, 24rem); background: var(--surface-card); border-radius: var(--radius-xl); padding: 1.1rem 1.2rem; box-shadow: var(--shadow-lg); }
.pwa-steps { margin: .5rem 0 0; padding-left: 1.2rem; display: grid; gap: .35rem; }
[hidden] { display: none !important; }

/* ── Flash messages ───────────────────────────────────────────────────────── */
.flash-stack { width: min(100%, var(--shell-max)); margin: .75rem auto 0; padding: 0 var(--space-4); }
.flash-message { margin: 0; padding: .75rem .9rem; border: 1px solid var(--color-success); border-radius: var(--radius-md); background: var(--success-bg); color: var(--success-text); font-weight: var(--weight-heavy); }
.flash-message.error { border-color: var(--danger-border); background: var(--danger-bg); color: var(--danger-text); }

/* ── Navigation progress + optimistic pending shimmer ─────────────────────── */
.nav-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px; z-index: 100;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-primary-hover) 50%, var(--color-primary) 100%);
  background-size: 200% 100%;
  animation: nav-progress-shimmer 1.1s ease-in-out infinite;
  pointer-events: none;
}
@keyframes nav-progress-shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }
.is-pending { position: relative; pointer-events: none; }
.is-pending::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit;
  background: linear-gradient(90deg, transparent, rgba(127,127,127,.12), transparent);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.2s ease-in-out infinite;
}
@keyframes skeleton-shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }

/* ── Pointer/hover affordances for swipe + reduced motion ─────────────────── */
@media (prefers-reduced-motion: reduce) {
  .nav-progress { animation: none; background: var(--color-primary); }
  .is-pending::after { animation: none; background: rgba(127,127,127,.08); }
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
}
@media (hover: hover) and (pointer: fine) {
  .swipe-row:hover .item-main { transform: translateX(var(--swipe-left-offset)); }
  .swipe-row:hover .swipe-actions-right { opacity: 1; pointer-events: auto; }
  .item-actions-menu { display: block; }
}
@media (hover: none), (pointer: coarse) {
  .item-actions-menu { display: block; }
}

/* ── Collapsible store groups (weekly list) ───────────────────────────────── */
.store-group { margin-top: 1.1rem; }
.store-group-summary { list-style: none; display: flex; align-items: center; gap: .5rem; padding: .35rem 0; cursor: pointer; color: var(--color-primary-text); }
.store-group-summary::-webkit-details-marker { display: none; }
.store-group-name { font-weight: var(--weight-heavy); font-size: 1rem; }
.store-group-count { display: inline-flex; align-items: center; justify-content: center; min-width: 1.4rem; height: 1.4rem; padding: 0 .4rem; border-radius: var(--radius-pill); background: var(--color-primary-soft); color: var(--color-primary-text); font-size: .72rem; font-weight: var(--weight-heavy); }
.store-group-chevron { margin-left: auto; width: .62rem; height: .62rem; border-right: 2px solid var(--text-secondary); border-bottom: 2px solid var(--text-secondary); transform: rotate(45deg); transition: transform var(--dur-base) var(--ease); }
.store-group[open] .store-group-chevron { transform: rotate(225deg); }

/* ── Store chooser ────────────────────────────────────────────────────────── */
.store-chooser { display: grid; gap: .6rem; margin-top: .5rem; }
.store-choice { display: flex; align-items: center; justify-content: space-between; gap: .5rem; min-height: 3.4rem; padding: .85rem 1rem; border: 1px solid var(--hairline); border-radius: var(--radius-md); background: var(--surface-card); color: var(--text-primary); text-decoration: none; font-weight: var(--weight-heavy); box-shadow: var(--shadow-sm); }
.store-choice:focus-visible { outline: 3px solid var(--focus-ring); outline-offset: 2px; }
.store-choice-count { display: inline-flex; align-items: center; justify-content: center; min-width: 1.7rem; height: 1.7rem; padding: 0 .5rem; border-radius: var(--radius-pill); background: var(--color-primary-soft); color: var(--color-primary-text); font-size: .8rem; }

/* ── Task list ────────────────────────────────────────────────────────────── */
.task-filter-bar { display: flex; gap: .4rem; overflow-x: auto; padding-bottom: .35rem; scrollbar-width: none; margin-bottom: .9rem; }
.task-filter-bar::-webkit-scrollbar { display: none; }
.filter-pill { display: inline-flex; align-items: center; min-height: 2.25rem; padding: .35rem .85rem; border-radius: var(--radius-pill); font-size: var(--text-meta); font-weight: var(--weight-bold); text-decoration: none; white-space: nowrap; border: 1.5px solid var(--hairline); color: var(--text-secondary); background: var(--surface-card); }
.filter-pill.active { background: var(--chip-active-bg); color: var(--chip-active-text); border-color: var(--chip-active-bg); }
.task-assignee-badge { display: inline-flex; align-items: center; justify-content: center; width: 1.7rem; height: 1.7rem; border-radius: var(--radius-pill); background: var(--color-primary-soft); color: var(--color-primary-text); font-size: .7rem; font-weight: 900; flex-shrink: 0; }
.task-category-chip { display: inline-flex; align-items: center; padding: .15rem .5rem; border-radius: var(--radius-pill); font-size: .72rem; font-weight: var(--weight-bold); background: var(--warning-bg); color: var(--warning-text); }
.hugo-badge { display: inline-flex; align-items: center; padding: .15rem .5rem; border-radius: var(--radius-pill); font-size: .72rem; font-weight: var(--weight-bold); background: var(--color-primary-soft); color: var(--color-primary-text); }
.task-due { font-size: var(--text-small); color: var(--text-secondary); }
.task-done-section { margin-top: 1.25rem; }
.task-done-section summary { font-weight: var(--weight-heavy); color: var(--text-secondary); cursor: pointer; padding: .35rem 0; }
.task-done-row { opacity: .65; }
.task-done-row .item-main strong { text-decoration: line-through; }
.task-reopen-form { flex-shrink: 0; }
.task-reopen-btn { font-size: var(--text-small); padding: .35rem .65rem; min-height: 2.25rem; }

/* ── Floating action button (add/create => orange) ────────────────────────── */
.fab-task { position: fixed; right: 1rem; bottom: calc(5rem + env(safe-area-inset-bottom)); width: 3.5rem; height: 3.5rem; border-radius: var(--radius-pill); background: var(--fab-bg); color: var(--fab-text); font-size: 1.5rem; display: grid; place-items: center; text-decoration: none; z-index: 15; box-shadow: var(--shadow-lg); border: 0; }
.fab-task:hover { background: var(--btn-primary-bg-hover); }

/* ── HugoAI teaser ────────────────────────────────────────────────────────── */
.hugoai-teaser { display: grid; gap: 1rem; }
.hugoai-hero { position: relative; overflow: hidden; padding: var(--space-5); border: 1px solid var(--hairline); border-radius: var(--radius-xl); background: radial-gradient(circle at 82% 12%, color-mix(in srgb, var(--color-primary) 30%, transparent), transparent 32%), linear-gradient(135deg, var(--hero-from), var(--hero-to)); box-shadow: var(--shadow-md); }
.hugoai-hero::after { content: "✦"; position: absolute; right: 1rem; top: .7rem; color: color-mix(in srgb, var(--color-primary) 40%, transparent); font-size: 4rem; line-height: 1; }
.hugoai-hero p { max-width: 33rem; margin-bottom: 0; }
.hugoai-chip-row { display: flex; flex-wrap: wrap; gap: .45rem; margin-top: .9rem; }
.hugoai-chip { display: inline-flex; align-items: center; gap: .25rem; padding: .35rem .65rem; border-radius: var(--radius-pill); background: var(--surface-card); border: 1px solid var(--hairline); color: var(--color-primary-text); font-size: var(--text-small); font-weight: var(--weight-heavy); }
.hugoai-card-grid { display: grid; gap: .75rem; }
.hugoai-card { display: grid; gap: .25rem; background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-lg); padding: var(--space-4); }
.hugoai-card strong { font-size: 1rem; }
.hugoai-card p { margin: 0; }
.hugoai-soon { border-style: dashed; background: var(--surface-inset); }

/* ── Floating profile avatar (top-right) ──────────────────────────────────── */
.page-avatar { float: right; margin: 0 0 .35rem .65rem; display: inline-flex; border-radius: var(--radius-pill); text-decoration: none; }
.page-avatar:focus-visible { outline: 3px solid var(--focus-ring); outline-offset: 2px; }
.avatar-circle { width: 2.5rem; height: 2.5rem; border-radius: var(--radius-pill); display: grid; place-items: center; color: #fff; font-weight: var(--weight-heavy); font-size: 1rem; line-height: 1; box-shadow: var(--shadow-sm); }
.page-avatar.is-active .avatar-circle { outline: 2px solid var(--color-primary); outline-offset: 2px; }
.page-body::after { content: ""; display: block; clear: both; }

/* ── Profile page ─────────────────────────────────────────────────────────── */
.profile-hero { display: grid; justify-items: center; gap: .4rem; text-align: center; margin: .25rem 0 1.25rem; }
.avatar-xl { width: 5.5rem; height: 5.5rem; border-radius: var(--radius-pill); display: grid; place-items: center; color: #fff; font-weight: var(--weight-heavy); font-size: 2.2rem; line-height: 1; box-shadow: var(--shadow-md); }
.profile-hero h1 { margin: .25rem 0 0; }
.profile-sub { margin: 0; }
.profile-card { margin-top: 1rem; }
.profile-card h2 { margin: 0 0 .5rem; font-size: 1.05rem; }
.profile-row { display: flex; justify-content: space-between; gap: .75rem; padding: .55rem 0; border-top: 1px solid var(--hairline); }
.profile-row:first-of-type { border-top: 0; }
.profile-row .label { color: var(--text-secondary); font-weight: var(--weight-bold); }
.profile-row .value { text-align: right; overflow-wrap: anywhere; }
.device-subhead { margin: 1rem 0 .5rem; font-size: .95rem; }
.device-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .5rem; }
.device-row { display: flex; align-items: center; justify-content: space-between; gap: .5rem; padding: .6rem .7rem; border: 1px solid var(--hairline); border-radius: var(--radius-md); background: var(--surface-card); }
.device-meta { display: grid; min-width: 0; }
.device-name { font-weight: var(--weight-bold); overflow-wrap: anywhere; }
.device-sub { font-size: var(--text-small); color: var(--text-secondary); }
.device-empty { color: var(--text-secondary); }
.device-add { margin-top: .75rem; }

/* Avatar colour swatches + icon pickers */
.swatch-grid { display: flex; flex-wrap: wrap; gap: .55rem; }
.swatch { position: relative; display: inline-flex; }
.swatch input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.swatch .dot { width: 2.1rem; height: 2.1rem; border-radius: var(--radius-pill); border: 2px solid transparent; box-shadow: inset 0 0 0 1px rgba(255,255,255,.4); transition: border-color .12s ease, box-shadow .12s ease; }
.swatch input:checked + .dot { border-color: var(--color-primary); box-shadow: inset 0 0 0 2px var(--surface-card); }
.swatch input:focus-visible + .dot { outline: 3px solid var(--focus-ring); outline-offset: 2px; }
.icon-grid { display: flex; flex-wrap: wrap; gap: .5rem; }
.icon-opt { position: relative; display: inline-flex; }
.icon-opt input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.icon-opt .glyph { width: 2.7rem; height: 2.7rem; border-radius: var(--radius-sm); border: 1.5px solid var(--hairline); background: var(--surface-card); display: grid; place-items: center; font-size: 1.3rem; }
.icon-opt input:checked + .glyph { border-color: var(--color-primary); background: var(--color-primary-soft); }
.icon-opt input:focus-visible + .glyph { outline: 3px solid var(--focus-ring); outline-offset: 2px; }

/* Skin / theme preview chips (Profile appearance pickers) */
.skin-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(7.5rem, 1fr)); gap: .55rem; }
.skin-opt { position: relative; display: block; }
.skin-opt input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.skin-card { display: grid; gap: .5rem; padding: .65rem; border: 1.5px solid var(--hairline); border-radius: var(--radius-md); background: var(--surface-card); }
.skin-opt input:checked + .skin-card { border-color: var(--color-primary); box-shadow: 0 0 0 2px var(--color-primary-soft); }
.skin-opt input:focus-visible + .skin-card { outline: 3px solid var(--focus-ring); outline-offset: 2px; }
.skin-swatches { display: flex; gap: .3rem; }
.skin-swatches span { width: 1.25rem; height: 1.25rem; border-radius: var(--radius-pill); border: 1px solid rgba(0,0,0,.08); }
.skin-name { font-weight: var(--weight-bold); font-size: var(--text-meta); }

/* ── Misc utilities ───────────────────────────────────────────────────────── */
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ── Auth / onboarding ────────────────────────────────────────────────────── */
.auth-wrap { width: min(100%, 27rem); margin: 1rem auto 0; display: grid; gap: 1rem; }
.auth-brand { text-align: center; display: grid; gap: .35rem; }
.auth-brand .wordmark { font-family: var(--font-heading); font-size: 1.35rem; font-weight: 900; color: var(--color-primary-text); letter-spacing: -.01em; }
.auth-brand .tagline { margin: 0; font-size: var(--text-meta); }
.auth-tabs { display: grid; grid-template-columns: 1fr 1fr; gap: .25rem; padding: .25rem; background: var(--surface-inset); border: 1px solid var(--hairline); border-radius: var(--radius-pill); }
.auth-tab { display: grid; place-items: center; min-height: 2.6rem; border-radius: var(--radius-pill); text-decoration: none; font-weight: var(--weight-heavy); color: var(--text-secondary); font-size: var(--text-meta); }
.auth-tab.active { background: var(--surface-card); color: var(--text-primary); box-shadow: var(--shadow-sm); }
.auth-card { background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-xl); padding: 1.25rem; box-shadow: var(--shadow-md); }
.auth-card h1 { font-size: clamp(1.4rem, 6vw, 1.9rem); }
.auth-lede { margin: 0 0 1rem; }
.auth-primary-btn { width: 100%; min-height: 3rem; font-size: 1rem; }
.auth-passkey-btn { width: 100%; min-height: 3rem; display: inline-flex; align-items: center; justify-content: center; gap: .5rem; background: var(--surface-card); color: var(--color-primary-text); border: 1.5px solid var(--color-primary); border-radius: var(--radius-md); padding: .8rem 1rem; font-weight: var(--weight-heavy); font: inherit; cursor: pointer; text-decoration: none; }
.auth-passkey-btn:focus-visible { outline: 3px solid var(--focus-ring); outline-offset: 2px; }
.auth-divider { display: flex; align-items: center; gap: .75rem; color: var(--text-secondary); font-size: var(--text-small); font-weight: var(--weight-bold); margin: .25rem 0; }
.auth-divider::before, .auth-divider::after { content: ""; flex: 1; height: 1px; background: var(--hairline); }
.provider-row { display: grid; gap: .5rem; }
.provider-btn { display: flex; align-items: center; gap: .6rem; min-height: 2.8rem; padding: .65rem .85rem; border: 1.5px solid var(--hairline); border-radius: var(--radius-md); background: var(--surface-card); color: var(--text-secondary); font-weight: var(--weight-heavy); font-size: var(--text-meta); text-align: left; cursor: not-allowed; }
a.provider-btn { color: var(--text-primary); cursor: pointer; text-decoration: none; }
a.provider-btn:hover { border-color: var(--color-primary); background: var(--surface-card); }
.provider-btn .provider-glyph { width: 1.4rem; height: 1.4rem; display: grid; place-items: center; font-weight: 900; }
.provider-btn .soon-badge { margin-left: auto; font-size: .68rem; text-transform: uppercase; letter-spacing: .05em; background: var(--warning-bg); color: var(--warning-text); border-radius: var(--radius-pill); padding: .15rem .5rem; font-weight: var(--weight-heavy); }
.auth-steps { list-style: none; counter-reset: s; margin: 0; padding: 0; display: grid; gap: .9rem; }
.auth-steps li { counter-increment: s; display: grid; grid-template-columns: 1.7rem minmax(0, 1fr); column-gap: .7rem; row-gap: .15rem; align-items: start; color: var(--text-primary); }
.auth-steps li::before { content: counter(s); grid-column: 1; grid-row: 1 / span 2; display: grid; place-items: center; width: 1.7rem; height: 1.7rem; border-radius: var(--radius-pill); background: var(--color-primary-soft); color: var(--color-primary-text); font-weight: 900; font-size: .85rem; }
.auth-steps li strong { grid-column: 2; grid-row: 1; font-weight: var(--weight-heavy); font-size: .95rem; line-height: 1.3; }
.auth-steps li span { grid-column: 2; grid-row: 2; color: var(--text-secondary); font-weight: var(--weight-medium); font-size: .85rem; line-height: 1.45; display: block; }
.auth-foot { text-align: center; margin: 0; font-size: var(--text-meta); }
.auth-foot a { color: var(--color-primary-text); font-weight: var(--weight-heavy); }
.auth-success { display: grid; justify-items: center; text-align: center; gap: .5rem; }
.auth-success .check { width: 3.25rem; height: 3.25rem; border-radius: var(--radius-pill); background: var(--success-bg); color: var(--success-text); display: grid; place-items: center; font-size: 1.6rem; }
.auth-error { margin: .25rem 0 0; color: var(--danger-text); font-weight: var(--weight-heavy); font-size: var(--text-meta); }
.auth-hint { margin: .75rem 0 0; font-size: var(--text-small); color: var(--text-secondary); }

/* ── Page header pattern (eyebrow → H1 → lede) ────────────────────────────── */
.lede { margin: 0 0 var(--space-2); color: var(--text-secondary); font-size: var(--text-body); }
.section-title { margin: 1.5rem 0 .5rem; font-size: 1.05rem; font-weight: var(--weight-heavy); color: var(--text-primary); }

/* ── Empty states (warm, useful) ──────────────────────────────────────────── */
.empty-state {
  display: grid; justify-items: center; text-align: center; gap: .35rem;
  background: var(--surface-card-warm);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-5);
  margin-top: var(--space-5);
  box-shadow: var(--shadow-sm);
}
.empty-state-icon {
  width: 3.25rem; height: 3.25rem; border-radius: var(--radius-pill);
  display: grid; place-items: center; font-size: 1.6rem; margin-bottom: .25rem;
  background: var(--color-primary-soft); color: var(--color-primary-text);
}
.empty-state-icon.is-success { background: var(--success-bg); color: var(--success-text); }
.empty-state-title { margin: 0; font-size: 1.1rem; font-weight: var(--weight-heavy); color: var(--text-primary); }
.empty-state p { margin: 0; font-size: var(--text-meta); }
.empty-state .button, .empty-state .button-link { margin-top: var(--space-3); }

/* ── Module tiles (home dashboard) ────────────────────────────────────────── */
.module-tile { display: flex; align-items: center; gap: .85rem; text-decoration: none; color: var(--text-primary); font-weight: var(--weight-heavy); min-height: var(--tap-min); }
.module-tile-icon { width: 2.6rem; height: 2.6rem; flex-shrink: 0; border-radius: var(--radius-md); display: grid; place-items: center; font-size: 1.45rem; background: var(--color-primary-soft); color: var(--color-primary-text); }
.module-tile-name { flex: 1; min-width: 0; }
.module-tile-locked { opacity: .8; }
.module-tile-locked .module-tile-icon { background: var(--surface-inset); color: var(--text-secondary); }
.module-tile .module-chevron { color: var(--text-muted); font-weight: 900; }

/* ── Dashboard summary cards ──────────────────────────────────────────────── */
.dashboard { display: grid; gap: 1rem; }
.summary-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.summary-card { display: grid; gap: .15rem; background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-lg); padding: var(--space-4); text-decoration: none; color: var(--text-primary); box-shadow: var(--shadow-sm); }
.summary-card .summary-num { font-family: var(--font-heading); font-size: 1.8rem; font-weight: var(--weight-heavy); line-height: 1; }
.summary-card .summary-label { font-size: var(--text-small); color: var(--text-secondary); font-weight: var(--weight-bold); }
.summary-card.is-shopping .summary-num { color: var(--color-primary-text); }
.summary-card.is-tasks .summary-num { color: var(--color-success-text); }

/* ── Founding-families / feedback + referral card ─────────────────────────── */
.founding-card { border: 1px solid var(--color-primary-soft); background: linear-gradient(135deg, var(--surface-card), var(--color-primary-soft)); }
.founding-card .eyebrow { color: var(--color-primary-text); }
.community-actions { display: grid; gap: .5rem; margin-top: .75rem; }

/* ── Settings link list (grouped rows with chevrons) ──────────────────────── */
.settings-group { margin-top: 1rem; }
.settings-list { list-style: none; padding: 0; margin: 0; background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.settings-list li { border-top: 1px solid var(--hairline); }
.settings-list li:first-child { border-top: 0; }
.settings-list a, .settings-list button {
  display: flex; align-items: center; gap: .75rem; width: 100%;
  min-height: var(--tap-min); padding: .9rem 1rem;
  background: transparent; border: 0; border-radius: 0;
  color: var(--text-primary); font-weight: var(--weight-bold); font-size: var(--text-body);
  text-decoration: none; text-align: left; cursor: pointer;
}
.settings-list a:hover, .settings-list button:hover { background: var(--surface-inset); }
.settings-list .row-icon { width: 1.6rem; text-align: center; font-size: 1.1rem; }
.settings-list .row-label { flex: 1; min-width: 0; }
.settings-list .row-chevron { color: var(--text-muted); font-weight: 900; }
.settings-list .is-danger { color: var(--danger-text); }

/* ── Task date groups + pager ─────────────────────────────────────────────── */
.task-date-group { margin-top: 1.25rem; }
.task-date-group:first-of-type { margin-top: .75rem; }
.task-date-group-title { margin: 0 0 .5rem; font-size: var(--text-eyebrow); text-transform: uppercase; letter-spacing: .06em; font-weight: var(--weight-heavy); color: var(--text-secondary); }
.pager { display: flex; gap: .75rem; justify-content: center; align-items: center; margin-top: .75rem; font-size: var(--text-meta); }
.pager a { color: var(--color-primary-text); font-weight: var(--weight-heavy); text-decoration: none; min-height: var(--tap-min); display: inline-flex; align-items: center; padding: 0 .5rem; }
.pager span { color: var(--text-secondary); }

/* ── Trash / restore list ─────────────────────────────────────────────────── */
.trash-list { gap: .65rem; margin-top: var(--space-4); }
.trash-row { display: grid; gap: .65rem; }
.trash-row-head { display: flex; flex-wrap: wrap; align-items: baseline; gap: .5rem; justify-content: space-between; }
.trash-row-head strong { overflow-wrap: anywhere; }
.trash-row-actions { display: flex; gap: .5rem; flex-wrap: wrap; }
.trash-row-actions button { flex: 1 1 auto; }

/* ── Branded confirmation dialog (replaces native confirm) ────────────────── */
.hf-dialog {
  width: min(100%, 24rem);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  background: var(--surface-card);
  color: var(--text-primary);
  box-shadow: var(--shadow-lg);
}
.hf-dialog::backdrop { background: var(--overlay); }
.hf-dialog h2 { margin: 0 0 .35rem; font-size: 1.2rem; }
.hf-dialog p { margin: 0; color: var(--text-secondary); }
.hf-dialog-actions { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; margin-top: 1.25rem; }
.hf-dialog-actions button { width: 100%; }
.hf-dialog-confirm.is-danger { background: var(--btn-danger-bg); color: var(--btn-danger-text); }
.hf-dialog-confirm.is-danger:hover { background: var(--btn-danger-bg-hover); }
