/* ==========================================================================
   STYLE.CSS — Native CSS style guide
   Synthesized from nomads.com, remoteok.com, hotelist.com, photoai.com,
   airlinelist.com, luggagelosers.com, ideasai.com
   Drop-in framework for simple, fast websites. No build step required.
   ========================================================================== */

/* --- Dark mode: apply before first paint (copy to inline <script> in HTML) ---
(function () {
  try {
    var d = localStorage.getItem('ui_dark');
    if (d === '1') document.documentElement.classList.add('dark');
    else if (d === '0') return;
    else if (matchMedia('(prefers-color-scheme: dark)').matches)
      document.documentElement.classList.add('dark');
  } catch (e) {}
})();
--- */

/* ==========================================================================
   1. DESIGN TOKENS
   ========================================================================== */

:root {
  /* Brand — override per project */
  --ui-brand: #ff4742;
  --ui-brand-light: #ff6b66;
  --ui-accent: #0072b1;
  --ui-gradient: linear-gradient(90deg, #ff0f7b 0%, #f89b29 100%);

  /* Semantic colors */
  --ui-green: #2bde73;
  --ui-green-alt: #16bf63;
  --ui-yellow: #ffc924;
  --ui-yellow-active: #ffff00;
  --ui-blue: #42b4ff;
  --ui-red: #ff5252;
  --ui-error-bg: #ffc4c3;

  /* Surfaces */
  --ui-bg: #fbfaf8;
  --ui-bg-alt: #f5f5f5;
  --ui-surface: #ffffff;
  --ui-surface-muted: #f9f9f9;

  /* Text */
  --ui-text: #1c1c1c;
  --ui-text-alt: #0f1115;
  --ui-text-dim: #686868;
  --ui-text-muted: #888888;

  /* Borders & shadows */
  --ui-border: #dddddd;
  --ui-border-subtle: #dcdddd;
  --ui-shadow: 0 0 0 1px var(--ui-border);
  --ui-shadow-brutal: 3px 3px 0 var(--ui-text-alt);

  /* Highlight */
  --ui-highlight: #fff38f;

  /* Typography */
  --ui-font: -apple-system, system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --ui-font-mono: "JetBrains Mono", "SF Mono", Monaco, Inconsolata, "Fira Code", monospace;
  --ui-weight-normal: 400;
  --ui-weight-medium: 500;
  --ui-weight-bold: 700;
  --ui-weight-heavy: 800;

  /* Spacing & shape */
  --ui-padding: 14px;
  --ui-radius: 12px;
  --ui-radius-sm: 6px;
  --ui-radius-pill: 50px;
  --ui-max-width: 1100px;
  --ui-header-height: 60px;

  /* Interaction */
  --ui-transition: 0.15s ease;
}

/* Dark theme */
html.dark {
  --ui-bg: #111111;
  --ui-bg-alt: #1a1a1a;
  --ui-surface: #161616;
  --ui-surface-muted: #1f1e1e;
  --ui-text: #bfbfbf;
  --ui-text-alt: #f2f2f2;
  --ui-text-dim: #9a9a9a;
  --ui-text-muted: #6a6a6a;
  --ui-border: #343434;
  --ui-border-subtle: #2b2b2b;
  --ui-shadow: 0 0 0 1px var(--ui-border);
  --ui-shadow-brutal: 3px 3px 0 var(--ui-text-alt);
  --ui-error-bg: #5a2c2b;
}

/* Sharp/brutalist mode — hotelist-inspired */
html.ui-sharp {
  --ui-font: var(--ui-font-mono);
  --ui-radius-sm: 6px;
}

/* ==========================================================================
   2. RESET & BASE
   ========================================================================== */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--ui-font);
  font-size: 16px;
  font-weight: var(--ui-weight-normal);
  line-height: 1.5;
  color: var(--ui-text);
  background: var(--ui-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  touch-action: manipulation;
}

::selection {
  background: var(--ui-highlight);
}

::-moz-selection {
  background: var(--ui-highlight);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: var(--ui-text);
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
}

a:hover {
  opacity: 0.75;
}

a:active {
  opacity: 0.5;
}

/* Underline link variant (remoteok/nomads style) */
a.ui-link-underline:hover {
  opacity: 1;
  border-bottom: 2px solid currentColor;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0 0 0.5em;
  font-weight: var(--ui-weight-heavy);
  line-height: 1.25;
  color: var(--ui-text-alt);
}

h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }

p {
  margin: 0 0 1em;
}

/* ==========================================================================
   3. LAYOUT
   ========================================================================== */

.ui-container {
  width: 100%;
  max-width: var(--ui-max-width);
  margin: 0 auto;
  padding: 0 var(--ui-padding);
}

.ui-container-wide {
  max-width: 1200px;
}

.ui-stack {
  display: flex;
  flex-direction: column;
  gap: var(--ui-padding);
}

.ui-cluster {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.ui-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ui-padding);
}

@media (max-width: 768px) {
  .ui-split {
    grid-template-columns: 1fr;
  }
}

.ui-center {
  text-align: center;
}

/* ==========================================================================
   4. HEADER & NAV
   ========================================================================== */

.ui-header {
  position: sticky;
  top: 0;
  z-index: 50;
  height: var(--ui-header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--ui-padding);
  background: var(--ui-surface);
  border-bottom: 1px solid var(--ui-border);
}

.ui-header-transparent {
  background: transparent;
  border-bottom: none;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}

.ui-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: var(--ui-weight-heavy);
  font-size: 1.1rem;
}

.ui-logo-icon {
  width: 30px;
  height: 30px;
  border-radius: var(--ui-radius-sm);
  background: var(--ui-gradient);
  background-size: 300% 300%;
  animation: ui-gradient-shift 6s ease infinite alternate;
}

.ui-logo-gradient-text {
  background: var(--ui-gradient);
  background-size: 300% 300%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: ui-gradient-shift 6s ease infinite alternate;
}

@keyframes ui-gradient-shift {
  0% { background-position: 0% 50%; }
  100% { background-position: 100% 50%; }
}

