/* =====================================================
   ALTO PIEMONTE — ALPINE WINE ATLAS
   Art direction: rich editorial, earthy volcanic reds,
   aged parchment, mineral slate — Cormorant serif +
   DM Sans sans-serif. Dark alpine feel with warm accents.
   ===================================================== */

/* ---- TOKENS ---- */
:root,
[data-theme='light'] {
  /* Type */
  --text-xs:   clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem, 1.2rem + 2.5vw, 3.5rem);
  --text-3xl:  clamp(2.5rem, 1rem + 4vw, 5rem);

  /* Spacing */
  --sp-1: 0.25rem; --sp-2: 0.5rem; --sp-3: 0.75rem;
  --sp-4: 1rem;    --sp-5: 1.25rem; --sp-6: 1.5rem;
  --sp-8: 2rem;    --sp-10: 2.5rem; --sp-12: 3rem;
  --sp-16: 4rem;   --sp-20: 5rem;   --sp-24: 6rem;

  /* Surfaces — parchment / mineral off-white */
  --color-bg:              #F8F5EF;
  --color-surface:         #FAF7F2;
  --color-surface-2:       #FCFBF8;
  --color-surface-offset:  #F2ECE3;
  --color-surface-offset-2:#EDE5D8;
  --color-divider:         #DDD5C6;
  --color-border:          #CEC5B4;

  /* Text */
  --color-text:            #2A2318;
  --color-text-muted:      #7A7060;
  --color-text-faint:      #B8B0A2;
  --color-text-inverse:    #F8F5EF;

  /* Primary — volcanic burgundy / terracotta red */
  --color-primary:         #8B2020;
  --color-primary-hover:   #6E1414;
  --color-primary-active:  #520E0E;
  --color-primary-highlight:#E8D0D0;

  /* Accent gold — DOCG highlight */
  --color-gold:            #C8960C;
  --color-gold-light:      #F0DFA0;

  /* Province colors */
  --color-vercelli:        #8B2020;
  --color-novara:          #4A3060;
  --color-biella:          #1F4E4A;
  --color-turin:           #3A5A2A;

  /* Radii */
  --radius-sm: 0.25rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-full: 9999px;

  /* Transitions */
  --tx: 180ms cubic-bezier(0.16, 1, 0.3, 1);

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(42,35,24,0.08);
  --shadow-md: 0 4px 12px rgba(42,35,24,0.10);
  --shadow-lg: 0 12px 32px rgba(42,35,24,0.14);

  /* Content widths */
  --content-narrow:  640px;
  --content-default: 960px;
  --content-wide:    1260px;

  /* Fonts */
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'DM Sans', system-ui, sans-serif;

  /* Map colors */
  --map-sky-top:      #C8D8E8;
  --map-sky-bottom:   #E8EEF4;
  --map-alpine:       #8090A0;
  --map-terrain-top:  #C0B090;
  --map-terrain-bottom:#D8CCB8;
  --map-novara:       #9090C8;
  --map-river:        #4472A8;
  --map-label:        #2A2318;
  --map-label-sub:    #6A6050;
  --map-text-muted:   #888080;
  --map-border:       #CEC5B4;
  --map-compass-bg:   rgba(248,245,239,0.9);
  --map-compass-text: #2A2318;
  --map-compass-arrow:#8B2020;
  --legend-docg:      #C8960C;
  --legend-doc:       #8090A0;

  /* Appellation fill colors — light */
  --ap-carema:         rgba(58,90,42,0.15);
  --ap-carema-stroke:  #3A5A2A;
  --ap-lessona:        rgba(139,32,32,0.15);
  --ap-lessona-stroke: #8B2020;
  --ap-bramaterra:     rgba(31,78,74,0.15);
  --ap-bramaterra-stroke:#1F4E4A;
  --ap-gattinara:      rgba(200,150,12,0.2);
  --ap-gattinara-stroke:#C8960C;
  --ap-ghemme:         rgba(200,150,12,0.2);
  --ap-ghemme-stroke:  #C8960C;
  --ap-boca:           rgba(74,48,96,0.15);
  --ap-boca-stroke:    #4A3060;
  --ap-colline:        rgba(74,48,96,0.10);
  --ap-colline-stroke: #6A5F9E;
  --ap-fara:           rgba(74,48,96,0.12);
  --ap-fara-stroke:    #4A3060;
  --ap-sizzano:        rgba(74,48,96,0.12);
  --ap-sizzano-stroke: #4A3060;
}

