:root {
  --bg: #f6f1ea;
  --bg-soft: #efe6da;
  --card: rgba(255,255,255,0.72);
  --text: #201619;
  --muted: #6e5e60;
  --line: rgba(45, 24, 27, 0.12);
  --wine: #5a161c;
  --wine-deep: #2a1012;
  --gold: #b8924e;
  --olive: #7a7c53;
  --shadow: 0 20px 70px rgba(30, 16, 18, 0.14);
  --radius: 28px;
  --radius-lg: 38px;
  --container: 1240px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Inter', sans-serif;
  background:
    radial-gradient(circle at top left, rgba(184,146,78,.08), transparent 35%),
    linear-gradient(180deg, #faf6f0 0%, #f6f1ea 100%);
  color: var(--text);
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { font: inherit; }
.container { width: min(calc(100% - 32px), var(--container)); margin: 0 auto; }
.page-noise {
  position: fixed; inset: 0; pointer-events: none; z-index: 1;
  background-image: radial-gradient(rgba(0,0,0,.018) 1px, transparent 1px);
  background-size: 6px 6px; opacity: .28;
}
#preloader {
  position: fixed; inset: 0; z-index: 3000; display: grid; place-items: center;
  background: #16090a; color: #fff; transition: opacity .8s ease, visibility .8s ease;
}
#preloader.hidden { opacity: 0; visibility: hidden; }
#preloader p { letter-spacing: .35em; font-size: 11px; text-transform: uppercase; opacity: .72; }
.loader-mark {
  width: 92px; height: 92px; border-radius: 999px; position: relative; margin: 0 auto 20px;
  border: 1px solid rgba(255,255,255,.12);
}
.loader-mark::before, .loader-mark::after {
  content: ''; position: absolute; inset: 14px; border-radius: inherit; border: 1px solid rgba(184,146,78,.4);
  animation: pulse 2s infinite ease-in-out;
}
.loader-mark::after { inset: 28px; animation-delay: .45s; }
@keyframes pulse { 0%,100%{ transform: scale(.96); opacity: .5;} 50%{ transform: scale(1.06); opacity: 1;} }
.age-gate {
  position: fixed; inset: 0; z-index: 2500; display: grid; place-items: center; padding: 20px;
  background: linear-gradient(180deg, rgba(20,8,10,.9), rgba(42,16,18,.96)); backdrop-filter: blur(10px);
}
.age-gate.hidden { display: none; }
.age-card {
  max-width: 560px; padding: 36px; border-radius: 32px; color: #fff;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); box-shadow: var(--shadow); text-align: center;
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 10px; font-size: 12px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--gold); font-weight: 700;
}
.eyebrow::before {
  content: ''; width: 42px; height: 1px; background: currentColor; opacity: .5;
}
.btn {
  display: inline-flex; align-items: center; justify-content: center; padding: 15px 22px; border-radius: 999px;
  border: 1px solid transparent; transition: .35s ease; cursor: pointer; font-weight: 600;
}
.btn-solid {
  background: linear-gradient(135deg, var(--gold), #c9a86f); color: #120708; box-shadow: 0 12px 30px rgba(184,146,78,.24);
}
.btn-solid:hover { transform: translateY(-2px); }
.btn-outline {
  border-color: rgba(255,255,255,.24); color: #fff; background: transparent;
}
.btn-outline:hover { background: rgba(255,255,255,.08); }
.site-header {
  position: fixed; top: 16px; left: 0; width: 100%; z-index: 1200; transition: .35s ease;
}
.site-header.scrolled .nav-wrap {
  background: rgba(255,248,239,.8); backdrop-filter: blur(18px); border-color: rgba(42,16,18,.08); box-shadow: var(--shadow);
}
.nav-wrap {
  display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 16px 20px;
  border: 1px solid transparent; border-radius: 999px;
}
.brand { display: flex; flex-direction: column; gap: 4px; position: relative; z-index: 2; }
.brand-title {
  font-family: 'Cormorant Garamond', serif; font-size: clamp(1.3rem, 2vw, 2rem); font-weight: 700; line-height: 1;
}
.brand-sub { font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); }
.desktop-nav { display: flex; align-items: center; gap: 26px; }
.desktop-nav a { font-size: 13px; font-weight: 600; color: var(--muted); }
.desktop-nav a:hover { color: var(--wine); }
.menu-toggle {
  display: none; width: 52px; height: 52px; border: 1px solid rgba(42,16,18,.12); background: rgba(255,255,255,.75);
  border-radius: 999px; align-items: center; justify-content: center; flex-direction: column; gap: 5px;
}
.menu-toggle span { width: 18px; height: 2px; background: var(--wine); border-radius: 2px; transition: .3s ease; }
.mobile-menu {
  display: none; width: min(calc(100% - 32px), 1240px); margin: 12px auto 0; padding: 18px; border-radius: 28px;
  background: rgba(255,248,239,.95); backdrop-filter: blur(16px); box-shadow: var(--shadow); border: 1px solid rgba(42,16,18,.08);
}
.mobile-menu.open { display: grid; gap: 10px; }
.mobile-menu a { padding: 14px 10px; border-bottom: 1px solid rgba(42,16,18,.08); font-weight: 600; }
.hero {
  position: relative; min-height: 100svh; display: flex; align-items: center; padding: 140px 0 80px; overflow: clip;
}
.hero-media {
  position: absolute; inset: 0; display: grid; place-items: center; isolation: isolate;
}
.hero-image-main {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(.95) contrast(1.02) brightness(.68);
}
.hero-image-float {
  position: absolute; right: 8%; bottom: 8%; width: min(28vw, 380px); aspect-ratio: 4/5; object-fit: cover;
  border-radius: 34px; border: 1px solid rgba(255,255,255,.18); box-shadow: 0 30px 80px rgba(0,0,0,.28); transform: rotate(7deg);
}
.hero-overlay {
  position: absolute; inset: 0; background:
    linear-gradient(180deg, rgba(22,9,10,.22), rgba(22,9,10,.56)),
    radial-gradient(circle at 20% 30%, rgba(184,146,78,.18), transparent 30%);
}
.hero-content { position: relative; z-index: 2; color: #fff; max-width: 760px; }
.hero h1 {
  font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: clamp(3.2rem, 7vw, 6.6rem); line-height: .95; margin: 18px 0 18px;
}
.hero p { font-size: clamp(1rem, 1.4vw, 1.15rem); line-height: 1.8; max-width: 680px; color: rgba(255,255,255,.82); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.hero-stats {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin-top: 40px; max-width: 640px;
}
.hero-stats div {
  padding: 16px 18px; border-radius: 22px; background: rgba(255,255,255,.07); backdrop-filter: blur(14px); border: 1px solid rgba(255,255,255,.08);
}
.hero-stats strong { display: block; font-size: 1.35rem; }
.hero-stats span { color: rgba(255,255,255,.7); font-size: .92rem; }
.scroll-indicator {
  position: absolute; left: 50%; bottom: 30px; transform: translateX(-50%); width: 30px; height: 52px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.34); z-index: 2;
}
.scroll-indicator::after {
  content: ''; position: absolute; left: 50%; top: 10px; transform: translateX(-50%); width: 4px; height: 12px; border-radius: 999px; background: #fff;
  animation: scroll 2s infinite;
}
@keyframes scroll { 0%{ opacity: 0; transform: translate(-50%,0);} 40%{ opacity:1;} 100%{ opacity:0; transform: translate(-50%,18px);} }
.section { position: relative; z-index: 2; padding: 110px 0; }
.section-light { background: transparent; }
.section-dark {
  color: #fff; background:
  radial-gradient(circle at top right, rgba(184,146,78,.13), transparent 30%),
  linear-gradient(180deg, #261012 0%, #160a0b 100%);
}
.split {
  display: grid; grid-template-columns: 1.05fr .95fr; gap: 48px; align-items: center;
}
.split-content h2, .section-heading h2, .contact-copy h2, .experience-panel h2 {
  font-family: 'Cormorant Garamond', serif; font-size: clamp(2.6rem, 4.8vw, 4.5rem); line-height: .95; margin: 18px 0 18px;
}
.split-content p, .section-heading p, .wine-copy p, .estate-body p, .contact-copy p, .experience-panel p {
  font-size: 1.03rem; line-height: 1.9; color: inherit;
}
.quote-card {
  margin-top: 26px; padding: 24px 26px; border-radius: 28px; background: rgba(255,255,255,.62); border: 1px solid rgba(42,16,18,.08); box-shadow: var(--shadow);
}
.quote-card p { margin: 0; font-family: 'Cormorant Garamond', serif; font-size: 1.8rem; line-height: 1.2; }
.story-collage {
  position: relative; min-height: 640px;
}
.story-card {
  overflow: hidden; border-radius: 34px; box-shadow: var(--shadow); position: absolute; border: 1px solid rgba(42,16,18,.08);
}
.story-card img { width: 100%; height: 100%; object-fit: cover; }
.story-card.tall { width: min(80%, 420px); height: 560px; top: 0; left: 0; }
.story-card.short { width: min(62%, 360px); height: 210px; right: 0; bottom: 40px; }
.story-card.short img { object-fit: contain; background: #d7c6b0; }
.story-card.tall img { object-position: center center; }
.wine-photo-box img { object-position: center bottom; }
.story-badge {
  position: absolute; right: 20px; top: 48px; display: grid; gap: 8px; padding: 22px 24px; border-radius: 28px;
  background: linear-gradient(135deg, rgba(90,22,28,.94), rgba(42,16,18,.94)); color: #fff; box-shadow: var(--shadow);
}
.story-badge span { font-size: .82rem; text-transform: uppercase; letter-spacing: .18em; color: rgba(255,255,255,.7); }
.story-badge strong { font-size: 1.1rem; }
.section-heading { max-width: 840px; margin-bottom: 40px; }
.estate-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px;
}
.estate-card, .wine-card, .gallery-item, .experience-panel, .contact-map, .contact-copy {
  border: 1px solid rgba(255,255,255,.08);
}
.estate-card {
  border-radius: 30px; overflow: hidden; background: rgba(255,255,255,.05); backdrop-filter: blur(8px);
}
.estate-media { aspect-ratio: 4 / 4.2; overflow: hidden; }
.estate-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s ease; }
.estate-card:hover .estate-media img, .gallery-item:hover img { transform: scale(1.05); }
.estate-body { padding: 24px; }
.estate-body h3, .wine-copy h3 {
  font-family: 'Cormorant Garamond', serif; font-size: 2rem; margin: 0 0 10px;
}
.wines-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px;
}
.wine-card {
  display: grid; grid-template-columns: 240px 1fr; gap: 24px; align-items: center; padding: 24px;
  border-radius: 32px; background: rgba(255,255,255,.62); box-shadow: var(--shadow); border-color: rgba(42,16,18,.08);
}
.wine-card[data-accent="red"] { background: linear-gradient(135deg, rgba(255,255,255,.82), rgba(116,18,24,.06)); }
.wine-card[data-accent="dark"] { background: linear-gradient(135deg, rgba(255,255,255,.82), rgba(42,16,18,.08)); }
.wine-card[data-accent="rose"] { background: linear-gradient(135deg, rgba(255,255,255,.82), rgba(196,117,139,.08)); }
.wine-card[data-accent="gold"] { background: linear-gradient(135deg, rgba(255,255,255,.82), rgba(184,146,78,.09)); }
.wine-photo-placeholder {
  height: 360px; border-radius: 28px; border: 1px dashed rgba(90,22,28,.22);
  background:
    radial-gradient(circle at top, rgba(184,146,78,.16), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(239,230,218,.72));
  display: grid; place-items: center; position: relative; overflow: hidden;
}
.wine-photo-placeholder::before {
  content: ''; width: 94px; height: 220px; border-radius: 60px 60px 34px 34px / 50px 50px 24px 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.55), rgba(90,22,28,.08)); border: 1px solid rgba(90,22,28,.14);
  box-shadow: inset 0 -40px 40px rgba(90,22,28,.08);
}
.wine-photo-placeholder span {
  position: absolute; bottom: 22px; left: 20px; right: 20px; text-align: center; font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: var(--muted);
}
.wine-type {
  display: inline-flex; margin-bottom: 12px; font-size: 12px; letter-spacing: .24em; text-transform: uppercase; color: var(--wine); font-weight: 700;
}
.gallery-masonry {
  columns: 3 280px; column-gap: 18px;
}
.gallery-item {
  break-inside: avoid; margin-bottom: 18px; overflow: hidden; border-radius: 26px; background: rgba(255,255,255,.05);
}
.gallery-item img { width: 100%; height: auto; transition: transform .8s ease; }
.experience-panel {
  display: grid; grid-template-columns: .95fr 1fr; gap: 30px; padding: 34px; border-radius: 34px;
  background: linear-gradient(135deg, rgba(255,255,255,.7), rgba(255,255,255,.45)); box-shadow: var(--shadow); border-color: rgba(42,16,18,.08);
}
.contact-section {
  background:
    linear-gradient(180deg, rgba(22,10,11,.98), rgba(34,16,18,.98)),
    url('assets/images/XIROMERITIS_BACKGROUND.png') center/cover no-repeat;
  color: #fff;
}
.contact-grid {
  display: grid; grid-template-columns: .92fr 1.08fr; gap: 28px; align-items: stretch;
}
.contact-copy {
  padding: 34px; border-radius: 34px; background: rgba(255,255,255,.06); backdrop-filter: blur(10px);
}
.contact-list { display: grid; gap: 22px; margin-top: 30px; }
.contact-list span {
  display: inline-block; font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: var(--gold); font-weight: 700; margin-bottom: 8px;
}
.contact-list p, .contact-list a { color: rgba(255,255,255,.86); }
.contact-map {
  overflow: hidden; border-radius: 34px; min-height: 520px; background: rgba(255,255,255,.08); backdrop-filter: blur(10px);
}
.contact-map iframe { width: 100%; height: 100%; border: 0; filter: grayscale(.2) contrast(1.02); }
.site-footer {
  padding: 28px 0 40px; background: #160a0b; color: rgba(255,255,255,.62); position: relative; z-index: 2;
}
.footer-wrap { display: flex; justify-content: space-between; gap: 24px; align-items: center; }
.footer-wrap h3 {
  margin: 0 0 6px; font-family: 'Cormorant Garamond', serif; font-size: 1.8rem; color: #fff;
}
.footer-wrap p, .footer-meta span { font-size: .92rem; }
.footer-meta { display: flex; flex-wrap: wrap; gap: 14px 22px; justify-content: flex-end; }
.reveal {
  opacity: 0; transform: translateY(28px); transition: opacity .9s ease, transform .9s ease;
}
.reveal.in-view { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: .1s; }
.delay-2 { transition-delay: .2s; }
@media (max-width: 1100px) {
  .split, .experience-panel, .contact-grid, .wines-grid, .estate-grid { grid-template-columns: 1fr; }
  .wines-grid { gap: 18px; }
  .wine-card { grid-template-columns: 1fr; }
  .story-collage { min-height: 580px; }
}
@media (max-width: 860px) {
  .desktop-nav { display: none; }
  .menu-toggle { display: inline-flex; }
  .hero-image-float { width: 42vw; right: 16px; bottom: 24px; }
  .hero-stats { grid-template-columns: 1fr; max-width: 320px; }
  .story-card.tall { width: 78%; height: 420px; }
  .story-card.short { width: 56%; height: 160px; }
}
@media (max-width: 720px) {
  .site-header { top: 10px; }
  .nav-wrap { padding: 14px 16px; }
  .hero { padding-top: 130px; }
  .hero h1 { font-size: clamp(2.8rem, 14vw, 4.8rem); }
  .hero-image-float { display: none; }
  .section { padding: 82px 0; }
  .split-content h2, .section-heading h2, .contact-copy h2, .experience-panel h2 { font-size: clamp(2.3rem, 11vw, 3.5rem); }
  .story-collage { min-height: auto; display: grid; gap: 16px; }
  .story-card, .story-badge { position: static; width: 100% !important; height: auto !important; }
  .story-card img { aspect-ratio: 4/5; }
  .wine-photo-placeholder { height: 300px; }
  .gallery-masonry { columns: 1; }
  .contact-map { min-height: 380px; }
  .footer-wrap { flex-direction: column; align-items: flex-start; }
  .footer-meta { justify-content: flex-start; }
}

