/* General styles */
:root {
  /* Base palette */
  --bg: #f8f9fa;
  --surface: #fffefd;
  --text: #242424;
  --primary: #005a9e;
  --secondary: #6c757d;
  --accent: #007bff;
  /* Hero theme */
  --hero-bg: #0b0d1c;
  --hero-fg: #e6eefc;
  --cta: #22c55e;
  --cta-hover: #16a34a;

  /* Greys (Bootstrap-like scale) */
  --gray-100: #f8f9fa; /* light bg */
  --gray-200: #e9ecef; /* light border */
  --gray-300: #dee2e6; /* standard border */
  --gray-400: #ced4da; /* medium border */
  --gray-500: #adb5bd; /* muted control */
  --gray-600: #6c757d; /* muted text */
  --gray-700: #495057; /* strong muted */
  /* Pruned unused deep grays to keep palette lean */

  /* Semantic */
  --success: #28a745;
  --danger: #dc3545;
  --warning: #ffc107;

  /* Links */
  --link: var(--primary);
  --link-hover: #b8d1ff;

  /* Accent variants */
  --accent-hover: #0056b3;
  --accent-deep: #004085;

  /* Radii & shadows */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --border-radius: var(--radius-md);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.1);
  --shadow: 0 2px 4px rgba(0,0,0,0.1);
  --shadow-md: 0 4px 8px rgba(0,0,0,0.12);
  --shadow-lg: 0 8px 16px rgba(0,0,0,0.15);

  /* Motion */
  --transition-fast: 150ms ease;
  --transition: 200ms ease;

  /* Card accents (transactions) */
  --card-accent: #0d6efd;
  --card-border: #e6eaf2;
  --card-border-hover: #d6deef;
  --card-bg-top: #ffffff;
  --card-bg-bottom: #f9fbff;
  --pill-bg: #eef2ff;
  --pill-border: #dde5ff;
  --chip-bg: #f8fafc;
  --chip-border: #e5e7eb;
  --muted: #64748b;
}

html {
  background-color: #0b0d1c;
  color-scheme: dark;
}

/* Box-sizing and media defaults */
*, *::before, *::after { box-sizing: border-box; }
img, svg, video { max-width: 100%; height: auto; }
body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background: var(--bg);
    color: var(--text);
    margin: 0;
    padding: 0;
    line-height: 1.5;
    min-height: 100vh;
    overflow-x: hidden;
}