[data-theme='dark'] {
  --color-bg:              #18140E;
  --color-surface:         #1E1A13;
  --color-surface-2:       #231F17;
  --color-surface-offset:  #1A160F;
  --color-surface-offset-2:#201C14;
  --color-divider:         #2E2820;
  --color-border:          #3C352A;
  --color-text:            #D8D0C4;
  --color-text-muted:      #8A8070;
  --color-text-faint:      #5C5448;
  --color-text-inverse:    #18140E;
  --color-primary:         #E05050;
  --color-primary-hover:   #F07070;
  --color-primary-active:  #F89090;
  --color-primary-highlight:#3A1A1A;
  --color-gold:            #E8B030;
  --color-gold-light:      #3A2E10;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.25);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.35);
  --shadow-lg: 0 12px 32px rgba(0,0,0,0.50);

  --map-sky-top:      #1A2530;
  --map-sky-bottom:   #202E3A;
  --map-alpine:       #383C42;
  --map-terrain-top:  #2A2418;
  --map-terrain-bottom:#302A1C;
  --map-novara:       #20202E;
  --map-river:        #2A4060;
  --map-label:        #D8D0C4;
  --map-label-sub:    #9A9080;
  --map-text-muted:   #686060;
  --map-border:       #3C352A;
  --map-compass-bg:   rgba(30,26,19,0.92);
  --map-compass-text: #D8D0C4;
  --map-compass-arrow:#E05050;
  --legend-docg:      #E8B030;
  --legend-doc:       #686060;

  --ap-carema:         rgba(58,90,42,0.30);
  --ap-carema-stroke:  #5A8A40;
  --ap-lessona:        rgba(200,80,80,0.25);
  --ap-lessona-stroke: #E06060;
  --ap-bramaterra:     rgba(40,90,84,0.30);
  --ap-bramaterra-stroke:#4A9A94;
  --ap-gattinara:      rgba(232,176,48,0.25);
  --ap-gattinara-stroke:#E8B030;
  --ap-ghemme:         rgba(232,176,48,0.25);
  --ap-ghemme-stroke:  #E8B030;
  --ap-boca:           rgba(120,100,160,0.30);
  --ap-boca-stroke:    #9A80C8;
  --ap-colline:        rgba(100,90,140,0.20);
  --ap-colline-stroke: #8A7AB0;
  --ap-fara:           rgba(100,90,140,0.22);
  --ap-fara-stroke:    #8A7AB0;
  --ap-sizzano:        rgba(100,90,140,0.22);
  --ap-sizzano-stroke: #8A7AB0;
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --color-bg: #18140E;
    --color-surface: #1E1A13;
    --color-surface-2: #231F17;
    --color-surface-offset: #1A160F;
    --color-surface-offset-2: #201C14;
    --color-divider: #2E2820;
    --color-border: #3C352A;
    --color-text: #D8D0C4;
    --color-text-muted: #8A8070;
    --color-text-faint: #5C5448;
    --color-text-inverse: #18140E;
    --color-primary: #E05050;
    --color-primary-hover: #F07070;
    --color-primary-highlight: #3A1A1A;
    --color-gold: #E8B030;
    --color-gold-light: #3A2E10;
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.25);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.35);
    --shadow-lg: 0 12px 32px rgba(0,0,0,0.50);
    --map-sky-top: #1A2530;
    --map-sky-bottom: #202E3A;
    --map-alpine: #383C42;
    --map-terrain-top: #2A2418;
    --map-terrain-bottom: #302A1C;
    --map-novara: #20202E;
    --map-river: #2A4060;
    --map-label: #D8D0C4;
    --map-label-sub: #9A9080;
    --map-text-muted: #686060;
    --map-border: #3C352A;
    --map-compass-bg: rgba(30,26,19,0.92);
    --map-compass-text: #D8D0C4;
    --map-compass-arrow: #E05050;
    --legend-docg: #E8B030;
    --legend-doc: #686060;
    --ap-carema: rgba(58,90,42,0.30);
    --ap-carema-stroke: #5A8A40;
    --ap-lessona: rgba(200,80,80,0.25);
    --ap-lessona-stroke: #E06060;
    --ap-bramaterra: rgba(40,90,84,0.30);
    --ap-bramaterra-stroke: #4A9A94;
    --ap-gattinara: rgba(232,176,48,0.25);
    --ap-gattinara-stroke: #E8B030;
    --ap-ghemme: rgba(232,176,48,0.25);
    --ap-ghemme-stroke: #E8B030;
    --ap-boca: rgba(120,100,160,0.30);
    --ap-boca-stroke: #9A80C8;
    --ap-colline: rgba(100,90,140,0.20);
    --ap-colline-stroke: #8A7AB0;
    --ap-fara: rgba(100,90,140,0.22);
    --ap-fara-stroke: #8A7AB0;
    --ap-sizzano: rgba(100,90,140,0.22);
    --ap-sizzano-stroke: #8A7AB0;
  }
}

