/* Base */
:root{--bg:#0f0f10;--panel:#151517;--muted:#6b6b70;--text:#1b1b1d;--brand:#8d5a2b;--brand-2:#b07a3f;--stroke:#e7e2db}
body.theme--brown{--bg:#f9f4ee;--panel:#fff;--muted:#6b6b70;--text:#1b1b1d;--brand:#8d5a2b;--brand-2:#b07a3f;--stroke:#e7e2db}
*{box-sizing:border-box}
html,body{margin:0;height:100%;scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* Layout */
.container{width:100%;max-width:1120px;margin:0 auto;padding:0 20px}
.section{padding:72px 0;border-top:1px solid var(--stroke)}
.section--alt{background:var(--panel)}

/* Vision */
#vision h2{font-family:"Playfair Display",serif;font-size:36px;line-height:1.2;margin:0 0 12px}
#vision h2::after{content:"";display:block;width:56px;height:4px;background:var(--brand);border-radius:999px;margin-top:10px}
#vision p{color:var(--muted);max-width:880px;margin:8px 0 0}

/* Mission - mirrors Vision styles */
#mission h2{font-family:"Playfair Display",serif;font-size:36px;line-height:1.2;margin:0 0 12px}
#mission h2::after{content:"";display:block;width:56px;height:4px;background:var(--brand);border-radius:999px;margin-top:10px}
#mission p{color:var(--muted);max-width:880px;margin:8px 0 0}

/* Section taglines */
.section-tag{display:inline-block;font-weight:600;letter-spacing:.02em;color:var(--brand-2);background:linear-gradient(135deg, rgba(176,122,63,.10), rgba(141,90,43,.08));border:1px solid var(--stroke);padding:6px 10px;border-radius:999px;margin:0 0 10px}

/* Subtle decorative backgrounds */
#vision{position:relative;overflow:hidden}
#mission{position:relative;overflow:hidden}
#vision::before,#mission::before{content:"";position:absolute;inset:auto -80px -60px auto;width:220px;height:220px;border-radius:50%;background:radial-gradient(closest-side, rgba(141,90,43,.12), transparent 70%);pointer-events:none;filter:blur(0.4px)}

/* Header */
.site-header{position:sticky;top:0;background:rgba(255,255,255,.7);backdrop-filter:saturate(140%) blur(8px);z-index:50;border-bottom:1px solid var(--stroke)}
.site-header .nav{display:flex;align-items:center;justify-content:space-between;height:140px}
.logo{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:14px;background:linear-gradient(135deg, rgba(141,90,43,.18), rgba(176,122,63,.10));border:1px solid var(--stroke);box-shadow:0 4px 14px rgba(0,0,0,.06);transition:transform .18s ease, box-shadow .18s ease, background .18s ease}
.logo:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,0,0,.08);background:linear-gradient(135deg, rgba(141,90,43,.22), rgba(176,122,63,.14))}
.site-header .logo img{height:120px;width:auto;filter: drop-shadow(0 3px 8px rgba(0,0,0,.10))}
.site-footer .logo img{height:40px;width:auto}
.nav-links{display:flex;gap:24px;align-items:center}
.nav-links a{color:var(--muted)}
.nav-links a:hover{color:var(--text)}
.btn{background:var(--brand);color:#1a1a1a;padding:10px 16px;border-radius:999px;font-weight:600;display:inline-block}
.btn--small{padding:8px 14px}
.link{color:var(--brand)}

.nav-toggle{display:none;flex-direction:column;gap:4px;background:transparent;border:0;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:2px;background:#e9e9ea}
.mobile-menu{display:none;flex-direction:column;gap:16px;padding:16px 20px;border-bottom:1px solid var(--stroke);background:rgba(255,255,255,.95)}
.mobile-menu.show{display:flex}

/* Hero */
.hero{padding:96px 0;background:radial-gradient(1200px 500px at 70% -10%, rgba(141,90,43,.12), transparent), linear-gradient(180deg, rgba(0,0,0,.02), transparent)}
.hero__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.hero__text h1{font-family:"Playfair Display",serif;font-size:48px;line-height:1.1;margin:0 0 16px}
.hero__text p{color:var(--muted);margin:0 0 24px}
.hero__actions{display:flex;gap:16px;align-items:center}
.hero__media .card{border:1px solid var(--stroke);border-radius:16px;overflow:hidden;background:#fff}
.hero__media img{aspect-ratio:4/3;object-fit:cover}

/* Slider */
.slider{position:relative}
.slides{display:flex;transition:transform .45s ease;will-change:transform}
.slide{min-width:100%}

/* Fade effect variant */
.slider--fade{position:relative}
.slider--fade .slides{position:relative;display:block;transition:none}
.slider--fade .slide{position:absolute;inset:0;min-width:0;opacity:0;transition:opacity .5s ease}
.slider--fade .slide.is-active{opacity:1;position:relative}
.slider__btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.9);border:1px solid var(--stroke);width:36px;height:36px;border-radius:999px;display:grid;place-items:center;cursor:pointer;color:#333}
.slider__btn--prev{left:10px}
.slider__btn--next{right:10px}
.slider__dots{position:absolute;left:0;right:0;bottom:8px;display:flex;gap:6px;justify-content:center}
.slider__dots button{width:8px;height:8px;border-radius:999px;border:0;background:rgba(0,0,0,.22);cursor:pointer}
.slider__dots button[aria-current="true"]{background:var(--brand)}

/* Minimal variant for hero */
.slider--minimal .slider__dots{bottom:12px}
.slider--minimal .slider__btn{display:none}
.slider--minimal .slider__dots button{background:rgba(0,0,0,.18)}
.slider--minimal .slider__dots button[aria-current="true"]{background:var(--brand);box-shadow:0 0 0 3px rgba(141,90,43,.12)}

/* Grid / Cards */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:20px}
.card{border:1px solid var(--stroke);border-radius:12px;padding:16px;background:#fff}
.card h3{margin:0 0 8px}
.card img{border-radius:10px;border:1px solid var(--stroke);aspect-ratio:4/3;object-fit:cover;margin:0 0 12px}

/* Menu categories */
.menu-category{margin-top:36px}
.menu-category h3{margin:0 0 12px}

/* Menu slider variant */
.slider--menu{margin-top:16px}
.slider--menu .slider__btn{background:#fff}

.media-tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.media-tiles img{border-radius:12px;border:1px solid var(--stroke);aspect-ratio:4/3;object-fit:cover}

/* Locations */
.locations{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.location{border:1px solid var(--stroke);border-radius:12px;padding:16px;background:#fff}
.location h3{margin:0 0 6px}
.location img{border-radius:10px;border:1px solid var(--stroke);aspect-ratio:16/9;object-fit:cover;margin:0 0 10px}
.location iframe{width:100%;height:240px;border:1px solid var(--stroke);border-radius:10px}
.contact-list{list-style:none;padding:0;margin:16px 0 0;display:grid;gap:6px;color:var(--muted)}
.contact-list .social-links{display:flex;gap:12px;align-items:center}
.contact-list .social-links a{display:inline-flex;gap:8px;align-items:center;color:var(--text)}
.contact-list .social-links a:hover{color:var(--brand)}
.contact-list .social-links svg{width:16px;height:16px;display:block}
.contact-form{display:grid;gap:12px}
.contact-form label{display:grid;gap:6px;color:var(--muted)}
.contact-form input,.contact-form textarea{padding:10px 12px;border-radius:10px;border:1px solid var(--stroke);background:#fff;color:#1b1b1d}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#8a8a8f}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(141,90,43,.12)}
.contact-form button{justify-self:start}

/* Footer */
.site-footer{border-top:1px solid var(--stroke);padding:28px 0;background:#fff}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:20px}
.footer-links{display:flex;gap:16px;color:var(--muted)}
.footer-links a:hover{color:var(--text)}
.footer-hours ul{list-style:none;margin:0;padding:0;color:var(--muted);display:grid;gap:2px;font-size:14px}
.copyright{color:var(--muted);margin:0}

/* To top */
.to-top{position:fixed;right:20px;bottom:24px;background:#fff;border:1px solid var(--stroke);border-radius:999px;width:40px;height:40px;color:#333;display:grid;place-items:center;cursor:pointer;opacity:0;transform:translateY(8px);transition:all .2s ease}
.to-top.show{opacity:1;transform:none}

/* Responsive */
@media (max-width: 960px){
  .hero__inner{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .locations{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 720px){
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .cards{grid-template-columns:1fr}
  .hero__text h1{font-size:40px}
  .mobile-menu{display:flex}
}

