
:root{
  --cream:#fbf7ef;
  --paper:#fffaf2;
  --ink:#263126;
  --muted:#6e6a5e;
  --green:#314c31;
  --green-2:#243b26;
  --gold:#c18b2c;
  --red:#7f1018;
  --red-dark:#5e0b12;
  --line:#e5d9c4;
  --shadow:0 12px 30px rgba(49,38,24,.12);
  --radius:18px;
  --font-serif:Georgia,"Times New Roman",serif;
  --font-sans:Arial,"Helvetica Neue",sans-serif;
  --font-script:"Segoe Script","Brush Script MT",cursive;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--font-serif);
  font-size:18px;
  line-height:1.5;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1120px,92vw);margin:0 auto}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,250,242,.96);
  border-bottom:1px solid rgba(229,217,196,.8);
  backdrop-filter:blur(10px);
}
.navbar{
  height:92px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
}
.logo{width:260px;display:flex;align-items:center}
.logo img{width:100%;height:auto}
.menu{display:flex;align-items:center;gap:34px;font-size:18px}
.menu a{
  position:relative;
  padding:10px 2px;
  transition:color .25s ease, transform .25s ease, background-color .25s ease;
}
.menu a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:2px;
  height:2px;
  background:var(--green);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .25s ease;
}
.menu a:hover,.menu a.active{color:var(--green);transform:translateY(-1px)}
.menu a:hover::after,.menu a.active::after{transform:scaleX(1)}

.btn{
  border:1px solid var(--green);
  padding:14px 26px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  text-transform:uppercase;
  font-family:var(--font-sans);
  letter-spacing:.04em;
  font-weight:700;
  font-size:13px;
  border-radius:3px;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease;
  cursor:pointer;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 18px rgba(35,43,30,.12)}