/* ---- RESET & BASE ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: none; text-size-adjust: none;
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility; scroll-behavior: smooth;
  scroll-padding-top: var(--sp-16);
}
body {
  min-height: 100dvh; line-height: 1.65;
  font-family: var(--font-body); font-size: var(--text-base);
  color: var(--color-text); background-color: var(--color-bg);
}
img, svg { display: block; max-width: 100%; }
h1,h2,h3,h4,h5,h6 { text-wrap: balance; line-height: 1.15; font-family: var(--font-display); font-weight: 500; }
p, li, figcaption { text-wrap: pretty; max-width: 72ch; }
a { color: var(--color-primary); text-decoration: none; transition: color var(--tx); }
a:hover { color: var(--color-primary-hover); }
button { cursor: pointer; background: none; border: none; font: inherit; color: inherit; }
table { border-collapse: collapse; width: 100%; }
ul[role='list'], ol[role='list'] { list-style: none; }
:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 3px; border-radius: var(--radius-sm); }
::selection { background: rgba(139,32,32,0.18); color: var(--color-text); }

/* ---- LAYOUT HELPERS ---- */
.container { max-width: var(--content-default); margin-inline: auto; padding-inline: clamp(var(--sp-6), 5vw, var(--sp-16)); }
.container-wide { max-width: var(--content-wide); margin-inline: auto; padding-inline: clamp(var(--sp-6), 5vw, var(--sp-16)); }

/* =====================================================
   HEADER
   ===================================================== */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in srgb, var(--color-bg) 92%, transparent);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-divider);
  transition: box-shadow var(--tx);
}
.header-inner {
  max-width: var(--content-wide); margin-inline: auto;
  padding: var(--sp-4) clamp(var(--sp-6), 5vw, var(--sp-16));
  display: flex; align-items: center; gap: var(--sp-8);
}
.logo { display: flex; align-items: center; gap: var(--sp-3); color: var(--color-text); text-decoration: none; }
.logo svg { color: var(--color-primary); }
.logo-text { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 500; letter-spacing: 0.01em; }
.main-nav { display: flex; gap: var(--sp-6); margin-left: auto; }
.main-nav a { font-size: var(--text-sm); font-weight: 500; color: var(--color-text-muted); letter-spacing: 0.01em; }
.main-nav a:hover { color: var(--color-primary); }
.theme-toggle {
  width: 36px; height: 36px; border-radius: var(--radius-full);
  display: grid; place-items: center; color: var(--color-text-muted);
  transition: background var(--tx), color var(--tx); flex-shrink: 0;
}
.theme-toggle:hover { background: var(--color-surface-offset); color: var(--color-text); }

/* =====================================================
   HERO
   ===================================================== */
