/**
 * Inro Theme
 *
 * Visuals modeled on the legacy Inro app (sn-pro typography, flat 5px radii,
 * gray secondary surface, blue primary accent). Token system mirrors
 * `climb/www/static/theme.css` so a second theme can be slotted in later by
 * overriding the HSL triples in `:root`.
 */

@font-face {
  font-family: sn-pro;
  src: url(/static/fonts/sn-pro/SNPro-Regular.woff2) format('woff2');
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: sn-pro;
  src: url(/static/fonts/sn-pro/SNPro-RegularItalic.woff2) format('woff2');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: sn-pro;
  src: url(/static/fonts/sn-pro/SNPro-Light.woff2) format('woff2');
  font-weight: 300;
  font-display: swap;
}
@font-face {
  font-family: sn-pro;
  src: url(/static/fonts/sn-pro/SNPro-Medium.woff2) format('woff2');
  font-weight: 500;
  font-display: swap;
}
@font-face {
  font-family: sn-pro;
  src: url(/static/fonts/sn-pro/SNPro-Semibold.woff2) format('woff2');
  font-weight: 600;
  font-display: swap;
}
@font-face {
  font-family: sn-pro;
  src: url(/static/fonts/sn-pro/SNPro-Bold.woff2) format('woff2');
  font-weight: 700;
  font-display: swap;
}