.skip-link {
  position: absolute;
  left: 16px;
  top: -60px;
  background: #fff;
  color: #160a0b;
  padding: 12px 16px;
  border-radius: 14px;
  z-index: 3000;
  font-weight: 700;
}
.skip-link:focus { top: 16px; }

.wines-grid-five {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.wine-photo-frame {
  position: relative;
  min-height: 360px;
  border-radius: 28px;
  overflow: hidden;
  background:
    radial-gradient(circle at top, rgba(184,146,78,.16), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(239,230,218,.72));
  border: 1px solid rgba(90,22,28,.09);
  display: flex;
  align-items: center;
  justify-content: center;
}

.wine-photo-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.wine-card {
  align-items: stretch;
}

.wine-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.wine-copy p {
  margin: 0 0 14px;
}

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

.wine-meta li {
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(42,16,18,.08);
  color: var(--text);
  line-height: 1.6;
}

.availability-note {
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(184,146,78,.12);
  border: 1px solid rgba(184,146,78,.18);
}

.wine-card-wide {
  grid-column: 1 / -1;
  grid-template-columns: minmax(280px, 420px) 1fr;
}

.wine-card[data-accent="box"] {
  background: linear-gradient(135deg, rgba(255,255,255,.82), rgba(184,146,78,.11));
}

.wine-photo-box {
  min-height: 320px;
}

@media (max-width: 1100px) {
  .wines-grid-five,
  .wine-card-wide {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .wine-photo-frame,
  .wine-photo-box {
    min-height: 280px;
  }

  .wine-card {
    padding: 18px;
    border-radius: 24px;
  }

  .wine-copy h3 {
    font-size: 1.75rem;
  }

  .wine-meta li {
    padding: 11px 12px;
    font-size: .95rem;
  }
}

.header-tools{display:flex;align-items:center;gap:12px;position:relative;z-index:2}
.lang-toggle{height:48px;padding:0 16px;border-radius:999px;border:1px solid rgba(42,16,18,.12);background:rgba(255,255,255,.75);font-weight:700;color:var(--wine);cursor:pointer}
.btn-light{border-color:rgba(255,255,255,.28);color:#fff}
.loader-mark{display:none}
.loader-scene{position:relative;width:220px;height:130px;margin:0 auto 18px}
.loader-bottle{position:absolute;left:8px;top:10px;width:44px;height:100px;border:3px solid rgba(255,255,255,.95);border-radius:14px 14px 10px 10px;transform:rotate(-23deg);transform-origin:center center}
.loader-bottle:before{content:'';position:absolute;top:-18px;left:11px;width:16px;height:22px;border:3px solid rgba(255,255,255,.95);border-bottom:none;border-radius:8px 8px 0 0;background:#16090a}
.loader-pour{position:absolute;left:60px;top:46px;width:74px;height:6px;background:linear-gradient(90deg, rgba(184,146,78,.2), rgba(132,24,34,.95));border-radius:999px;transform:rotate(12deg);transform-origin:left center;animation:pourStream 1.5s ease forwards .25s;opacity:0}
.loader-glass{position:absolute;right:18px;bottom:0;width:72px;height:96px;border:3px solid rgba(255,255,255,.95);border-top:none;clip-path:polygon(16% 0,84% 0,72% 66%,57% 66%,57% 86%,66% 86%,66% 90%,34% 90%,34% 86%,43% 86%,43% 66%,28% 66%);display:flex;align-items:flex-end;justify-content:center;overflow:hidden}
.loader-wine-fill{width:70%;height:0;background:linear-gradient(180deg,#c99249,#7d1521);border-radius:0 0 16px 16px;animation:fillWine 1.5s ease forwards .3s}
@keyframes pourStream{0%{opacity:0;width:0}15%{opacity:1}100%{opacity:1;width:78px}}
@keyframes fillWine{0%{height:0}100%{height:48%}}
.age-cloud{max-width:620px;padding:44px 38px;border-radius:38px;background:linear-gradient(180deg,rgba(255,252,247,.96),rgba(244,236,228,.96));color:var(--text);box-shadow:var(--shadow);border:1px solid rgba(42,16,18,.08);text-align:center;position:relative}
.age-cloud:before,.age-cloud:after{content:'';position:absolute;background:inherit;border:1px solid rgba(42,16,18,.06);border-radius:50%}
.age-cloud:before{width:90px;height:90px;left:36px;bottom:-24px}.age-cloud:after{width:66px;height:66px;left:92px;bottom:-54px}
.age-cloud h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,4vw,3.4rem);margin:16px 0 10px;color:var(--wine-deep)}
.age-cloud p{font-size:1.04rem;line-height:1.8;color:var(--muted)}
.age-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:20px}.age-actions .btn-outline{color:var(--wine);border-color:rgba(42,16,18,.18)}
.story-layout{align-items:start}
.framed-history{display:grid;gap:18px}
.history-frame{background:linear-gradient(145deg,#8d6030,#4e3119);padding:22px;border-radius:30px;box-shadow:0 30px 70px rgba(40,22,8,.22)}
.history-frame img{width:100%;border-radius:14px;display:block}
.history-caption{padding:18px 22px;border-radius:24px;background:rgba(255,255,255,.65);border:1px solid rgba(42,16,18,.08)}
.history-caption span{display:block;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:8px}
.history-caption strong{font-family:'Cormorant Garamond',serif;font-size:1.8rem;line-height:1.08}
.wine-card-textonly{grid-template-columns:1fr;padding:34px 30px}.wide-only{max-width:920px}.wine-card-textonly .wine-copy p:last-child{margin-bottom:0}
.footer-meta-links a{opacity:.9}.footer-meta-links a:hover{color:#fff}
.legal-page{background:var(--bg)}.legal-box{max-width:820px;padding:44px;border-radius:34px;background:rgba(255,255,255,.7);box-shadow:var(--shadow);border:1px solid rgba(42,16,18,.08)}.legal-box h1{font-family:'Cormorant Garamond',serif;font-size:3.2rem;margin:24px 0 16px}.legal-box p{line-height:1.9}
@media (max-width: 860px){.lang-toggle{height:44px;padding:0 12px;font-size:13px}.age-cloud{padding:34px 24px}.history-caption strong{font-size:1.5rem}}


#preloader {
  position: fixed; inset: 0; z-index: 3000; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 22px; background: radial-gradient(circle at top, rgba(140,40,50,.18), transparent 35%), linear-gradient(180deg, #140809 0%, #241012 100%);
  color: #fff; transition: opacity .7s ease, visibility .7s ease;
}
.loader-title {
  margin: 0; font-family: 'Cormorant Garamond', serif; font-size: clamp(2rem, 4vw, 3.5rem); font-weight: 700; letter-spacing: .02em; opacity: .96;
}
.loader-wineglass-wrap { perspective: 700px; }
.loader-wineglass {
  position: relative; width: 110px; height: 150px; transform-origin: 50% 20%;
  animation: swayGlass 1.6s ease-in-out infinite;
}
.loader-wineglass::before {
  content: ''; position: absolute; left: 13px; right: 13px; top: 0; height: 88px;
  border: 4px solid rgba(255,255,255,.9); border-bottom-left-radius: 32px; border-bottom-right-radius: 32px;
  border-top-left-radius: 10px; border-top-right-radius: 10px; border-top-width: 3px;
}
.loader-wineglass::after {
  content: ''; position: absolute; left: 50%; top: 88px; width: 6px; height: 42px; background: rgba(255,255,255,.9); transform: translateX(-50%);
  box-shadow: 0 42px 0 10px rgba(255,255,255,.9); border-radius: 999px;
}
.loader-wine {
  position: absolute; left: 18px; right: 18px; bottom: 62px; height: 34px; border-bottom-left-radius: 18px; border-bottom-right-radius: 18px;
  background: linear-gradient(180deg, rgba(158,31,49,.95), rgba(111,18,32,.98));
  box-shadow: 0 0 24px rgba(143,24,44,.35);
}
@keyframes swayGlass { 0%,100%{ transform: rotate(-8deg);} 50%{ transform: rotate(8deg);} }
.age-gate { background: linear-gradient(180deg, rgba(20,8,10,.86), rgba(42,16,18,.94)); }
.age-cloud {
  max-width: 620px; padding: 38px 34px; border-radius: 42px; color: #fff; text-align: center;
  background: radial-gradient(circle at top, rgba(255,255,255,.14), rgba(255,255,255,.07));
  border: 1px solid rgba(255,255,255,.14); box-shadow: 0 25px 80px rgba(0,0,0,.28); backdrop-filter: blur(16px);
}
.age-cloud p { color: rgba(255,255,255,.82); font-size: 1.02rem; line-height: 1.75; }
.age-cloud h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(2.2rem, 4vw, 3.4rem); margin: 14px 0 10px; }
.age-actions { display:flex; justify-content:center; gap:12px; flex-wrap:wrap; margin-top:20px; }
.history-frame-composite {
  padding: 0; overflow: hidden; border-radius: 34px; background: #f1e7d8; border: 1px solid rgba(42,16,18,.08); box-shadow: var(--shadow);
}
.history-frame-composite img { width: 100%; height: auto; display:block; }
.history-caption { display:none !important; }
@media (max-width: 768px) {
  .loader-title { font-size: 2.1rem; text-align: center; line-height: 1.05; padding: 0 18px; }
  .loader-wineglass { transform: scale(.9); }
  .age-cloud { padding: 30px 22px; border-radius: 30px; }
}

/* Final preloader + age gate adjustments */
#preloader {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 18px;
  background: radial-gradient(circle at top, rgba(140,40,50,.14), transparent 34%), linear-gradient(180deg, #140809 0%, #241012 100%);
  color: #fff;
  transition: opacity .6s ease, visibility .6s ease;
}

.loader-icon-wrap {
  display: grid;
  place-items: center;
  margin-bottom: 10px;
}

.loader-wineglass-svg {
  width: 108px;
  height: 144px;
  overflow: visible;
  filter: drop-shadow(0 10px 24px rgba(0,0,0,.22));
}

.glass-bowl {
  fill: none;
  stroke: rgba(255,255,255,.96);
  stroke-width: 4.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.glass-wine {
  fill: url(#wineGradient);
}

.loader-wineglass-svg defs { display:block; }
.glass-shine {
  fill: none;
  stroke: rgba(255,255,255,.35);
  stroke-width: 3;
  stroke-linecap: round;
}

.loader-wineglass-svg {
  background-image: none;
}

.loader-title {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.5rem, 5vw, 4.2rem);
  font-weight: 700;
  letter-spacing: .02em;
  line-height: 1;
  text-align: center;
}

.loader-progress {
  width: min(340px, calc(100vw - 64px));
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
}

.loader-progress-bar {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #b8924e, #d7b77a, #b8334d);
  animation: preloaderFill 2.5s linear forwards;
}

@keyframes preloaderFill {
  from { width: 0; }
  to { width: 100%; }
}

.age-gate {
  display: grid;
}

.age-gate.hidden {
  display: none;
}

.age-cloud {
  max-width: 650px;
  padding: 40px 36px;
  border-radius: 36px;
  color: #fff;
  text-align: center;
  background: linear-gradient(180deg, rgba(34,13,16,.95), rgba(58,20,25,.92));
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 25px 80px rgba(0,0,0,.34);
  backdrop-filter: blur(16px);
}

.age-cloud h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.4rem, 4vw, 3.6rem);
  margin: 14px 0 12px;
  color: #fff;
}

.age-cloud p {
  color: rgba(255,255,255,.84);
  font-size: 1.04rem;
  line-height: 1.8;
  max-width: 520px;
  margin: 0 auto;
}

.age-actions {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 24px;
}
.age-yes {
  min-width: 210px;
}
.age-no {
  min-width: 150px;
  color: #fff;
  border-color: rgba(255,255,255,.24);
  background: rgba(255,255,255,.08);
}
.age-no:hover {
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.34);
}

@media (max-width: 768px) {
  .loader-title {
    font-size: 2.35rem;
    line-height: 1.04;
    padding: 0 18px;
  }
  .loader-progress {
    width: min(260px, calc(100vw - 56px));
  }
  .age-cloud {
    padding: 30px 22px;
    border-radius: 28px;
  }
}


/* --- Final stability overrides --- */
#preloader{
  position:fixed;
  inset:0;
  z-index:3000;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:20px;
  background:radial-gradient(circle at top, rgba(140,40,50,.16), transparent 35%), linear-gradient(180deg, #140809 0%, #241012 100%);
  color:#fff;
  transition:opacity .55s ease, visibility .55s ease;
}
#preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-icon-wrap{
  width:96px;
  height:96px;
  display:grid;
  place-items:center;
  margin:0 auto 8px;
}
.loader-wineglass-svg{
  width:88px;
  height:118px;
  overflow:visible;
  color:#fff;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.28));
}
.loader-title{
  margin:0;
  text-align:center;
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(2.4rem,4.2vw,4rem);
  line-height:1;
  letter-spacing:.03em;
}
.loader-progress{
  width:min(340px,80vw);
  height:8px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.09);
}
.loader-progress-bar,
.loader-progress span{
  display:block;
  width:0;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,#d3ad67 0%, #c96073 50%, #7c1421 100%);
  animation:loaderProgress 2.5s linear forwards;
}
@keyframes loaderProgress{from{width:0}to{width:100%}}

.loader-wineglass-svg .glass-bowl,
.loader-wineglass-svg .glass-shine,
.loader-wineglass-svg .glass-stem,
.loader-wineglass-svg .glass-base{
  stroke:currentColor;
  stroke-width:4.5;
  stroke-linecap:round;
  stroke-linejoin:round;
  fill:none;
}
.loader-wineglass-svg .glass-wine{fill:url(#wineGradient)}

.age-gate{
  position:fixed;
  inset:0;
  z-index:2900;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:linear-gradient(180deg, rgba(20,8,10,.72), rgba(42,16,18,.82));
  backdrop-filter:blur(10px);
}
.age-gate.hidden{display:none}
.age-cloud{
  max-width:640px;
  width:min(100%,640px);
  padding:42px 36px;
  border-radius:36px;
  background:linear-gradient(180deg,rgba(255,252,247,.98),rgba(244,236,228,.98));
  color:var(--text);
  box-shadow:0 24px 80px rgba(0,0,0,.28);
  border:1px solid rgba(42,16,18,.08);
  text-align:center;
}
.age-cloud:before,.age-cloud:after{display:none}
.age-cloud h2{
  font-family:'Cormorant Garamond', serif;
  color:var(--wine-deep);
  font-size:clamp(2.3rem,4vw,3.5rem);
  line-height:1;
  margin:14px 0 12px;
}
.age-cloud p{
  color:var(--muted);
  font-size:1.04rem;
  line-height:1.8;
  margin:0;
}
.age-actions{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:24px;
}
.age-yes{
  background:linear-gradient(135deg,#d3ad67,#bb8d43)!important;
  color:#2b1012!important;
  border:1px solid transparent!important;
  box-shadow:0 14px 28px rgba(184,146,78,.22);
}
.age-no{
  background:rgba(255,255,255,.7)!important;
  color:#9f1f26!important;
  border:1px solid #d3ad67!important;
  box-shadow:0 10px 24px rgba(42,16,18,.08);
}
.age-no:hover{
  background:#fff7eb!important;
  color:#7f131a!important;
  transform:translateY(-2px);
}

@media (max-width:768px){
  .loader-title{font-size:2.3rem;padding:0 18px}
  .loader-progress{width:min(290px,82vw)}
  .age-cloud{padding:32px 22px;border-radius:28px}
}

.made-by a {
  color: #d4af37; /* χρυσό */
  text-decoration: none;
}

.made-by a:hover {
  text-decoration: underline;
}


/* === FINAL WINES SECTION FIX: show new photos whole, no cropping === */
.wines-grid-five{
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 26px !important;
}

.wines-grid-five .wine-card{
  display: grid !important;
  grid-template-columns: 1fr !important;
  align-items: start !important;
  gap: 20px !important;
  padding: 24px !important;
}

.wines-grid-five .wine-photo-frame{
  height: 420px !important;
  min-height: 420px !important;
  padding: 14px !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.wines-grid-five .wine-photo-frame img{
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  display: block !important;
}

.wines-grid-five .wine-copy{
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
}

.wines-grid-five .wine-copy h3{
  margin-top: 2px !important;
  margin-bottom: 10px !important;
  line-height: 1.08 !important;
}

.wines-grid-five .wine-copy p{
  margin-bottom: 12px !important;
}

.wines-grid-five .wine-meta{
  gap: 10px !important;
}

.wines-grid-five .wine-card-wide{
  grid-column: 1 / -1 !important;
}

@media (max-width: 980px){
  .wines-grid-five{
    grid-template-columns: 1fr !important;
  }
  .wines-grid-five .wine-photo-frame{
    height: 380px !important;
    min-height: 380px !important;
  }
}

@media (max-width: 640px){
  .wines-grid-five .wine-card{
    padding: 18px !important;
  }
  .wines-grid-five .wine-photo-frame{
    height: 300px !important;
    min-height: 300px !important;
    padding: 10px !important;
  }
}

/* BIGGER WINE IMAGES - FINAL FIX */
.wines-grid-five .wine-photo-frame{
  height: 380px !important;   /* ΜΕΓΑΛΥΤΕΡΗ */
  min-height: 380px !important;
  padding: 6px !important;    /* λιγότερο κενό */
}

.wines-grid-five .wine-photo-frame img{
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

/* πιο tight layout */
.wines-grid-five .wine-card{
  padding: 16px !important;
}

.wines-grid-five{
  gap: 16px !important;
}

@media (max-width: 768px){
  .wines-grid-five .wine-photo-frame{
    height: 320px !important;
  }
}