  :root{
    /* Pink sky */
    --blush:        #f4d6d4;
    --rose:         #e6aeb0;
    --rose-deep:    #cf8d90;
    --dusk:         #b9747a;
    /* Fields + gold */
    --field:        #cdb079;
    --field-deep:   #b7965e;
    --gold:         #a9854f; /* decorative: borders, lines, hover */
    --gold-text:    #7c5d2e; /* darker gold for small text — passes WCAG AA on cream */
    /* Paper */
    --paper:        #fbf6ef;
    --paper-2:      #f5ece1;
    --paper-warm:   #f0e4d6;
    /* Ink */
    --ink:          #3a2c2b;
    --ink-soft:     #6f5d59;
    --line:         #e2d3c6;

    --serif: "Cormorant Garamond", Georgia, serif;
    --sans:  "Jost", "Helvetica Neue", Arial, sans-serif;
    --maxw: 1180px;
  }

  *{ box-sizing:border-box; margin:0; padding:0; }
  html{ scroll-behavior:smooth; scroll-padding-top:92px; }
  body{
    font-family:var(--sans);
    color:var(--ink);
    background:var(--paper);
    -webkit-font-smoothing:antialiased;
    line-height:1.6;
    overflow-x:hidden;
  }
  h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.05; }
  .label{
    font-family:var(--sans);
    font-weight:400;
    text-transform:uppercase;
    letter-spacing:.34em;
    font-size:.68rem;
    color:var(--gold-text);
  }
  a{ color:inherit; text-decoration:none; }
  .wrap{ max-width:var(--maxw); margin:0 auto; padding:0 32px; }

  /* visible keyboard focus everywhere */
  a:focus-visible, button:focus-visible, iframe:focus-visible{
    outline:2px solid var(--dusk); outline-offset:3px; border-radius:2px;
  }

  /* ---------- NAV ---------- */
  header{
    position:fixed; inset:0 0 auto 0; z-index:50;
    display:flex; align-items:center; justify-content:center;
    transition:background .4s ease, box-shadow .4s ease;
  }
  header.solid{ background:rgba(251,246,239,.9); backdrop-filter:blur(10px); box-shadow:0 1px 0 var(--line); }
  .nav{
    width:100%; max-width:var(--maxw); margin:0 auto; padding:20px 32px;
    display:flex; align-items:center; justify-content:space-between;
  }
  .brand{ display:flex; align-items:center; gap:12px; }
  .brand svg{ width:34px; height:34px; }
  .brand .name{ font-family:var(--serif); font-size:1.4rem; letter-spacing:.02em; }
  .navlinks{ display:flex; gap:36px; align-items:center; }
  .navlinks a{
    font-size:.8rem; text-transform:uppercase; letter-spacing:.18em; color:var(--ink);
    position:relative; padding:4px 0; transition:color .25s;
  }
  .navlinks a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:var(--dusk); transition:width .3s; }
  .navlinks a:hover{ color:var(--dusk); }
  .navlinks a:hover::after{ width:100%; }
  .nav-cta{
    border:1px solid var(--gold); color:var(--gold-text)!important; padding:9px 20px!important;
    border-radius:2px; letter-spacing:.18em!important;
  }
  .nav-cta::after{ display:none; }
  .nav-cta:hover{ background:var(--gold); color:var(--paper)!important; }
  .burger{ display:none; background:none; border:0; cursor:pointer; flex-direction:column; gap:5px; padding:6px; }
  .burger span{ width:24px; height:1.5px; background:var(--ink); display:block; }

  /* mobile fullscreen menu */
  .mobile-menu{
    position:fixed; inset:0; z-index:60; background:rgba(251,246,239,.98);
    backdrop-filter:blur(8px); display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:6px;
    opacity:0; visibility:hidden; transition:opacity .3s ease, visibility 0s linear .3s;
  }
  /* delay visibility 0s on open → becomes visible (and focusable) immediately; on close it
     stays visible for the .3s opacity fade-out before hiding */
  .mobile-menu.open{ opacity:1; visibility:visible; transition:opacity .3s ease, visibility 0s linear 0s; }
  .mobile-menu a{ font-family:var(--serif); font-size:1.9rem; color:var(--ink); padding:10px 16px; }
  .mobile-menu a.menu-cta{ margin-top:18px; font-family:var(--sans); font-size:.8rem; text-transform:uppercase; letter-spacing:.2em; border:1px solid var(--gold); color:var(--gold); border-radius:2px; padding:12px 26px; }
  .mobile-menu .close{ position:absolute; top:22px; right:26px; width:40px; height:40px; background:none; border:0; cursor:pointer; color:var(--ink); font-size:0; }
  .mobile-menu .close::before, .mobile-menu .close::after{ content:""; position:absolute; left:9px; top:19px; width:22px; height:1.5px; background:var(--ink); }
  .mobile-menu .close::before{ transform:rotate(45deg); }
  .mobile-menu .close::after{ transform:rotate(-45deg); }

  /* ---------- HERO ---------- */
  .hero{ position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
  .hero-photo{
    position:absolute; inset:0; z-index:0;
    background-image:url("../img/hero.jpg");
    background-position:center 38%; background-size:cover; background-repeat:no-repeat;
  }
  .hero-photo::after{
    content:""; position:absolute; inset:0;
    background:linear-gradient(180deg, rgba(244,214,212,.12) 0%, rgba(58,44,43,0) 30%, rgba(58,44,43,.16) 58%, rgba(58,44,43,.62) 100%);
  }
  .hero-inner{ position:relative; z-index:5; width:100%; padding-bottom:9vh; }
  .hero-card{ max-width:680px; }
  .hero .eyebrow{ color:#ffe7dd; letter-spacing:.4em; text-shadow:0 1px 14px rgba(58,44,43,.7); }
  .hero h1{
    font-size:clamp(3.4rem, 9vw, 7.2rem);
    color:#fff8f1; margin:.18em 0 .1em; letter-spacing:.01em; text-shadow:0 2px 30px rgba(58,44,43,.5);
  }
  .hero h1 em{ font-style:italic; font-weight:400; }
  .hero .sub{
    font-family:var(--serif); font-size:clamp(1.25rem,2.4vw,1.7rem); font-style:italic;
    color:#fdeee7; max-width:30ch; margin-bottom:28px; text-shadow:0 1px 18px rgba(58,44,43,.65);
  }
  .hero-meta{
    display:flex; gap:28px; align-items:center; flex-wrap:wrap;
    font-size:.74rem; letter-spacing:.22em; text-transform:uppercase; color:#fbe7dd; text-shadow:0 1px 12px rgba(58,44,43,.75);
  }
  .hero-meta .dot{ width:5px; height:5px; border-radius:50%; background:#f0c9b8; }
  .btn{
    display:inline-block; margin-top:30px; padding:14px 34px; border-radius:2px;
    background:#43292b; color:var(--paper); font-size:.76rem; letter-spacing:.22em; text-transform:uppercase;
    transition:transform .25s, background .25s;
  }
  .btn:hover{ background:#5b3a3b; transform:translateY(-2px); }

  /* botanical divider */
  .flourish{ display:flex; align-items:center; justify-content:center; gap:18px; color:var(--rose-deep); }
  .flourish .ln{ height:1px; width:64px; background:linear-gradient(90deg, transparent, var(--rose-deep)); }
  .flourish .ln.r{ background:linear-gradient(90deg, var(--rose-deep), transparent); }
  .flourish svg{ width:26px; height:26px; }

  /* ---------- STORY ---------- */
  section{ position:relative; }
  .story{ background:var(--paper); padding:120px 0 110px; }
  .story-grid{ display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
  .story h2{ font-size:clamp(2.3rem,4vw,3.4rem); margin:18px 0 22px; }
  .story p{ color:var(--ink-soft); margin-bottom:18px; font-size:1.02rem; }
  .story .sign{ font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--dusk); margin-top:8px; }
  .portrait{
    position:relative; aspect-ratio:4/5; border-radius:3px; overflow:hidden;
    background-image:url("../img/story.jpg");
    background-position:center 30%; background-size:cover; background-repeat:no-repeat;
    box-shadow:0 30px 60px -30px rgba(95,58,59,.4);
  }
  .portrait::after{ content:""; position:absolute; inset:0;
    background:linear-gradient(180deg, rgba(58,44,43,0) 45%, rgba(58,44,43,.6) 100%); }
  .portrait .frame{ position:absolute; inset:16px; border:1px solid rgba(255,255,255,.5); border-radius:2px; z-index:2; }
  .portrait .cap{ position:absolute; bottom:26px; left:0; right:0; text-align:center; color:#fff; z-index:2; }
  .portrait .cap .label{ color:rgba(255,255,255,.85); }
  .portrait .cap .nm{ font-family:var(--serif); font-size:1.4rem; }

  /* ---------- PRODUCE ---------- */
  .produce{ background:var(--paper-2); padding:120px 0; }
  .sec-head{ text-align:center; max-width:620px; margin:0 auto 64px; }
  .sec-head h2{ font-size:clamp(2.3rem,4.4vw,3.6rem); margin:16px 0 14px; }
  .sec-head p{ color:var(--ink-soft); }
  .cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
  .card{
    background:var(--paper); border:1px solid var(--line); border-radius:3px; overflow:hidden;
    transition:transform .35s ease, box-shadow .35s ease;
  }
  .card:hover{ transform:translateY(-6px); box-shadow:0 26px 50px -28px rgba(95,58,59,.35); }
  .card .top{ height:240px; overflow:hidden; }
  .card .top img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s ease; }
  .card:hover .top img{ transform:scale(1.05); }
  .card .body{ padding:26px 26px 30px; }
  .card h3{ font-size:1.7rem; margin-bottom:8px; }
  .card p{ color:var(--ink-soft); font-size:.95rem; margin-bottom:16px; }
  .tags{ display:flex; gap:8px; flex-wrap:wrap; }
  .tag{ font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-text);
    border:1px solid var(--line); border-radius:20px; padding:5px 12px; }

  /* ---------- FIELDS BANNER (pink sky) ---------- */
  .banner{ position:relative; min-height:70vh; display:flex; align-items:center; justify-content:center; text-align:center; overflow:hidden; }
  .banner-photo{ position:absolute; inset:0;
    background-image:url("../img/banner.jpg");
    background-position:center; background-size:cover; background-repeat:no-repeat; }
  .banner-photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(58,44,43,.25), rgba(58,44,43,.1) 40%, rgba(58,44,43,.45)); }
  .banner .inner{ position:relative; z-index:5; color:#fff8f1; padding:60px 24px; text-shadow:0 2px 22px rgba(58,44,43,.55); }
  .banner h2{ font-size:clamp(2.2rem,5vw,4rem); font-style:italic; max-width:18ch; margin:14px auto; }
  .banner .label{ color:#ffe3d8; }
  .banner .flourish{ color:#ffd9cb; }

  /* ---------- EVENTS ---------- */
  .events{ background:var(--ink); color:var(--paper); padding:130px 0; position:relative; overflow:hidden; }
  .events::before{ content:""; position:absolute; top:-40%; right:-10%; width:60%; height:120%;
    background:radial-gradient(circle, rgba(207,141,144,.35), transparent 65%); }
  .events-grid{ position:relative; display:grid; grid-template-columns:1.1fr .9fr; gap:64px; align-items:center; }
  .events .label{ color:var(--rose); }
  .events h2{ font-size:clamp(2.4rem,4.6vw,3.8rem); margin:18px 0 22px; color:var(--paper); }
  .events p{ color:#d8c7c1; margin-bottom:18px; }
  .events .soon{ display:inline-block; margin-top:14px; border:1px solid rgba(230,174,176,.4); color:var(--rose);
    padding:10px 22px; border-radius:2px; font-size:.72rem; letter-spacing:.24em; text-transform:uppercase; }
  .venue{ aspect-ratio:5/4; border-radius:3px; position:relative; overflow:hidden;
    background-image:url("../img/events.jpg");
    background-position:center; background-size:cover; background-repeat:no-repeat;
    box-shadow:0 30px 60px -30px rgba(0,0,0,.6);
  }

  /* ---------- VISIT / FOOTER ---------- */
  .visit{ background:var(--paper-warm); padding:110px 0 0; }
  .visit-grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; }
  .visit h2{ font-size:clamp(2.2rem,4vw,3.2rem); margin:16px 0 24px; }
  .vrow{ display:flex; gap:16px; padding:18px 0; border-top:1px solid var(--line); }
  .vrow .k{ width:120px; flex-shrink:0; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-text); padding-top:3px; }
  .vrow .v{ color:var(--ink); }
  .vrow .v a{ color:var(--dusk); }
  .vrow .v a:hover{ text-decoration:underline; }
  /* contact channels */
  .channels{ display:flex; flex-wrap:wrap; gap:12px; margin-top:30px; }
  .chan{ display:inline-flex; align-items:center; gap:9px; padding:12px 20px; border-radius:2px;
    font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; border:1px solid var(--line);
    color:var(--ink); transition:border-color .25s, color .25s, background .25s, transform .25s; }
  .chan svg{ width:16px; height:16px; }
  .chan:hover{ border-color:var(--dusk); color:var(--dusk); transform:translateY(-2px); }
  .chan.primary{ background:#43292b; color:var(--paper); border-color:#43292b; }
  .chan.primary:hover{ background:#5b3a3b; color:var(--paper); }
  /* map */
  .map-col{ display:flex; flex-direction:column; gap:14px; }
  .map{ border-radius:3px; overflow:hidden; border:1px solid var(--line); flex:1; min-height:340px; }
  .map iframe{ width:100%; height:100%; min-height:340px; border:0; display:block; }
  .directions{ align-self:flex-start; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--dusk); display:inline-flex; align-items:center; gap:8px; }
  .directions svg{ width:15px; height:15px; }
  .directions:hover{ text-decoration:underline; }

  footer{ margin-top:100px; background:var(--ink); color:#d8c7c1; padding:64px 0 36px; }
  .foot-grid{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; align-items:flex-start; }
  .foot-brand .name{ font-family:var(--serif); font-size:1.6rem; color:var(--paper); display:flex; align-items:center; gap:12px; }
  .foot-brand p{ margin-top:12px; max-width:34ch; font-size:.92rem; }
  .foot-col h4{ font-family:var(--sans); font-weight:500; text-transform:uppercase; letter-spacing:.2em; font-size:.7rem; color:var(--rose); margin-bottom:16px; }
  .foot-col a{ display:block; color:#d8c7c1; font-size:.92rem; padding:5px 0; transition:color .2s; }
  .foot-col a:hover{ color:var(--paper); }
  .foot-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:48px; padding-top:24px;
    display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.78rem; color:#a9928b; }

  /* ---------- VALUES / TRUST STRIP ---------- */
  .values{ background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
  .values .row{ display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:20px 52px; padding:36px 0; }
  .values .item{ display:inline-flex; align-items:center; gap:11px; font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink); }
  .values .item svg{ width:18px; height:18px; color:var(--dusk); flex-shrink:0; }

  /* WebP backgrounds — applied ONLY when the browser fully supports image-set + type();
     otherwise the plain JPG url above is kept, so backgrounds always render. */
  @supports (background-image: image-set(url("x.webp") type("image/webp"))){
    .hero-photo{   background-image:image-set(url("../img/hero.webp")   type("image/webp"), url("../img/hero.jpg")   type("image/jpeg")); }
    .portrait{     background-image:image-set(url("../img/story.webp")  type("image/webp"), url("../img/story.jpg")  type("image/jpeg")); }
    .banner-photo{ background-image:image-set(url("../img/banner.webp") type("image/webp"), url("../img/banner.jpg") type("image/jpeg")); }
    .venue{        background-image:image-set(url("../img/events.webp") type("image/webp"), url("../img/events.jpg") type("image/jpeg")); }
  }

  /* reveal — only hidden when JS is present, so no-JS users still see content */
  .js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s ease, transform .9s ease; }
  .js .reveal.in{ opacity:1; transform:none; }

  /* ---------- RESPONSIVE ---------- */
  @media (max-width:880px){
    .navlinks{ display:none; }
    .burger{ display:flex; }
    .story-grid,.events-grid,.visit-grid{ grid-template-columns:1fr; gap:40px; }
    .cards{ grid-template-columns:1fr; }
    .hero-inner{ padding-bottom:12vh; }
    .values .row{ gap:26px 36px; padding:28px 0; }
    /* phones get a lighter hero (≈125KB webp vs 396KB) */
    .hero-photo{ background-image:url("../img/hero-mobile.jpg"); }
  }
  @supports (background-image: image-set(url("x.webp") type("image/webp"))){
    @media (max-width:880px){
      .hero-photo{ background-image:image-set(url("../img/hero-mobile.webp") type("image/webp"), url("../img/hero-mobile.jpg") type("image/jpeg")); }
    }
  }
  @media (prefers-reduced-motion:reduce){
    .js .reveal{ opacity:1; transform:none; transition:none; }
    .card:hover .top img{ transform:none; }
    html{ scroll-behavior:auto; }
  }

  /* design comparison switcher — remove before launch */
  .vswitch{position:fixed;z-index:90;bottom:18px;left:50%;transform:translateX(-50%);background:rgba(58,44,43,.94);backdrop-filter:blur(8px);color:#fbf6ef;border-radius:100px;padding:7px 8px 7px 16px;display:flex;align-items:center;gap:10px;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;box-shadow:0 14px 30px -14px rgba(0,0,0,.6)}
  .vswitch span{opacity:.6}
  .vswitch a{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fbf6ef;font-size:.8rem}
  .vswitch a.on{background:var(--dusk);color:#fff;font-weight:600}
