
:root{
  --bg:#fff;
  --text:#1b1b1b;
  --muted:#6b705c;
  --accent:#c8573a; /* terracotta */
  --accent-2:#d3ad7f; /* warm sand */
  --card:#f7f5f2;
  --border:#e9e5df;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text); background:var(--bg); line-height:1.6;
}

img{max-width:100%; display:block; height:auto; border-radius:16px}
a{color:var(--accent); text-decoration:none}
a:hover{opacity:.9}

.container{width:min(1100px, 92vw); margin-inline:auto}
.container.narrow{width:min(800px, 90vw)}

.site-header{
  position:sticky; top:0; z-index:10; backdrop-filter:saturate(180%) blur(8px);
  background:color-mix(in oklab, white 85%, var(--accent-2) 15%);
  border-bottom:1px solid var(--border);
}
.site-header .nav{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
.brand{font-weight:800; letter-spacing:.12em}
.site-header ul{list-style:none; display:flex; gap:1.2rem; margin:0; padding:0}
.site-header a{color:inherit}
.site-header a:hover{color:var(--accent)}

.hero{position:relative; min-height:68svh; display:grid; place-items:stretch; overflow:hidden}
.hero-image{position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.06)}
.hero-overlay{position:relative; padding:18svh 0 12svh; background:linear-gradient(to bottom, rgba(0,0,0,.55), rgba(0,0,0,.35), rgba(0,0,0,.05), transparent); color:#fff}
.hero h1{font-size:clamp(2rem,6vw,4rem); margin:0 0 .6rem}
.hero .tagline{font-weight:600; letter-spacing:.02em; margin:.2rem 0 1.2rem}
.hero .lead{max-width:60ch}

.section{padding:72px 0}
.center{text-align:center}

.grid-2{display:grid; grid-template-columns:1fr; gap:28px}
@media(min-width:880px){.grid-2{grid-template-columns:1fr 1fr}}

.grid-3{display:grid; grid-template-columns:1fr; gap:22px}
@media(min-width:900px){.grid-3{grid-template-columns:repeat(3,1fr)}}

.card{background:var(--card); border:1px solid var(--border); border-radius:22px; overflow:hidden; display:flex; flex-direction:column; box-shadow:0 10px 26px rgba(0,0,0,.04)}
.card-body{padding:18px 18px 22px}
.card h3{margin:0 0 .4rem}

.masonry{columns:1; column-gap:18px}
.masonry-item{break-inside:avoid; margin:0 0 18px}
@media(min-width:680px){.masonry{columns:2}}
@media(min-width:1040px){.masonry{columns:3}}

.hours table{width:100%; border-collapse:collapse}
.hours th,.hours td{padding:10px 8px; border-bottom:1px dashed var(--border); text-align:left}
.hours th{font-weight:600; white-space:nowrap}

.btn{display:inline-block; background:var(--accent); color:#fff; padding:.7rem 1rem; border-radius:999px; border:2px solid var(--accent); font-weight:600}
.btn.btn-outline{background:transparent; color:#fff; border-color:#fff}
.btn + .btn{margin-left:.4rem}

.site-footer{background:#111; color:#eee; padding:48px 0 22px; margin-top:72px}
.site-footer a{color:#fff}
.site-footer .legal{margin-top:14px; border-top:1px solid rgba(255,255,255,.12); padding-top:12px}
.small{font-size:.92rem; color:#bbb}

.section.page h1{margin-top:0}
.content p{margin:.6rem 0 1rem}

/* Scroll reveal animation */
[data-reveal]{opacity:0; transform:translateY(18px); transition:opacity 1.4s ease, transform 1.4s ease}
.reveal-visible,[data-reveal].reveal-visible{opacity:1; transform:none}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  [data-reveal]{opacity:1!important; transform:none!important; transition:none!important}
  .hero-image{transform:none}
}

/* A11y helpers */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Make menu wrap when space is tight (fallback) */
.site-header ul{flex-wrap:wrap}

/* Hamburger for small screens */
.menu-toggle{display:none;background:transparent;border:0;width:44px;height:44px;border-radius:8px}
.menu-toggle .bar{display:block;height:2px;margin:6px 8px;background:currentColor}

@media (max-width: 860px){
  .menu-toggle{display:inline-block}
  .site-header .mainnav{position:relative}
  .site-header .mainnav ul{
    display:none; position:absolute; right:0; top:60px;
    background:color-mix(in oklab, white 92%, black 8%);
    border:1px solid var(--border); border-radius:16px; padding:12px 16px;
    box-shadow:0 10px 30px rgba(0,0,0,.1);
    flex-direction:column; gap:.6rem; min-width:230px
  }
  .site-header .mainnav[data-open="true"] ul{display:flex}
}
