:root{
    --wine:#4A1E2B;
    --wine-deep:#33141D;
    --gold:#C99A3E;
    --gold-light:#E4C780;
    --cream:#F6EFE3;
    --ink:#22201D;
    --sage:#7C8868;
    --line:rgba(34,32,29,0.12);
    --max:1120px;
  }
  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0;
    background:var(--cream);
    color:var(--ink);
    font-family:'Inter',sans-serif;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3,.display{
    font-family:'Fraunces',serif;
    font-weight:600;
    letter-spacing:-0.01em;
    margin:0;
  }
  a{color:inherit;text-decoration:none;}
  .wrap{max-width:var(--max);margin:0 auto;padding:0 28px;}
  .eyebrow{
    font-size:12.5px;
    letter-spacing:.14em;
    text-transform:uppercase;
    font-weight:600;
    color:var(--wine);
    opacity:.75;
  }

  /* ---------- HEADER ---------- */
  header{
    position:sticky;top:0;z-index:50;
    background:rgba(246,239,227,0.92);
    backdrop-filter:blur(8px);
    border-bottom:1px solid var(--line);
  }
  .nav{
    display:flex;align-items:center;justify-content:space-between;
    padding:16px 28px;max-width:var(--max);margin:0 auto;
  }
  .brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:600;font-size:18px;color:var(--wine-deep);}
  .brand svg{width:30px;height:30px;flex-shrink:0;}
  .navlinks{display:flex;gap:28px;font-size:14.5px;font-weight:500;}
  .navlinks a{opacity:.8;transition:opacity .15s;border-bottom:2px solid transparent;padding-bottom:2px;}
  .navlinks a:hover{opacity:1;border-color:var(--gold);}
  .navcta{
    background:var(--wine);color:var(--cream);
    padding:9px 18px;border-radius:3px;font-size:14px;font-weight:600;
    transition:background .15s;
  }
  .navcta:hover{background:var(--wine-deep);}
  .burger{display:none;}
  @media (max-width:780px){
    .navlinks{display:none;}
  }

  /* ---------- HERO ---------- */
  .hero{
    position:relative;
    overflow:hidden;
    padding:84px 0 0;
    background:linear-gradient(180deg,#F6EFE3 0%, #F1E6D2 100%);
  }
  .hero-grid{
    display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;
  }
  @media (max-width:900px){ .hero-grid{grid-template-columns:1fr;} }
  .hero h1{
    font-size:clamp(38px,5vw,60px);
    line-height:1.04;
    color:var(--wine-deep);
    margin-top:14px;
  }
  .hero h1 em{color:var(--gold);font-style:normal;}
  .hero p.lede{
    font-size:18px;color:var(--ink);opacity:.8;max-width:480px;margin-top:18px;
  }
  .hero-actions{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;}
  .btn{
    display:inline-flex;align-items:center;gap:8px;
    padding:13px 24px;border-radius:3px;font-weight:600;font-size:14.5px;
    transition:transform .15s, box-shadow .15s;
  }
  .btn-primary{background:var(--wine);color:var(--cream);}
  .btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(74,30,43,0.28);}
  .btn-ghost{border:1.5px solid var(--ink);color:var(--ink);}
  .btn-ghost:hover{background:var(--ink);color:var(--cream);}

  .event-card{
    background:var(--wine-deep);color:var(--cream);
    border-radius:6px;padding:30px 32px;
    position:relative;
    box-shadow:0 24px 60px -12px rgba(51,20,29,0.45);
  }
  .event-card .tag{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-light);font-weight:700;}
  .event-card h3{font-size:28px;margin-top:10px;color:#fff;}
  .event-card .when{font-size:15px;margin-top:4px;opacity:.85;}
  .event-rule{height:1px;background:rgba(255,255,255,0.18);margin:18px 0;}
  .event-detail{display:flex;justify-content:space-between;font-size:14px;padding:6px 0;opacity:.92;}
  .event-detail span:first-child{opacity:.65;}
  .event-card a.dirlink{display:inline-block;margin-top:16px;font-size:14px;font-weight:600;color:var(--gold-light);border-bottom:1px solid var(--gold-light);}

  /* sunrise-over-vineyard signature motif */
  .horizon{width:100%;height:auto;display:block;margin-top:54px;}

  /* ---------- VERSE ---------- */
  .verse{
    background:var(--wine);color:var(--cream);
    padding:64px 0;text-align:center;
  }
  .verse blockquote{
    font-family:'Fraunces',serif;font-weight:500;font-style:italic;
    font-size:clamp(22px,2.6vw,30px);line-height:1.45;max-width:760px;margin:18px auto 0;
  }
  .verse cite{display:block;margin-top:18px;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light);font-style:normal;}

  /* ---------- SECTION GENERIC ---------- */
  section{padding:88px 0;}
  .section-head{max-width:620px;margin-bottom:48px;}
  .section-head h2{font-size:clamp(28px,3.4vw,38px);color:var(--wine-deep);margin-top:10px;}
  .section-head p{margin-top:14px;font-size:16.5px;opacity:.78;}

  /* ---------- TIMELINE ---------- */
  .timeline{position:relative;padding-left:0;}
  .tl-row{
    display:grid;grid-template-columns:120px 1fr;gap:28px;
    padding:26px 0;border-top:1px solid var(--line);
  }
  .tl-row:first-child{border-top:none;}
  .tl-year{font-family:'Fraunces',serif;font-weight:600;font-size:26px;color:var(--gold);}
  .tl-row h4{font-size:17px;font-weight:700;margin-bottom:6px;}
  .tl-row p{margin:0;opacity:.78;font-size:15px;max-width:600px;}
  @media (max-width:600px){ .tl-row{grid-template-columns:1fr;gap:6px;} }

  /* ---------- DIRECTORY ---------- */
  .directory-shell{
    background:#fff;border:1px solid var(--line);border-radius:8px;padding:36px;
  }
  .dir-search{
    display:flex;gap:10px;margin-bottom:26px;
  }
  .dir-search input{
    flex:1;padding:13px 16px;border:1.5px solid var(--line);border-radius:4px;
    font-family:'Inter',sans-serif;font-size:15px;background:var(--cream);
  }
  .dir-search input:focus{outline:2px solid var(--gold);border-color:var(--gold);}
  .country-label{
    font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--sage);
    margin:22px 0 12px;
  }
  .city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
  @media (max-width:700px){.city-grid{grid-template-columns:repeat(2,1fr);}}
  .city-chip{
    padding:11px 14px;border:1px solid var(--line);border-radius:4px;font-size:14px;font-weight:500;
    transition:border-color .15s, background .15s;
  }
  .city-chip:hover{border-color:var(--gold);background:var(--cream);}
  .city-chip.featured{background:var(--wine);color:#fff;border-color:var(--wine);font-weight:600;}
  .add-city{margin-top:22px;font-size:14px;}

  /* ---------- GET INVOLVED ---------- */
  .involve-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
  @media (max-width:850px){.involve-grid{grid-template-columns:1fr;}}
  .involve-card{
    background:#fff;border:1px solid var(--line);border-radius:8px;padding:32px 28px;
    transition:transform .18s, box-shadow .18s;
  }
  .involve-card:hover{transform:translateY(-3px);box-shadow:0 16px 36px -16px rgba(34,32,29,0.2);}
  .involve-card .ic{width:38px;height:38px;margin-bottom:18px;color:var(--gold);}
  .involve-card h3{font-size:19px;margin-bottom:8px;}
  .involve-card p{font-size:14.5px;opacity:.75;margin:0 0 18px;}
  .involve-card a.go{font-size:13.5px;font-weight:700;color:var(--wine);}

  /* ---------- FOOTER ---------- */
  footer{background:var(--ink);color:rgba(246,239,227,0.7);padding:54px 0 28px;}
  .foot-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:32px;}
  .foot-brand{font-family:'Fraunces',serif;color:#fff;font-size:19px;}
  .foot-links{display:flex;gap:26px;font-size:14px;flex-wrap:wrap;}
  .foot-links a:hover{color:#fff;}
  .foot-bottom{
    margin-top:40px;padding-top:22px;border-top:1px solid rgba(246,239,227,0.12);
    font-size:12.5px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  }

  @media (prefers-reduced-motion: reduce){
    *{transition:none !important;}
  }