.hero {
  position: relative; min-height: 72vh;
  display: flex; flex-direction: column; justify-content: center;
  overflow: hidden;
  background: linear-gradient(160deg, var(--color-surface) 0%, var(--color-bg) 60%);
  padding: clamp(var(--sp-20), 10vw, var(--sp-24)) clamp(var(--sp-6), 6vw, var(--sp-24));
  border-bottom: 1px solid var(--color-divider);
}
.hero-bg-pattern {
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 39px, var(--color-divider) 40px),
    repeating-linear-gradient(90deg, transparent, transparent 39px, var(--color-divider) 40px);
  opacity: 0.18;
}
.hero-content { position: relative; max-width: var(--content-default); }
.hero-kicker {
  font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--color-primary); margin-bottom: var(--sp-4);
}
.hero-title {
  font-family: var(--font-display); font-size: var(--text-3xl); font-weight: 300;
  letter-spacing: -0.01em; line-height: 1.0;
  color: var(--color-text); margin-bottom: var(--sp-6);
}
.hero-subtitle {
  font-size: var(--text-lg); font-weight: 300; color: var(--color-text-muted);
  max-width: 52ch; line-height: 1.6; margin-bottom: var(--sp-10);
}
.hero-stats { display: flex; align-items: center; gap: var(--sp-8); flex-wrap: wrap; }
.stat { display: flex; flex-direction: column; gap: var(--sp-1); }
.stat-num { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 400; color: var(--color-primary); line-height: 1; }
.stat-label { font-size: var(--text-xs); color: var(--color-text-muted); letter-spacing: 0.02em; }
.stat-divider { width: 1px; height: 40px; background: var(--color-border); }
.hero-scroll-hint {
  position: absolute; bottom: var(--sp-8); left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: var(--sp-2);
  font-size: var(--text-xs); color: var(--color-text-faint); letter-spacing: 0.08em;
  animation: bounce 2s ease-in-out infinite;
}
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(4px)} }

/* =====================================================
   SECTION STYLES
   ===================================================== */
.section-header { margin-bottom: var(--sp-10); }
.section-header h2 { font-size: var(--text-xl); margin-bottom: var(--sp-4); }
.section-intro { font-size: var(--text-base); color: var(--color-text-muted); max-width: 68ch; }
.section-label {
  font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--color-primary); margin-bottom: var(--sp-6);
}

/* =====================================================
   PROVINCE BAND
   ===================================================== */
.province-band {
  padding-block: clamp(var(--sp-12), 7vw, var(--sp-20));
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-divider);
}
.province-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--sp-5); }
.province-card {
  background: var(--color-surface-2); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--sp-6);
  position: relative; overflow: hidden;
  transition: box-shadow var(--tx), transform var(--tx);
}
.province-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.province-accent {
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--accent, var(--color-primary));
}
.province-card h3 { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 500; margin-bottom: var(--sp-3); margin-top: var(--sp-3); }
.province-card p { font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--sp-4); max-width: 100%; }
.province-tags { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.tag {
  font-size: var(--text-xs); padding: var(--sp-1) var(--sp-2);
  background: var(--color-surface-offset); border: 1px solid var(--color-border);
  border-radius: var(--radius-full); color: var(--color-text-muted); white-space: nowrap;
}

/* =====================================================
   MAP SECTION
   ===================================================== */
.map-section {
  padding-block: clamp(var(--sp-12), 7vw, var(--sp-20));
  border-bottom: 1px solid var(--color-divider);
}
.map-header { margin-bottom: var(--sp-8); }
.map-header h2 { font-size: var(--text-xl); margin-bottom: var(--sp-3); }
.map-intro { font-size: var(--text-sm); color: var(--color-text-muted); max-width: 60ch; }
.map-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: var(--sp-8);
  align-items: start;
}
.map-wrapper {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.region-map { width: 100%; height: auto; display: block; }

/* Appellation hover interactions */
.appellation-group { cursor: pointer; }
.appellation-group .ap-shape {
  transition: fill var(--tx), filter var(--tx);
}
.appellation-group:hover .ap-shape,
.appellation-group:focus .ap-shape,
.appellation-group.active .ap-shape {
  filter: brightness(1.15) saturate(1.3);
  stroke-width: 2.5;
}
.appellation-group:hover .ap-label,
.appellation-group.active .ap-label {
  font-weight: 700;
}
.appellation-group:focus { outline: none; }
.ap-shape.docg { stroke-dasharray: none; }

/* Info panel */
.map-info-panel {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--sp-6);
  min-height: 320px;
  position: sticky;
  top: calc(var(--sp-16) + var(--sp-4));
}
.panel-default {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; text-align: center; height: 100%;
  padding: var(--sp-8) var(--sp-4); gap: var(--sp-4);
}
.panel-icon { color: var(--color-text-faint); margin-bottom: var(--sp-2); }
.panel-default h3 { font-size: var(--text-lg); color: var(--color-text-muted); font-weight: 400; }
.panel-default p { font-size: var(--text-sm); color: var(--color-text-faint); }