.ui-nav {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ui-nav a {
  font-weight: var(--ui-weight-bold);
  font-size: 0.9rem;
}

.ui-nav a:hover {
  opacity: 1;
  color: var(--ui-brand);
}

/* ==========================================================================
   5. BUTTONS
   ========================================================================== */

.ui-btn {
  display: inline-block;
  padding: 9px 16px;
  font-family: inherit;
  font-size: 16px;
  font-weight: var(--ui-weight-bold);
  line-height: 1.25;
  text-align: center;
  cursor: pointer;
  border: 2px solid transparent;
  border-radius: var(--ui-radius);
  -webkit-user-select: none;
  user-select: none;
  transition: background var(--ui-transition), color var(--ui-transition), border-color var(--ui-transition);
}

.ui-btn:active {
  opacity: 0.5;
}

.ui-btn:disabled {
  opacity: 0.5;
  pointer-events: none;
  filter: saturate(0);
}

/* Primary — brand coral (nomads default) */
.ui-btn-primary {
  background: var(--ui-brand);
  border-color: var(--ui-brand);
  color: #ffffff;
}

.ui-btn-primary:hover {
  background: transparent;
  color: var(--ui-brand);
}

/* Accent — blue (remoteok) */
.ui-btn-accent {
  background: var(--ui-accent);
  border-color: var(--ui-accent);
  color: #ffffff;
}

.ui-btn-accent:hover {
  background: transparent;
  color: var(--ui-accent);
}

/* Gradient (photoai) — animated shift like photoai.com */
.ui-btn-gradient {
  background-color: transparent;
  background-image: var(--ui-gradient);
  background-repeat: no-repeat;
  background-size: 300% 100%;
  background-position: 0% 50%;
  animation: ui-gradient-shift 6s ease infinite alternate;
  border-color: transparent;
  color: #ffffff;
}

.ui-btn-gradient:hover {
  animation: none;
  background-image: none;
  background-color: transparent;
  border-color: var(--ui-text);
  color: var(--ui-text);
}

html.dark .ui-btn-gradient:hover {
  border-color: #ffffff;
  color: #ffffff;
}

/* Black/white invert */
.ui-btn-black {
  background: #000000;
  border-color: #000000;
  color: #ffffff;
}

.ui-btn-black:hover {
  background: transparent;
  color: #000000;
}

html.dark .ui-btn-black {
  background: #ffffff;
  border-color: #ffffff;
  color: #000000;
}

html.dark .ui-btn-black:hover {
  background: transparent;
  color: #ffffff;
}

/* Outline / reverse */
.ui-btn-outline {
  background: transparent;
  border-color: var(--ui-text-alt);
  color: var(--ui-text-alt);
}

.ui-btn-outline:hover {
  background: var(--ui-text-alt);
  color: var(--ui-bg);
}

/* Semantic */
.ui-btn-green {
  background: var(--ui-green-alt);
  border-color: var(--ui-green-alt);
  color: #ffffff;
}

.ui-btn-green:hover {
  background: transparent;
  color: var(--ui-green-alt);
}

/* Brutalist — hotelist pressable */
.ui-btn-brutal {
  background: var(--ui-surface);
  border: 2px solid var(--ui-text-alt);
  box-shadow: var(--ui-shadow-brutal);
  color: var(--ui-text-alt);
  position: relative;
  top: 0;
  left: 0;
  transition: box-shadow 0.3s ease-in-out, top 0.3s ease-in-out, left 0.3s ease-in-out;
}

.ui-btn-brutal:hover {
  opacity: 1;
  box-shadow: 1px 1px 0 var(--ui-text-alt);
  top: 2px;
  left: 2px;
}

.ui-btn-brutal:active {
  opacity: 1;
  box-shadow: 0 0 0 var(--ui-text-alt);
  top: 3px;
  left: 3px;
}

/* Size variants */
.ui-btn-sm {
  padding: 6px 12px;
  font-size: 0.85rem;
}

.ui-btn-lg {
  padding: 14px 28px;
  font-size: 1.1rem;
  font-weight: var(--ui-weight-heavy);
}

/* ==========================================================================
   6. BADGES & TRUST SIGNALS
   ========================================================================== */

.ui-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  font-weight: var(--ui-weight-bold);
}

.ui-badge-stars {
  color: var(--ui-yellow);
  letter-spacing: 1px;
}

.ui-badge-rank {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ui-text-dim);
}

/* Avatar stack (nomads social proof) */
.ui-avatars {
  display: inline-flex;
  align-items: center;
}

.ui-avatars img {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid var(--ui-surface);
  margin-left: -8px;
  object-fit: cover;
}

.ui-avatars img:first-child {
  margin-left: 0;
}

/* Live counter */
.ui-counter {
  font-size: 0.9rem;
  color: var(--ui-text-dim);
}

.ui-counter strong {
  color: var(--ui-text-alt);
  font-weight: var(--ui-weight-heavy);
}

/* ==========================================================================
   7. HERO (landing page pattern)
   ========================================================================== */

.ui-hero {
  padding: 56px var(--ui-padding) 42px;
  text-align: center;
}

.ui-hero h1 {
  font-size: clamp(1.75rem, 5vw, 2.75rem);
  margin-bottom: 0.25em;
}

.ui-hero h1 .ui-emoji {
  display: block;
  font-size: 1.2em;
  margin-bottom: 0.15em;
}

.ui-hero .ui-subtitle {
  font-size: 1.1rem;
  color: var(--ui-text-dim);
  max-width: 600px;
  margin: 0 auto 1.5em;
  font-weight: var(--ui-weight-normal);
}

.ui-hero-steps {
  list-style: none;
  padding: 0;
  margin: 0 auto 2em;
  max-width: 500px;
  text-align: left;
}

.ui-hero-steps li {
  padding: 6px 0;
  font-size: 0.95rem;
}

.ui-hero-steps li::before {
  content: none;
}

.ui-hero-image {
  width: 100%;
  max-width: 700px;
  margin: 2em auto;
  border-radius: var(--ui-radius);
  overflow: hidden;
}

.ui-hero-cta {
  margin-top: 1.5em;
}

.ui-hero-note {
  font-size: 0.85rem;
  color: var(--ui-text-dim);
  margin-top: 0.75em;
}

/* Photo header variant (remoteok) */
.ui-hero-photo {
  position: relative;
  min-height: 25vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.5);
  overflow: hidden;
}

.ui-hero-photo .ui-hero-bg {
  position: absolute;
  inset: -10px;
  background-size: cover;
  background-position: center;
  z-index: 0;
}

.ui-hero-photo > *:not(.ui-hero-bg) {
  position: relative;
  z-index: 1;
}

/* ==========================================================================
   8. FILTER CHIPS & TAGS
   ========================================================================== */

.ui-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: var(--ui-padding);
  background: var(--ui-surface);
  border-top: 1px solid var(--ui-border);
  border-bottom: 1px solid var(--ui-border);
}

.ui-filters-scroll {
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.ui-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 8px 12px;
  font-family: inherit;
  font-size: 14px;
  font-weight: var(--ui-weight-medium);
  color: var(--ui-text);
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--ui-transition);
}

.ui-chip:hover {
  background: var(--ui-bg-alt);
  opacity: 1;
}

.ui-chip-active,
.ui-chip.is-active {
  background: var(--ui-yellow-active);
  border-color: var(--ui-text-alt);
  font-weight: var(--ui-weight-bold);
  color: var(--ui-text-alt);
}

html.dark .ui-chip-active,
html.dark .ui-chip.is-active {
  background: var(--ui-yellow-active);
  color: #000000;
}

/* Brutalist chip variant */
html.ui-sharp .ui-chip {
  border: 2px solid var(--ui-text-alt);
  box-shadow: var(--ui-shadow-brutal);
  border-radius: var(--ui-radius-sm);
}

/* Dotted filter link (nomads sort options) */
.ui-filter-link {
  display: inline-block;
  border-bottom: 1px dotted var(--ui-brand);
  color: var(--ui-brand);
  cursor: pointer;
  margin: 0 4px;
}

.ui-filter-link:hover {
  opacity: 1;
}

/* ==========================================================================
   9. CARDS & GRID
   ========================================================================== */

.ui-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--ui-padding);
  padding: var(--ui-padding);
}

.ui-card {
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  overflow: hidden;
  cursor: pointer;
  transition: box-shadow var(--ui-transition);
}

.ui-card:hover {
  box-shadow: var(--ui-shadow);
  opacity: 1;
}

.ui-card:active {
  opacity: 0.75;
}

.ui-card-image {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  background: var(--ui-bg-alt);
}

.ui-card-body {
  padding: var(--ui-padding);
}

.ui-card-title {
  font-size: 1.1rem;
  font-weight: var(--ui-weight-heavy);
  margin-bottom: 0.25em;
}

.ui-card-meta {
  font-size: 0.85rem;
  color: var(--ui-text-dim);
}

.ui-card-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
  font-size: 0.8rem;
}

