    :root {
      --bg: #0e0c0a;
      --panel: #15100c;
      --gold: #cfa56b;
      --gold-muted: #b48853;
      --text: #f2e9db;
      --muted: #c7b69d;
      --card: #1a120d;
      --accent: linear-gradient(135deg, rgba(195,146,88,0.28), rgba(90,62,36,0.12));
      --shadow: 0 18px 40px rgba(0,0,0,0.4);
      --radius: 18px;
      --max-width: 1200px;
    }

    * { box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body.no-scroll { overflow: hidden; }
    body {
      margin: 0;
      background:
        linear-gradient(180deg, rgba(52,38,26,0.32), rgba(14,10,8,0.94)),
        var(--bg);
      color: var(--text);
      font-family: 'Space Grotesk', 'Segoe UI', sans-serif;
      line-height: 1.6;
      letter-spacing: 0.01em;
      -webkit-font-smoothing: antialiased;
      position: relative;
      overflow-x: hidden;
    }

    body::before {
      content: '';
      position: fixed;
      inset: -10% -10%;
      background:
        radial-gradient(circle at 25% 30%, rgba(120,84,54,0.18), transparent 32%),
        radial-gradient(circle at 72% 68%, rgba(88,60,36,0.16), transparent 34%);
      filter: blur(32px);
      opacity: 0.45;
      pointer-events: none;
      z-index: 0;
    }

    body::after { display: none; }

    a { color: inherit; text-decoration: none; }
    img { max-width: 100%; display: block; border-radius: var(--radius); }

    header {
      position: sticky;
      top: 0;
      z-index: 40;
      backdrop-filter: blur(12px);
      background: rgba(15,15,15,0.78);
      border-bottom: 1px solid rgba(200,160,99,0.18);
    }

    .nav {
      position: relative;
      max-width: var(--max-width);
      margin: 0 auto;
      padding: 14px 20px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
    }

    .logo {
      display: flex;
      align-items: center;
      gap: 12px;
      font-weight: 600;
      font-size: 1.05rem;
      letter-spacing: 0.04em;
    }

    .logo img { height: 52px; width: auto; display: block; object-fit: contain; }

    .contact-lines small { display: block; color: var(--muted); line-height: 1.5; }

    nav {
      display: flex;
      align-items: center;
      gap: 22px;
      font-size: 0.95rem;
    }

    nav a { opacity: 0.78; transition: opacity 0.25s ease, transform 0.25s ease; }
    nav a:hover { opacity: 1; transform: translateY(-1px); }

    .menu-toggle {
      display: none;
      background: rgba(207,165,107,0.12);
      color: var(--text);
      border: 1px solid rgba(207,165,107,0.4);
      border-radius: 12px;
      padding: 8px 12px;
      font-size: 1.1rem;
      cursor: pointer;
    }

    .nav-overlay {
      position: fixed;
      inset: 0;
      background: rgba(0,0,0,0.4);
      display: none;
      z-index: 15;
    }

    .nav-overlay.open { display: block; }

    .cta {
      padding: 12px 18px;
      border-radius: 999px;
      background: linear-gradient(135deg, #c8a063, #b48b4b);
      color: #0f0f0f;
      font-weight: 700;
      letter-spacing: 0.02em;
      box-shadow: 0 12px 24px rgba(200,160,99,0.35);
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .cta:hover { transform: translateY(-1px); box-shadow: 0 18px 34px rgba(200,160,99,0.45); }

    main { max-width: var(--max-width); margin: 0 auto; padding: 32px 20px 80px; }

    .hero {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
      gap: 26px;
      padding: 48px 0 32px;
      align-items: center;
    }

    .hero-text h1 {
      font-family: 'Playfair Display', serif;
      font-size: clamp(2.2rem, 4vw, 3.4rem);
      margin: 0 0 14px;
      letter-spacing: 0.01em;
    }

    .hero-text p { color: var(--muted); margin: 0 0 18px; }

    .hero-actions { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }

    .ghost-btn {
      padding: 11px 16px;
      border-radius: 999px;
      border: 1px solid rgba(200,160,99,0.4);
      color: var(--text);
      background: transparent;
      transition: border-color 0.2s ease, transform 0.2s ease;
    }

    .ghost-btn:hover { border-color: rgba(200,160,99,0.7); transform: translateY(-1px); }

    .hero-image {
      position: relative;
      background: var(--card);
      border-radius: var(--radius);
      padding: 14px;
      overflow: hidden;
      box-shadow: var(--shadow), 0 0 0 1px rgba(207,165,107,0.16);
      isolation: isolate;
      max-height: 520px;
    }

    .hero-image::before {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(circle at 30% 20%, rgba(200,160,99,0.3), transparent 40%);
      z-index: 1;
      pointer-events: none;
    }

    .hero-image img { width: 100%; height: auto; max-height: 520px; object-fit: cover; border-radius: 12px; filter: saturate(0.9); }

    section { margin-top: 64px; scroll-margin-top: 90px; }

    .section-head {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 14px;
      margin-bottom: 20px;
    }

    .section-head h2 {
      margin: 0;
      font-family: 'Playfair Display', serif;
      letter-spacing: 0.02em;
      font-size: 1.8rem;
    }

    .pill {
      position: relative;
      padding: 10px 16px;
      border-radius: 999px;
      border: 1px solid rgba(200,160,99,0.45);
      background: linear-gradient(120deg, rgba(200,160,99,0.18), rgba(21,21,21,0.85));
      color: #e9dfc8;
      font-size: 0.95rem;
      letter-spacing: 0.01em;
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 10px 28px rgba(0,0,0,0.28);
      overflow: hidden;
      transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
    }

    .pill::after {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(circle at 20% 20%, rgba(255,255,255,0.12), transparent 36%),
                  linear-gradient(90deg, transparent, rgba(255,255,255,0.18), transparent);
      opacity: 0;
      transform: translateX(-20%);
      transition: opacity 0.25s ease;
      pointer-events: none;
    }

    .pill:hover {
      border-color: rgba(200,160,99,0.65);
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 16px 34px rgba(0,0,0,0.38);
      transform: translateY(-1px);
    }

    .pill:hover::after { opacity: 1; }

    .grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
      gap: 18px;
    }

    .listino-carousel {
      overflow-x: auto;
      overflow-y: hidden;
      position: relative;
      padding: 4px 0;
      -ms-overflow-style: none;
      scrollbar-width: none;
      cursor: grab;
    }

    .listino-carousel::-webkit-scrollbar { display: none; }

    .listino-track {
      display: flex;
      align-items: stretch;
      gap: 18px;
      animation: scroll-left 28s linear infinite;
      will-change: transform;
    }

    .listino-track:hover { animation-play-state: paused; }

    .listino-track .card {
      flex: 0 0 320px;
      max-width: 340px;
      min-width: 280px;
    }

    @keyframes scroll-left {
      0% { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }

    .card {
      background: var(--card);
      border-radius: var(--radius);
      padding: 18px;
      border: 1px solid rgba(207,165,107,0.22);
      box-shadow: var(--shadow), 0 0 0 1px rgba(207,165,107,0.12);
      position: relative;
      overflow: hidden;
    }

    .card::after {
      content: '';
      position: absolute;
      inset: 0;
      background: var(--accent);
      opacity: 0;
      transition: opacity 0.25s ease;
      pointer-events: none;
    }

    .card:hover::after { opacity: 1; }
    .card h3 { margin: 0 0 8px; font-size: 1.1rem; }
    .card p { margin: 0; color: var(--muted); font-size: 0.95rem; }

    .price-tag {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      margin-top: 10px;
      padding: 8px 12px;
      border-radius: 12px;
      background: rgba(200,160,99,0.12);
      color: var(--text);
      font-weight: 600;
    }

    .products .price-tag.bio-badge {
      background: rgba(34,160,90,0.18);
      border: 1px solid rgba(34,160,90,0.35);
      color: #c4f4d7;
      font-weight: 800;
      letter-spacing: 0.04em;
    }

    .products .card img {
      margin-bottom: 12px;
      height: 200px;
      width: 100%;
      object-fit: cover;
      background: transparent;
      padding: 0;
      border: 1px solid rgba(207,165,107,0.25);
      box-shadow: 0 12px 28px rgba(0,0,0,0.28);
    }

    .products .card { cursor: pointer; transition: transform 0.2s ease, box-shadow 0.2s ease; }
    .products .card:hover { transform: translateY(-4px); box-shadow: 0 22px 46px rgba(0,0,0,0.45); }

    .products-carousel {
      overflow-x: auto;
      overflow-y: hidden;
      position: relative;
      padding: 4px 0;
      -ms-overflow-style: none;
      scrollbar-width: none;
      cursor: grab;
    }
    .products-carousel::-webkit-scrollbar { display: none; }
    .products-track {
      display: flex;
      align-items: stretch;
      gap: 18px;
      animation: scroll-products 32s linear infinite;
      will-change: transform;
    }
    .products-track:hover { animation-play-state: paused; }
    .products-track .card { flex: 0 0 260px; max-width: 280px; min-width: 240px; }

    @keyframes scroll-products {
      0% { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }

    .carousel-dragging { cursor: grabbing !important; }

    /* Desktop only: make carousels span the full viewport width,
       breaking out of the centered main { max-width: 1200px }. */
    @media (min-width: 901px) {
      .listino-carousel,
      .products-carousel {
        width: 100vw;
        max-width: 100vw;
        position: relative;
        left: 50%;
        right: 50%;
        margin-left: -50vw;
        margin-right: -50vw;
        padding-left: clamp(24px, 5vw, 80px);
        padding-right: clamp(24px, 5vw, 80px);
        box-sizing: border-box;
      }
    }

    .modal {
      position: fixed;
      inset: 0;
      background: rgba(0,0,0,0.7);
      display: none;
      align-items: center;
      justify-content: center;
      padding: 20px;
      z-index: 100;
    }

    .modal.open { display: flex; animation: fade-in 0.25s ease; }

    .modal-card {
      background: #111;
      border: 1px solid rgba(200,160,99,0.35);
      border-radius: 18px;
      max-width: 520px;
      width: 100%;
      box-shadow: var(--shadow);
      overflow: hidden;
    }

    .modal-media img { width: 100%; height: 260px; object-fit: cover; display: block; }
    .modal-body { padding: 18px 18px 20px; }
    .modal-body h3 { margin: 0 0 8px; font-size: 1.3rem; }
    .modal-body p { margin: 0 0 12px; color: var(--muted); }
    .modal-price { display: inline-flex; align-items: center; gap: 6px; padding: 8px 12px; border-radius: 12px; background: rgba(200,160,99,0.12); font-weight: 700; }

    .modal-close {
      position: absolute;
      top: 14px;
      right: 14px;
      background: rgba(0,0,0,0.6);
      border: 1px solid rgba(200,160,99,0.4);
      color: var(--text);
      border-radius: 50%;
      width: 38px;
      height: 38px;
      display: grid;
      place-items: center;
      cursor: pointer;
      transition: transform 0.15s ease;
    }

    .modal-close:hover { transform: scale(1.05); }

    @keyframes fade-in {
      from { opacity: 0; }
      to { opacity: 1; }
    }

    .about {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
      gap: 20px;
      align-items: center;
    }

    .about .story { background: var(--card); padding: 20px; border-radius: var(--radius); border: 1px solid rgba(207,165,107,0.22); box-shadow: var(--shadow), 0 0 0 1px rgba(207,165,107,0.12); }
    .about .story p { color: var(--muted); margin: 0 0 12px; }
    .about .story strong { color: var(--text); }

    .badge-row { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
    .badge { padding: 8px 10px; border-radius: 10px; border: 1px solid rgba(200,160,99,0.35); color: var(--text); background: rgba(21,21,21,0.7); font-size: 0.9rem; }

    .cta-banner {
      margin-top: 70px;
      padding: 26px;
      border-radius: 20px;
      background: linear-gradient(135deg, rgba(200,160,99,0.35), rgba(15,15,15,0.8)), #1a140c;
      display: grid;
      grid-template-columns: 1fr;
      gap: 12px;
      align-items: center;
      border: 1px solid rgba(207,165,107,0.26);
      box-shadow: var(--shadow), 0 0 0 1px rgba(207,165,107,0.12);
    }

    .cta-banner h3 { margin: 0; font-size: 1.4rem; font-family: 'Playfair Display', serif; }
    .cta-banner p { margin: 0; color: var(--muted); }
    .cta-actions { display: flex; gap: 10px; flex-wrap: wrap; }

    .map-embed { margin-top: 64px; }
    .map-embed .map-frame {
      width: 100%;
      height: 380px;
      border: 1px solid rgba(207,165,107,0.26);
      border-radius: 18px;
      overflow: hidden;
      box-shadow: var(--shadow), 0 0 0 1px rgba(207,165,107,0.12);
    }
    .map-embed iframe { width: 100%; height: 100%; border: 0; }

    .snow-overlay {
      position: fixed;
      inset: 0;
      pointer-events: none;
      background-image:
        radial-gradient(2px 2px at 12% 18%, rgba(255,255,255,0.62), transparent),
        radial-gradient(2px 2px at 18% 10%, rgba(255,255,255,0.64), transparent),
        radial-gradient(2px 2px at 22% 26%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 28% 32%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 32% 14%, rgba(255,255,255,0.62), transparent),
        radial-gradient(2px 2px at 42% 12%, rgba(255,255,255,0.62), transparent),
        radial-gradient(2px 2px at 46% 28%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 52% 22%, rgba(255,255,255,0.64), transparent),
        radial-gradient(2px 2px at 58% 26%, rgba(255,255,255,0.64), transparent),
        radial-gradient(2px 2px at 62% 12%, rgba(255,255,255,0.62), transparent),
        radial-gradient(2px 2px at 68% 18%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 72% 18%, rgba(255,255,255,0.62), transparent),
        radial-gradient(2px 2px at 78% 10%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 82% 32%, rgba(255,255,255,0.58), transparent),
        radial-gradient(2px 2px at 86% 14%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 92% 26%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 96% 18%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 8% 42%, rgba(255,255,255,0.62), transparent),
        radial-gradient(2px 2px at 14% 52%, rgba(255,255,255,0.64), transparent),
        radial-gradient(2px 2px at 18% 64%, rgba(255,255,255,0.62), transparent),
        radial-gradient(2px 2px at 26% 58%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 32% 72%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 38% 66%, rgba(255,255,255,0.64), transparent),
        radial-gradient(2px 2px at 44% 54%, rgba(255,255,255,0.62), transparent),
        radial-gradient(2px 2px at 48% 68%, rgba(255,255,255,0.64), transparent),
        radial-gradient(2px 2px at 54% 68%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 60% 52%, rgba(255,255,255,0.62), transparent),
        radial-gradient(2px 2px at 64% 74%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 70% 78%, rgba(255,255,255,0.64), transparent),
        radial-gradient(2px 2px at 74% 62%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 78% 58%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 82% 72%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 86% 66%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 90% 78%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 94% 62%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 24% 88%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 28% 92%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 36% 84%, rgba(255,255,255,0.64), transparent),
        radial-gradient(2px 2px at 42% 90%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 48% 90%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 52% 92%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 60% 88%, rgba(255,255,255,0.62), transparent),
        radial-gradient(2px 2px at 66% 92%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 72% 86%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 76% 90%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 82% 88%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 86% 90%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 92% 88%, rgba(255,255,255,0.6), transparent),
        radial-gradient(1.6px 1.6px at 14% 8%, rgba(255,255,255,0.6), transparent),
        radial-gradient(1.6px 1.6px at 18% 18%, rgba(255,255,255,0.6), transparent),
        radial-gradient(1.6px 1.6px at 24% 6%, rgba(255,255,255,0.6), transparent),
        radial-gradient(1.6px 1.6px at 32% 16%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 40% 10%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 44% 24%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 52% 8%, rgba(255,255,255,0.6), transparent),
        radial-gradient(1.6px 1.6px at 56% 18%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 64% 6%, rgba(255,255,255,0.6), transparent),
        radial-gradient(1.6px 1.6px at 68% 22%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 74% 12%, rgba(255,255,255,0.6), transparent),
        radial-gradient(1.6px 1.6px at 80% 18%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 84% 8%, rgba(255,255,255,0.6), transparent),
        radial-gradient(1.6px 1.6px at 90% 14%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 10% 48%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 16% 54%, rgba(255,255,255,0.6), transparent),
        radial-gradient(1.6px 1.6px at 22% 62%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 30% 52%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 34% 68%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 40% 60%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 44% 54%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 50% 70%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 56% 62%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 60% 54%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 66% 68%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 72% 60%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 78% 58%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 84% 64%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 88% 58%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.6px 1.6px at 92% 70%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.4px 1.4px at 8% 26%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 12% 36%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 18% 30%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 26% 24%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 32% 6%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 40% 16%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 46% 10%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 52% 4%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 58% 16%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 64% 6%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 70% 12%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 78% 6%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 82% 18%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 88% 10%, rgba(255,255,255,0.56), transparent),
        radial-gradient(1.4px 1.4px at 6% 72%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 10% 80%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 16% 86%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 22% 92%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 30% 82%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 34% 90%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 42% 82%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 48% 94%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 54% 86%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 60% 92%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 66% 84%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 72% 92%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 78% 84%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 84% 92%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 88% 82%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.4px 1.4px at 92% 90%, rgba(255,255,255,0.58), transparent),
        radial-gradient(1.8px 1.8px at 18% 10%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 24% 4%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.8px 1.8px at 32% 14%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 42% 8%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 52% 6%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.8px 1.8px at 62% 12%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.8px 1.8px at 72% 10%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 82% 6%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.8px 1.8px at 92% 12%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.8px 1.8px at 10% 54%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 20% 60%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.8px 1.8px at 30% 52%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 40% 68%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 50% 58%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 60% 72%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.8px 1.8px at 70% 64%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 80% 70%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 90% 62%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 14% 86%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 26% 90%, rgba(255,255,255,0.62), transparent),
        radial-gradient(1.8px 1.8px at 36% 82%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 48% 94%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 58% 86%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 68% 92%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 78% 84%, rgba(255,255,255,0.64), transparent),
        radial-gradient(1.8px 1.8px at 88% 92%, rgba(255,255,255,0.64), transparent);
      background-size: 220% 220%;
      animation: snow 12s linear infinite;
      opacity: 0.6;
      z-index: 5;
      display: none;
    }

    @keyframes snow {
      0% { transform: translateY(-30%); }
      100% { transform: translateY(110%); }
    }

    .snow-overlay.active { display: block; }

    footer { margin: 60px auto 0; padding: 22px 0 32px; max-width: var(--max-width); color: var(--muted); font-size: 0.95rem; text-align: center; }
    footer a { color: var(--gold); }
    .footer-made { margin-top: 6px; color: var(--text); font-weight: 700; letter-spacing: 0.01em; }

    @media (max-width: 720px) {
      .nav {
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        padding: 12px 14px;
        gap: 10px;
      }
      .logo { width: auto; flex: 1; }
      .logo small { display: block; line-height: 1.5; }
      nav {
        position: absolute;
        top: 70px;
        right: 14px;
        width: calc(100% - 28px);
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        background: linear-gradient(135deg, rgba(27,22,16,0.96), rgba(14,12,10,0.96));
        border: 1px solid rgba(207,165,107,0.32);
        border-radius: 16px;
        box-shadow: 0 18px 44px rgba(0,0,0,0.55), 0 0 0 1px rgba(207,165,107,0.14);
        padding: 14px 14px 16px;
        display: none;
        z-index: 50;
      }
      nav.open { display: flex; }
      nav a { padding: 6px 2px; width: 100%; }
      nav .cta {
        width: 100%;
        justify-content: center;
        text-align: center;
        padding: 12px 16px;
        margin-top: 2px;
      }
      .menu-toggle {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        margin-left: auto;
      }
      .cta { padding: 10px 14px; }
      .hero { padding-top: 32px; }
      .section-head { flex-direction: column; align-items: flex-start; }
    }

    .closures-banner {
      margin: 18px 0 0;
      padding: 14px 18px;
      border-radius: 14px;
      background: linear-gradient(135deg, rgba(207,165,107,0.18), rgba(21,21,21,0.85));
      border: 1px solid rgba(207,165,107,0.35);
      color: var(--text);
      display: flex;
      flex-wrap: wrap;
      gap: 10px 18px;
      align-items: center;
      font-size: 0.95rem;
      box-shadow: var(--shadow);
    }
    .closures-banner strong { color: var(--gold); margin-right: 6px; }
    .closures-banner .closure-item { color: var(--muted); }