.btn.green{background:var(--green);color:#fff}
.btn.green:hover{background:var(--green-2)}
.btn.red{background:var(--red);border-color:var(--red);color:#fff}
.btn.red:hover{background:var(--red-dark)}
.btn.light{background:#fffaf2;color:var(--green)}

.hero{
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--line);
  background:linear-gradient(90deg,#fffaf2 0%,#fffaf2 42%,rgba(255,250,242,.15) 62%,transparent 100%);
}
.hero::before{
  content:"";
  position:absolute;
  left:-20px;top:0;bottom:0;
  width:160px;
  opacity:.35;
  background:
    radial-gradient(ellipse at 25px 100px, transparent 20px, rgba(68,91,68,.35) 21px, transparent 23px),
    radial-gradient(ellipse at 52px 170px, transparent 20px, rgba(68,91,68,.3) 21px, transparent 23px);
}
.hero-wrap{display:grid;grid-template-columns:1fr 1.2fr;min-height:510px;align-items:center}
.hero-copy{position:relative;z-index:2;padding:70px 0}
.eyebrow{font-family:var(--font-script);color:var(--gold);font-size:40px;margin:0 0 4px}
.hero h1,.page-title{color:var(--green);font-size:72px;line-height:.98;margin:0 0 24px;font-weight:600}
.hero p{max-width:470px;color:#2c2f27;margin:0 0 30px}
.decor{width:120px;height:18px;margin:0 0 26px;position:relative}
.decor-center{margin:0 auto 10px}
.decor::before,.decor::after{content:"";position:absolute;top:8px;width:46px;height:1px;background:var(--gold)}
.decor::before{left:0}.decor::after{right:0}
.decor span{position:absolute;left:50%;top:50%;width:16px;height:16px;border:1px solid var(--gold);transform:translate(-50%,-50%) rotate(45deg)}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap}
.hero-img{position:absolute;right:0;top:0;bottom:0;width:58%}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-img::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#fffaf2 0%,rgba(255,250,242,.78) 16%,rgba(255,250,242,.08) 45%,transparent 100%)}

.section{padding:58px 0}
.section-compact{padding-top:0}
.section-gallery-wall{padding-top:10px}
.section-soft{background:linear-gradient(180deg,rgba(255,250,242,.35),rgba(246,237,224,.42))}
.section-title{text-align:center;margin-bottom:34px}
.section-title h2{color:var(--green);font-size:42px;line-height:1;margin:0 0 8px;font-weight:600}
.section-title p{margin:0;color:var(--muted)}
.gold-lead{color:var(--gold);font-size:24px}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.card{
  background:rgba(255,250,242,.72);
  border:1px solid var(--line);
  border-radius:10px;
  padding:34px 28px;
  text-align:center;
  box-shadow:0 10px 28px rgba(74,52,24,.05);
}
.icon{width:68px;height:68px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;margin:-12px auto 18px;font-size:30px}
.small-icon{margin:0;width:48px;height:48px;font-size:22px}
.card h3{font-size:28px;color:var(--green);margin:0 0 8px}
.card p{font-size:17px;margin:0;color:#3d3a31}

.photo-grid,
.photo-wall{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:12px;
}
.photo-card{
  margin:0;
  background:#fffaf2;
  border:1px solid rgba(229,217,196,.95);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 10px 25px rgba(72,52,25,.08);
  min-height:0;
}
.photo-card img{
  width:100%;
  height:100%;
  display:block;
  background:linear-gradient(135deg,#fffaf2,#f2eadf);
  object-fit:contain;
}
.photo-card.cover img{object-fit:cover}
.photo-card.contain img{object-fit:contain;padding:6px}
.photo-card.wide{grid-column:span 6;aspect-ratio:16/9}
.photo-card.landscape{grid-column:span 4;aspect-ratio:4/3}
.photo-card.square{grid-column:span 4;aspect-ratio:1/1}
.photo-card.portrait{grid-column:span 3;aspect-ratio:3/4}
.photo-card.tall{grid-column:span 4;grid-row:span 2;aspect-ratio:3/4}

.home-gallery .portrait{grid-column:span 4}
.home-gallery .square{grid-column:span 4}
.menu-gallery .portrait{grid-column:span 3}
.story-gallery .portrait{grid-column:span 3}
.story-gallery .square{grid-column:span 3}
.reservation-gallery{margin-top:26px}
.reservation-gallery .wide{grid-column:span 4}

.photo-duo{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.photo-duo .photo-card{aspect-ratio:4/5}

.split{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}
.split h2{font-size:44px;color:var(--green);line-height:1.05;margin:0 0 14px}
.script{font-family:var(--font-script);font-size:42px;color:var(--red);margin-top:22px}

.cta{background:linear-gradient(135deg,var(--red),#54080f);color:#fff;padding:36px 0;text-align:center}
.cta h2{font-size:36px;margin:0 0 18px;font-weight:500}

.footer{background:linear-gradient(135deg,#314c31,#1e3423);color:#fffaf2;padding:44px 0 18px}
.footer-grid{display:grid;grid-template-columns:1.2fr 1.1fr 1fr 1.2fr;gap:36px}
.footer h3{color:#d7ad5d;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-sans);font-size:15px;margin:0 0 16px}
.footer p,.footer li{margin:0 0 8px;font-size:16px;color:#f8eddc}
.footer ul{list-style:none;padding:0;margin:0}
.footer .brand{font-family:var(--font-script);font-size:40px;line-height:.9;margin-bottom:8px}
.footer-bottom{margin-top:34px;padding-top:14px;border-top:1px solid rgba(255,255,255,.16);display:flex;justify-content:center;gap:24px;font-size:14px;color:#e6d7c3}

.category-bar{margin-top:-36px;position:relative;z-index:4}
.category-wrap{background:#fffaf2;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(4,1fr)}
.category{padding:24px 18px;display:flex;align-items:center;justify-content:center;gap:15px;font-size:26px;color:var(--green);border-right:1px solid var(--line)}
.category:last-child{border-right:0}
.menu-list{display:grid;grid-template-columns:repeat(4,1fr);gap:34px}
.menu-col{border-right:1px solid var(--line);padding-right:24px}
.menu-col:last-child{border-right:0}
.menu-col h3{text-align:center;color:var(--green);font-size:28px;margin:0 0 22px;text-transform:uppercase}
.menu-item{margin-bottom:24px}
.menu-item strong{display:flex;justify-content:space-between;font-size:18px;gap:12px}
.menu-item em{display:block;color:#4f4a41;font-size:17px;margin-top:4px}

.form-layout{display:grid;grid-template-columns:1.9fr .95fr;gap:24px;margin-top:-26px;position:relative;z-index:5}
.panel{background:#fffaf2;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:34px}
.panel h2,.side-box h2{text-align:center;color:var(--green);font-size:38px;margin:0 0 28px}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 22px}
.form-grid .wide{grid-column:1/-1}
label{display:block;font-weight:700;color:#2e332b;margin-bottom:6px}
input,select,textarea{width:100%;padding:14px 14px;border:1px solid #d9cbb6;border-radius:4px;background:#fffdf8;font:16px var(--font-sans);color:#2e332b}
textarea{min-height:110px;resize:vertical}
.char-counter{margin-top:5px;text-align:right;font:12px var(--font-sans);color:var(--muted)}
.form-submit{width:100%;margin-top:20px}
.side-box{background:#fffaf2;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:34px 30px}
.info-row{display:flex;gap:15px;margin:22px 0;align-items:flex-start}
.info-row .round{flex:0 0 42px;height:42px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center}
.note{font-size:14px;text-align:center;color:var(--muted);margin-top:12px}

.history-hero{background:#111;color:#fff;position:relative;overflow:hidden}
.history-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.72}
.history-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.78),rgba(0,0,0,.42),rgba(0,0,0,.05))}
.history-hero .container{min-height:380px;position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center}
.history-hero h1{font-size:58px;line-height:1.1;margin:0 0 24px}
.history-hero p{font-size:22px;max-width:520px;margin:0}
.hand{font-family:var(--font-script);color:var(--green);font-size:45px;line-height:1;margin:0 0 18px}
.history-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:58px;align-items:center}
.history-grid.reverse{grid-template-columns:1.2fr 1fr}
.story-photo{aspect-ratio:16/9}
.thanks{background:#f4eadc;border-radius:14px;padding:34px 42px;display:grid;grid-template-columns:170px 1fr 170px;gap:24px;align-items:center}
.home-mark{font-size:72px;color:var(--green);text-align:center}

.gallery-hero{display:grid;grid-template-columns:1fr 1.25fr;align-items:center;gap:20px;min-height:420px}
.gallery-hero .page-title{font-size:88px}
.gallery-hero img{width:100%;height:420px;object-fit:cover;mask-image:linear-gradient(90deg,transparent 0%,black 22%,black 100%)}
.photo-wall{grid-auto-flow:dense}
.photo-wall .wide{grid-column:span 6}
.photo-wall .landscape{grid-column:span 4}
.photo-wall .portrait{grid-column:span 3}
.photo-wall .tall{grid-column:span 4;grid-row:span 2}
.photo-wall .photo-card{min-height:220px}
.photo-card:hover img{transform:scale(1.02)}
.photo-card img{transition:transform .3s ease, filter .3s ease}
.photo-card:hover img{filter:saturate(1.07)}
.quote{text-align:center;color:var(--green);font-size:34px;padding:42px 0}

@media (max-width:900px){
  .navbar{height:auto;min-height:82px;align-items:flex-start;padding:15px 0;flex-wrap:wrap}
  .logo{width:220px}
  .menu{order:3;width:100%;gap:18px;justify-content:center;flex-wrap:wrap;font-size:16px}
  .btn.red{padding:12px 16px}
  .hero-wrap,.split,.history-grid,.history-grid.reverse,.gallery-hero,.form-layout{grid-template-columns:1fr}
  .hero-img{position:relative;width:100%;height:330px;order:-1}
  .hero-copy{padding:42px 0}
  .hero h1,.page-title{font-size:52px}
  .cards,.menu-list,.footer-grid{grid-template-columns:1fr}
  .category-wrap{grid-template-columns:1fr 1fr}
  .category{border-bottom:1px solid var(--line)}
  .form-grid{grid-template-columns:1fr}
  .thanks{grid-template-columns:1fr;text-align:center}
  .photo-grid,.photo-wall{grid-template-columns:repeat(2,1fr)}
  .photo-card.wide,.photo-card.landscape,.photo-card.square,.photo-card.portrait,.photo-card.tall,
  .home-gallery .portrait,.home-gallery .square,.reservation-gallery .wide,
  .photo-wall .wide,.photo-wall .landscape,.photo-wall .portrait,.photo-wall .tall{
    grid-column:span 1;
    aspect-ratio:4/3;
    min-height:0;
  }
  .photo-card.portrait.contain,.photo-card.tall.contain{aspect-ratio:3/4}
  .photo-duo{grid-template-columns:1fr}
}