.ui-card-stat {
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

/* ==========================================================================
   10. TABLE (remoteok job board pattern)
   ========================================================================== */

.ui-table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.ui-table {
  width: 100%;
  max-width: var(--ui-max-width);
  margin: var(--ui-padding) auto;
  border-collapse: separate;
  border-spacing: 0 4px;
}

.ui-table th {
  text-align: left;
  padding: 8px var(--ui-padding);
  font-size: 0.85rem;
  font-weight: var(--ui-weight-heavy);
  color: var(--ui-text-dim);
}

.ui-table td {
  padding: 12px var(--ui-padding);
  background: var(--ui-surface);
  vertical-align: middle;
}

.ui-table tr.ui-row {
  cursor: pointer;
}

.ui-table tr.ui-row td:first-child {
  border-radius: var(--ui-radius) 0 0 var(--ui-radius);
}

.ui-table tr.ui-row td:last-child {
  border-radius: 0 var(--ui-radius) var(--ui-radius) 0;
}

.ui-table tr.ui-row:hover td {
  background: var(--ui-bg-alt);
}

.ui-table tr.ui-row:active td {
  opacity: 0.75;
}

.ui-table .ui-position {
  font-weight: var(--ui-weight-heavy);
}

.ui-table .ui-company {
  color: var(--ui-text-dim);
  font-size: 0.9rem;
}

.ui-table .ui-salary {
  font-weight: var(--ui-weight-bold);
  white-space: nowrap;
}

.ui-table .ui-date {
  font-size: 0.75rem;
  color: var(--ui-text-muted);
  text-transform: uppercase;
}

/* ==========================================================================
   11. FORMS & INPUTS
   ========================================================================== */

.ui-input,
.ui-select,
.ui-textarea {
  font-family: inherit;
  font-size: 16px;
  padding: 10px 12px;
  color: var(--ui-text);
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  outline: none;
  width: 100%;
  transition: border-color var(--ui-transition), background var(--ui-transition);
}

.ui-input:focus,
.ui-select:focus,
.ui-textarea:focus {
  border-color: var(--ui-brand);
}

.ui-input::placeholder {
  color: var(--ui-text-dim);
}

/* Brutalist input */
html.ui-sharp .ui-input,
html.ui-sharp .ui-select {
  border: 2px solid var(--ui-text-alt);
  box-shadow: var(--ui-shadow-brutal);
  border-radius: var(--ui-radius-sm);
}

.ui-label {
  display: block;
  font-size: 0.85rem;
  font-weight: var(--ui-weight-bold);
  margin-bottom: 4px;
  color: var(--ui-text-dim);
}

.ui-field {
  margin-bottom: var(--ui-padding);
}

/* Email capture bar */
.ui-capture {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 10px var(--ui-padding);
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
}

.ui-capture .ui-input {
  flex: 1;
  min-width: 200px;
  border: none;
  background: transparent;
  padding: 6px 0;
}

/* ==========================================================================
   12. MODAL
   ========================================================================== */

.ui-modal-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 100;
  cursor: pointer;
}

.ui-modal-backdrop.is-open {
  display: block;
}

.ui-modal {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 101;
  width: calc(100% - 28px);
  max-width: 560px;
  max-height: 85vh;
  overflow-y: auto;
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.3);
  padding: calc(var(--ui-padding) * 2);
}

.ui-modal.is-open {
  display: block;
}

.ui-modal-close {
  position: absolute;
  top: 12px;
  right: 12px;
  background: none;
  border: none;
  font-size: 1.5rem;
  cursor: pointer;
  color: var(--ui-text-dim);
  line-height: 1;
}

/* ==========================================================================
   13. PRESS & TESTIMONIALS (photoai pattern)
   ========================================================================== */

.ui-press {
  text-align: center;
  padding: 2em var(--ui-padding);
}

.ui-press-label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ui-text-dim);
  margin-bottom: 1em;
}

.ui-press-logos {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 24px;
  opacity: 0.7;
}

.ui-press-logos img {
  height: 32px;
  width: auto;
  filter: grayscale(100%);
  object-fit: contain;
}

.ui-quote {
  max-width: 600px;
  margin: 2em auto;
  padding: var(--ui-padding);
  text-align: center;
}

.ui-quote blockquote {
  margin: 0 0 0.75em;
  font-size: 1rem;
  font-style: italic;
  color: var(--ui-text);
}

.ui-quote cite {
  font-size: 0.85rem;
  color: var(--ui-text-dim);
  font-style: normal;
}

.ui-testimonial {
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  padding: var(--ui-padding);
  max-width: 360px;
}

.ui-testimonial-stars {
  color: var(--ui-yellow);
  margin-bottom: 8px;
}

.ui-testimonial-text {
  font-size: 0.9rem;
  margin-bottom: 8px;
}

.ui-testimonial-author {
  font-size: 0.85rem;
  font-weight: var(--ui-weight-bold);
}

.ui-testimonial-verified {
  font-size: 0.75rem;
  color: var(--ui-green-alt);
}

/* ==========================================================================
   14. SIDEBAR WIDGET (nomads pattern)
   ========================================================================== */

.ui-widget {
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  padding: var(--ui-padding);
  margin-bottom: var(--ui-padding);
  font-size: 0.9rem;
}

.ui-widget-title {
  font-weight: var(--ui-weight-heavy);
  margin-bottom: 8px;
  font-size: 0.95rem;
}

.ui-widget-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ui-widget-list li {
  padding: 4px 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Pros / cons (hotelist) */
.ui-pro {
  background: rgba(43, 222, 115, 0.25);
  padding: 4px 8px;
  border-radius: var(--ui-radius-sm);
  font-size: 0.85rem;
}

.ui-con {
  background: rgba(255, 71, 66, 0.35);
  padding: 4px 8px;
  border-radius: var(--ui-radius-sm);
  font-size: 0.85rem;
}

/* ==========================================================================
   15. TOOLTIP
   ========================================================================== */

.ui-tooltip {
  position: relative;
}

.ui-tooltip[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) scale(0.9);
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  color: var(--ui-text);
  padding: 6px 10px;
  border-radius: var(--ui-radius);
  font-size: 0.75rem;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--ui-transition), transform var(--ui-transition);
  z-index: 200;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.14);
}

.ui-tooltip:hover[data-tooltip]::after {
  opacity: 1;
  transform: translateX(-50%) scale(1);
}

/* ==========================================================================
   16. DATA RANKINGS (airlinelist / luggagelosers)
   ========================================================================== */

/* Attribution line — "by @levelsio · part of …" */
.ui-attribution {
  font-size: 0.9rem;
  color: var(--ui-text-dim);
  margin-bottom: 1em;
}

.ui-attribution a {
  color: var(--ui-text);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Live freshness badge */
.ui-freshness {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  color: var(--ui-text-dim);
  padding: 6px 12px;
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius-pill);
}

.ui-freshness strong {
  color: var(--ui-text-alt);
}

/* Pipe-separated press links (luggagelosers) */
.ui-press-links {
  font-size: 0.85rem;
  color: var(--ui-text-dim);
  line-height: 1.8;
}