.panel-badge-row { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-3); }
.panel-badge {
  font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.1em;
  padding: 2px 8px; border-radius: var(--radius-full);
}
.panel-badge.docg { background: var(--color-gold-light); color: var(--color-gold); border: 1px solid var(--color-gold); }
.panel-badge.doc  { background: var(--color-surface-offset); color: var(--color-text-muted); border: 1px solid var(--color-border); }
.panel-province { font-size: var(--text-xs); color: var(--color-text-muted); }
.panel-name { font-size: var(--text-xl); font-weight: 400; margin-bottom: var(--sp-1); }
.panel-elev { font-size: var(--text-xs); color: var(--color-text-muted); margin-bottom: var(--sp-5); letter-spacing: 0.04em; }
.panel-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.panel-item { display: flex; flex-direction: column; gap: var(--sp-1); }
.panel-item--full { grid-column: 1 / -1; }
.panel-item-label { font-size: var(--text-xs); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.08em; }
.panel-item-val { font-size: var(--text-sm); color: var(--color-text); font-weight: 500; }

/* =====================================================
   APPELLATIONS SECTION
   ===================================================== */
.appellations-section {
  padding-block: clamp(var(--sp-12), 7vw, var(--sp-20));
  border-bottom: 1px solid var(--color-divider);
}
.filter-tabs {
  display: flex; gap: var(--sp-2); flex-wrap: wrap;
  margin-bottom: var(--sp-8); border-bottom: 1px solid var(--color-divider);
  padding-bottom: var(--sp-4);
}
.filter-tab {
  padding: var(--sp-2) var(--sp-5); border-radius: var(--radius-full);
  font-size: var(--text-sm); font-weight: 500;
  border: 1px solid var(--color-border);
  background: var(--color-surface); color: var(--color-text-muted);
  transition: all var(--tx);
}
.filter-tab:hover { border-color: var(--color-primary); color: var(--color-primary); }
.filter-tab.active {
  background: var(--color-primary); color: var(--color-text-inverse);
  border-color: var(--color-primary);
}
.appellation-cards {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--sp-6);
}
.ap-card {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-xl); overflow: hidden;
  transition: box-shadow var(--tx), transform var(--tx);
}
.ap-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.ap-card[hidden] { display: none; }
.ap-card-header {
  padding: var(--sp-5) var(--sp-6) var(--sp-4);
  border-bottom: 1px solid var(--color-divider);
  position: relative;
  background: linear-gradient(135deg, var(--color-surface) 0%, var(--color-surface-offset) 100%);
}
.ap-card-header::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--card-accent, var(--color-primary));
}
.ap-card-meta { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-2); }
.ap-status { font-size: var(--text-xs); font-weight: 700; padding: 2px 8px; border-radius: var(--radius-full); letter-spacing: 0.08em; }
.docg-badge { background: var(--color-gold-light); color: var(--color-gold); border: 1px solid var(--color-gold); }
.doc-badge { background: var(--color-surface-offset); color: var(--color-text-muted); border: 1px solid var(--color-border); }
.ap-prov { font-size: var(--text-xs); color: var(--color-text-muted); }
.ap-card-header h3 { font-size: var(--text-lg); font-weight: 400; margin-bottom: var(--sp-1); }
.ap-elev { font-size: var(--text-xs); color: var(--color-text-muted); letter-spacing: 0.04em; }
.ap-card-body { padding: var(--sp-5) var(--sp-6) var(--sp-6); }
.ap-row {
  display: flex; gap: var(--sp-3);
  padding-block: var(--sp-2);
  border-bottom: 1px solid var(--color-divider);
  font-size: var(--text-sm);
}
.ap-row:last-of-type { border-bottom: none; }
.ap-key { color: var(--color-text-muted); min-width: 110px; flex-shrink: 0; font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.05em; padding-top: 2px; }
.ap-val { color: var(--color-text); }
.ap-note {
  font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65;
  margin-top: var(--sp-5); margin-bottom: var(--sp-5);
  padding-top: var(--sp-4); border-top: 1px solid var(--color-divider);
  font-style: italic; max-width: 100%;
}

