:root{
  --bg:#fcfbf7;
  --paper:#ffffff;
  --paper-2:#f4efe8;
  --text:#1f1b18;
  --muted:#6e6761;
  --line:#e5ded5;
  --line-strong:#d7cfc4;
  --shadow:0 18px 45px rgba(25,20,16,.08);
  --radius:28px;
  --max:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:Arial, Helvetica, sans-serif;
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
@media (prefers-reduced-motion: reduce){*{transition:none!important;animation:none!important}}
.container{width:min(calc(100% - 36px),var(--max));margin:0 auto}

.site-header{
  position:sticky;top:0;z-index:30;
  background:rgba(252,251,247,.88);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(31,27,24,.08);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:14px 0;
}
.brand img{height:86px;width:auto}
.nav{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.nav a{
  position:relative;overflow:hidden;
  padding:11px 14px;border-radius:999px;color:var(--muted);
  border:1px solid transparent;transition:color .28s ease, border-color .28s ease, background-color .28s ease, transform .28s ease, box-shadow .28s ease;
}
.nav a::after{
  content:"";position:absolute;left:18px;right:18px;bottom:9px;height:1px;
  background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .32s ease;opacity:.65;
}
.nav a:hover,.nav a.is-active{
  color:var(--text);
  border-color:var(--line);
  background:rgba(255,255,255,.82);
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(25,20,16,.06);
}
.nav a:hover::after,.nav a.is-active::after{transform:scaleX(1)}
.nav .book-link{
  border-color:var(--text);
  background:var(--text);
  color:#fff;
  font-weight:700;
}
.nav .book-link:hover{background:#000;border-color:#000;color:#fff}

.section{padding:82px 0}
.section-soft{background:linear-gradient(180deg,#f7f2eb 0%, #faf7f2 100%);border-top:1px solid rgba(31,27,24,.04);border-bottom:1px solid rgba(31,27,24,.04)}

.hero-grid,.page-hero-grid,.cols-2,.intro-grid,.cards-3,.footer-grid{
  display:grid;gap:24px;
}
.hero-grid{grid-template-columns:1.05fr .95fr;align-items:center}
.page-hero-grid,.cols-2{grid-template-columns:1fr 1fr;align-items:start}
.intro-grid{grid-template-columns:1.05fr .95fr .95fr}
.cards-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.hero-copy h1,.section-head h2,.page-hero h1,.info-card h2,.panel h2,.booking-band h2{
  margin:0;
  font-family:Georgia,"Times New Roman",serif;
  font-weight:600;
  line-height:.98;
  letter-spacing:.01em;
}
.hero-copy h1{font-size:clamp(48px,7vw,86px);margin-bottom:18px}
.page-hero h1{font-size:clamp(38px,5vw,68px);margin-bottom:14px}
.lead{
  font-size:clamp(18px,2vw,21px);
  color:var(--muted);
  max-width:640px;
}
.eyebrow,.card-label,.footer-label{
  display:inline-block;
  font-size:12px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.eyebrow{margin-bottom:16px;color:var(--muted)}
.eyebrow.dark{color:#4b443f}
.card-label,.footer-label{color:#6f675e;margin-bottom:14px}
.hero-actions,.band-actions,.inline-links{
  display:flex;gap:12px;flex-wrap:wrap;
}
.hero-actions{margin-top:28px}
.btn{
  position:relative;overflow:hidden;isolation:isolate;
  min-height:52px;
  padding:0 24px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;
  font-weight:700;letter-spacing:.01em;
  border:1px solid var(--line-strong);
  transition:transform .28s ease, box-shadow .28s ease, background-color .28s ease, border-color .28s ease, color .28s ease;
}
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.06) 30%, rgba(255,255,255,.34) 48%, rgba(255,255,255,.08) 62%, transparent 100%);
  transform:translateX(-140%);transition:transform .75s cubic-bezier(.19,1,.22,1);
}
.btn::after{
  content:"";position:absolute;left:22px;right:22px;bottom:11px;height:1px;opacity:.45;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .34s ease;
}
.btn-dark{background:var(--text);color:#fff;border-color:var(--text);box-shadow:0 12px 30px rgba(31,27,24,.14)}
.btn-dark:hover{background:#000;border-color:#000;color:#fff;transform:translateY(-2px);box-shadow:0 18px 38px rgba(31,27,24,.2)}
.btn-light{background:rgba(255,255,255,.82);box-shadow:0 10px 26px rgba(31,27,24,.06)}
.btn-light:hover{background:#fff;transform:translateY(-2px);box-shadow:0 18px 34px rgba(31,27,24,.1)}
.btn:hover::before{transform:translateX(140%)}
.btn:hover::after{transform:scaleX(1)}

.hero-image,.brand-panel,.info-card,.service-card,.panel,.stack-card,.page-logo-card,.booking-band,.preview-tile,.masonry-item{
  background:var(--paper);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.hero-image,.stack-card,.page-logo-card,.booking-band,.panel,.info-card,.service-card,.preview-tile,.masonry-item{border-radius:var(--radius)}

.hero-image{
  overflow:hidden;
  aspect-ratio:4 / 5.2;
}
.hero-image img{
  width:100%;height:100%;object-fit:cover
}
.brand-panel{
  margin-top:26px;
  padding:22px;
  border-radius:32px;
}
.brand-panel img{
  width:min(100%,520px);
  margin:0 auto;
}
.info-card,.service-card,.panel{padding:28px}
.info-card h2,.panel h2{font-size:clamp(28px,3vw,44px);margin-bottom:12px}
.info-card p,.service-card p,.panel p,.section-note,.footer-copy{color:var(--muted);margin:0}
.feature-list,.hours-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.feature-list li,.hours-list li,.menu-list > div{
  display:flex;justify-content:space-between;gap:14px;padding:14px 0;
  border-bottom:1px solid var(--line);
}
.feature-list li:last-child,.hours-list li:last-child,.menu-list > div:last-child{border-bottom:0}
.feature-list li{display:block}
.hours-list li span,.menu-list span{color:var(--muted)}
.hours-list.compact li{padding:10px 0}
.service-card h3{
  margin:0 0 10px;
  font-family:Georgia,"Times New Roman",serif;
  font-size:32px;
}

.section-head{
  display:flex;align-items:end;justify-content:space-between;gap:18px;
  margin-bottom:26px;
}
.section-head h2{font-size:clamp(34px,4vw,58px)}
.section-note{max-width:560px}
.text-link{
  font-weight:700;color:var(--text);
  border-bottom:1px solid var(--text)
}

.preview-grid{
  display:grid;gap:18px;
  grid-template-columns:1.05fr .95fr .95fr;
  grid-auto-rows:240px;
}
.preview-tile{
  position:relative;overflow:hidden;transition:transform .34s ease, box-shadow .34s ease, border-color .34s ease;
}
.preview-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(255,255,255,0) 35%, rgba(31,27,24,.08) 100%);opacity:0;transition:opacity .34s ease}
.preview-tile img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.preview-tile:hover{transform:translateY(-4px);box-shadow:0 24px 44px rgba(25,20,16,.12);border-color:var(--line-strong)}
.preview-tile:hover img{transform:scale(1.04)}
.preview-tile:hover::after{opacity:1}
.preview-tile span{
  position:absolute;left:16px;bottom:16px;
  padding:8px 12px;border-radius:999px;
  background:rgba(255,255,255,.88);
  font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
}
.preview-tile.tall{grid-row:span 2}
.preview-tile.wide{grid-column:span 2}

.booking-band{
  padding:32px;
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:18px;
}
.booking-band h2{font-size:clamp(34px,4vw,54px);margin-bottom:6px}
.booking-band p{margin:0;color:var(--muted)}

.page-logo-card{
  padding:30px;
}
.page-logo-card img{width:min(100%,520px);margin:0 auto}
.stack-card{padding:0;overflow:hidden}
.stack-card img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover}

.masonry{
  column-count:3;
  column-gap:18px;
}
.masonry-item{
  display:inline-block;width:100%;overflow:hidden;margin:0 0 18px;
}
.masonry-item img{width:100%;height:auto;display:block}
.masonry-item figcaption{
  padding:14px 16px;
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#5f5851
}
.map-frame{
  margin-top:18px;border-radius:24px;overflow:hidden;border:1px solid var(--line);min-height:360px
}
.map-frame iframe{width:100%;height:360px;border:0}
.contact-stack{display:grid;gap:12px;margin-top:18px}
.contact-stack a,.inline-links a{
  color:var(--text);font-weight:700;border-bottom:1px solid rgba(31,27,24,.22);width:max-content
}
.menu-list{display:grid}
.footer-grid{grid-template-columns:1.2fr .9fr .8fr}
.site-footer{
  padding:32px 0 48px;
  border-top:1px solid var(--line);
}
.footer-logo{height:100px;width:auto;margin-bottom:12px}
.footer-copy{max-width:440px}

@media (max-width: 1100px){
  .hero-grid,.page-hero-grid,.cols-2,.intro-grid,.cards-3,.footer-grid,.booking-band{grid-template-columns:1fr}
  .preview-grid{grid-template-columns:1fr 1fr}
  .preview-tile.tall,.preview-tile.wide{grid-row:auto;grid-column:auto}
}
@media (max-width: 760px){
  .header-inner{flex-direction:column;align-items:flex-start}
  .nav{width:100%;justify-content:flex-start}
  .brand img{height:78px}
  .section{padding:64px 0}
  .hero-copy h1{font-size:44px}
  .page-hero h1,.section-head h2,.info-card h2,.panel h2,.booking-band h2{font-size:34px}
  .preview-grid{grid-template-columns:1fr;grid-auto-rows:260px}
  .masonry{column-count:1}
  .btn{width:100%}
  .hero-actions,.band-actions,.inline-links{display:grid;grid-template-columns:1fr}
}


/* Premium underline animation */
.navbar a,
.btn-outline,
.btn-secondary,
.btn.ghost,
a.text-link {
  position: relative;
}

.navbar a::after,
.btn-outline::after,
.btn-secondary::after,
.btn.ghost::after,
a.text-link::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 12px;
  width: 0;
  height: 1.5px;
  background: currentColor;
  transform: translateX(-50%);
  transition: width 0.38s ease;
  opacity: 0.95;
}

.navbar a:hover::after,
.btn-outline:hover::after,
.btn-secondary:hover::after,
.btn.ghost:hover::after,
a.text-link:hover::after {
  width: calc(100% - 34px);
}

.btn-outline,
.btn-secondary,
.btn.ghost {
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease;
}

.btn-outline:hover,
.btn-secondary:hover,
.btn.ghost:hover {
  transform: translateY(-1px);
}

/* Fullscreen intro */
#intro {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  transition: opacity 0.6s ease;
}

.intro-logo {
  width: 180px;
  opacity: 0;
  animation: fadeIn 1s ease forwards;
}

@keyframes fadeIn {
  to { opacity: 1; }
}


/* Big hero logo */
.hero-logo {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 40px 0;
}

.hero-logo img {
  width: 320px;
  max-width: 80%;
}


.brand-text {
  padding-top: 20px;
  padding-bottom: 60px;
  text-align: center;
}

.brand-title {
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 1.05;
  margin: 0 0 24px;
  letter-spacing: 0.02em;
}

.brand-desc {
  max-width: 680px;
  margin: 0 auto 14px;
  color: #5f5852;
  font-size: 1rem;
  line-height: 1.8;
}


.brand-text {
  padding: 80px 20px;
  text-align: center;
}

.brand-title {
  font-size: 42px;
  margin-bottom: 30px;
}

.brand-desc {
  max-width: 750px;
  margin: 0 auto 20px;
  font-size: 17px;
  line-height: 1.9;
  color: #444;
}


.split-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
  align-items: center;
}

.split-text {
  text-align: left;
}

.split-image img {
  width: 100%;
  border-radius: 10px;
}

@media (max-width: 768px) {
  .split-grid {
    grid-template-columns: 1fr;
  }

  .split-text {
    text-align: center;
  }
}


.split-image {
  width: 100%;
  height: 100%;
}

.split-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  display: block;
}