.ui-press-links a {
  color: var(--ui-text);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Trend indicators in table cells */
.ui-trend {
  font-weight: var(--ui-weight-bold);
  white-space: nowrap;
}

.ui-trend-up { color: var(--ui-green-alt); }
.ui-trend-down { color: var(--ui-brand); }
.ui-trend-flat { color: var(--ui-text-dim); }

/* Rank number column */
.ui-rank-num {
  font-weight: var(--ui-weight-heavy);
  color: var(--ui-text-dim);
  font-size: 0.9rem;
  width: 2.5em;
}

/* Multi-axis score row (airlinelist FlyScore™) */
.ui-score-bars {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 0.8rem;
  color: var(--ui-text-dim);
}

.ui-score-bars span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* "New" badge */
.ui-new-badge {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: var(--ui-weight-heavy);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 6px;
  background: var(--ui-brand);
  color: #ffffff;
  border-radius: 4px;
  vertical-align: middle;
  margin-left: 4px;
}

/* Medal podium (luggagelosers winners/losers) */
.ui-podium {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: center;
  gap: 16px;
  padding: 24px var(--ui-padding);
  text-align: center;
}

.ui-podium-item {
  flex: 0 1 140px;
}

.ui-podium-medal {
  font-size: 2rem;
  line-height: 1;
  margin-bottom: 8px;
}

.ui-podium-flag {
  font-size: 2.5rem;
  line-height: 1;
  margin-bottom: 4px;
}

.ui-podium-name {
  font-weight: var(--ui-weight-heavy);
  font-size: 0.9rem;
}

/* Table median/summary row */
.ui-table tr.ui-row-summary td {
  background: var(--ui-bg-alt);
  font-weight: var(--ui-weight-bold);
  border-top: 2px solid var(--ui-border);
}

/* ==========================================================================
   17. CONTENT FEED (ideasai)
   ========================================================================== */

.ui-feed-section {
  margin-bottom: calc(var(--ui-padding) * 2);
}

.ui-feed-section h2 {
  font-size: 1.25rem;
  margin-bottom: var(--ui-padding);
}

.ui-feed {
  list-style: none;
  padding: 0;
  margin: 0;
  max-width: var(--ui-max-width);
}

.ui-feed-item {
  display: block;
  padding: var(--ui-padding);
  margin-bottom: 8px;
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  transition: background var(--ui-transition);
}

.ui-feed-item:hover {
  background: var(--ui-bg-alt);
}

.ui-feed-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  font-size: 0.8rem;
  color: var(--ui-text-dim);
  margin-bottom: 8px;
}

.ui-feed-vote {
  font-weight: var(--ui-weight-heavy);
  font-size: 0.95rem;
  min-width: 2.5em;
}

.ui-feed-vote.is-positive { color: var(--ui-green-alt); }
.ui-feed-vote.is-negative { color: var(--ui-brand); }

.ui-feed-title {
  font-size: 1rem;
  font-weight: var(--ui-weight-bold);
  margin: 0 0 8px;
  line-height: 1.4;
}

.ui-feed-title a {
  color: inherit;
}

.ui-feed-title a:hover {
  color: var(--ui-brand);
}

.ui-feed-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
}

/* Inline sponsor slot */
.ui-feed-sponsor {
  padding: var(--ui-padding);
  margin: var(--ui-padding) 0;
  background: var(--ui-bg-alt);
  border: 1px dashed var(--ui-border);
  border-radius: var(--ui-radius);
  font-size: 0.9rem;
  color: var(--ui-text-dim);
}

.ui-feed-sponsor strong {
  color: var(--ui-text);
}

/* ==========================================================================
   18. UTILITIES
   ========================================================================== */

.ui-hidden { display: none !important; }
.ui-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.ui-text-dim { color: var(--ui-text-dim); }
.ui-text-brand { color: var(--ui-brand); }
.ui-text-accent { color: var(--ui-accent); }
.ui-bg-surface { background: var(--ui-surface); }
.ui-mono { font-family: var(--ui-font-mono); }
.ui-bold { font-weight: var(--ui-weight-heavy); }
.ui-small { font-size: 0.85rem; }
.ui-uppercase { text-transform: uppercase; letter-spacing: 0.05em; }

.ui-mt-0 { margin-top: 0; }
.ui-mt-1 { margin-top: var(--ui-padding); }
.ui-mt-2 { margin-top: calc(var(--ui-padding) * 2); }
.ui-mb-1 { margin-bottom: var(--ui-padding); }
.ui-mb-2 { margin-bottom: calc(var(--ui-padding) * 2); }

/* Dark mode toggle button */
.ui-dark-toggle {
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius-pill);
  padding: 6px 12px;
  font-family: inherit;
  font-size: 0.85rem;
  cursor: pointer;
  color: var(--ui-text);
}

html.ui-sharp .ui-dark-toggle {
  border: 2px solid var(--ui-text-alt);
  box-shadow: var(--ui-shadow-brutal);
  border-radius: var(--ui-radius-sm);
}

/* Mark / highlight text */
mark, .ui-mark {
  background: var(--ui-highlight) !important;
  color: inherit;
}

/* Error state */
.ui-error {
  background: var(--ui-error-bg);
  padding: var(--ui-padding);
  border-radius: var(--ui-radius);
}

/* Footer */
.ui-footer {
  margin-top: 56px;
  padding: 28px var(--ui-padding);
  border-top: 1px solid var(--ui-border);
  font-size: 0.85rem;
  color: var(--ui-text-dim);
}

.ui-footer a {
  color: var(--ui-text-dim);
}

/* ==========================================================================
   19. LOGIN PAGE (photoai / nomads pattern)
   ========================================================================== */

.ui-login-page {
  min-height: 100vh;
  display: flex;
  overflow: hidden;
}

.ui-login-visual {
  flex: 1;
  position: relative;
  background-size: cover;
  background-position: center;
  background-color: var(--ui-bg-alt);
  min-height: 240px;
}

.ui-login-visual-dim {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.55) 0%,
    rgba(0, 0, 0, 0.1) 45%,
    transparent 100%
  );
}

.ui-login-visual-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 32px 28px 24px;
  color: #ffffff;
  z-index: 1;
}

.ui-login-visual-content h2 {
  color: #ffffff;
  font-size: 1.5rem;
  margin-bottom: 0.35em;
  text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.35);
}

.ui-login-visual-content p {
  margin: 0;
  font-size: 0.9rem;
  opacity: 0.9;
  text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.35);
}

.ui-login-visual-credit {
  margin-top: 12px;
  font-size: 0.75rem;
  opacity: 0.75;
}

.ui-login-visual-credit a {
  color: #ffffff;
  text-decoration: underline;
}

.ui-login-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 28px;
  background: var(--ui-bg);
  position: relative;
  min-width: 0;
}

html.dark .ui-login-panel {
  background: var(--ui-bg);
}

.ui-login-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--ui-border);
  background: var(--ui-surface);
  color: var(--ui-text);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  padding-bottom: 2px;
}

.ui-login-close:hover {
  opacity: 1;
  background: var(--ui-bg-alt);
}

.ui-login-form-wrap {
  width: 100%;
  max-width: 360px;
  text-align: center;
}

.ui-login-logo {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  font-size: 1.5rem;
  font-weight: var(--ui-weight-heavy);
}

.ui-login-logo .ui-logo-icon {
  width: 36px;
  height: 36px;
}

.ui-login-tagline {
  font-size: 0.9rem;
  color: var(--ui-text-dim);
  margin-bottom: 28px;
}

.ui-login-form {
  text-align: left;
}

.ui-login-form .ui-field {
  margin-bottom: 12px;
}

.ui-login-form .ui-input {
  padding: 14px 16px;
}

.ui-login-form .ui-btn {
  width: 100%;
  display: block;
  padding: 14px;
  margin-top: 4px;
}

.ui-login-forgot {
  display: block;
  text-align: right;
  font-size: 0.8rem;
  margin-top: 6px;
  color: var(--ui-text-dim);
}

.ui-login-forgot:hover {
  color: var(--ui-brand);
  opacity: 1;
}

.ui-login-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 20px 0;
  color: var(--ui-text-dim);
  font-size: 0.8rem;
}