/* Profile bars */
.ap-profile { display: flex; flex-direction: column; gap: var(--sp-2); border-top: 1px solid var(--color-divider); padding-top: var(--sp-4); }
.profile-bar { display: flex; align-items: center; gap: var(--sp-3); }
.profile-label { font-size: var(--text-xs); color: var(--color-text-muted); min-width: 52px; text-align: right; letter-spacing: 0.03em; }
.bar-track { flex: 1; height: 6px; background: var(--color-surface-offset-2); border-radius: var(--radius-full); overflow: hidden; }
.bar-fill { height: 100%; background: var(--color-primary); border-radius: var(--radius-full); }
.profile-val { font-size: var(--text-xs); color: var(--color-text-muted); min-width: 80px; }

/* =====================================================
   TERROIR TABLE
   ===================================================== */
.table-section {
  padding-block: clamp(var(--sp-12), 7vw, var(--sp-20));
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-divider);
}
.table-scroll { overflow-x: auto; border-radius: var(--radius-lg); border: 1px solid var(--color-border); }
.terroir-table {
  width: 100%; min-width: 900px; font-size: var(--text-sm);
  background: var(--color-surface-2);
}
.terroir-table thead { background: var(--color-surface-offset); }
.terroir-table th {
  padding: var(--sp-4) var(--sp-5); text-align: left;
  font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--color-text-muted); border-bottom: 2px solid var(--color-divider);
  white-space: nowrap;
}
.terroir-table td {
  padding: var(--sp-4) var(--sp-5); border-bottom: 1px solid var(--color-divider);
  color: var(--color-text); vertical-align: middle;
}
.terroir-table tbody tr:last-child td { border-bottom: none; }
.terroir-table tbody tr:hover td { background: var(--color-surface-offset); }
.row-docg td { background: color-mix(in srgb, var(--color-gold-light) 25%, transparent); }
.row-docg:hover td { background: color-mix(in srgb, var(--color-gold-light) 40%, transparent) !important; }
.td-name { font-weight: 500; white-space: nowrap; }
.td-ph { font-family: 'DM Sans', monospace; font-size: var(--text-xs); color: var(--color-primary); font-weight: 600; }
.tbl-docg { display: inline-block; font-size: var(--text-xs); font-weight: 700; padding: 2px 7px; border-radius: var(--radius-full); background: var(--color-gold-light); color: var(--color-gold); border: 1px solid var(--color-gold); letter-spacing: 0.06em; }
.tbl-doc  { display: inline-block; font-size: var(--text-xs); font-weight: 600; padding: 2px 7px; border-radius: var(--radius-full); background: var(--color-surface-offset); color: var(--color-text-muted); border: 1px solid var(--color-border); letter-spacing: 0.06em; }
.tbl-bar { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--text-xs); color: var(--color-text-muted); white-space: nowrap; }
.tbl-bar > div { width: 60px; height: 5px; background: var(--color-surface-offset-2); border-radius: var(--radius-full); overflow: hidden; flex-shrink: 0; }
.tbl-bar > div::before { content: ''; display: block; height: 100%; background: var(--color-primary); width: inherit; border-radius: var(--radius-full); }

/* =====================================================
   COMPARISON SECTION
   ===================================================== */