/* Search page theming (scoped) */
.search-page {
    background-color: #0b0d1c;
    background-image: linear-gradient(180deg, #10162f, var(--hero-bg) 60%, #0d111a 100%);
    min-height: 100dvh;
}

@supports (color: color-mix(in srgb, white, black)) {
  .search-page {
    background-image: linear-gradient(180deg, color-mix(in srgb, var(--hero-bg), #000 8%), var(--hero-bg) 60%, #0d111a 100%);
  }
}
.search-page .main-container { justify-content: flex-start; }
.search-page .disclaimer-footer {
    background: transparent;
    border-top: 1px solid rgba(255,255,255,.08);
    color: rgba(255,255,255,.7);
}
.search-page .disclaimer-footer a { 
    color: #9dd3ff; 
    margin: 0 5px;
}

.search-page .disclaimer-footer a:hover { color: #ffffff; }

/* Search page result layout */
.search-page .results-container { max-width: 1220px; margin: 0 auto 0; }
.search-page .map-section { width: 100%; margin: 10px auto 24px; border: 1px solid rgba(255,255,255,.12); border-radius: 12px; box-shadow: 0 10px 20px rgba(0,0,0,.25); }
.search-page .map-section .map-container { border-radius: 12px; overflow: hidden; }

/* Accordion dark skin (scoped) */
/* Light cards for all accordion sections inside the search results */
.search-page .accordion-section { background: var(--surface); border: 1px solid var(--gray-300); box-shadow: var(--shadow); }
/* Higher specificity to ensure we override any generic header styles */
body.search-page .results-container .accordion-header { 
    background: linear-gradient(125deg, var(--surface), #fff8f1);
}
body.search-page .results-container .accordion-header h3,
body.search-page .results-container .accordion-header h4 { 
    color: var(--text); 
    font-size: large;
}
body.search-page .results-container .accordion-content { background: var(--surface); }
body.search-page .results-container .sort-btn { color: var(--text); background: var(--surface); border-color: var(--gray-300); }
body.search-page .results-container .sort-btn:hover { background: var(--gray-200); border-color: var(--gray-500); }
body.search-page .results-container .sort-btn.active { background: var(--accent); color: white; border-color: var(--accent); }
.search-page .accordion-content { background: #10162a; }

@supports (color: color-mix(in srgb, white, black)) {
  .search-page .accordion-content { background: color-mix(in srgb, var(--hero-bg), #fff 3%); }
}

/* Cards on dark: keep white content readable but soften borders */
.search-page .result-card { 
    border-color: var(--gray-300); 
    box-shadow: 0 2px 20px 2px rgb(255 255 255 / 40%); 
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: space-between;
    background: linear-gradient(125deg, var(--surface), #e9e9e9);
}

@media (max-width: 450px) {
    .search-page .result-card { 
        width: 100%;
    }
}

.fiscalite-grid {
  display: flex;
  flex-direction: column;
  margin-top: 16px;
}

.fiscalite-section {
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.96), rgba(244, 248, 255, 0.88));
  border: 1px solid rgba(15, 40, 80, 0.08);
  border-radius: var(--radius-lg);
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  box-shadow: 0 10px 22px rgba(15, 45, 90, 0.08);
}

.fiscalite-rates {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}

.fiscalite-rates li {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 14px;
  font-size: 0.95rem;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  transition: background 150ms ease;
}

.fiscalite-rates li:hover {
  background: rgba(0, 90, 158, 0.08);
}

.fiscalite-rates strong {
  font-weight: 600;
  font-size: 1rem;
}

.fiscalite-estimate {
  background: linear-gradient(160deg, rgba(235, 244, 255, 0.96), rgba(218, 233, 255, 0.9));
  border: 1px solid rgba(40, 110, 180, 0.2);
  border-radius: var(--radius-lg);
  padding: 24px 26px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  box-shadow: 0 14px 26px rgba(27, 72, 126, 0.12);
}

.fiscalite-estimate .estimate-label {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--secondary);
}

.fiscalite-estimate .estimate-value {
  font-size: 1.6rem;
  font-weight: 700;
  margin: 4px 0;
}

.fiscalite-estimate .estimate-subtle {
  font-size: 0.9rem;
  color: var(--secondary);
}

.fiscalite-estimate .estimate-note {
  margin-top: 12px;
  font-size: 0.85rem;
  line-height: 1.4;
}

.fiscalite-customizer {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px 16px;
  border: 1px dashed rgba(27, 72, 126, 0.2);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.65);
}

.fiscalite-customizer .customizer-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.fiscalite-customizer label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.85rem;
  color: var(--secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.fiscalite-coefficient-label {
  position: relative;
}

.fiscalite-coefficient-label .hint-button {
  position: absolute;
  top: -6px;
  right: 0;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: none;
  background: rgba(40, 110, 180, 0.15);
  color: rgba(27, 72, 126, 0.9);
  font-size: 0.75rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 120ms ease, color 120ms ease;
}

.fiscalite-coefficient-label .hint-button:hover {
  background: rgba(40, 110, 180, 0.2);
}

.fiscalite-coefficient-label .hint-button.is-open {
  background: rgba(40, 110, 180, 0.25);
  color: rgba(27, 72, 126, 1);
}

.fiscalite-coefficient-label .hint-tooltip {
  position: absolute;
  top: 30px;
  right: 0;
  width: 260px;
  background: rgba(12, 28, 60, 0.94);
  color: white;
  font-size: 0.75rem;
  line-height: 1.4;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  box-shadow: 0 10px 18px rgba(12, 28, 60, 0.2);
  opacity: 0;
  pointer-events: none;
  transition: opacity 120ms ease;
  z-index: 10;
}

.fiscalite-coefficient-label .hint-button.is-open .hint-tooltip {
  opacity: 1;
}

.fiscalite-customizer input {
  border-radius: var(--radius-md);
  border: 1px solid rgba(0, 0, 0, 0.1);
  padding: 8px 10px;
  font-size: 1rem;
  color: var(--text);
  background: rgba(255, 255, 255, 0.9);
}

.fiscalite-customizer input:focus {
  outline: none;
  border-color: rgba(40, 110, 180, 0.6);
  box-shadow: 0 0 0 2px rgba(40, 110, 180, 0.15);
}

.fiscalite-customizer .customizer-actions {
  display: flex;
  justify-content: flex-end;
}

.fiscalite-customizer [data-fiscalite-reset] {
  border: none;
  background: rgba(40, 110, 180, 0.1);
  color: rgba(27, 72, 126, 0.9);
  padding: 8px 14px;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-size: 0.9rem;
  transition: background 120ms ease, color 120ms ease;
}

.fiscalite-customizer [data-fiscalite-reset]:hover {
  background: rgba(40, 110, 180, 0.2);
  color: rgba(27, 72, 126, 1);
}

.fiscalite-warning {
  margin-top: 12px;
  padding: 12px 14px;
  background: rgba(255, 165, 0, 0.12);
  border: 1px solid rgba(255, 165, 0, 0.4);
  border-radius: var(--radius-md);
  color: #A15c00;
  font-size: 0.9rem;
  line-height: 1.4;
}

.fiscalite-breakdown {
  margin-top: 4px;
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.fiscalite-breakdown-item {
  border-radius: var(--radius-lg);
  border: 1px solid rgba(40, 110, 180, 0.16);
  background: rgba(255, 255, 255, 0.92);
  padding: 16px 18px;
  display: grid;
  gap: 8px;
  align-content: start;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.fiscalite-breakdown-item .breakdown-label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: var(--secondary);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.fiscalite-breakdown-item .breakdown-label small {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: none;
  opacity: 0.8;
}

.fiscalite-breakdown-item .breakdown-value {
  font-weight: 700;
  font-size: 1.08rem;
}

.fiscalite-breakdown-item.is-total {
  border-color: rgba(27, 72, 126, 0.45);
  background: linear-gradient(150deg, rgba(219, 235, 255, 0.92), rgba(198, 222, 255, 0.88));
  box-shadow: 0 6px 18px rgba(27, 72, 126, 0.12);
}

.fiscalite-alert {
  margin-top: 18px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  background: rgba(220, 53, 69, 0.1);
  color: var(--danger);
  font-size: 0.95rem;
}

a {
    color: var(--link);
    transition: color var(--transition);
}

a:hover {
    color: var(--link-hover);
}

/* Accessible focus states */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role="button"]:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

@supports (outline: 2px solid color-mix(in srgb, white, black)) {
  a:focus-visible,
  button:focus-visible,
  input:focus-visible,
  select:focus-visible,
  textarea:focus-visible,
  [role="button"]:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--accent), #000 10%);
  }
}

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
}

/* Main container */
.main-container {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    justify-content: space-between;
}

/* INSEE section */
.insee-section .metrics { list-style: none; padding: 0; margin: 0; }
.insee-section .metrics li { margin: 4px 0; }
.insee-section .result-card h4 { margin-bottom: 8px; }
.insee-chart { display: flex; align-items: center; justify-content: center; padding: 8px 0; }
.insee-chart svg { max-width: 220px; }
.insee-chart-empty { color: #6b7280; font-style: italic; }
.insee-legend { margin-top: 6px; }
.insee-legend .legend-wrap { display: flex; flex-wrap: wrap; gap: 8px 14px; }
.insee-legend .legend-item { display: inline-flex; align-items: center; gap: 8px; font-size: 0.9rem; color: #374151; }
.insee-legend .legend-color { display: inline-block; width: 12px; height: 12px; border-radius: 3px; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.08); }
.insee-kpis { display: grid; gap: 12px; margin-bottom: 12px; }
.insee-kpis .kpi-card { background: #ffffff; border: 1px solid #e5e7eb; border-radius: 10px; padding: 14px; box-shadow: 0 1px 2px rgba(0,0,0,0.04); }
.insee-kpis .kpi-label { color: #6b7280; font-size: .9rem; margin-bottom: 6px; }
.insee-kpis .kpi-value { font-size: 1.5rem; font-weight: 700; color: #111827; letter-spacing: -0.01em; }
.subtle { color: #6b7280; font-size: .85rem; margin-bottom: 6px; }
.insee-section .result-card { 
    border: 1px solid #e5e7eb; 
    border-radius: 10px; 
    padding: 14px; 
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.search-page .accordion-section .result-card { 
    background: white;
    display: flex;
    align-items: center;
}
.insee-section .result-grid-2, .insee-section .result-grid-3 { gap: 12px; }
.insee-legend .legend-item { background: #f9fafb; padding: 4px 8px; border-radius: 6px; border: 1px solid #eef2f7; }

/* Hero header */
.hero {
    position: relative;
    background-color: #0b0d1c;
    background-image: radial-gradient(1200px 600px at 20% -10%, #122042 0%, transparent 60%),
                      radial-gradient(1000px 500px at 90% 10%, #0f2d2d 0%, transparent 55%),
                      linear-gradient(180deg, #10162f, var(--hero-bg));
    color: var(--hero-fg);
    min-height: 35vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 64px 20px 40px;
    overflow: unset;
}

@supports (color: color-mix(in srgb, white, black)) {
  .hero {
    background-image: radial-gradient(1200px 600px at 20% -10%, #122042 0%, transparent 60%),
                      radial-gradient(1000px 500px at 90% 10%, #0f2d2d 0%, transparent 55%),
                      linear-gradient(180deg, color-mix(in srgb, var(--hero-bg), #000 8%), var(--hero-bg));
  }
}

.hero-inner { width: 100%; max-width: 940px; }
.brand { text-align: center; margin-bottom: 28px; }
.brand-row { display: inline-flex; align-items: center; gap: 12px; }
.brand-title { font-size: clamp(42px, 7vw, 88px); margin: 0; letter-spacing: -0.02em; }
.brand-logo { height: clamp(46px, 8vw, 90px); width: auto; filter: drop-shadow(0 2px 6px rgba(0,0,0,.3)) brightness(10); }
.brand-tag { margin: 6px 0 0; opacity: .9; font-size: clamp(14px, 2.2vw, 20px); }

.hero-search { display: flex; flex-direction: column; gap: 16px; align-items: stretch; }
.hero-search .search-input-container { display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: center; }
.search-field { display: flex; align-items: center; gap: 10px; background: #11162a; border: 1px solid rgba(255,255,255,.08); border-radius: 14px; box-shadow: 0 10px 25px rgba(0,0,0,.25); padding-right: 6px; }

@supports (color: color-mix(in srgb, white, black)) {
  .search-field { background: color-mix(in srgb, var(--hero-bg), #fff 6%); }
}
.search-icon { display: inline-flex; align-items: center; justify-content: center; padding: 0 14px; color: #2de3c5; pointer-events: none; }
.hero-input { background: transparent; color: var(--hero-fg); border: none; outline: none; text-align: left; font-size: 18px; padding: 18px 16px; flex: 1 1 auto; width: auto; }
.hero-input::placeholder { color: rgba(255,255,255,.7); }
.hero-input:focus { box-shadow: none; }
.search-button.cta { background: linear-gradient(156deg, #3e7a8e, #0f485d); padding: 16px 22px; font-size: 16px; font-weight: 700; }
.search-button:hover { filter: hue-rotate(45deg); }

@media (max-width: 720px) {
  .hero-search .search-input-container { grid-template-columns: 1fr; }
  .search-button.cta { width: 100%; }
}

/* Search container */
.search-container {
    background: var(--surface);
    padding: 30px;
    border-radius: var(--border-radius);
    box-shadow: var(--shadow);
    border: 1px solid var(--gray-300);
    margin: 20px;
    width: 90vw;
    margin-left: auto;
    margin-right: auto;
    margin-top: 40px;
}

.search-title {
    text-align: center;
    margin-bottom: 30px;
    font-size: 2.5em;
    font-weight: 600;
    color: var(--primary);
    display: flex;
    align-items: center;
    justify-content: center;
}

.search-title .logo {
    height: 40px;
    width: auto;
    margin-left: 12px;
}

.search-form {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 20px;
    align-items: center;
}

.search-input-container {
    position: relative;
    width: 100%;
    max-width: 600px;
}

.search-input {
    padding: 14px 16px;
    border: 1px solid var(--gray-400);
    border-radius: var(--border-radius);
    font-size: 16px;
    width: 100%;
    box-sizing: border-box;
    background: var(--surface);
    transition: border-color var(--transition);
    text-align: center;
}

.search-input::placeholder {
    color: var(--gray-600);
}

.search-input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.25);
}

/* Hero overrides for the shared input class */
.hero .search-input {
    text-align: left;
    background: transparent;
    border: none;
    box-shadow: none;
}

.search-button {
    padding: 14px 24px;
    background: var(--accent);
    color: white;
    border: none;
    border-radius: var(--border-radius);
    cursor: pointer;
    font-size: 16px;
    font-weight: 500;
    transition: background-color var(--transition);
    min-width: 140px;
    transition: 200ms;
}

.search-button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* --- Pro pages: generic buttons (avoid search-button style) --- */
.pro-btn {
    display: inline-block;
    padding: 12px 18px;
    border: none;
    border-radius: var(--border-radius);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: transform var(--transition), box-shadow var(--transition), filter var(--transition);
    box-shadow: 0 6px 16px rgba(0,0,0,.15);
}
.pro-btn:active { transform: translateY(1px); }
.pro-btn:disabled { opacity: .6; cursor: not-allowed; }

.pro-btn-primary {
    color: #fff;
    background: linear-gradient(156deg, #3e7a8e, #0f485d);
    margin-bottom: 5px;
    transition: 200ms;
}
.pro-btn-primary:hover { filter: brightness(1.05) hue-rotate(40deg); }

.pro-btn-danger {
    color: #fff;
    background: linear-gradient(156deg, #b62424, #7a0f0f);
    margin-bottom: 5px;
    transition: 200ms;
}
.pro-btn-danger:hover { filter: brightness(1.05) hue-rotate(40deg); }

/* Autocomplete styles */
.autocomplete-suggestions {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--surface);
    border: 1px solid var(--gray-300);
    border-top: none;
    border-radius: 0 0 var(--border-radius) var(--border-radius);
    box-shadow: var(--shadow-md);
    max-height: 300px;
    overflow-y: auto;
    z-index: 1000;
}

.autocomplete-suggestions.hidden {
    display: none;
}

/* Dark dropdown inside hero */
.hero .autocomplete-suggestions { background: #11162a; border-color: rgba(255,255,255,.12); }

@supports (color: color-mix(in srgb, white, black)) {
  .hero .autocomplete-suggestions { background: color-mix(in srgb, var(--hero-bg), #fff 6%); }
}
.hero .autocomplete-item { border-bottom-color: rgba(255,255,255,.08); }
.hero .autocomplete-item:hover, .hero .autocomplete-item.focused { background-color: rgba(255,255,255,.06); }
.hero .suggestion-label { color: var(--hero-fg); }
.hero .suggestion-context { color: rgba(255,255,255,.7); }

.autocomplete-item {
    padding: 12px 16px;
    cursor: pointer;
    border-bottom: 1px solid var(--gray-200);
    transition: background-color var(--transition);
}

.autocomplete-item:last-child {
    border-bottom: none;
    border-radius: 0 0 10px 10px;
}

.autocomplete-item:hover {
    background-color: var(--gray-100);
}

.autocomplete-item.focused {
    background-color: var(--gray-100);
}

.suggestion-label {
    font-weight: 500;
    color: var(--text);
    margin-bottom: 2px;
}

.suggestion-context {
    font-size: 0.85em;
    color: var(--gray-600);
}

/* Disclaimer footer */
.disclaimer-footer {
    text-align: center;
    padding: 30px 20px;
    color: var(--gray-600);
    font-style: italic;
    background: var(--surface);
    border-top: 1px solid var(--gray-300);
    margin-top: auto;
}

.disclaimer-footer a {
    text-decoration: none;
}

.disclaimer-footer a:hover,
.disclaimer-footer a:focus-visible,
.disclaimer-footer a:active {
    text-decoration: none;
}

/* Results container */

.results-container {
    backdrop-filter: blur(10px);
    /* Top padding is 0 to avoid overlap with sticky map */
    padding: 0 30px 30px;
    border-radius: 20px;
}

.results-container h2 {
    text-align: center;
    color: #dfdfdf;
    padding-bottom: 12px;
    margin-bottom: 24px;
    font-size: 1.6em;
    font-weight: 600;
}

.report-paywall {
    margin: 32px auto;
    padding: 28px 24px;
    max-width: 720px;
    text-align: center;
    border-radius: 16px;
    background: rgba(7, 9, 20, 0.68);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 14px 32px rgba(6, 10, 26, 0.45);
}

.report-paywall__title {
    margin: 0 0 12px;
    font-size: 1.6rem;
    font-weight: 600;
    color: #ffffff;
}

.report-paywall__description {
    margin: 0 auto 20px;
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.78);
    max-width: 520px;
    line-height: 1.5;
}

.report-paywall__note {
    margin-top: 16px;
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.6);
}

.results-warning {
    margin: 1.5rem 0;
    padding: 0.9rem 1.1rem;
    border-radius: 12px;
    background: rgba(245, 158, 11, 0.14);
    border: 1px solid rgba(217, 119, 6, 0.4);
    color: #f59e0b;
    font-weight: 600;
}

.purchase-button {
    min-width: 280px;
    font-size: 1rem;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    padding: 16px 28px;
    border-radius: 999px;
    background: linear-gradient(142deg, #3e7a8e 0%, #0f485d 55%, #0a2834 100%);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: 0 18px 34px rgba(8, 22, 35, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.18);
    font-weight: 600;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    transition: transform 180ms ease, box-shadow 220ms ease, filter 220ms ease;
}

.purchase-button:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 40px rgba(8, 22, 35, 0.55), inset 0 1px 0 rgba(255, 255, 255, 0.25);
    filter: brightness(1.05);
}

.purchase-button:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(45, 227, 197, 0.28), 0 18px 34px rgba(8, 22, 35, 0.45);
}

.purchase-button:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
    box-shadow: 0 12px 22px rgba(8, 22, 35, 0.3);
}

/* Crime and meteo sections */
.crime-section,
.meteo-section {
    margin: 0;
    padding: 20px;
}

.crime-section h3,
.meteo-section h3 {
    color: var(--primary);
    margin-bottom: 20px;
    font-size: 1.4em;
    text-align: center;
    padding-top: 10px;
}

/* Crime indicators */
.crime-section {
    margin: 20px 0;
}

.crime-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
    margin-bottom: 20px;
}

.crime-stat-card {
    background: linear-gradient(135deg, #fefefe 0%, #f8f9fa 100%);
    position: relative;
    overflow: hidden;
}

/* Crime card hover uses result-card base styling */

.crime-stat-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 20px;
}

.crime-type {
    margin: 0;
    font-size: 1.1em;
  color: var(--gray-700);
    font-weight: 600;
    line-height: 1.4;
    flex: 1;
    padding-right: 10px;
}

.trend-indicator {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    font-size: 1.1em;
    font-weight: 600;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.trend-indicator.up {
    background: linear-gradient(135deg, #ffb3ba, #ffccd5);
    color: #721c24;
}

.trend-indicator.down {
    background: linear-gradient(135deg, #b3ffb3, #ccffcc);
    color: #1e7e34;
}

.trend-indicator.stable {
    background: linear-gradient(135deg, #e2e3e5, #f8f9fa);
    color: #495057;
}

.crime-stat-content {
    text-align: center;
    margin-bottom: 20px;
}

.main-rate {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 6px;
    margin-bottom: 12px;
}

.rate-value {
    font-size: 2.8em;
    font-weight: 700;
    color: #495057;
    line-height: 0.9;
}

.rate-unit {
    font-size: 1.3em;
    color: #6c757d;
    font-weight: 500;
}

.rate-label {
    font-size: 0.95em;
    color: #6c757d;
    font-weight: 500;
    letter-spacing: 0.3px;
}

.severity-indicator {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    border-radius: 16px 16px 0 0;
    opacity: 0.8;
}

/* Yearly data */
.yearly-data {
    margin-top: 15px;
}

.stat-item {
    display: flex;
    flex-direction: column;
    padding: 10px 0;
    border-bottom: 1px solid #eee;
}

.year {
    font-weight: bold;
    color: var(--primary);
    margin-bottom: 5px;
}

.count {
    text-align: left;
    margin: 0 0 5px 0;
}

.rate {
    font-weight: bold;
    color: #28a745;
    text-align: left;
}

/* Meteo info */
.meteo-info p {
    margin: 8px 0;
    padding: 8px 0;
}

/* Meteo tables */
.meteo-tables {
    margin: 20px 0;
}

.meteo-table {
    width: 100%;
    border-collapse: collapse;
    margin: 10px 0;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.meteo-table th {
    background-color: #2c3e50;
    color: white;
    padding: 12px 8px;
    text-align: center;
    font-weight: bold;
}

.meteo-table td {
    padding: 10px 8px;
    text-align: center;
    border-bottom: 1px solid #ecf0f1;
}

.meteo-table tr:last-child td {
    border-bottom: none;
}

.month-name {
    font-weight: bold;
    background-color: #f8f9fa !important;
    text-align: left !important;
}

.temp-cell, .precip-cell {
    font-weight: bold;
    color: #2c3e50;
    text-shadow: 0 1px 2px rgba(255, 255, 255, 0.8);
}

.meteo-tables h4 {
    margin: 15px 0 10px 0;
    color: #2c3e50;
    font-size: 1.1em;
}

/* DVF Section */
.dvf-section {
    margin: 30px 0;
    padding: 20px;
    background: #f8f9fa;
    border-radius: 10px;
    border: 1px solid #dee2e6;
}

.dvf-map-container {
    margin: 20px 0;
}

.dvf-map {
    height: min(600px, 50vh);
    width: 100%;
    border-radius: 8px;
    border: 1px solid #ddd;
}

.dvf-transactions {
    margin: 20px 0;
}

/* transactions-grid uses result-grid-2 base class */
.transactions-grid {
    margin-top: 15px;
    gap: 18px;
}

/* =====================
   DVF mobile‑first cards
   ===================== */
.dvf-cards .transaction-card::before,
.dvf-cards .transaction-card::after { content: none !important; display: none !important; }

.dvf-card {
  border-radius: 18px;
  padding: 18px;
  background: linear-gradient(180deg, var(--card-bg-top), var(--card-bg-bottom));
  border: 1px solid rgba(19, 43, 99, 0.08);
  box-shadow: 0 10px 24px rgba(15, 32, 77, 0.08);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.dvf-card:hover { transform: translateY(-2px); box-shadow: 0 14px 30px rgba(13, 35, 67, 0.16); border-color: rgba(19, 43, 99, 0.18); }
.dvf-card.selected { box-shadow: 0 0 0 2px rgba(13,110,253,.18), 0 16px 32px rgba(13,35,67,.16); border-color: var(--card-accent); }

.dvf-card__main { display: flex; flex-direction: column; gap: 10px; }
.dvf-card__price-bar { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.dvf-card__price-group { display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.dvf-card__price { font-weight: 800; font-size: 1.3rem; color: var(--card-accent); letter-spacing: -0.01em; }
.dvf-card__icon { opacity: .85; font-size: .95em; }
.dvf-card__date { background: var(--pill-bg); border: 1px solid var(--pill-border); border-radius: 999px; font-weight: 600; font-size: .78rem; padding: 4px 10px; color: #334155; }

.dvf-card__addr { color: #0f172a; font-weight: 600; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

.dvf-card__chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chip { background: var(--chip-bg); border: 1px solid var(--chip-border); color: #1f2937; padding: 4px 10px; border-radius: 999px; font-size: .78rem; font-weight: 600; }
.chip--type { background: #eef2ff; border-color: #dbe4ff; color: #1d4ed8; }
.chip--property { background: #f6f7fb; border-color: #d2d9f7; color: #0f172a; }


.dvf-card__distance { font-size: .78rem; color: var(--muted); }

.dvf-card__aside { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.pill { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 999px; font-size: .78rem; font-weight: 700; border: 1px solid transparent; }
.pill.price-per-m2-built { background: linear-gradient(135deg, #fff4d6, #fee4a8); color: #854d0e; border-color: #fddc8a; }
.pill.price-per-m2 { background: linear-gradient(135deg, #e8f7ef, #d1f4e2); color: #14532d; border-color: #b8e9ce; }
.pill.outlier-pill.low { background: rgba(34,197,94,.15); color: #166534; border-color: rgba(34,197,94,.35); }
.pill.outlier-pill.high { background: rgba(239,68,68,.15); color: #991b1b; border-color: rgba(239,68,68,.35); }

.dvf-card__warning { font-size: 1rem; color: #d97706; line-height: 1; }

.dvf-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
@media (min-width: 1200px) { .dvf-cards { grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); } }
@media (max-width: 520px) { .dvf-card { padding: 16px; gap: 12px; } .dvf-card__price { font-size: 1.16rem; } }

/* Transaction cards inherit from result-card base class */
.transactions-grid .transaction-card {
    position: relative;
    overflow: hidden;
    border-radius: 16px;
    padding: 18px 20px 14px;
    background: linear-gradient(180deg, var(--card-bg-top) 0%, var(--card-bg-bottom) 100%);
    border: 1px solid var(--card-border);
    box-shadow: 0 6px 18px rgba(13, 35, 67, 0.06);
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.transactions-grid .transaction-card::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    background: linear-gradient(90deg, rgba(13,110,253,.35), rgba(99,102,241,.30), rgba(56,189,248,.28));
    opacity: .9;
}

/* Left accent to balance the top line (very subtle) */
.transactions-grid .transaction-card::after {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, rgba(13,110,253,.22), rgba(99,102,241,.18));
  opacity: .65;
}

.transactions-grid .transaction-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(13, 35, 67, 0.12);
    border-color: var(--card-border-hover);
}

.transactions-grid .transaction-card.selected {
    border-color: var(--card-accent);
    box-shadow: 0 0 0 2px rgba(13, 110, 253, 0.18), 0 10px 28px rgba(13,35,67,.12);
}

.dependencies {
    margin-top: 10px;
    padding: 8px 12px;
    background-color: #f8f9fa;
    border-radius: 6px;
    border-left: 3px solid #007bff;
}

.dependency-header {
    margin-bottom: 5px;
    color: #495057;
    font-size: 0.9em;
}

.dependency-list {
    font-size: 0.85em;
    color: var(--gray-600);
    line-height: 1.4;
}

/* Responsive grid adjustments */
@media (max-width: 768px) {
    .transactions-grid {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 769px) and (max-width: 1200px) {
    .transactions-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1201px) {
    .transactions-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1600px) {
    .transactions-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.transaction-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}

.transaction-price { font-weight: 800; font-size: 1.28em; color: var(--card-accent); letter-spacing: -0.01em; }

.transaction-date { font-size: 0.78em; color: #334155; background-color: var(--pill-bg); border: 1px solid var(--pill-border); padding: 4px 8px; border-radius: 999px; font-weight: 600; }

.transaction-details p {
    margin: 4px 0;
    font-size: 0.85em;
    line-height: 1.4;
}

.transaction-details .address { color: #0f172a; margin-bottom: 6px; font-weight: 600; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

.transaction-details .type {
    display: inline-block;
    color: #1d4ed8;
    background: #eef2ff;
    border: 1px solid #dbe4ff;
    border-radius: 999px;
    padding: 2px 8px;
    font-size: 0.78em;
    font-weight: 700;
    margin-bottom: 8px;
}

.transaction-details .surface,
.transaction-details .distance {
    color: #6c757d;
    font-size: 0.8em;
    margin: 2px 0;
}

.price-metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 8px 0 2px 0;
}

.price-per-m2,
.price-per-m2-built {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: linear-gradient(135deg, #e8f5e8, #d4edda);
    color: #14532d;
    padding: 5px 10px;
    border-radius: 999px;
    font-size: 0.78em;
    font-weight: 700;
    border: 1px solid #c3e6cb;
}

.outlier-pill {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 0.72em;
    font-weight: 700;
    line-height: 1;
    border: 1px solid transparent;
}
.outlier-pill.low { background: rgba(34,197,94,.15); color: #166534; border-color: rgba(34,197,94,.35); }
.outlier-pill.high { background: rgba(239,68,68,.15); color: #991b1b; border-color: rgba(239,68,68,.35); }

.transaction-card.outlier-low {
    border-color: rgba(34,197,94,.6);
    box-shadow: 0 6px 20px rgba(34,197,94,.18);
}
.transaction-card.outlier-high {
    border-color: rgba(239,68,68,.6);
    box-shadow: 0 6px 20px rgba(239,68,68,.18);
}

@media (max-width: 520px) {
  .transaction-header { gap: 8px; }
  .transaction-price { font-size: 1.2em; }
  .transaction-date { font-size: 0.7em; }
  .price-metrics { gap: 6px; }
  .surface-info .metric { font-size: 0.72em; }
}

.price-per-m2-built {
    background: linear-gradient(135deg, #fff3cd, #ffeaa7);
    color: #856404;
    border-color: #fde047;
}

.surface-info {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 8px 0;
}

.surface-info .metric { background: var(--chip-bg); color: #1f2937; padding: 4px 8px; border-radius: 999px; font-size: 0.78em; font-weight: 600; border: 1px solid var(--chip-border); }

.dvf-marker {
    background: #007bff;
    color: white;
    border-radius: 4px;
    text-align: center;
    font-weight: bold;
    font-size: 0.8em;
    border: 2px solid white;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.dvf-marker-content {
    padding: 2px 4px;
    line-height: 16px;
}

.dvf-popup h4 {
    margin: 0 0 10px 0;
    color: #28a745;
}

.dvf-popup p {
    margin: 5px 0;
    font-size: 0.9em;
}

.no-data {
    text-align: center;
    color: #6c757d;
    font-style: italic;
    padding: 20px;
}

/* Error and loading indicators */
.error {
    padding: 20px;
    border-radius: 15px;
    margin: 20px 0;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(10px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
}

.loading {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 12px;
    padding: 20px;
    font-size: 1.1em;
    color: var(--primary);
    font-weight: 500;
    margin: 20px 0;
    text-align: center;
}

.loading-message {
    color: var(--secondary);
    font-size: 1rem;
}

.loading-bar {
    width: min(320px, 80%);
    height: 6px;
    background: rgba(15, 118, 110, 0.18);
    border-radius: 999px;
    overflow: hidden;
    position: relative;
    box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.08);
}

.loading-bar-progress {
    display: block;
    width: 40%;
    height: 100%;
    background: linear-gradient(90deg, rgba(15, 118, 110, 0.25), rgba(15, 118, 110, 0.9));
    border-radius: inherit;
    animation: loading-bar-slide 1.4s ease-in-out infinite;
    will-change: transform;
}

@keyframes loading-bar-slide {
    0% {
        transform: translateX(-100%);
    }
    100% {
        transform: translateX(280%);
    }
}

/* Results transition states */
#results {
    position: relative;
    opacity: 1;
    transform: translateY(0);
    transition: opacity 220ms ease, transform 220ms ease;
    will-change: opacity, transform;
}

#results.is-fading-out {
    opacity: 0;
    transform: translateY(12px);
}

#results.is-cleared {
    pointer-events: none;
}

/* School section styles */
.school-section {
    background: var(--surface);
    padding: 25px;
    border-radius: 15px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    margin-bottom: 25px;
}

.school-section .section-header {
    text-align: center;
    margin-bottom: 25px;
}

.school-section .section-header h3 {
    color: #005a9e;
    font-size: 1.8em;
    margin-bottom: 8px;
}

.school-section .address-info {
    color: #6c757d;
    font-size: 1.1em;
    margin-bottom: 0;
}

/* Summary statistics */
.school-summary {
    margin-bottom: 30px;
}

.summary-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin-bottom: 25px;
}

#summary-stats > .subsection-header > h5 {
    margin: 0;
}

/* Stat cards inherit from stat-card-base class */
.stat-card {
    background: #f8f9fa;
    color: #333;
}

.stat-card.total-schools {
    background: linear-gradient(135deg, #e3f2fd, #bbdefb);
    color: #1565c0;
    border-left: 4px solid #1565c0;
}

.stat-card .stat-number {
    font-size: 2.2em;
    font-weight: bold;
    line-height: 1;
    margin-bottom: 5px;
}

.stat-card .stat-label {
    font-size: 0.9em;
    opacity: 0.8;
    font-weight: 500;
}

/* Type comparison */
.type-comparison h4 {
    color: #333;
    margin-bottom: 15px;
    font-size: 1.3em;
}

.type-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 15px;
}

/* Type cards inherit from stat-card-base class */

.type-header {
    display: flex;
    align-items: center;
    margin-bottom: 12px;
}

.type-icon {
    font-size: 1.5em;
    margin-right: 10px;
}

.type-name {
    font-weight: bold;
    font-size: 1.1em;
}

.type-stats-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.type-count {
    color: #6c757d;
    font-size: 0.9em;
}

.type-rate {
    font-weight: bold;
    font-size: 1.1em;
}

/* Top schools */
.top-schools h4 {
    color: #333;
    margin-bottom: 20px;
    font-size: 1.4em;
}

.schools-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
}

/* School cards inherit from result-card base class */

.school-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 15px;
}

.school-name {
    font-size: 1.1em;
    font-weight: bold;
    color: #333;
    margin: 0;
    flex: 1;
    margin-right: 10px;
}

.school-sector {
    font-size: 0.8em;
    padding: 4px 8px;
    border-radius: 6px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.school-sector.public {
    background-color: #e3f2fd;
    color: #1565c0;
}

.school-sector.private,
.school-sector[class*="privé"] {
    background-color: #fff3e0;
    color: #ef6c00;
}

.school-stats {
    display: flex;
    gap: 15px;
    margin-bottom: 15px;
    flex-wrap: wrap;
}

.main-stat {
    flex: 1;
    min-width: 100px;
}

.main-stat .stat-value {
    font-size: 1.8em;
    font-weight: bold;
    line-height: 1;
    display: block;
}

.main-stat .stat-desc {
    font-size: 0.8em;
    opacity: 0.7;
    margin-top: 3px;
}

.secondary-stat {
    text-align: center;
    min-width: 70px;
}

.secondary-stat .stat-value {
    font-size: 1.2em;
    font-weight: bold;
    display: block;
    line-height: 1;
}

.secondary-stat .stat-desc {
    font-size: 0.75em;
    opacity: 0.7;
    margin-top: 2px;
}

.secondary-stat.positive {
    color: #28a745;
}

.secondary-stat.negative {
    color: #dc3545;
}

.secondary-stat.neutral {
    color: #6c757d;
}

.school-info {
    display: flex;
    justify-content: space-between;
    color: #6c757d;
    font-size: 0.85em;
    padding-top: 10px;
    border-top: 1px solid #eee;
}

/* All schools list */
.all-schools {
    margin-top: 30px;
}

.schools-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    flex-wrap: wrap;
    gap: 15px;
}

.schools-header h4 {
    color: #333;
    margin: 0;
    font-size: 1.3em;
}

.schools-filters {
    display: flex;
    gap: 10px;
}

.filter-select {
    padding: 8px 12px;
    border: 1px solid var(--gray-300);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--text);
    cursor: pointer;
}

.filter-select:focus {
    outline: none;
    border-color: #005a9e;
}

.schools-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.school-row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 20px;
    padding: 15px;
    background: #f8f9fa;
    border-radius: 8px;
    align-items: center;
    transition: background-color 0.2s;
}

.school-row:hover {
    background: #e9ecef;
}

.school-row.public-sector {
    border-left: 3px solid #1565c0;
}

.school-row.private-sector {
    border-left: 3px solid #ef6c00;
}

.school-basic-info {
    min-width: 0;
}

.school-name-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 5px;
}

.school-name {
    font-weight: bold;
    color: #333;
}

.school-sector-badge {
    font-size: 0.7em;
    padding: 2px 6px;
    border-radius: 4px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.school-sector-badge.public {
    background-color: #e3f2fd;
    color: #1565c0;
}

.school-sector-badge[class*="privé"] {
    background-color: #fff3e0;
    color: #ef6c00;
}

.school-location {
    font-size: 0.85em;
    color: #6c757d;
}

.school-metrics {
    display: flex;
    gap: 15px;
}

.metric {
    text-align: center;
    padding: 8px;
    border-radius: 6px;
    min-width: 60px;
}

.metric-value {
    display: block;
    font-weight: bold;
    font-size: 0.95em;
    line-height: 1;
}

.metric-label {
    display: block;
    font-size: 0.7em;
    opacity: 0.7;
    margin-top: 2px;
}

.metric.value-added.positive {
    background-color: #d4edda;
    color: #155724;
}

.metric.value-added.negative {
    background-color: #f8d7da;
    color: #721c24;
}

.metric.mentions {
    background-color: #e2e3e5;
    color: #383d41;
}

.school-year-info {
    text-align: right;
    color: #6c757d;
    font-size: 0.85em;
}

.school-year-info .year {
    display: block;
    font-weight: 600;
    margin-bottom: 3px;
}

.school-year-info .students {
    display: block;
    font-size: 0.8em;
}

/* Establishment grouping styles */
.establishments-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.establishment-group {
    background: #f8f9fa;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
    transition: box-shadow 0.2s;
}

.establishment-group:hover {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
}

.establishment-group.public-sector {
    border-left: 4px solid #1565c0;
}

.establishment-group.private-sector {
    border-left: 4px solid #ef6c00;
}

.establishment-header {
    background: var(--surface);
    padding: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--gray-200);
}

.establishment-info {
    flex: 1;
}

.establishment-name {
    color: #333;
    font-size: 1.2em;
    margin: 0 0 8px 0;
    font-weight: bold;
}

.establishment-meta {
    display: flex;
    align-items: center;
    gap: 15px;
}

.establishment-sector {
    font-size: 0.8em;
    padding: 4px 8px;
    border-radius: 6px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.establishment-sector.public {
    background-color: #e3f2fd;
    color: #1565c0;
}

.establishment-sector[class*="privé"] {
    background-color: #fff3e0;
    color: #ef6c00;
}

.establishment-location {
    color: #6c757d;
    font-size: 0.9em;
}

.establishment-summary {
    text-align: center;
}

.best-rate {
    padding: 12px 16px;
    border-radius: 8px;
    text-align: center;
    min-width: 100px;
}

.best-rate .rate-value {
    display: block;
    font-size: 1.4em;
    font-weight: bold;
    line-height: 1;
}

.best-rate .rate-label {
    display: block;
    font-size: 0.8em;
    opacity: 0.8;
    margin-top: 3px;
}

.years-data {
    background: #f8f9fa;
}

.year-row {
    display: flex;
    align-items: center;
    padding: 15px 20px;
    border-bottom: 1px solid #e9ecef;
    transition: background-color 0.2s;
}

.year-row:last-child {
    border-bottom: none;
}

.year-row:hover {
    background: #e9ecef;
}

.year-header {
    display: flex;
    align-items: center;
    gap: 15px;
    min-width: 200px;
}

.year-badge {
    background: #005a9e;
    color: white;
    padding: 6px 12px;
    border-radius: 6px;
    font-weight: bold;
    font-size: 0.9em;
}

.students-count {
    color: #6c757d;
    font-size: 0.85em;
}

.year-metrics {
    display: flex;
    gap: 15px;
    margin-left: auto;
}

.year-metrics .metric {
    min-width: 70px;
    padding: 8px 10px;
}

.year-metrics .metric-value {
    font-size: 0.95em;
}

.year-metrics .metric-label {
    font-size: 0.7em;
}

/* Responsive design */
@media (max-width: 768px) {
    .crime-stats-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .crime-stats-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    
    .crime-stat-card {
        padding: 20px;
        border-radius: 12px;
    }
    
    .rate-value {
        font-size: 2.2em;
    }
    
    .trend-indicator {
        width: 32px;
        height: 32px;
        font-size: 1em;
    }

    .search-container {
        padding: 30px 20px;
        margin: 10px;
        margin-top: 40px;
        width: auto;
    }
    
    .search-title {
        font-size: 2.5em;
        margin-bottom: 30px;
    }
    
    .search-title .logo {
        height: 40px;
        margin-left: 10px;
    }
    
    .search-input {
        padding: 16px 20px;
        font-size: 16px;
        max-width: 100%;
    }
    
    .search-button {
        padding: 16px 28px;
        font-size: 15px;
    }
    
    .results-container {
        padding: 5px;
    }
    
    .summary-stats {
        grid-template-columns: 1fr;
    }
    
    .schools-grid {
        grid-template-columns: 1fr;
    }
    
    .school-row {
        grid-template-columns: 1fr;
        gap: 15px;
    }
    
    .school-metrics {
        justify-self: start;
    }
    
    .school-year-info {
        text-align: left;
    }
    
    .schools-header {
        flex-direction: column;
        align-items: stretch;
    }
    
    .schools-filters {
        justify-content: center;
    }
    
    /* Establishment responsive */
    .establishment-header {
        flex-direction: column;
        gap: 15px;
        align-items: stretch;
    }
    
    .establishment-summary {
        align-self: center;
    }
    
    .year-row {
        flex-direction: column;
        gap: 10px;
        align-items: stretch;
    }
    
    .year-header {
        min-width: auto;
        justify-content: center;
    }
    
    .year-metrics {
        margin-left: 0;
        justify-content: center;
    }
}

@media (max-width: 480px) {
    .school-stats {
        flex-direction: column;
        gap: 10px;
    }
    
    .school-metrics {
        gap: 10px;
    }
    
    .metric {
        min-width: 50px;
        padding: 6px;
    }
}

/* Sort Controls */
.sort-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 15px;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  background: var(--surface);
  border: 1px solid var(--gray-300);
  box-shadow: var(--shadow-sm);
  flex-wrap: wrap;
}

.sort-controls label {
  font-weight: 600;
  color: var(--gray-700);
  margin-right: 5px;
}

.sort-btn {
  padding: 6px 12px;
  border: 1px solid var(--gray-300);
  background: var(--surface);
  border-radius: var(--radius-sm);
  font-size: 13px;
  cursor: pointer;
  transition: all var(--transition);
}

.sort-btn:hover {
  background: var(--gray-200);
  border-color: var(--gray-500);
}

.sort-btn.active {
  background: var(--accent);
  color: white;
  border-color: var(--accent);
}

.sort-btn.active:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

.map-section {
  z-index: 1000;
  width: 100%;
  margin: 10px 0 24px;
  border: 1px solid var(--gray-300);
  border-radius: 12px;
  box-shadow: var(--shadow);
  background: var(--surface);
}

.map-section h3 {
  margin: 0 0 10px 0;
  padding: 0 20px;
}

/* Ensure the results container has proper spacing */

/* Add some padding to prevent content from hiding behind sticky map */
.results-container > div:not(.map-section) {
  margin-top: 10px;
}

.htmx-indicator {
    display: none;
}

.htmx-request.htmx-indicator,
.htmx-request .htmx-indicator {
    display: flex;
}

/* School Accordion Styles */
.school-accordion {
    margin-bottom: 30px;
}

.accordion-section {
    margin-bottom: 12px;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    border: 1px solid rgba(0, 0, 0, 0.05);
    overflow: hidden;
}

.accordion-header {
    background: #f8f9fa;
    padding: 12px 16px;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all 0.2s ease;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.accordion-header:hover {
    background: #f1f3f4;
}

.accordion-header h4 {
    margin: 0;
    color: #005a9e;
    font-size: 1.2em;
}

.accordion-toggle {
    font-size: 1.2em;
    font-weight: bold;
    color: #005a9e;
    transition: transform 0.3s ease;
}

.accordion-content {
    background: #f0f8ff;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease-out;
}

.accordion-content.open {
    max-height: none;
    transition: max-height 0.4s ease-in;
}

.accordion-content > div {
    padding: 5px;
}

/* Adjust existing sections for accordion */
.accordion-content .summary-stats {
    margin-bottom: 0;
}

.accordion-content .type-stats {
    margin-bottom: 0;
}

.accordion-content .crime-stats {
    margin-bottom: 0;
    padding: 0;
}

.accordion-content .meteo-info {
    margin-bottom: 0;
}

.accordion-content .meteo-tables {
    margin-bottom: 0;
}

.accordion-content .transactions-grid {
    margin-bottom: 0;
}

.accordion-content .dvf-map-container {
    margin-bottom: 0;
}

/* Ensure proper spacing for accordion content */
.accordion-content .dvf-map {
    height: min(600px, 50vh);
    border-radius: 8px;
}

/* ===== SITADEL SECTION STYLES ===== */
.sitadel-overview {
    padding: 20px;
    background: linear-gradient(135deg, #fff8f0 0%, #ffffff 100%);
    border-radius: 12px;
    margin-bottom: 20px;
}

.construction-score-card {
    display: flex;
    align-items: center;
    gap: 20px;
    margin: 10px 0;
    border-left: 4px solid #ff8c00;
}

.score-circle {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    border: 4px solid #ff8c00;
    border-radius: 50%;
    background: #fff;
    flex-shrink: 0;
}

.score-number {
    font-size: 1.5em;
    font-weight: bold;
    color: #ff8c00;
    line-height: 1;
}

.score-grade {
    font-size: 0.9em;
    font-weight: bold;
    color: #666;
    line-height: 1;
}

.score-description h4 {
    margin: 0 0 8px 0;
    color: #333;
    font-size: 1.1em;
}

.score-description p {
    margin: 4px 0;
    color: #666;
    font-size: 0.95em;
}

.activity-level {
    font-weight: bold;
    font-size: 0.9em;
}

.permits-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 15px;
    margin-bottom: 20px;
}

/* permit-stat-card removed - unused */

.stat-number {
    font-size: 1.8em;
    font-weight: bold;
    margin-bottom: 5px;
    display: block;
}

.stat-label {
    font-size: 0.9em;
    color: #666;
    margin-bottom: 3px;
}

.stat-percentage {
    font-size: 0.8em;
    color: #999;
    font-style: italic;
}

.yearly-trend {
    background: var(--surface);
    padding: 15px;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.yearly-trend h4 {
    margin: 0 0 10px 0;
    color: #333;
    font-size: 1em;
}

.trend-indicator {
    display: flex;
    align-items: center;
    gap: 10px;
}

.trend-arrow {
    font-size: 1.2em;
    font-weight: bold;
}

.trend-arrow.up {
    color: #28a745;
}

.trend-arrow.down {
    color: #dc3545;
}

.trend-arrow.stable {
    color: #6c757d;
}

.trend-text {
    font-weight: 500;
    color: #333;
}

.trend-percentage {
    font-weight: bold;
    color: #ff8c00;
}

.permits-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 15px;
    padding: 20px;
}

.permit-card {
    border-left: 4px solid #ff8c00;
}

/* Permit card hover uses result-card base styling */

.permit-card.selected {
    background-color: #fff3e0;
    border-left-color: #ff0000;
    border-left-width: 6px;
    box-shadow: 0 4px 15px rgba(255, 0, 0, 0.3);
    transform: translateY(-2px);
}

.permit-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid #f0f0f0;
}

.permit-type {
    background-color: #ff8c00;
    color: white;
    padding: 4px 8px;
    border-radius: 15px;
    font-size: 0.8em;
    font-weight: 500;
}

.permit-date {
    font-size: 0.85em;
    color: #666;
    font-weight: 500;
}

.permit-details {
    color: #333;
}

.permit-address {
    margin: 0 0 8px 0;
    font-size: 0.95em;
}

.permit-nature {
    margin: 0 0 10px 0;
    font-size: 0.9em;
    color: #666;
    font-style: italic;
}

.permit-status {
    margin: 10px 0;
}

.status-badge {
    display: inline-block;
    padding: 3px 8px;
    border-radius: 12px;
    font-size: 0.8em;
    color: white;
    font-weight: 500;
}

.permit-metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 10px 0;
}

.metric {
    background: #f8f9fa;
    padding: 3px 6px;
    border-radius: 8px;
    font-size: 0.8em;
    color: #666;
    border: 1px solid #e9ecef;
}

.cadastral-ref {
    margin: 8px 0 0 0;
    font-size: 0.8em;
    color: #999;
    font-family: monospace;
}

.error-content {
    color: #ff949f;
    display: flex;
    justify-content: center;
}

/* Mobile responsiveness for Sitadel */
@media (max-width: 768px) {
    .construction-score-card {
        flex-direction: column;
        text-align: center;
        gap: 15px;
    }
    
    .permits-stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .permits-grid {
        grid-template-columns: 1fr;
        padding: 10px;
    }
    
    .permit-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        margin-bottom: 12px;
        padding-bottom: 6px;
    }
    
    /* Water section responsive */
    .water-summary-card {
        flex-direction: column;
    }
    
    .summary-stats {
        grid-template-columns: 1fr;
    }
    
    .network-details {
        grid-template-columns: 1fr;
    }
    
    .parameters-grid {
        grid-template-columns: 1fr;
    }
    
    .sample-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
    
    .sample-info {
        flex-direction: column;
        gap: 5px;
    }
}

/* Map container styles */
#dvf-map-leaflet.measure-active .leaflet-interactive,
#dvf-map-leaflet.measure-active .leaflet-marker-icon,
#dvf-map-leaflet.measure-active .leaflet-marker-shadow {
    pointer-events: none !important;
}

#dvf-map-leaflet.measure-active .leaflet-popup-pane,
#dvf-map-leaflet.measure-active .leaflet-tooltip-pane,
#dvf-map-leaflet.measure-active .leaflet-overlay-pane {
    pointer-events: none !important;
}

.map-container {
    height: clamp(320px, 50vh, 520px);
    width: 100%;
}

.map-context-menu {
    position: fixed;
    display: none;
    flex-direction: column;
    gap: 8px;
    min-width: 220px;
    max-width: 280px;
    padding: 12px 14px;
    background: none;
    color: var(--text-primary, #111827);
    z-index: 3000;
}

.map-context-menu.is-visible {
    display: flex;
}

.map-context-menu__action {
    width: 100%;
    border: 1px solid transparent;
    border-radius: 10px;
    padding: 11px 18px;
    font-weight: 600;
    font-size: 0.95rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    line-height: 1.4;
    letter-spacing: 0.01em;
    color: #ffffff;
    background: linear-gradient(135deg, var(--primary, #1d4ed8), var(--primary-strong, #1e3a8a));
    box-shadow: 0 12px 30px rgba(29, 78, 216, 0.35);
    transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

.map-context-menu__action:hover,
.map-context-menu__action:focus-visible {
    filter: brightness(1.05);
    transform: translateY(-1px);
    box-shadow: 0 16px 34px rgba(30, 64, 175, 0.32);
}

.map-context-menu__action:disabled {
    opacity: 0.7;
    cursor: wait;
    transform: none;
    box-shadow: none;
}

.map-context-menu__action:focus-visible {
    outline: 3px solid rgba(191, 219, 254, 0.9);
    outline-offset: 2px;
}

.map-context-menu__status {
    font-size: 0.9rem;
    color: var(--text-secondary, #4b5563);
    line-height: 1.4;
    display: none;
}

.map-context-menu__status.is-visible {
    display: block;
}

@media (max-width: 640px) {
    .map-context-menu {
        min-width: 200px;
        max-width: 240px;
        padding: 12px;
    }

    .map-context-menu__action {
        font-size: 0.9rem;
        padding: 10px 15px;
    }
}

.map-context-menu__action-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    background: rgba(255, 255, 255, 0.16);
    border-radius: 50%;
    box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.18);
}

.map-context-menu__action-icon svg {
    width: 14px;
    height: 14px;
    display: block;
}

.map-context-menu__action-label {
    flex: 1;
    text-align: left;
}

@media (prefers-reduced-motion: reduce) {
    .map-context-menu__action {
        transition: none;
    }

    .map-context-menu__action:hover,
    .map-context-menu__action:focus-visible {
        transform: none;
    }
}

/* Sticky map positioning */
.map-section.sticky-top {
    position: sticky;
    top: 10px;
    z-index: 1000;
}

.map-section.sticky-top .map-container {
    border-radius: var(--border-radius);
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
    border: 2px solid var(--primary);
    background: var(--surface);
}

/* Fullscreen toggle button style */
.leaflet-control-custom {
    background: var(--surface);
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    margin: 0;
    padding: 0;
    border: none;
}

/* Utility classes */
.hidden {
    display: none;
}

/* Improved focus styles for accessibility */
.search-input:focus,
.search-button:focus {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

/* Improved mobile touch targets */
@media (max-width: 480px) {
    .search-button {
        min-height: 48px;
        touch-action: manipulation;
    }
    
    .autocomplete-item {
        min-height: 48px;
        display: flex;
        align-items: center;
    }
}

/* Screen reader only content */
.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;
}

/* ========== COMMON RESULT COMPONENTS ========== */

/* Base card style for all result cards */
.result-card {
    background: rgba(255, 255, 255, 0.95);
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 12px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    border: 1px solid rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
    cursor: pointer;
}

.result-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
    border-color: var(--accent);
}

.result-card.selected {
    border-color: var(--accent);
    box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.2);
    background: rgba(0, 123, 255, 0.05);
}

.summary-overview {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.summary-grid {
    display: flex;
    gap: 12px;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
}

.summary-overview-block {
    margin: 20px 0 32px;
}

.summary-ai {
    background: rgba(15, 118, 110, 0.05);
    border: 1px solid rgba(15, 118, 110, 0.2);
    border-radius: 10px;
    padding: 25px;
    color: #ffffff;
    font-size: 1rem;
}

.summary-ai p {
    margin: 0 0 6px;
}

.summary-ai p:last-child {
    margin-bottom: 0;
}

.summary-card {
    cursor: default;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
    border-color: rgba(0, 0, 0, 0.08);
}

.summary-card:hover {
    transform: none;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
    border-color: rgba(0, 0, 0, 0.12);
}

.summary-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 6px;
}

.summary-label {
    margin: 0;
    font-size: 0.95rem;
    color: #1f2937;
}

.summary-value {
    margin: 0;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--accent-deep);
}

.summary-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    border: 1px solid transparent;
    color: #1f2937;
    background: rgba(15, 23, 42, 0.06);
    white-space: nowrap;
}

.summary-badge::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: currentColor;
    opacity: 0.9;
}

.summary-badge-positive {
    background: rgba(34, 197, 94, 0.18);
    border-color: rgba(34, 197, 94, 0.35);
    color: #047857;
}

.summary-badge-neutral {
    background: rgba(148, 163, 184, 0.18);
    border-color: rgba(148, 163, 184, 0.35);
    color: #475569;
}

.summary-badge-warning {
    background: rgba(250, 204, 21, 0.2);
    border-color: rgba(250, 204, 21, 0.38);
    color: #92400e;
}

.summary-badge-critical {
    background: rgba(248, 113, 113, 0.2);
    border-color: rgba(248, 113, 113, 0.42);
    color: #b91c1c;
}

.summary-badge-info {
    background: rgba(59, 130, 246, 0.18);
    border-color: rgba(59, 130, 246, 0.36);
    color: #1d4ed8;
}

.summary-detail {
    margin: 6px 0 0;
    color: #4b5563;
    font-size: 0.9rem;
}

.summary-notes {
    margin: 4px 0 0 1.2rem;
    padding: 0;
    color: #4b5563;
    font-size: 0.9rem;
}

.summary-notes li {
    margin-bottom: 4px;
}

/* Base section style for all result sections */
.result-section {
    background: rgba(255, 255, 255, 0.95);
    border-radius: 15px;
    margin-bottom: 25px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    overflow: hidden;
}

/* Common header styles */
.result-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

/* Common stat card styles */
.stat-card-base {
    padding: 20px;
    border-radius: 12px;
    text-align: center;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.stat-card-base:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

/* Common grid layouts */
.result-grid-2 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 16px;
}

.result-grid-3 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
}

.result-grid-4 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
}

/* Common metric displays */
.metric-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin: 8px 0;
}

.metric-item {
    background: rgba(0, 0, 0, 0.05);
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 0.9em;
    font-weight: 500;
}

/* Common price/number formatting */
.price-display {
    font-size: 1.4em;
    font-weight: 700;
    color: #2d5aa0;
}

.number-highlight {
    font-weight: 600;
    color: #007bff;
}

/* Common status badges */
.status-badge {
    padding: 4px 10px;
    border-radius: 15px;
    font-size: 0.8em;
    font-weight: 600;
    color: white;
}

/* ========== WATER QUALITY SECTION ========== */
.water-section {
    margin: 20px 0;
}

.water-summary-card {
    display: flex;
    gap: 20px;
    margin-bottom: 20px;
    padding: 20px;
    background: var(--surface);
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.quality-score {
    min-width: 120px;
    border-radius: 10px;
    padding: 20px;
    text-align: center;
    color: white;
    text-shadow: 0 3px 6px rgba(15,23,42,0.55);
}

.score-number {
    font-size: 2.5em;
    font-weight: bold;
    line-height: 1;
    text-shadow: 0 4px 8px rgba(15,23,42,0.6);
}

.score-grade {
    font-size: 1.2em;
    font-weight: bold;
    margin: 5px 0;
    text-shadow: 0 3px 6px rgba(15,23,42,0.55);
}

.score-label {
    font-size: 0.9em;
    opacity: 0.9;
    text-shadow: 0 2px 4px rgba(15,23,42,0.5);
}

.summary-stats {
    flex: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

.stat-item {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.stat-label {
    font-size: 0.9em;
    color: #666;
}

.stat-value {
    font-size: 1.2em;
    font-weight: bold;
    color: #333;
}

/* ========== AIR QUALITY SECTION ========== */
.air-quality-section {
    margin: 20px 0;
}



.aq-summary-note {
    margin: 0;
    font-size: 0.85rem;
    color: #6b7280;
}

.aq-summary-warning {
    color: #b45309;
    font-weight: 500;
}

.aq-measurements h4 {
    margin-bottom: 12px;
}

.aq-measurements-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
}

.aq-measurement-card {
    background: #fff;
    border: 1px solid var(--gray-300);
    border-radius: 10px;
    padding: 16px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.aq-measurement-card--far {
    background: #f3f4f6;
    border-color: var(--gray-400);
}

.aq-measurement-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.aq-pollutant {
    font-weight: 600;
    font-size: 1rem;
}

.aq-severity-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 8px;
    border-radius: 999px;
    font-size: 0.75rem;
    color: #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,0.12);
}

.aq-value-row {
    display: flex;
    align-items: baseline;
    gap: 8px;
}

.aq-value {
    font-size: 1.2rem;
    font-weight: 600;
}

.aq-distance {
    font-size: 0.85rem;
    color: #6b7280;
}

.aq-distance-alert {
    font-size: 0.8rem;
    color: #4b5563;
    background: rgba(107,114,128,0.15);
    padding: 4px 8px;
    border-radius: 999px;
    width: fit-content;
}

.aq-station {
    font-size: 0.95rem;
    color: #374151;
}

.aq-period {
    font-size: 0.85rem;
    color: #6b7280;
}

.aq-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    font-size: 0.75rem;
    color: #4b5563;
}

.aq-meta-item {
    background: #eef2f7;
    padding: 4px 8px;
    border-radius: 999px;
}

.aq-metrics {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 0.8rem;
    color: #4b5563;
}

.aq-metric strong {
    color: #111827;
}

.no-air-quality-data {
    margin: 16px 0;
    font-size: 0.95rem;
    color: #6b7280;
}

.aq-popup {
    font-size: 0.9rem;
    line-height: 1.4;
}

.aq-popup-info {
    font-size: 0.75rem;
    color: #6b7280;
}




.network-info {
    background: #f8f9fa;
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 20px;
}

.network-info h4 {
    margin: 0 0 10px 0;
    color: #333;
}

.network-details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 10px;
}

.network-item {
    display: flex;
    gap: 10px;
}

.network-label {
    font-weight: bold;
    color: #555;
}

.network-value {
    color: #333;
}

.recent-samples h4 {
    margin: 0 0 15px 0;
    color: #333;
}

.sample-card {
    background: var(--surface);
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 15px;
}

.sample-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.sample-date {
    font-weight: bold;
    font-size: 1.1em;
    color: #333;
}

.compliance-badge {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    border-radius: 20px;
    color: white;
    font-size: 0.9em;
    font-weight: bold;
}

.sample-info {
    display: flex;
    gap: 20px;
    margin-bottom: 10px;
    font-size: 0.9em;
    color: #666;
}

.sample-conclusion {
    background: #f0f8f0;
    padding: 10px;
    border-radius: 5px;
    margin: 10px 0;
    font-size: 0.9em;
    line-height: 1.4;
}

.key-parameters h5 {
    margin: 15px 0 10px 0;
    color: #333;
}

.parameters-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 10px;
}

.parameter-item {
    background: #fafafa;
    padding: 10px;
    border-radius: 5px;
    border-left: 3px solid #007bff;
}

.parameter-name {
    font-size: 0.85em;
    color: #555;
    margin-bottom: 3px;
}

.parameter-value {
    font-weight: bold;
    font-size: 1.1em;
}

.parameter-unit {
    font-size: 0.9em;
    color: #666;
    margin-left: 5px;
}

.parameter-reference {
    font-size: 0.8em;
    color: #888;
    margin-top: 3px;
}

.quality-confidence {
    background: #e8f4f8;
    padding: 10px;
    border-radius: 5px;
    text-align: center;
    font-size: 0.9em;
    margin-top: 20px;
}

.confidence-label {
    font-weight: bold;
    color: #555;
}

.confidence-value {
    font-weight: bold;
    color: #007bff;
    margin: 0 5px;
}

.rent-section {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.rent-summary-card {
    background: var(--surface);
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.08);
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.rent-summary-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.rent-summary-header h4 {
    margin: 0;
    font-size: 1.4em;
    color: #1f2937;
}

.rent-subtitle {
    margin: 4px 0 0 0;
    color: #6b7280;
    font-size: 0.9em;
}

.rent-badge {
    background: #1d4ed8;
    color: white;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 0.85em;
    font-weight: 600;
    line-height: 1.3;
}

.rent-table-label {
    display: none;
}

.rent-table-value {
    display: inline;
}

@media (max-width: 600px) {
    .rent-summary-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .rent-badge {
        align-self: stretch;
        text-align: center;
    }
}

.rent-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
}

.rent-summary-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 12px;
    border-radius: 8px;
    background: #f9fafb;
    justify-content: space-between;
}

.rent-zone-highlight {
    background: #edf2ff;
    border: 1px solid #c7d2fe;
    border-radius: 12px;
    padding: 18px;
    box-shadow: 0 1px 6px rgba(59, 130, 246, 0.08);
}

.rent-zone-header {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 12px;
}

.rent-zone-header h5 {
    margin: 0;
    font-size: 1.1em;
    color: #1d4ed8;
}

.rent-zone-cities {
    margin: 0;
    font-size: 0.85em;
    color: #374151;
}

.rent-zone-grid .rent-summary-item {
    background: #ffffff;
    border: 1px solid rgba(59, 130, 246, 0.15);
}

.rent-label {
    font-size: 0.85em;
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.rent-value {
    font-size: 1.3em;
    font-weight: 600;
    color: #1f2937;
}

.rent-breakdowns {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.rent-breakdown h5 {
    margin: 0 0 12px 0;
    font-size: 1.1em;
    color: #1f2937;
}

.rent-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--surface);
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.rent-table th,
.rent-table td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid #e5e7eb;
    font-size: 0.95em;
}

.rent-table th {
    background: #f3f4f6;
    font-weight: 600;
    color: #374151;
    text-transform: uppercase;
    font-size: 0.8em;
    letter-spacing: 0.04em;
}

.rent-table tr:last-child td {
    border-bottom: none;
}

.rent-table tr.is-selected {
    background: rgba(59, 130, 246, 0.12);
    font-weight: 600;
}

.rent-table tr.is-selected td {
    border-bottom-color: rgba(59, 130, 246, 0.25);
}

@media (max-width: 768px) {
    .rent-table {
        border-radius: 0;
        box-shadow: none;
        background: transparent;
    }

    .rent-table thead {
        position: absolute;
        top: 0;
        left: 0;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: 0;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        clip-path: inset(100%);
        white-space: nowrap;
        border: 0;
    }

    .rent-table tbody {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }

    .rent-table tr {
        display: block;
        background: var(--surface);
        border-radius: 12px;
        border: 1px solid #e5e7eb;
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
        overflow: hidden;
    }

    .rent-table tr.is-selected {
        border-color: rgba(59, 130, 246, 0.35);
        box-shadow: 0 2px 10px rgba(59, 130, 246, 0.15);
    }

    .rent-table tr:last-child td {
        border-bottom: 1px solid #e5e7eb;
    }

    .rent-table td {
        display: block;
        width: 100%;
        padding: 14px 16px;
        border-bottom: 1px solid #e5e7eb;
        font-size: 0.95em;
    }

    .rent-table td:last-child {
        border-bottom: none;
    }

    .rent-table-label {
        display: block;
        margin-bottom: 6px;
        font-size: 0.75em;
        font-weight: 600;
        color: #6b7280;
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }

    .rent-table-value {
        display: block;
        font-size: 1.05em;
        color: #1f2937;
    }

    .rent-table td[data-label="Zone"] .rent-table-value,
    .rent-table td[data-label="Type"] .rent-table-value,
    .rent-table td[data-label="Typologie"] .rent-table-value {
        font-weight: 600;
    }
}

.rent-methodology {
    font-size: 0.85em;
    color: #6b7280;
    margin: 0;
}

.rent-empty {
    padding: 16px;
    background: #fef2f2;
    border: 1px solid #fee2e2;
    border-radius: 8px;
    color: #991b1b;
}

.confidence-detail {
    color: #666;
}

.no-water-data {
    text-align: center;
    padding: 20px;
    color: #666;
}

/* ========== 404 ERROR PAGE ========== */
.error-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 80vh;
    text-align: center;
    padding: 2rem;
}

.error-code {
    font-size: 8rem;
    font-weight: bold;
    color: #e74c3c;
    margin: 0;
    line-height: 1;
}

.error-message {
    font-size: 1.5rem;
    color: #adb6c0;
    margin: 1rem 0;
}

.error-description {
    font-size: 1rem;
    color: #7f8c8d;
    margin-bottom: 2rem;
    max-width: 500px;
}

.back-button {
    display: inline-block;
    padding: 12px 24px;
    background-color: #d0ecff;
    color: white;
    text-decoration: none;
    border-radius: 5px;
    font-weight: 500;
    transition: background-color 0.3s;
}

.back-button:hover {
    background-color: #2980b9;
    color: white;
}

.suggestions {
    margin-top: 2rem;
    text-align: left;
}

.suggestions h3 {
    color: #2c3e50;
    margin-bottom: 1rem;
}

.suggestions ul {
    list-style: none;
    padding: 0;
}

.suggestions li {
    margin: 0.5rem 0;
}

.suggestions a {
    color: #3498db;
    text-decoration: none;
}

.suggestions a:hover {
    text-decoration: underline;
}

/* ========== PARCELLE FILTER MODAL ========== */
.filter-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    backdrop-filter: blur(4px);
}

.filter-modal-content {
    background: var(--surface);
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    max-width: 400px;
    width: 90%;
    max-height: 80vh;
    overflow-y: auto;
    animation: modalSlideIn 0.3s ease;
}

@keyframes modalSlideIn {
    from {
        opacity: 0;
        transform: scale(0.8) translateY(-50px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.filter-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    border-bottom: 1px solid #e9ecef;
    background: linear-gradient(135deg, #f8f9fa, #e9ecef);
    border-radius: 12px 12px 0 0;
}

.filter-modal-header h4 {
    margin: 0;
    color: #333;
    font-size: 1.2em;
    font-weight: 600;
}

.filter-modal-close {
    background: none;
    border: none;
    font-size: 1.5em;
    cursor: pointer;
    color: #666;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.2s;
}

.filter-modal-close:hover {
    background-color: #f8f9fa;
    color: #333;
}

.filter-modal-body {
    padding: 24px;
}

.filter-modal-body p {
    margin: 8px 0;
    color: #666;
    font-size: 0.95em;
}

.filter-actions {
    display: flex;
    gap: 12px;
    margin-top: 20px;
    justify-content: flex-end;
}

.filter-btn {
    padding: 10px 20px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.2s;
    min-width: 100px;
}

.filter-btn.primary {
    background: linear-gradient(135deg, var(--accent), var(--accent-hover));
    color: white;
    box-shadow: 0 2px 8px rgba(0, 123, 255, 0.3);
}

.filter-btn.primary:hover {
    background: linear-gradient(135deg, var(--accent-hover), var(--accent-deep));
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 123, 255, 0.4);
}

.filter-btn.secondary {
    background: #f8f9fa;
    color: #666;
    border: 1px solid #dee2e6;
}

.filter-btn.secondary:hover {
    background: #e9ecef;
    color: #333;
}

/* Clear filter button */
.clear-filter-btn {
    background: #dc3545;
    color: white;
    border: none;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.75em;
    cursor: pointer;
    margin-left: 10px;
    transition: all 0.2s;
}

.clear-filter-btn:hover {
    background: #c82333;
    transform: translateY(-1px);
}

/* Fullscreen-mode modal: allow scrolling and larger text */
/* When modal is displayed inside a fullscreen element */
.filter-modal.in-fullscreen {
    align-items: flex-start;
    padding-top: 20px;
}

.filter-modal.in-fullscreen .filter-modal-content {
    max-width: 600px;
    max-height: 90vh;
    font-size: 1.1rem;
    overflow-y: auto;
}

.filter-modal.in-fullscreen .filter-modal-body p {
    font-size: 1rem;
}

/* Popup "voir plus" button styles */
.voir-plus-btn {
    background: linear-gradient(135deg, var(--accent), var(--accent-hover));
    color: white;
    border: none;
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 12px;
    cursor: pointer;
    font-weight: 500;
    transition: all 0.2s;
    box-shadow: 0 2px 4px rgba(0, 123, 255, 0.3);
}

.voir-plus-btn:hover {
    background: linear-gradient(135deg, var(--accent-hover), var(--accent-deep));
    transform: translateY(-1px);
    box-shadow: 0 3px 8px rgba(0, 123, 255, 0.4);
}

/* Popup container styles */
.parcelle-popup,
.permit-popup {
    font-size: 13px;
    line-height: 1.4;
    max-width: 250px;
}

.parcelle-popup strong,
.permit-popup strong {
    color: #333;
    font-size: 14px;
}

/* Modal content sections */
.parcelle-info,
.permit-info {
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 1px solid #e9ecef;
}

.parcelle-actions,
.permit-actions {
    text-align: center;
}

.parcelle-actions h5,
.permit-actions h5 {
    margin: 0 0 15px 0;
    color: #495057;
    font-size: 1em;
    font-weight: 600;
}

.action-buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 15px;
}

.close-actions {
    padding-top: 10px;
    border-top: 1px solid #f1f3f4;
}

/* Modal sections for parcelle details */
.modal-section {
    margin: 20px 0;
    padding: 15px;
    background: #f8f9fa;
    border-radius: 8px;
}

.modal-section h5 {
    margin: 0 0 15px 0;
    color: #495057;
    font-size: 1.1em;
    font-weight: 600;
}

.transaction-item, .permit-item {
    background: #fff;
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    border-left: 3px solid #6692c094;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.transaction-item:hover, .permit-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.permit-item {
    border-left-color: #ff8c00;
}

.transaction-item:last-child, .permit-item:last-child {
    margin-bottom: 0;
}

.transaction-price, .permit-number {
    font-weight: 700;
    color: #007bff;
    font-size: 1.3em;
    margin-bottom: 8px;
    display: block;
}

.permit-item .permit-number {
    color: #ff8c00;
    font-size: 1.1em;
}

.transaction-details, .permit-details {
    color: #495057;
    line-height: 1.5;
}

.transaction-details p, .permit-details p {
    margin: 6px 0;
    font-size: 0.9em;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.transaction-details strong, .permit-details strong {
    color: #343a40;
    font-weight: 600;
    min-width: fit-content;
}

.transaction-details small, .permit-details small {
    display: block;
    line-height: 1.3;
    color: #6c757d;
    font-size: 0.85em;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid #e9ecef;
}

/* Mobile responsiveness */
@media (max-width: 768px) {
    .transaction-item, .permit-item {
        padding: 12px;
        margin-bottom: 10px;
        border-radius: 6px;
    }
    
    .transaction-price, .permit-number {
        font-size: 1.2em;
        margin-bottom: 6px;
    }
    
    .transaction-details p, .permit-details p {
        flex-direction: column;
        align-items: flex-start;
        gap: 2px;
        margin: 4px 0;
    }
    
    .transaction-details strong, .permit-details strong {
        font-size: 0.85em;
        margin-bottom: 2px;
    }
    
    .transaction-details, .permit-details {
        font-size: 0.85em;
    }
}

@media (max-width: 480px) {
    .transaction-item, .permit-item {
        padding: 10px;
        margin-bottom: 8px;
        border-left-width: 3px;
    }
    
    .transaction-price, .permit-number {
        font-size: 1.1em;
    }
    
    .transaction-details p, .permit-details p {
        margin: 3px 0;
    }
    
    .transaction-details, .permit-details {
        font-size: 0.8em;
    }
}

/* Data warning style */
.data-warning {
    color: #ff8c00;
    font-weight: 500;
    font-style: italic;
}

.summary-section {
    border-radius: var(--border-radius);
    margin: 0;
    padding: 0;
    box-shadow: var(--shadow);
}

.summary-section p {
    margin: 0 0 12px 0;
    line-height: 1.6;
}

.summary-section p:last-child {
    margin-bottom: 0;
}

.summary-loading {
    text-align: center;
    color: var(--secondary);
    font-style: italic;
    padding: 10px;
}

.results-header {
    text-align: center;
    color: var(--hero-fg);
}

.results-header > h1 {
    font-size: larger;
}

/* FDep socio-economic section */
.fdep-section {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.fdep-summary {
  background: rgba(255, 255, 255, 0.85);
  border-radius: 12px;
  padding: 18px;
  box-shadow: var(--shadow);
  border: 1px solid rgba(0, 0, 0, 0.08);
}

.fdep-summary-main {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 24px;
}

.fdep-score {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  font-weight: 700;
  width: 50%
}

.fdep-score-value {
  font-size: 2.4rem;
  line-height: 1;
}

.fdep-score-label {
  font-size: 0.85rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--gray-600);
}

.fdep-summary-text {
  display: flex;
  flex-direction: column;
  gap: 8px;
  color: var(--text);
  flex: 1 1 auto;
  min-width: 0;
}

.fdep-category {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #fff;
  font-weight: 600;
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 0.9rem;
  box-shadow: var(--shadow-sm);
}

.fdep-percentile {
  font-weight: 500;
  color: var(--gray-700);
}

.fdep-description {
  margin: 0;
  font-size: 0.95rem;
  color: var(--gray-700);
}

.fdep-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 0.85rem;
  color: var(--gray-600);
}

.fdep-components h4,
.fdep-extremes h4 {
  margin: 0 0 12px 0;
  color: var(--text);
}

.fdep-components-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
}

.fdep-component {
  background: rgba(255, 255, 255, 0.75);
  border-radius: 10px;
  padding: 14px;
  border: 1px solid rgba(0, 0, 0, 0.05);
  box-shadow: var(--shadow-sm);
}

.fdep-component-label {
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
}

.fdep-component-value {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--primary);
}

.fdep-component-hint {
  font-size: 0.85rem;
  color: var(--gray-600);
  margin-top: 6px;
}

.fdep-extreme-cards {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

.fdep-extreme-card {
  flex: 1 1 260px;
  background: rgba(255, 255, 255, 0.75);
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.05);
  padding: 16px;
  box-shadow: var(--shadow-sm);
}

.fdep-extreme-title {
  font-weight: 700;
  margin-bottom: 6px;
  color: var(--text);
}

.fdep-extreme-label {
  font-weight: 500;
  margin-bottom: 4px;
  color: var(--gray-700);
}

.fdep-extreme-score {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--primary);
}

.fdep-extreme-category {
  font-size: 0.85rem;
  color: var(--gray-600);
  margin-left: 6px;
}

.fdep-extreme-population {
  font-size: 0.85rem;
  color: var(--gray-600);
  margin-top: 6px;
}

.fdep-ranking {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

.fdep-ranking-column {
  flex: 1 1 260px;
  background: rgba(255, 255, 255, 0.75);
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.05);
  box-shadow: var(--shadow-sm);
  padding: 16px;
}

.fdep-ranking-column h5 {
  margin: 0 0 10px 0;
  color: var(--text);
}

.fdep-ranking-column ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.fdep-ranking-column li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.95rem;
  color: var(--text);
}

.fdep-ranking-label {
  font-weight: 500;
}

.fdep-ranking-score {
  font-weight: 700;
  color: var(--primary);
}

.fdep-empty {
  background: rgba(255, 255, 255, 0.6);
  border-radius: 10px;
  padding: 16px;
  color: var(--gray-600);
  text-align: center;
  border: 1px dashed var(--gray-300);
}

@media (max-width: 640px) {
  .fdep-summary-main {
    flex-direction: column;
    align-items: flex-start;
  }

  .fdep-meta {
    flex-direction: column;
    gap: 4px;
  }

  .fdep-components-grid {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  }

  .fdep-ranking {
    flex-direction: column;
  }
}

@media (min-width: 1024px) {
  .fdep-summary-main {
    flex-wrap: nowrap;
    align-items: stretch;
  }

  .fdep-score {
    width: auto;
    min-width: 220px;
    flex: 0 0 240px;
  }
}

.footer-nearby-list {
    list-style: none;
    padding: 0;
}

.footer-nearby-list li {
    margin: 10px 0px;
}

.account-badge-floating {
  position: fixed;
  z-index: 1200;
  pointer-events: none;
  right: 10px;
  top: 10px;
}

.account-badge-floating .account-badge {
  pointer-events: auto;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 1rem;
  background: rgba(13, 27, 45, 0.9);
  border-radius: 18px;
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.28);
  color: #e2e8f0;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  position: relative;
  flex-wrap: nowrap;
  flex-direction: column;
}

.account-badge__meta {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.account-badge__label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #94a3b8;
}

.account-badge__email {
  font-weight: 600;
  font-size: 0.95rem;
}

.account-badge__status {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 0 0 auto;
}

.account-badge__caption {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #94a3b8;
}

.account-badge__value {
  font-size: 1.6rem;
  font-weight: 600;
}

.account-badge__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.55rem 1.15rem;
  border-radius: 999px;
  background: #283163;
  color: #f8fafc;
  text-decoration: none;
  font-weight: 600;
  transition: filter var(--transition-fast), background var(--transition);
}

.account-badge__cta:hover {
  filter: hue-rotate(-50deg);
}

.account-badge__cta--secondary {
  background: transparent;
  color: #93c5fd;
  border: 1px solid rgba(147, 197, 253, 0.6);
  box-shadow: none;
}

.account-badge__hint {
  margin: 0;
  color: #cbd5f5;
  font-size: 0.88rem;
  max-width: 240px;
}

.account-badge__actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex: 0 0 auto;
}

.account-badge__meta--guest {
  gap: 0.4rem;
}

.account-badge--loading {
  color: #94a3b8;
  font-size: 0.85rem;
}

@media (max-width: 768px) {
  .account-badge-floating {
    position: static;
  }

  .account-badge-floating .account-badge {
    flex-direction: row;
    border-radius: 0;
    width: 100vw;
    height: 100%;
    justify-content: space-evenly;
  }

  .account-badge__actions {
    flex-direction: column;
    justify-content: center;
  }

.account-badge__cta {
    /*  */
  }
}
.transaction-header .dependency-indicator, .transaction-header .merged-indicator {
  font-size: 0.9em;
  opacity: .9;
  margin-left: 6px;
}

@media (max-width: 520px) {
  .transactions-grid { gap: 14px; }
  .transactions-grid .transaction-card { padding: 16px; }
  .transaction-header { gap: 8px; }
  .transaction-price { font-size: 1.22em; }
  .surface-info .metric, .price-metrics .price-per-m2, .price-metrics .price-per-m2-built { font-size: 0.76em; }
}

.credit-confirm-backdrop {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  background: rgba(8, 12, 24, 0.75);
  backdrop-filter: blur(10px);
  z-index: 1400;
}

.credit-confirm-backdrop.is-open {
  display: flex;
}

body.credit-confirm-open {
  overflow: hidden;
}

.credit-confirm-modal {
  width: min(460px, 100%);
  border-radius: 18px;
  border: 1px solid rgba(99, 102, 241, 0.38);
  background: linear-gradient(155deg, rgba(12, 18, 38, 0.95), rgba(9, 13, 26, 0.98));
  color: #f8fafc;
  box-shadow: 0 32px 70px rgba(4, 9, 24, 0.55);
  padding: 1.8rem;
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}

.credit-confirm-modal h3 {
  margin: 0;
  font-size: 1.35rem;
}

.credit-confirm-modal p {
  margin: 0;
  line-height: 1.6;
  color: rgba(226, 232, 255, 0.78);
}

.credit-confirm-modal strong {
  color: #f8fafc;
}

.credit-confirm-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: flex-end;
}

.credit-confirm-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 0.65rem 1.2rem;
  font-weight: 600;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: transform 120ms ease, box-shadow 120ms ease, background-color 120ms ease;
}

.credit-confirm-button:focus-visible {
  outline: 3px solid rgba(129, 140, 248, 0.5);
  outline-offset: 2px;
}

.credit-confirm-button--primary {
  background: linear-gradient(135deg, #4c6fff, #2650ee);
  color: #ffffff;
  box-shadow: 0 20px 42px rgba(38, 80, 238, 0.35);
}

.credit-confirm-button--primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 26px 48px rgba(38, 80, 238, 0.45);
}

.credit-confirm-button--link {
  background: linear-gradient(135deg, #22c55e, #16a34a);
  color: #ffffff;
  border: 1px solid rgba(34, 197, 94, 0.45);
  box-shadow: 0 20px 40px rgba(34, 197, 94, 0.35);
}

.credit-confirm-button--link:hover {
  transform: translateY(-1px);
  box-shadow: 0 26px 48px rgba(34, 197, 94, 0.45);
}

.credit-confirm-button--ghost {
  background: transparent;
  color: #a3b6ff;
  border: 1px solid rgba(129, 140, 248, 0.45);
}

.credit-confirm-button--ghost:hover {
  transform: translateY(-1px);
  background: rgba(129, 140, 248, 0.12);
}

.credit-confirm-modal[data-mode='insufficient'] .credit-confirm-button--primary,
.credit-confirm-modal[data-mode='insufficient'] .credit-confirm-button--ghost {
  display: none;
}

.credit-confirm-modal[data-mode='insufficient'] .credit-confirm-button--link {
  flex: 1 1 100%;
  justify-content: center;
}

@media (max-width: 520px) {
  .credit-confirm-modal {
    padding: 1.4rem;
  }

  .credit-confirm-actions {
    width: 100%;
    justify-content: stretch;
  }

  .credit-confirm-button {
    flex: 1 1 100%;
  }
}