.ui-login-divider::before,
.ui-login-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--ui-border);
}

.ui-login-google {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px;
  font-family: inherit;
  font-size: 16px;
  font-weight: var(--ui-weight-bold);
  border-radius: var(--ui-radius);
  border: 1px solid var(--ui-border);
  background: var(--ui-surface);
  color: var(--ui-text-alt);
  cursor: pointer;
  transition: background var(--ui-transition);
}

.ui-login-google:hover {
  opacity: 1;
  background: var(--ui-bg-alt);
}

.ui-login-google:active {
  opacity: 0.5;
}

html.dark .ui-login-google {
  background: var(--ui-surface);
  border-color: var(--ui-border);
  color: var(--ui-text);
}

.ui-login-note {
  margin-top: 16px;
  font-size: 0.8rem;
  color: var(--ui-text-dim);
  text-align: center;
}

.ui-login-note a {
  color: var(--ui-brand);
  font-weight: var(--ui-weight-bold);
}

.ui-login-note a:hover {
  opacity: 1;
}

.ui-login-legal {
  margin-top: 24px;
  font-size: 0.72rem;
  color: var(--ui-text-muted);
  line-height: 1.5;
  text-align: center;
}

.ui-login-toolbar {
  position: absolute;
  top: 16px;
  left: 16px;
  display: flex;
  gap: 8px;
}

.ui-login-error {
  display: none;
  margin-bottom: 12px;
  padding: 10px 12px;
  font-size: 0.85rem;
  text-align: left;
}

.ui-login-error.is-visible {
  display: block;
}

@media (max-width: 900px) {
  .ui-login-page {
    flex-direction: column;
  }

  .ui-login-visual {
    min-height: 200px;
    max-height: 28vh;
  }

  .ui-login-panel {
    flex: 1;
    padding: 32px 20px 48px;
  }
}

/* ==========================================================================
   20. BLOCKS & COMMON COMPONENTS
   ========================================================================== */

.ui-section-head {
  margin-bottom: calc(var(--ui-padding) * 1.5);
}

.ui-section-head h2 {
  margin-bottom: 0.25em;
}

.ui-section-head p {
  margin: 0;
  color: var(--ui-text-dim);
  font-size: 0.95rem;
}

.ui-banner {
  padding: 10px var(--ui-padding);
  text-align: center;
  font-size: 0.9rem;
  font-weight: var(--ui-weight-bold);
  background: var(--ui-yellow);
  color: var(--ui-text-alt);
  border-bottom: 1px solid var(--ui-border);
}

.ui-banner a {
  color: var(--ui-accent);
  font-weight: var(--ui-weight-heavy);
}

.ui-cta {
  text-align: center;
  padding: calc(var(--ui-padding) * 3) var(--ui-padding);
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
}

.ui-cta h2 {
  margin-bottom: 0.35em;
}

.ui-cta p {
  color: var(--ui-text-dim);
  max-width: 480px;
  margin: 0 auto 1.25em;
}

.ui-cta-dark {
  background: var(--ui-text-alt);
  border-color: var(--ui-text-alt);
  color: #ffffff;
}

.ui-cta-dark h2,
.ui-cta-dark p {
  color: #ffffff;
}

.ui-cta-dark p {
  opacity: 0.85;
}

.ui-alert {
  padding: 12px var(--ui-padding);
  border-radius: var(--ui-radius);
  border: 1px solid var(--ui-border);
  font-size: 0.9rem;
  margin-bottom: var(--ui-padding);
}

.ui-alert strong {
  font-weight: var(--ui-weight-heavy);
}

.ui-alert-error {
  background: var(--ui-error-bg);
  border-color: var(--ui-red);
}

.ui-alert-success {
  background: rgba(43, 222, 115, 0.15);
  border-color: var(--ui-green-alt);
}

.ui-alert-warning {
  background: rgba(255, 201, 36, 0.2);
  border-color: var(--ui-yellow);
}

.ui-alert-info {
  background: rgba(66, 180, 255, 0.12);
  border-color: var(--ui-blue);
}

.ui-tag {
  display: inline-block;
  padding: 3px 8px;
  font-size: 0.75rem;
  font-weight: var(--ui-weight-bold);
  border-radius: var(--ui-radius-sm);
  background: var(--ui-bg-alt);
  border: 1px solid var(--ui-border);
}

.ui-tag-red { background: rgba(255, 82, 82, 0.12); border-color: var(--ui-red); color: var(--ui-brand); }
.ui-tag-blue { background: rgba(0, 114, 177, 0.1); border-color: var(--ui-accent); color: var(--ui-accent); }
.ui-tag-green { background: rgba(22, 191, 99, 0.12); border-color: var(--ui-green-alt); color: var(--ui-green-alt); }

.ui-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  color: var(--ui-text-dim);
  margin-bottom: var(--ui-padding);
}

.ui-breadcrumb a:hover {
  color: var(--ui-brand);
  opacity: 1;
}

.ui-breadcrumb-sep {
  opacity: 0.5;
}

.ui-pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin: var(--ui-padding) 0;
}

.ui-pagination a,
.ui-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border-radius: var(--ui-radius);
  border: 1px solid var(--ui-border);
  background: var(--ui-surface);
  font-size: 0.9rem;
  font-weight: var(--ui-weight-bold);
}

.ui-pagination a:hover {
  opacity: 1;
  background: var(--ui-bg-alt);
}

.ui-pagination .is-active {
  background: var(--ui-brand);
  border-color: var(--ui-brand);
  color: #ffffff;
}

.ui-pagination .is-disabled {
  opacity: 0.4;
  pointer-events: none;
}

.ui-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  border-bottom: 1px solid var(--ui-border);
  margin-bottom: var(--ui-padding);
}

.ui-tab {
  padding: 10px 16px;
  font-family: inherit;
  font-size: 0.9rem;
  font-weight: var(--ui-weight-bold);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  color: var(--ui-text-dim);
}

.ui-tab:hover {
  color: var(--ui-text);
  opacity: 1;
}

.ui-tab.is-active {
  color: var(--ui-brand);
  border-bottom-color: var(--ui-brand);
}

.ui-tab-panel {
  display: none;
}

.ui-tab-panel.is-active {
  display: block;
}

.ui-accordion {
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  overflow: hidden;
}

.ui-accordion details {
  border-bottom: 1px solid var(--ui-border);
}

.ui-accordion details:last-child {
  border-bottom: none;
}

.ui-accordion summary {
  padding: 14px var(--ui-padding);
  font-weight: var(--ui-weight-bold);
  cursor: pointer;
  list-style: none;
  background: var(--ui-surface);
}

.ui-accordion summary::-webkit-details-marker {
  display: none;
}

.ui-accordion summary::after {
  content: "+";
  float: right;
  font-weight: var(--ui-weight-heavy);
  color: var(--ui-text-dim);
}

.ui-accordion details[open] summary::after {
  content: "−";
}

.ui-accordion details[open] summary {
  border-bottom: 1px solid var(--ui-border);
}

.ui-accordion .ui-accordion-body {
  padding: var(--ui-padding);
  background: var(--ui-surface);
  font-size: 0.9rem;
  color: var(--ui-text-dim);
}

.ui-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--ui-padding);
}

.ui-stat {
  text-align: center;
  padding: var(--ui-padding);
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
}

.ui-stat-value {
  font-size: 1.75rem;
  font-weight: var(--ui-weight-heavy);
  color: var(--ui-text-alt);
  line-height: 1.2;
}

.ui-stat-label {
  font-size: 0.8rem;
  color: var(--ui-text-dim);
  margin-top: 4px;
}