@layer theme {
  :root {
    /* Typography */
    --font-family-base: sn-pro, -apple-system, BlinkMacSystemFont, 'Segoe UI',
      sans-serif;
    --font-family-mono: 'SF Mono', Monaco, 'Inconsolata', monospace;

    /* Font size — match Inro's heading ladder (h1/h2 = 2rem) */
    --f1: 2rem;
    --f2: 1.66rem;
    --f3: 1.45rem;
    --f4: 1.25rem;
    --f5: 1.125rem;
    --f6: 1rem;
    --f7: 0.875rem;
    --f8: 0.75rem;

    /* Spacing */
    --s0: 0;
    --s1: 0.25rem;
    --s2: 0.5rem;
    --s3: 1rem;
    --s4: 1.5rem;
    --s5: 2rem;
    --s6: 3rem;

    /* Font weight — sn-pro is at its best a bit lighter than usual */
    --fw-thin: 300;
    --fw-normal: 400;
    --fw-medium: 500;
    --fw-semibold: 600;
    --fw-bold: 700;

    /* Line height */
    --lh-tight: 1.3;
    --lh-base: 1.6;

    /* Border radius — Inro is flatter than climb */
    --br-sm: 3px;
    --br-base: 5px;
    --br-lg: 10px;
    --br-full: 9999px;

    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.06);
    --shadow-base: 0 2px 6px rgba(0, 0, 0, 0.08);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.10);

    /* Transitions */
    --transition-fast: 0.10s ease-out;
    --transition-base: 0.18s ease-out;

    /* Z-index */
    --z-header: 100;
    --z-dock: 400;

    /* ── Color palette (Inro basic-light) ────────────────────────────── */

    --whiteH: 0;
    --whiteS: 0%;
    --whiteL: 100%;

    --blackH: 0;
    --blackS: 0%;
    --blackL: 0%;

    --grayH: 210;
    --grayS: 10.8%;
    --grayL: 90%;

    --blueH: 215.8;
    --blueS: 98.4%;
    --blueL: 52.2%;

    --greenH: 152.2;
    --greenS: 68.8%;
    --greenL: 31.4%;

    --yellowH: 45;
    --yellowS: 100%;
    --yellowL: 51.4%;

    --orangeH: 27.3;
    --orangeS: 98.3%;
    --orangeL: 53.5%;

    --redH: 354.3;
    --redS: 70.5%;
    --redL: 53.5%;

    --purpleH: 261.3;
    --purpleS: 50.6%;
    --purpleL: 50.8%;

    /* Semantic — point named tokens at palette entries */
    --backgroundH: var(--whiteH);
    --backgroundS: var(--whiteS);
    --backgroundL: var(--whiteL);

    --bodyH: var(--blackH);
    --bodyS: var(--blackS);
    --bodyL: var(--blackL);

    --secondaryH: var(--grayH);
    --secondaryS: var(--grayS);
    --secondaryL: var(--grayL);

    --primaryH: var(--blueH);
    --primaryS: var(--blueS);
    --primaryL: var(--blueL);

    --errorH: var(--redH);
    --errorS: var(--redS);
    --errorL: var(--redL);

    --warningH: var(--yellowH);
    --warningS: var(--yellowS);
    --warningL: var(--yellowL);

    --successH: var(--greenH);
    --successS: var(--greenS);
    --successL: var(--greenL);

    --borderH: var(--blackH);
    --borderS: var(--blackS);
    --borderL: 85%;

    /* Resolved colors */
    --background: hsl(var(--backgroundH), var(--backgroundS), var(--backgroundL));
    --body: hsl(var(--bodyH), var(--bodyS), var(--bodyL));
    --body-dull: hsla(var(--bodyH), var(--bodyS), var(--bodyL), 0.3);
    --secondary: hsl(var(--secondaryH), var(--secondaryS), var(--secondaryL));
    --secondary-bg: var(--background);
    --secondary-dull: hsla(var(--secondaryH), var(--secondaryS), var(--secondaryL), 0.3);
    --secondary-muted: hsla(var(--secondaryH), var(--secondaryS), var(--secondaryL), 0.5);
    --primary: hsl(var(--primaryH), var(--primaryS), var(--primaryL));
    --primary-dull: hsla(var(--primaryH), var(--primaryS), var(--primaryL), 0.15);
    --error: hsl(var(--errorH), var(--errorS), var(--errorL));
    --success: hsl(var(--successH), var(--successS), var(--successL));
    --border: hsl(var(--borderH), var(--borderS), var(--borderL));
    --muted: hsla(var(--bodyH), var(--bodyS), var(--bodyL), 0.6);

    /* Layout */
    --header-height: 56px;
    --dock-height: 4.5rem;
  }

  /* ── Reset / globals ──────────────────────────────────────────────── */

  html {
    background-color: var(--background);
    color: var(--body);
    font-family: var(--font-family-base);
    font-size: 16px;
    font-weight: var(--fw-normal);
  }

  body {
    margin: 0;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    padding-bottom: 0;
    /* Page surface sits one shade below --background so elevated elements
       (event rows, command dock) read as cards on top. */
    background-color: hsl(var(--bodyH), var(--bodyS), 96%);
  }

  body[data-show-dock] {
    padding-bottom: var(--dock-height);
  }

  h1, h2, h3, h4, h5, h6 {
    font-weight: var(--fw-normal);
    margin: var(--s4) 0 var(--s3);
    line-height: var(--lh-tight);
  }

  h1, h2 { font-size: var(--f1); }
  h3 { font-size: var(--f2); }
  h4 { font-size: var(--f3); }
  h5 { font-size: var(--f4); font-weight: var(--fw-semibold); }
  h6 { font-size: var(--f5); font-weight: var(--fw-semibold); }

  p {
    line-height: var(--lh-base);
    margin: var(--s3) 0;
    max-width: 80ch;
  }

  small { font-size: var(--f8); }

  strong, b { font-weight: var(--fw-bold); }

  a, a:link, a:visited, a:active, a:focus {
    color: currentColor;
    font-weight: var(--fw-medium);
  }

  code, pre {
    font-family: var(--font-family-mono);
    font-size: 0.95em;
  }

  code {
    background: var(--secondary-dull);
    padding: 0 var(--s1);
    border-radius: var(--br-sm);
  }

  pre {
    background: var(--secondary-dull);
    padding: var(--s3);
    border-radius: var(--br-base);
    overflow-x: auto;
  }

  button {
    font: inherit;
  }

  input:not([type='file']), textarea, select {
    background-color: transparent;
    border: 1px solid var(--secondary);
    border-radius: var(--br-base);
    color: inherit;
    font: inherit;
    padding: var(--s2) var(--s3);
    margin: 0;
  }

  input:focus, textarea:focus, select:focus {
    outline: 2px solid var(--primary-dull);
    outline-offset: 1px;
    border-color: var(--primary);
  }

  .muted { color: var(--muted); }

  /* ── Header ───────────────────────────────────────────────────────── */

  body > header {
    position: sticky;
    top: 0;
    z-index: var(--z-header);
    background-color: var(--header-tint, var(--background));
    color: var(--header-fg, var(--body));
    border-bottom: 1px solid var(--border);
    transition: background-color var(--transition-base), color var(--transition-base);
  }

  /* Icon glyphs rendered via CSS mask so they pick up text color. */
  .icon {
    display: inline-block;
    width: 20px;
    height: 20px;
    background-color: currentColor;
    -webkit-mask: var(--icon-url) center / contain no-repeat;
    mask: var(--icon-url) center / contain no-repeat;
    flex-shrink: 0;
  }

  ui-header-content {
    display: flex;
    align-items: center;
    gap: var(--s2);
    height: var(--header-height);
    padding: 0 var(--s3);
  }

  ui-header-content h1 {
    flex: 1;
    margin: 0;
    font-size: var(--f5);
    font-weight: var(--fw-bold);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-family: var(--font-family-base);
  }

  ui-header-content .header-back {
    background: transparent;
    border: none;
    padding: var(--s1);
    color: var(--body);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
  }

  ui-header-content .header-actions {
    display: flex;
    align-items: center;
    gap: var(--s3);
  }

  .header-action {
    color: inherit;
    text-decoration: none;
    opacity: 0.7;
    transition: opacity var(--transition-fast);
    display: inline-flex;
    align-items: center;
    padding: var(--s1);
  }

  .header-action:hover, .header-action:focus-visible {
    opacity: 1;
  }

  /* ── Main ─────────────────────────────────────────────────────────── */

  main {
    flex: 1;
    padding: var(--s3);
    max-width: 720px;
    width: 100%;
    margin: 0 auto;
    box-sizing: border-box;
  }

  /* ── Command palette dock ─────────────────────────────────────────── */

  command-input {
    display: none;
  }

  body[data-show-dock] command-input {
    position: fixed;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 100%;
    max-width: 500px;
    padding: var(--s2) var(--s3);
    background-color: var(--background);
    border-top: 1px solid var(--border);
    border-top-left-radius: var(--br-base);
    border-top-right-radius: var(--br-base);
    box-shadow: var(--shadow-md);
    z-index: var(--z-dock);
    display: block;
  }

  command-input .command-form {
    display: flex;
    align-items: end;
    gap: var(--s2);
  }

  command-input .command-textarea {
    flex: 1;
    resize: none;
    min-height: 2.5rem;
    max-height: 8rem;
    background-color: var(--background);
    color: var(--body);
    border: 1px solid var(--border);
    border-radius: var(--br-base);
    padding: var(--s2) var(--s3);
    font: inherit;
  }

  command-input .command-submit {
    border: none;
    background-color: var(--primary);
    color: var(--background);
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--br-full);
    font-size: var(--f4);
    cursor: pointer;
    transition: opacity var(--transition-fast);
  }

  command-input .command-submit:disabled {
    opacity: 0.4;
    cursor: not-allowed;
  }

  command-input .command-suggestions {
    list-style: none;
    margin: 0 0 var(--s2) 0;
    padding: var(--s1);
    background-color: var(--background);
    border-radius: var(--br-base);
    border: 1px solid var(--border);
    max-height: 30vh;
    overflow-y: auto;
    animation: command-suggestions-rise 120ms ease-out;
  }

  command-input .command-suggestion {
    padding: var(--s2) var(--s3);
    border-radius: var(--br-sm);
    cursor: pointer;
    display: flex;
    gap: var(--s2);
    align-items: baseline;
  }

  command-input .command-suggestion.is-active,
  command-input .command-suggestion:hover {
    background-color: var(--secondary-dull);
  }

  command-input .command-suggestion strong {
    font-weight: var(--fw-semibold);
    color: var(--primary);
  }

  @keyframes command-suggestions-rise {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  @media (prefers-reduced-motion: reduce) {
    command-input .command-suggestions { animation: none; }
  }

  /* ── Event list (home + collection detail) ────────────────────────── */

  .event-list, .collection-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--s1);
  }

  /* Breathing room below the last row so the latest event isn't flush with the
     dock; also gives a bit of overscroll feel on long lists. */
  .event-list { padding-bottom: 100px; }

  .event-list-item a, .collection-list-item a {
    display: flex;
    align-items: center;
    gap: var(--s3);
    padding: var(--s2) var(--s3);
    border-radius: var(--br-base);
    border: 1px solid var(--border);
    background-color: var(--background);
    color: inherit;
    text-decoration: none;
    transition: background-color var(--transition-fast);
  }

  .event-list-item a:hover, .collection-list-item a:hover {
    background-color: var(--secondary-dull);
  }

  /* Title (bold) and snippet (regular) share clamp behavior; only weight differs. */
  .event-row-title,
  .event-row-snippet {
    flex: 1;
    min-width: 0;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
  }

  .event-row-title { font-weight: var(--fw-bold); }
  .event-row-snippet { font-weight: var(--fw-normal); }

  .event-thumb {
    width: 64px;
    height: 64px;
    object-fit: cover;
    border-radius: var(--br-sm);
    flex-shrink: 0;
  }

  .event-row-indicators {
    display: flex;
    align-items: center;
    gap: var(--s1);
    margin-left: auto;
    flex-shrink: 0;
  }

  .event-row-indicator {
    width: 16px;
    height: 16px;
    color: var(--body-dull);
  }

  /* ── Sub-header (tabs blended with header) ────────────────────────── */

  ui-sub-header {
    position: sticky;
    top: var(--header-height);
    z-index: calc(var(--z-header) - 1);
    background-color: var(--header-tint, var(--background));
    color: var(--header-fg, var(--body));
    border-bottom: 1px solid var(--border);
    transition: background-color var(--transition-base), color var(--transition-base);
    display: block;
  }

  ui-sub-header[hidden] {
    display: none;
  }

  /* Eliminate the visual seam between header and sub-header when tinted */
  body:has(> ui-sub-header:not([hidden])) > header {
    border-bottom: none;
  }

  /* ── Home tabs ────────────────────────────────────────────────────── */

  home-tabs {
    display: block;
  }

  .home-tabs {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: var(--s1);
    padding: var(--s2) var(--s3);
    scrollbar-width: none;
  }

  .home-tabs::-webkit-scrollbar { display: none; }

  .home-tab {
    --tab-color: currentColor;
    flex-shrink: 0;
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    color: inherit;
    padding: var(--s2) var(--s2) var(--s1);
    border-radius: 0;
    cursor: pointer;
    font-size: var(--f7);
    font-weight: var(--fw-medium);
    opacity: 0.6;
    transition: opacity var(--transition-fast), border-color var(--transition-fast);
    margin: 0 var(--s1);
  }

  .home-tab:hover { opacity: 0.85; }

  .home-tab.is-active {
    opacity: 1;
    border-bottom-color: var(--tab-color);
  }

  /* ── Event header (title; lock/edit live in the page header) ──────── */

  .event-header {
    display: flex;
    gap: var(--s2);
    align-items: center;
    margin-bottom: var(--s3);
  }

  .event-title {
    flex: 1;
    border: none;
    background: transparent;
    font-size: var(--f2);
    font-weight: var(--fw-semibold);
    padding: var(--s1) 0;
    border-bottom: 1px solid var(--border);
    color: inherit;
    border-radius: 0;
  }

  .event-title:disabled {
    -webkit-text-fill-color: var(--body);
    opacity: 1;
  }

  /* Edit/Lock injected into header-actions */
  .header-action-button {
    background: transparent;
    border: none;
    cursor: pointer;
  }

  /* ── Tags ─────────────────────────────────────────────────────────── */

  .event-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s1);
    align-items: center;
    margin: 0 0 var(--s3);
  }

  .event-tag-chip {
    display: inline-flex;
    align-items: center;
    gap: var(--s1);
    padding: 0 var(--s2);
    height: 1.6rem;
    background: var(--secondary-dull);
    color: var(--body);
    border-radius: var(--br-full);
    font-size: var(--f8);
    font-weight: var(--fw-medium);
  }

  .event-tag-remove {
    background: transparent;
    border: none;
    color: var(--muted);
    cursor: pointer;
    padding: 0 var(--s1);
    font-size: var(--f6);
    line-height: 1;
  }

  .event-tag-remove:hover { color: var(--body); }

  .event-tag-input {
    flex: 1;
    min-width: 6rem;
    border: none;
    background: transparent;
    padding: var(--s1) var(--s2);
    font-size: var(--f8);
    color: inherit;
  }

  .event-tag-input:focus {
    outline: none;
    border-bottom: 1px solid var(--primary);
  }

  /* Compact chips on home rows */
  .event-row-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
    flex: 1;
  }


  .event-row-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s1);
  }

  .event-tag-chip-mini {
    height: auto;
    padding: 0 var(--s1);
    font-size: var(--f8);
    font-weight: var(--fw-medium);
  }

  /* ── Map popup ────────────────────────────────────────────────────── */

  .geo-popup-link {
    display: block;
    color: var(--body);
    text-decoration: none;
    font-weight: var(--fw-medium);
    padding: var(--s1) var(--s2);
    max-width: 14rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .geo-popup-link:hover {
    color: var(--primary);
  }

  .maplibregl-popup-content {
    border-radius: var(--br-base);
    padding: var(--s2);
  }

  /* ── Event menu (dropdown) ────────────────────────────────────────── */

  .event-menu {
    position: fixed;
    top: calc(var(--header-height) + var(--s1));
    right: var(--s2);
    z-index: var(--z-header);
    list-style: none;
    margin: 0;
    padding: var(--s1);
    background: var(--background);
    color: var(--body);
    border: 1px solid var(--border);
    border-radius: var(--br-base);
    box-shadow: var(--shadow-md);
    min-width: 10rem;
    display: flex;
    flex-direction: column;
    gap: 2px;
    animation: event-menu-rise 120ms ease-out;
  }

  @keyframes event-menu-rise {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  @media (prefers-reduced-motion: reduce) {
    .event-menu { animation: none; }
  }

  .event-menu button {
    display: flex;
    align-items: center;
    gap: var(--s2);
    width: 100%;
    background: transparent;
    border: none;
    color: inherit;
    text-align: left;
    padding: var(--s2) var(--s3);
    border-radius: var(--br-sm);
    cursor: pointer;
    font-size: var(--f6);
  }

  .event-menu button:hover {
    background: var(--secondary-dull);
  }

  .event-menu-danger,
  .event-menu-danger .icon {
    color: var(--error);
  }

  /* ── Rich-text view ───────────────────────────────────────────────── */

  .rich-text-article {
    display: flex;
    flex-direction: column;
    gap: var(--s2);
  }

  .rich-text-header {
    display: flex;
    gap: var(--s2);
    align-items: center;
  }

  .rich-text-title {
    flex: 1;
    border: none;
    background: transparent;
    font-size: var(--f2);
    font-weight: var(--fw-semibold);
    padding: var(--s1) 0;
    border-bottom: 1px solid var(--border);
    color: inherit;
    border-radius: 0;
  }

  .rich-text-title:disabled {
    border-bottom-color: transparent;
  }

  .rich-text-lock {
    padding: var(--s1) var(--s3);
    border-radius: var(--br-full);
    border: 1px solid var(--border);
    background: transparent;
    color: inherit;
    cursor: pointer;
    font-size: var(--f7);
  }

  .rich-text-body .ProseMirror {
    min-height: 40dvh;
    outline: none;
    line-height: var(--lh-base);
  }

  .rich-text-body .ProseMirror p {
    margin: var(--s2) 0;
  }

  .rich-text-body .ProseMirror p.is-editor-empty:first-child::before {
    content: attr(data-placeholder);
    color: var(--muted);
    pointer-events: none;
    float: left;
    height: 0;
  }

  /* ── Search ───────────────────────────────────────────────────────── */

  .search-section {
    display: flex;
    flex-direction: column;
    gap: var(--s3);
  }

  .search-input {
    width: 100%;
    box-sizing: border-box;
  }

  .search-result-text {
    display: flex;
    flex-direction: column;
    gap: var(--s1);
    min-width: 0;
    flex: 1;
  }

  .search-result-text strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .search-result-text small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: var(--f8);
  }

  /* ── Image view ───────────────────────────────────────────────────── */

  .image-figure {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--s2);
  }

  .image-figure img {
    max-width: 100%;
    border-radius: var(--br-base);
    border: 1px solid var(--border);
  }

  .image-figure figcaption {
    font-size: var(--f8);
    color: var(--muted);
    font-family: var(--font-family-mono);
  }

  .image-picker label {
    display: flex;
    flex-direction: column;
    gap: var(--s2);
    padding: var(--s4);
    border: 2px dashed var(--border);
    border-radius: var(--br-base);
    cursor: pointer;
    text-align: center;
  }

  /* ── Geolocation view ─────────────────────────────────────────────── */

  .geolocation-article {
    display: flex;
    flex-direction: column;
    gap: var(--s2);
  }

  .geolocation-open {
    margin-left: var(--s2);
    padding: var(--s1) var(--s3);
    border: 1px solid var(--border);
    border-radius: var(--br-full);
    background: transparent;
    color: inherit;
    cursor: pointer;
  }

  .geolocation-body {
    font-size: var(--f8);
    line-height: var(--lh-tight);
  }

  /* ── Collections ──────────────────────────────────────────────────── */

  .collections-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s2);
  }

  .collections-new {
    padding: var(--s2) var(--s3);
    border-radius: var(--br-full);
    border: 1px solid var(--primary);
    background: var(--primary);
    color: var(--background);
    cursor: pointer;
    font-weight: var(--fw-medium);
    transition: opacity var(--transition-fast);
  }

  .collections-new:hover {
    opacity: 0.85;
  }

  .collection-list-item {
    display: flex;
    align-items: stretch;
    gap: var(--s2);
  }

  .collection-list-item a {
    flex: 1;
    display: flex;
    align-items: center;
    gap: var(--s2);
    grid-template-columns: none;
  }

  .collection-reorder {
    display: flex;
    flex-direction: column;
    gap: 2px;
  }

  .collection-reorder button {
    width: 32px;
    flex: 1;
    border: 1px solid var(--border);
    background: var(--background);
    color: var(--body);
    border-radius: var(--br-sm);
    cursor: pointer;
    padding: var(--s1);
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .collection-reorder button:disabled {
    opacity: 0.3;
    cursor: default;
  }

  .collection-swatch {
    display: inline-block;
    width: 1rem;
    height: 1rem;
    border-radius: var(--br-full);
    flex-shrink: 0;
  }

  .collection-detail-header {
    display: flex;
    align-items: center;
    gap: var(--s2);
    margin: 0 0 var(--s3);
  }

  .collection-detail-header h2 {
    margin: 0;
  }

  .collection-color-row {
    display: flex;
    flex-direction: column;
    gap: var(--s2);
    margin: 0 0 var(--s3);
  }

  .collection-color-label {
    font-size: var(--f7);
    color: var(--muted);
  }

  .collection-swatches {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s2);
  }

  .collection-swatch-btn {
    width: 28px;
    height: 28px;
    border-radius: var(--br-full);
    border: 2px solid transparent;
    background: var(--secondary);
    color: var(--muted);
    cursor: pointer;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--f7);
  }

  .collection-swatch-btn.is-active {
    border-color: var(--body);
  }

  .collection-swatch-custom {
    overflow: hidden;
    position: relative;
    border: 2px dashed var(--border);
  }

  .collection-swatch-custom input[type="color"] {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: none;
    padding: 0;
    background: transparent;
    cursor: pointer;
    opacity: 0;
  }

  .collection-filters {
    margin: 0 0 var(--s4);
  }

  .collection-filters-title {
    font-size: var(--f5);
    margin-bottom: var(--s2);
  }

  .collection-plugin-filters {
    border: 1px solid var(--border);
    border-radius: var(--br-base);
    padding: var(--s3);
    margin: 0 0 var(--s3);
    display: flex;
    flex-direction: column;
    gap: var(--s2);
  }

  .collection-plugin-filters legend {
    font-size: var(--f7);
    color: var(--muted);
    padding: 0 var(--s1);
  }

  .collection-filter-row {
    display: flex;
    align-items: center;
    gap: var(--s2);
    cursor: pointer;
  }

  .collection-filter-row input {
    margin: 0;
    width: auto;
    height: auto;
  }

  .collection-filter-hint {
    font-size: var(--f8);
    margin: var(--s1) 0 0;
  }

  .collection-view-type {
    display: flex;
    align-items: center;
    gap: var(--s3);
    margin: 0 0 var(--s3);
  }

  .collection-view-type-label {
    font-size: var(--f7);
    color: var(--muted);
  }

  .collection-view-type-option {
    display: inline-flex;
    align-items: center;
    gap: var(--s1);
    cursor: pointer;
  }

  .collection-view-type-option input {
    margin: 0;
    width: auto;
    height: auto;
  }

  /* ── Geolocation collection map ───────────────────────────────────── */

  .geo-collection-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--s2);
  }

  .geo-collection-map {
    width: 100%;
    height: 60vh;
  }

  /* Native maplibre markers are SVG; we cursor-pointer them so clicks navigate. */
  .maplibregl-marker { cursor: pointer; }

  .collection-actions {
    display: flex;
    gap: var(--s2);
    margin: 0 0 var(--s4);
  }

  .collection-actions button {
    padding: var(--s2) var(--s3);
    border-radius: var(--br-full);
    border: 1px solid var(--border);
    background: transparent;
    color: inherit;
    cursor: pointer;
  }

  /* ── Settings ─────────────────────────────────────────────────────── */

  settings-page, settings-about-page {
    display: block;
    padding: var(--s3);
    max-width: 600px;
    margin: 0 auto;
  }

  settings-page section,
  settings-about-page section {
    margin-bottom: var(--s5);
  }

  settings-page section > p,
  settings-about-page section > p {
    color: var(--muted);
    margin-bottom: var(--s3);
  }

  .settings-nav-list {
    display: flex;
    flex-direction: column;
    gap: var(--s2);
  }

  .settings-nav-link {
    display: block;
    padding: var(--s3);
    border: 1px solid var(--border);
    border-radius: var(--br-base);
    background: transparent;
    color: inherit;
    text-decoration: none;
    transition: background-color var(--transition-fast);
  }

  .settings-nav-link:hover {
    background-color: var(--secondary-dull);
  }

  .settings-nav-link-meta {
    font-size: var(--f8);
    color: var(--muted);
    margin-top: 2px;
  }

  /* ── ui-sync-input / ui-store-import ──────────────────────────────── */

  ui-sync-input form {
    display: flex;
    flex-direction: column;
    gap: var(--s2);
  }

  ui-sync-input label {
    display: flex;
    flex-direction: column;
    gap: var(--s1);
  }

  ui-sync-input label span {
    font-size: var(--f7);
    color: var(--muted);
  }

  ui-sync-input button.action,
  ui-sync-input button.link {
    padding: var(--s2) var(--s3);
    border-radius: var(--br-full);
    cursor: pointer;
  }

  ui-sync-input button.action {
    border: 1px solid var(--primary);
    background: var(--primary);
    color: var(--background);
  }

  ui-sync-input button.link {
    border: none;
    background: transparent;
    color: var(--primary);
    text-decoration: underline;
  }

  ui-sync-input .ui-sync-input__error {
    font-size: var(--f7);
    color: var(--error);
  }

  ui-sync-input .ui-sync-input__status {
    display: flex;
    gap: var(--s2);
    align-items: baseline;
  }

  ui-sync-input .ui-sync-input__indicator--ok { color: var(--success); }
  ui-sync-input .ui-sync-input__indicator--syncing { color: var(--primary); }

  ui-sync-input .ui-sync-input__actions {
    display: flex;
    gap: var(--s2);
    margin-top: var(--s2);
  }

  ui-store-import div {
    display: flex;
    gap: var(--s2);
    flex-wrap: wrap;
  }

  ui-store-import button {
    padding: var(--s2) var(--s3);
    border-radius: var(--br-full);
    border: 1px solid var(--border);
    background: transparent;
    color: inherit;
    cursor: pointer;
  }
}

nav {
  border: none;
  margin: 0;
}