.comparison-section {
  padding-block: clamp(var(--sp-12), 7vw, var(--sp-20));
  border-bottom: 1px solid var(--color-divider);
}
.comparison-grid { display: grid; grid-template-columns: 1fr auto 1fr; gap: var(--sp-8); align-items: start; margin-bottom: var(--sp-10); }
.compare-col { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: var(--sp-6); }
.compare-col--alto { border-top: 3px solid var(--color-primary); }
.compare-col--south { border-top: 3px solid var(--color-text-faint); }
.compare-header { margin-bottom: var(--sp-5); padding-bottom: var(--sp-4); border-bottom: 1px solid var(--color-divider); }
.compare-icon { color: var(--color-primary); margin-bottom: var(--sp-3); }
.compare-col--south .compare-icon { color: var(--color-text-muted); }
.compare-header h3 { font-size: var(--text-lg); font-weight: 400; margin-bottom: var(--sp-1); }
.compare-sub { font-size: var(--text-xs); color: var(--color-text-muted); }
.compare-list { list-style: none; display: flex; flex-direction: column; gap: var(--sp-3); }
.compare-list li { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.55; padding-left: var(--sp-4); position: relative; max-width: 100%; }
.compare-list li::before { content: '·'; position: absolute; left: 0; color: var(--color-primary); font-weight: 700; }
.compare-col--south .compare-list li::before { color: var(--color-text-faint); }
.compare-list li strong { color: var(--color-text); font-weight: 600; }
.compare-divider {
  display: flex; align-items: center; justify-content: center;
  padding-top: var(--sp-10);
}
.compare-divider span {
  font-family: var(--font-display); font-size: var(--text-lg); font-weight: 300;
  color: var(--color-text-faint); padding: var(--sp-2) var(--sp-4);
  border: 1px solid var(--color-border); border-radius: var(--radius-full);
  background: var(--color-surface);
}

/* Callout */
.callout-block {
  display: flex; gap: var(--sp-5); align-items: flex-start;
  background: var(--color-surface);
  border: 1px solid var(--color-border); border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-lg); padding: var(--sp-6);
}
.callout-icon { font-size: 1.5rem; color: var(--color-primary); flex-shrink: 0; margin-top: 2px; }
.callout-block h4 { font-size: var(--text-base); font-weight: 600; margin-bottom: var(--sp-3); }
.callout-block p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.7; max-width: 100%; }
.callout-block em { font-style: italic; color: var(--color-text); }

/* =====================================================
   FOOTER
   ===================================================== */
.site-footer {
  background: var(--color-surface);
  border-top: 1px solid var(--color-divider);
  padding-block: var(--sp-10);
}
.footer-inner { display: flex; gap: var(--sp-10); flex-wrap: wrap; align-items: flex-start; }
.footer-brand { display: flex; align-items: center; gap: var(--sp-3); font-size: var(--text-sm); color: var(--color-text-muted); min-width: 200px; }
.footer-brand svg { color: var(--color-primary); flex-shrink: 0; }
.footer-sources { flex: 1; }
.footer-label { font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-text-muted); margin-bottom: var(--sp-3); }
.footer-sources ul { list-style: none; display: flex; flex-direction: column; gap: var(--sp-1); }
.footer-sources li { font-size: var(--text-xs); }
.footer-sources a { color: var(--color-text-muted); }
.footer-sources a:hover { color: var(--color-primary); }

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media (max-width: 1000px) {
  .map-layout { grid-template-columns: 1fr; }
  .map-info-panel { position: static; min-height: 200px; }
  .comparison-grid { grid-template-columns: 1fr; }
  .compare-divider { display: none; }
}
@media (max-width: 700px) {
  .main-nav { display: none; }
  .hero-stats { gap: var(--sp-5); }
  .stat-divider { display: none; }
  .province-cards { grid-template-columns: 1fr; }
  .appellation-cards { grid-template-columns: 1fr; }
  .footer-inner { flex-direction: column; gap: var(--sp-6); }
}

/* Tbl bar inline width override using inline style width */
.terroir-table td .tbl-bar > div {
  position: relative;
  overflow: hidden;
}
.terroir-table td .tbl-bar > div::before {
  position: absolute;
  left: 0; top: 0; bottom: 0;
}

/* Tbl bar fix — table bars use inline style width directly on the div */
.terroir-table .tbl-bar > div {
  background: var(--color-primary) !important;
}