.ui-pricing {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--ui-padding);
  align-items: start;
}

.ui-price-card {
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  padding: calc(var(--ui-padding) * 1.5);
  text-align: center;
}

.ui-price-card.featured {
  border-color: var(--ui-brand);
  box-shadow: 0 0 0 2px rgba(255, 71, 66, 0.15);
}

.ui-price-amount {
  font-size: 2.25rem;
  font-weight: var(--ui-weight-heavy);
  margin: 0.5em 0;
}

.ui-price-amount span {
  font-size: 0.9rem;
  font-weight: var(--ui-weight-normal);
  color: var(--ui-text-dim);
}

.ui-price-features {
  list-style: none;
  padding: 0;
  margin: 1.25em 0;
  text-align: left;
  font-size: 0.9rem;
}

.ui-price-features li {
  padding: 6px 0;
  border-bottom: 1px solid var(--ui-border);
}

.ui-price-features li:last-child {
  border-bottom: none;
}

.ui-empty {
  text-align: center;
  padding: calc(var(--ui-padding) * 3);
  color: var(--ui-text-dim);
}

.ui-empty-icon {
  font-size: 2.5rem;
  margin-bottom: 0.5em;
}

.ui-footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: calc(var(--ui-padding) * 2);
  margin-bottom: var(--ui-padding);
}

.ui-footer-grid h4 {
  font-size: 0.85rem;
  font-weight: var(--ui-weight-heavy);
  margin-bottom: 0.75em;
  color: var(--ui-text-alt);
}

.ui-footer-grid ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ui-footer-grid li {
  margin-bottom: 6px;
}

.ui-footer-grid a {
  font-size: 0.85rem;
  color: var(--ui-text-dim);
}

.ui-swatch-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
}

.ui-swatch {
  border-radius: var(--ui-radius);
  overflow: hidden;
  border: 1px solid var(--ui-border);
  font-size: 0.75rem;
}

.ui-swatch-color {
  height: 64px;
}

.ui-swatch-meta {
  padding: 8px;
  background: var(--ui-surface);
  font-family: var(--ui-font-mono);
  line-height: 1.4;
}

.ui-swatch-meta strong {
  display: block;
  font-weight: var(--ui-weight-bold);
}

.ui-chart-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--ui-padding);
}

.ui-chart-card {
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  padding: var(--ui-padding);
}

.ui-chart-card h3 {
  font-size: 0.95rem;
  margin-bottom: 0.75em;
}

.ui-chart-wrap {
  position: relative;
  height: 220px;
}

/* ==========================================================================
   21. RESPONSIVE
   ========================================================================== */

@media (max-width: 768px) {
  .ui-nav .ui-nav-hide-mobile {
    display: none;
  }

  .ui-hero {
    padding-top: 32px;
  }

  .ui-card-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  :root {
    --ui-padding: 10px;
  }

  h1 { font-size: 1.5rem; }
}

/* Dark scrollbar (nomads/remoteok pattern) */
html.dark ::-webkit-scrollbar {
  width: 12px;
  height: 12px;
  background: #2c2c2c;
}

html.dark ::-webkit-scrollbar-thumb {
  background: #6b6b6c;
  border-radius: 1ex;
}

/* ==========================================================================
   AC MAP — app-specific
   ========================================================================== */

:root {
  --ui-brand: #ff8c42;
  --ui-gradient: linear-gradient(90deg, #ff4742 0%, #ffc924 50%, #42b4ff 100%);
  --acmap-logo-gradient: linear-gradient(90deg, #ff4742 0%, #2bde73 100%);
}

.acmap-page {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.acmap-header {
  flex-shrink: 0;
  display: block;
  width: 100%;
  height: auto;
  min-height: var(--ui-header-height);
  padding: 10px var(--ui-padding);
  position: relative;
  z-index: 700;
  box-sizing: border-box;
}

.acmap-menu-open .acmap-header {
  z-index: 900;
}

.acmap-label-short {
  display: none;
}

.acmap-header-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  width: 100%;
  max-width: none;
}

.acmap-logo-text.ui-logo-gradient-text {
  background: var(--acmap-logo-gradient);
  background-size: 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: none;
}

.acmap-header-brand {
  justify-self: start;
  min-width: 0;
}

.acmap-header-controls {
  justify-self: center;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.acmap-credit-mobile {
  display: none;
  margin: 0 0 8px;
  font-size: 0.72rem;
  color: var(--ui-text-dim);
  line-height: 1.45;
}

.acmap-credit-mobile a {
  color: var(--ui-text-dim);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.acmap-logo-link {
  align-items: flex-start;
}

.acmap-header-credit {
  margin: 2px 0 0 40px;
  font-size: 0.72rem;
  color: var(--ui-text-dim);
  line-height: 1.45;
}

.acmap-header-credit a {
  color: var(--ui-text-dim);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.acmap-header-credit a:hover {
  color: var(--ui-text);
  opacity: 1;
}

.acmap-header-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}

.acmap-header-tabs .ui-chip {
  font-weight: var(--ui-weight-bold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.acmap-locate-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.acmap-header-nav {
  justify-self: end;
  position: relative;
}

.acmap-locate-desktop {
  white-space: nowrap;
}

.acmap-locate-mobile {
  display: none;
}

.acmap-pin-wrap {
  background: none;
  border: none;
}

.acmap-pin {
  font-size: 1.75rem;
  line-height: 1;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.45));
}

.acmap-menu-btn {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  font-size: 1.25rem;
  font-family: inherit;
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  cursor: pointer;
  color: var(--ui-text);
}

.acmap-nav-drawer {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.acmap-drawer-label {
  display: none;
}

.acmap-menu-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 80;
  background: rgba(0, 0, 0, 0.35);
}

.acmap-menu-backdrop.is-active {
  display: block;
  z-index: 800;
}

.acmap-preload-bar {
  display: none;
  height: 3px;
  background: var(--ui-bg-alt);
  flex-shrink: 0;
  overflow: hidden;
}

.acmap-preload-bar.is-active {
  display: block;
}

.acmap-preload-fill {
  height: 100%;
  width: 0%;
  background: var(--ui-gradient);
  transition: width 0.3s ease;
}

.acmap-zone-skeleton {
  animation: acmap-skeleton-pulse 1.3s ease-in-out infinite;
}

@keyframes acmap-skeleton-pulse {
  0%, 100% { fill-opacity: 0.5; }
  50% { fill-opacity: 0.92; }
}

html.dark .acmap-zone-skeleton {
  animation-name: acmap-skeleton-pulse-dark;
}

@keyframes acmap-skeleton-pulse-dark {
  0%, 100% { fill-opacity: 0.35; }
  50% { fill-opacity: 0.7; }
}

.acmap-main {
  position: relative;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.acmap-page:not(.acmap-map-active) .acmap-main {
  overflow: auto;
}

.acmap-view-toggle {
  display: inline-flex;
  gap: 4px;
  flex-shrink: 0;
}

.acmap-view-toggle .ui-chip {
  font-weight: var(--ui-weight-bold);
  padding: 8px 10px;
}

.acmap-list-view {
  min-height: 100%;
  padding-bottom: calc(var(--ui-padding) * 2);
  max-width: 100%;
  overflow-x: clip;
}

.acmap-list-toolbar {
  position: sticky;
  top: 0;
  z-index: 20;
  padding: var(--ui-padding);
  background: var(--ui-bg);
  border-bottom: 1px solid var(--ui-border);
}

.acmap-list-toolbar-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.acmap-list-search {
  flex: 1 1 auto;
  min-width: 200px;
  max-width: 420px;
}

.acmap-list-sort {
  display: inline-flex;
  gap: 4px;
  flex-shrink: 0;
}

.acmap-list-sort .ui-chip {
  font-size: 0.82rem;
  padding: 8px 10px;
}

.acmap-continent-filter {
  margin-top: 10px;
  padding: 0;
  background: transparent;
  border: none;
}

.acmap-continent-filter .ui-chip {
  font-size: 0.8rem;
  padding: 7px 10px;
}

.acmap-list-hint {
  margin: 8px 0 0;
}

.acmap-charts {
  padding: 0 var(--ui-padding) var(--ui-padding);
  max-width: 100%;
  min-width: 0;
}

.acmap-charts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: var(--ui-padding);
  min-width: 0;
}

.acmap-chart-card {
  margin: 0;
  min-width: 0;
  overflow: hidden;
}

.acmap-chart-title {
  margin: 0 0 4px;
  font-size: 1rem;
  font-weight: var(--ui-weight-heavy);
  color: var(--ui-text-alt);
}

.acmap-chart-sub {
  margin: 0 0 12px;
}

.acmap-chart-wrap {
  position: relative;
  height: 220px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

.acmap-chart-wrap canvas {
  display: block;
  max-width: 100%;
}

.acmap-chart-wrap-tall {
  height: 300px;
}

.acmap-list-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 10px;
  padding: var(--ui-padding);
}

.acmap-list-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 2rem;
}

.acmap-country-card {
  display: flex;
  align-items: stretch;
  gap: 12px;
  width: 100%;
  padding: 12px;
  text-align: left;
  font-family: inherit;
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  cursor: pointer;
  transition: box-shadow var(--ui-transition), border-color var(--ui-transition);
}

.acmap-country-card:hover {
  box-shadow: var(--ui-shadow);
}

.acmap-country-card.is-selected {
  border-color: var(--ui-text-alt);
  box-shadow: 0 0 0 2px rgba(255, 140, 66, 0.25);
}

.acmap-country-card.is-skeleton {
  animation: acmap-card-skeleton 1.3s ease-in-out infinite;
}

@keyframes acmap-card-skeleton {
  0%, 100% { opacity: 0.65; }
  50% { opacity: 1; }
}

.acmap-card-swatch {
  flex-shrink: 0;
  width: 8px;
  border-radius: var(--ui-radius-pill);
  background: var(--acmap-card-accent, var(--ui-bg-alt));
}

.acmap-card-flag {
  flex-shrink: 0;
  font-size: 1.65rem;
  line-height: 1;
  align-self: center;
}

.acmap-card-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  flex: 1;
}

.acmap-card-title {
  font-weight: var(--ui-weight-heavy);
  font-size: 1rem;
  color: var(--ui-text-alt);
  line-height: 1.25;
}

.acmap-card-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.acmap-card-temp {
  font-weight: var(--ui-weight-heavy);
  font-size: 1.05rem;
  color: var(--ui-text-alt);
}

.acmap-card-verdict {
  font-size: 0.72rem;
  font-weight: var(--ui-weight-bold);
  padding: 2px 8px;
  border-radius: var(--ui-radius-pill);
}

.acmap-card-verdict-green {
  background: rgba(43, 222, 115, 0.25);
  color: var(--ui-green-alt);
}

.acmap-card-verdict-red {
  background: rgba(255, 71, 66, 0.2);
  color: var(--ui-brand);
}

.acmap-card-verdict-blue {
  background: rgba(66, 180, 255, 0.2);
  color: var(--ui-accent);
}

.acmap-card-shop {
  color: var(--ui-text-dim);
}

.acmap-shop-block {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--ui-border);
}

.acmap-shop-heading {
  margin: 0 0 8px;
  font-weight: var(--ui-weight-bold);
  font-size: 0.9rem;
  color: var(--ui-text-alt);
}

.acmap-shop-tag {
  margin: 0 0 6px;
}

.acmap-shop-detail {
  margin: 0 0 6px;
  line-height: 1.45;
}

.acmap-shop-stores {
  margin: 0 0 6px;
}

.acmap-shop-link {
  display: inline-block;
  color: var(--ui-accent);
  font-weight: var(--ui-weight-bold);
}

.acmap-shop-link:hover {
  opacity: 1;
  text-decoration: underline;
}

.acmap-view-hidden {
  display: none !important;
}

.acmap-map {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: var(--ui-bg-alt);
}

.acmap-panel {
  position: fixed;
  top: auto;
  bottom: 14px;
  right: 14px;
  left: auto;
  z-index: 600;
  width: min(360px, calc(100% - 28px));
  max-height: calc(100vh - var(--ui-header-height) - 28px);
  margin: 0;
  padding-top: calc(var(--ui-padding) + 6px);
  overflow-y: auto;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
}

.acmap-panel-hidden {
  display: none !important;
}

.acmap-panel-close {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  width: 32px;
  height: 32px;
  padding: 0;
  font-family: inherit;
  font-size: 1.4rem;
  line-height: 1;
  color: var(--ui-text-dim);
  background: var(--ui-bg-alt);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  cursor: pointer;
}

.acmap-panel-close:hover {
  color: var(--ui-text-alt);
  background: var(--ui-surface);
  opacity: 1;
}

.acmap-panel-content {
  position: relative;
}

.acmap-panel-title {
  margin: 0 0 8px;
  font-weight: var(--ui-weight-heavy);
  font-size: 1.35rem;
  line-height: 1.25;
  text-align: center;
  color: var(--ui-text-alt);
}

.acmap-verdict {
  width: 100%;
  margin: 0 0 12px;
  padding: 9px 12px;
  border-radius: var(--ui-radius);
  font-size: 0.9rem;
  font-weight: var(--ui-weight-bold);
  text-align: center;
  color: #1c1c1c;
}

.acmap-verdict-green {
  background: rgba(43, 222, 115, 0.45);
}

.acmap-verdict-red {
  background: rgba(255, 71, 66, 0.4);
}

.acmap-verdict-blue {
  background: rgba(66, 180, 255, 0.35);
}

.acmap-panel-range {
  margin: 0 0 8px;
  line-height: 1.45;
}

.acmap-panel-note {
  margin: 10px 0 6px;
}

.acmap-metric-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
}

.acmap-metric {
  text-align: center;
  padding: 10px 6px;
  border: 1px solid rgba(28, 28, 28, 0.12);
  border-radius: var(--ui-radius);
  color: #1c1c1c;
}

.acmap-metric-emoji {
  display: block;
  font-size: 1rem;
  line-height: 1;
  margin-bottom: 4px;
}

.acmap-metric-value {
  display: block;
  font-size: 1.2rem;
  font-weight: var(--ui-weight-heavy);
  line-height: 1.2;
  color: #1c1c1c;
}

.acmap-metric-label {
  display: block;
  margin-top: 4px;
  font-size: 0.65rem;
  font-weight: var(--ui-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #1c1c1c;
  opacity: 0.75;
  line-height: 1.2;
}

.acmap-legend {
  position: absolute;
  bottom: 14px;
  left: 14px;
  z-index: 500;
  margin: 0;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
}

.acmap-legend-list {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.8rem;
}

.acmap-legend-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 3px 0;
}

.acmap-swatch {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1px solid var(--ui-border);
  flex-shrink: 0;
}

.acmap-tooltip {
  font-family: var(--ui-font);
  font-weight: var(--ui-weight-bold);
  font-size: 0.8rem;
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius-sm);
  background: var(--ui-surface);
  color: var(--ui-text-alt);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  padding: 4px 8px;
}

.leaflet-container {
  font-family: var(--ui-font);
}

.acmap-map .leaflet-interactive {
  cursor: pointer;
}

.acmap-map .leaflet-interactive:focus,
.acmap-map .leaflet-interactive:focus-visible,
.acmap-map .leaflet-container:focus,
.acmap-map .leaflet-container:focus-visible {
  outline: none !important;
}

.acmap-logo-emoji {
  font-size: 1.5rem;
  line-height: 1;
}

.acmap-logo-text {
  font-size: clamp(0.85rem, 2.5vw, 1.1rem);
}

.acmap-loading {
  position: absolute;
  inset: 0;
  z-index: 600;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(251, 250, 248, 0.82);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

html.dark .acmap-loading {
  background: rgba(17, 17, 17, 0.82);
}

.acmap-loading.is-active {
  display: flex;
}

.acmap-loading-inner {
  text-align: center;
  width: min(320px, calc(100% - 40px));
  padding: calc(var(--ui-padding) * 2);
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}

.acmap-loading-emoji {
  display: block;
  font-size: 2rem;
  margin-bottom: 8px;
  animation: acmap-pulse 1.2s ease-in-out infinite;
}

@keyframes acmap-pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.08); }
}

.acmap-loading-title {
  margin: 0 0 6px;
  font-weight: var(--ui-weight-heavy);
  color: var(--ui-text-alt);
}

.acmap-loading-status {
  margin: 0 0 14px;
  font-size: 0.9rem;
  color: var(--ui-text-dim);
}

.acmap-loading-bar {
  height: 8px;
  background: var(--ui-bg-alt);
  border-radius: var(--ui-radius-pill);
  overflow: hidden;
  border: 1px solid var(--ui-border);
}

.acmap-loading-fill {
  height: 100%;
  width: 0%;
  background: var(--ui-gradient);
  border-radius: var(--ui-radius-pill);
  transition: width 0.25s ease;
}

@media (max-width: 900px) {
  .acmap-header-inner {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "brand menu"
      "controls controls";
    gap: 10px;
  }

  .acmap-header-brand {
    grid-area: brand;
  }

  .acmap-label-full {
    display: none;
  }

  .acmap-label-short {
    display: inline;
  }

  .acmap-header-controls {
    grid-area: controls;
    justify-self: stretch;
    justify-content: stretch;
    flex-wrap: wrap;
    gap: 6px;
    width: 100%;
  }

  .acmap-view-toggle {
    flex: 0 0 auto;
  }

  .acmap-view-toggle .ui-chip {
    font-size: 0.65rem;
    padding: 6px 8px;
  }

  .acmap-charts {
    padding-left: 10px;
    padding-right: 10px;
  }

  .acmap-charts-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .acmap-chart-card {
    padding: 10px;
  }

  .acmap-chart-title {
    font-size: 0.92rem;
  }

  .acmap-chart-sub {
    font-size: 0.75rem;
    margin-bottom: 8px;
  }

  .acmap-chart-wrap {
    height: 200px;
  }

  .acmap-chart-wrap-tall {
    height: 240px;
  }

  .acmap-list-grid {
    grid-template-columns: 1fr;
  }

  .acmap-list-toolbar-row {
    flex-direction: column;
    align-items: stretch;
  }

  .acmap-list-search {
    flex: none;
    min-width: 0;
    max-width: none;
    width: 100%;
    padding: 8px 10px;
    min-height: 0;
  }

  .acmap-list-sort {
    width: 100%;
  }

  .acmap-list-sort .ui-chip {
    flex: 1;
    justify-content: center;
    font-size: 0.75rem;
  }

  .acmap-continent-filter .ui-chip {
    font-size: 0.72rem;
    padding: 6px 8px;
  }

  .acmap-header-nav {
    grid-area: menu;
    justify-self: end;
  }

  .acmap-credit-desktop {
    display: none;
  }

  .acmap-credit-mobile {
    display: block;
  }

  .acmap-locate-desktop {
    display: none;
  }

  .acmap-locate-mobile {
    display: inline-flex;
    flex-shrink: 0;
  }

  .acmap-header-tabs {
    flex: 1 1 auto;
    flex-wrap: nowrap;
    justify-content: stretch;
    gap: 3px;
    min-width: 0;
    display: flex;
  }

  .acmap-header-tabs .ui-chip {
    flex: 1 1 0;
    min-width: 0;
    justify-content: center;
    text-align: center;
  }

  .acmap-header-tabs .ui-chip,
  .acmap-locate-mobile {
    font-size: 0.65rem;
    padding: 6px 4px;
    white-space: nowrap;
    flex-shrink: 1;
  }

  .acmap-locate-mobile {
    flex: 0 0 auto;
    min-width: 34px;
    padding-left: 6px;
    padding-right: 6px;
  }

  .acmap-menu-btn {
    display: inline-flex;
  }

  .acmap-nav-drawer {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 810;
    width: min(280px, 88vw);
    height: 100vh;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    padding: 20px var(--ui-padding);
    background: var(--ui-surface);
    border-left: 1px solid var(--ui-border);
    box-shadow: -8px 0 24px rgba(0, 0, 0, 0.12);
  }

  .acmap-header-nav.is-open .acmap-nav-drawer {
    display: flex;
  }

  .acmap-drawer-label {
    display: block;
    margin: 0 0 4px;
    font-size: 0.75rem;
    font-weight: var(--ui-weight-heavy);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--ui-text-dim);
  }

  .acmap-nav-drawer .ui-chip,
  .acmap-nav-drawer .ui-dark-toggle {
    width: 100%;
    text-align: center;
    items-align: center;
  }

  .acmap-panel {
    bottom: 10px;
    right: 10px;
    left: auto;
    width: min(400px, calc(100% - 20px));
    max-height: calc(100vh - var(--ui-header-height) - 20px);
    overflow-y: auto;
    padding: 10px 12px;
    padding-top: 36px;
    border-radius: var(--ui-radius);
  }

  .acmap-panel-close {
    top: 6px;
    right: 6px;
    width: 28px;
    height: 28px;
    font-size: 1.25rem;
  }

  .acmap-panel .acmap-panel-title {
    font-size: 1.05rem;
    margin-bottom: 6px;
  }

  .acmap-panel .acmap-verdict {
    margin-bottom: 8px;
    padding: 6px 10px;
    font-size: 0.82rem;
  }

  .acmap-panel .acmap-metric-row {
    gap: 5px;
  }

  .acmap-panel .acmap-metric {
    padding: 7px 4px;
  }

  .acmap-panel .acmap-metric-label {
    font-size: 0.55rem;
  }

  .acmap-panel .acmap-panel-note {
    margin: 6px 0 4px;
    font-size: 0.72rem;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .acmap-panel .ui-small:last-child {
    margin: 0;
    font-size: 0.7rem;
  }

  .acmap-legend {
    top: 8px;
    right: 10px;
    left: auto;
    bottom: auto;
    padding: 8px 10px;
    max-width: 108px;
  }

  .acmap-legend .ui-widget-title {
    display: none;
  }

  .acmap-legend-list {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 4px;
    font-size: 0.68rem;
  }

  .acmap-legend-list li {
    white-space: nowrap;
  }

  .acmap-metric-value {
    font-size: 1.05rem;
  }
}

@media (max-width: 600px) {
  .acmap-logo-text {
    font-size: 1rem;
  }

  .acmap-header-credit {
    font-size: 0.65rem;
  }

  .acmap-header-tabs .ui-chip,
  .acmap-locate-mobile {
    font-size: 0.6rem;
    padding: 5px 3px;
  }
}