/* 향촌흑염소 — sage-rust palette / Montserrat + Pretendard */
:root{
  --bg:#f5f5dc;
  --fg:#2d3a1e;
  --accent:#a0522d;
  --accent-2:#F0C674;
  --muted:#7b8c5a;
  --card:#ffffff;
  --border:#e0dfc7;
  --shadow-sm:0 2px 8px rgba(45,58,30,.06);
  --shadow-md:0 12px 28px rgba(45,58,30,.10);
  --shadow-lg:0 24px 60px rgba(45,58,30,.15);
  --radius-card:12px;
  --radius-btn:999px;
  --maxw:1200px;
  --gap:20px;
  --pad:64px;
  --pad-mobile:40px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--fg);
  font-family:Pretendard,-apple-system,BlinkMacSystemFont,'Apple SD Gothic Neo','Malgun Gothic',sans-serif;
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}

h1,h2,h3,h4{
  font-family:Montserrat,Pretendard,sans-serif;
  font-weight:800;
  letter-spacing:-.01em;
  color:var(--fg);
  margin:0 0 .6em;
  line-height:1.2;
}
h1{font-size:clamp(2rem,4.6vw,3.4rem);}
h2{font-size:clamp(1.6rem,3vw,2.4rem);}
h3{font-size:clamp(1.15rem,1.7vw,1.4rem);}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* === Nav === */
.nav{
  position:sticky;top:0;left:0;right:0;z-index:80;
  background:rgba(245,245,220,.92);
  backdrop-filter:saturate(160%) blur(10px);
  -webkit-backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid rgba(160,82,45,.12);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;}
.brand{display:flex;align-items:center;gap:10px;font-family:Montserrat,Pretendard,sans-serif;font-weight:800;font-size:18px;letter-spacing:-.01em;color:var(--fg);}
.brand-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#7c3a1f);display:grid;place-items:center;color:#fff;font-weight:900;font-family:Montserrat,sans-serif;font-size:15px;}
.nav-links{display:flex;gap:6px;align-items:center;}
.nav-links a{
  padding:10px 14px;font-size:14px;font-weight:600;color:var(--fg);
  border-radius:999px;transition:background .2s,color .2s;
}
.nav-links a:hover{background:rgba(160,82,45,.08);color:var(--accent);}
.nav-links a.cta{
  margin-left:8px;background:var(--accent);color:#fff;padding:10px 18px;
}
.nav-links a.cta:hover{background:#8b3f1f;color:#fff;transform:translateY(-1px);}
.nav-toggle{display:none;width:40px;height:40px;border-radius:10px;color:var(--fg);}
.nav-toggle:hover{background:rgba(160,82,45,.08);}
.nav-toggle svg{width:24px;height:24px;}

@media(max-width:760px){
  .nav-toggle{display:grid;place-items:center;}
  .nav-links{
    position:fixed;top:72px;left:0;right:0;
    background:var(--bg);border-bottom:1px solid var(--border);
    flex-direction:column;align-items:stretch;gap:0;padding:12px;
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:transform .25s ease,opacity .25s ease;
    box-shadow:var(--shadow-md);
  }
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto;}
  .nav-links a{padding:14px 12px;border-radius:8px;}
  .nav-links a.cta{margin-left:0;margin-top:6px;text-align:center;}
}

/* === Buttons (pill-icon) === */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 26px;border-radius:var(--radius-btn);
  font-family:Montserrat,Pretendard,sans-serif;font-weight:700;font-size:14px;
  letter-spacing:.02em;
  background:var(--accent);color:#fff;
  transition:background .25s,transform .15s,box-shadow .25s;
  box-shadow:0 6px 16px rgba(160,82,45,.25);
}
.btn .arrow{transition:transform .25s;}
.btn:hover{background:#8b3f1f;transform:translateY(-2px);box-shadow:0 10px 24px rgba(160,82,45,.35);}
.btn:hover .arrow{transform:translateX(4px);}
.btn-ghost{background:transparent;color:var(--fg);border:1.5px solid var(--fg);box-shadow:none;}
.btn-ghost:hover{background:var(--fg);color:var(--bg);}

/* === Hero (full-bleed-image) === */
.hero{
  position:relative;width:100%;height:80vh;min-height:520px;max-height:780px;
  display:grid;place-items:center;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background-image:url('/assets/img/img-15.webp');
  background-size:cover;background-position:center 40%;
  transform:scale(1.04);
  animation:hero-zoom 18s ease-in-out infinite alternate;
}
@keyframes hero-zoom{from{transform:scale(1.0);}to{transform:scale(1.08);}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(45,58,30,.45) 0%,rgba(45,58,30,.62) 100%);}
.hero-content{position:relative;z-index:2;text-align:center;color:#fff;padding:0 24px;max-width:880px;}
.hero-eyebrow{
  display:inline-block;font-family:Montserrat,sans-serif;font-size:12px;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;
  padding:7px 16px;border:1px solid rgba(255,255,255,.45);border-radius:999px;
  margin-bottom:24px;color:#fff;
}
.hero h1{color:#fff;font-size:clamp(2.4rem,5.8vw,4.4rem);text-shadow:0 4px 24px rgba(0,0,0,.4);}
.hero p.lede{font-size:clamp(1rem,1.6vw,1.2rem);opacity:.95;max-width:640px;margin:0 auto 32px;font-weight:400;text-shadow:0 2px 12px rgba(0,0,0,.4);}
.hero-cta{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center;}
.hero .btn-ghost{color:#fff;border-color:#fff;}
.hero .btn-ghost:hover{background:#fff;color:var(--fg);}
.hero-scroll{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  z-index:2;color:#fff;opacity:.85;font-size:11px;letter-spacing:.2em;text-transform:uppercase;
}
.hero-scroll::after{
  content:'';display:block;width:1px;height:38px;margin:8px auto 0;
  background:linear-gradient(180deg,#fff 50%,transparent 100%);
  animation:scroll-line 2s ease-in-out infinite;
}
@keyframes scroll-line{0%,100%{transform:scaleY(.4);transform-origin:top;}50%{transform:scaleY(1);}}

/* === Section base === */
.section{padding:var(--pad) 0;}
@media(max-width:760px){.section{padding:var(--pad-mobile) 0;}}
.section-head{margin-bottom:48px;}
.section-head .eyebrow{
  display:inline-block;font-family:Montserrat,sans-serif;font-size:11px;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;
}
.section-head h2{margin-bottom:14px;}
.section-head p{color:var(--muted);font-size:16px;max-width:640px;margin:0;}
.section-head.center{text-align:center;}
.section-head.center p{margin:0 auto;}

/* === Asymmetric layout helper === */
.asymmetric{
  display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;
}
.asymmetric.flip{grid-template-columns:.9fr 1.1fr;}
.asymmetric .media{position:relative;}
.asymmetric .media .img-wrap{
  border-radius:var(--radius-card);overflow:hidden;box-shadow:var(--shadow-md);
  aspect-ratio:4/3;
}
.asymmetric .media .img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;}
.asymmetric .media:hover .img-wrap img{transform:scale(1.04);}
.asymmetric .media::after{
  content:'';position:absolute;width:60%;height:60%;
  border:2px solid var(--accent);border-radius:var(--radius-card);
  bottom:-18px;right:-18px;z-index:-1;
}
@media(max-width:860px){
  .asymmetric,.asymmetric.flip{grid-template-columns:1fr;gap:32px;}
  .asymmetric .media::after{display:none;}
}

/* === Menu Grid (image-overlay cards) === */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--gap);}
.menu-card{
  position:relative;aspect-ratio:4/5;
  border-radius:var(--radius-card);overflow:hidden;
  background:var(--card);box-shadow:var(--shadow-sm);
  transition:transform .35s ease,box-shadow .35s ease;
}
.menu-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.menu-card img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .8s cubic-bezier(.2,.8,.2,1);
}
.menu-card:hover img{transform:scale(1.08);}
.menu-card .cover{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(45,58,30,0) 35%,rgba(45,58,30,.85) 100%);
}
.menu-card .label{
  position:absolute;left:0;right:0;bottom:0;padding:24px;color:#fff;z-index:2;
}
.menu-card .tag{
  display:inline-block;font-family:Montserrat,sans-serif;font-size:10px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  padding:5px 11px;background:var(--accent);border-radius:999px;margin-bottom:10px;
}
.menu-card h3{color:#fff;font-size:1.3rem;margin-bottom:6px;}
.menu-card .price{font-family:Montserrat,sans-serif;font-weight:700;font-size:14px;opacity:.92;}

/* Asymmetric grid offset */
.menu-grid.offset .menu-card:nth-child(odd){transform:translateY(0);}
.menu-grid.offset .menu-card:nth-child(even){transform:translateY(28px);}
.menu-grid.offset .menu-card:nth-child(odd):hover,
.menu-grid.offset .menu-card:nth-child(even):hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
@media(max-width:760px){.menu-grid.offset .menu-card:nth-child(even){transform:translateY(0);}}

/* === Gallery === */
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;}
.gallery .tile{
  position:relative;aspect-ratio:1/1;border-radius:var(--radius-card);overflow:hidden;
  cursor:pointer;background:var(--border);
}
.gallery .tile.tall{aspect-ratio:3/4;}
.gallery .tile.wide{aspect-ratio:4/3;}
.gallery .tile img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;}
.gallery .tile:hover img{transform:scale(1.06);}
.gallery .tile::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(45,58,30,.35));opacity:0;transition:opacity .3s;
}
.gallery .tile:hover::after{opacity:1;}

/* === Reviews === */
.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;}
.review-card{
  background:var(--card);border-radius:var(--radius-card);padding:30px 28px;
  box-shadow:var(--shadow-sm);border:1px solid var(--border);position:relative;
}
.review-card::before{
  content:'\201C';position:absolute;top:8px;left:18px;
  font-family:Montserrat,serif;font-size:64px;font-weight:900;color:var(--accent);opacity:.18;line-height:1;
}
.review-stars{color:var(--accent-2);font-size:16px;letter-spacing:2px;margin-bottom:14px;}
.review-text{font-size:15px;line-height:1.7;color:var(--fg);margin-bottom:18px;}
.review-author{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--muted);}
.review-author .name{font-weight:700;color:var(--fg);}

/* === Map / Location === */
.map-wrap{
  display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:stretch;
  background:var(--card);border-radius:var(--radius-card);overflow:hidden;
  box-shadow:var(--shadow-md);
}
.map-info{padding:40px 36px;}
.map-info h3{font-size:1.5rem;margin-bottom:18px;}
.map-info dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:14px 20px;font-size:15px;}
.map-info dt{font-family:Montserrat,sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:700;align-self:start;padding-top:3px;}
.map-info dd{margin:0;font-weight:500;}
.map-info dd a{color:var(--accent);font-weight:700;}
.map-info dd a:hover{text-decoration:underline;}
.map-frame{
  position:relative;min-height:380px;
  background-image:url('/assets/img/img-22.webp');background-size:cover;background-position:center;
}
.map-frame::after{
  content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(160,82,45,.18),rgba(45,58,30,.32));
}
.map-pin{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;
  background:#fff;color:var(--accent);font-family:Montserrat,sans-serif;font-weight:800;font-size:13px;
  padding:10px 16px;border-radius:999px;box-shadow:var(--shadow-lg);
  display:inline-flex;gap:8px;align-items:center;
}
.map-pin::before{content:'\01F4CD';font-size:18px;}
@media(max-width:860px){.map-wrap{grid-template-columns:1fr;}.map-info{padding:32px 24px;}}

/* === Reservation form === */
.form-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-grid .full{grid-column:1/-1;}
.field label{display:block;font-family:Montserrat,sans-serif;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:7px;}
.field input,.field textarea,.field select{
  width:100%;padding:12px 14px;
  background:var(--card);border:1.5px solid var(--border);border-radius:10px;
  font-family:inherit;font-size:15px;color:var(--fg);
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(160,82,45,.12);
}
.field textarea{min-height:130px;resize:vertical;}
@media(max-width:760px){.form-wrap,.form-grid{grid-template-columns:1fr;gap:18px;}}

/* === Footer (classic-3col) === */
.footer{
  background:var(--fg);color:#d8d6b8;padding:64px 0 28px;margin-top:80px;
}
.footer a{color:#d8d6b8;}
.footer-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;}
.footer-cols h4{color:#fff;font-family:Montserrat,sans-serif;font-size:13px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;}
.footer-cols .brand{color:#fff;font-size:20px;margin-bottom:14px;}
.footer-cols .brand-mark{background:linear-gradient(135deg,var(--accent),var(--accent-2));}
.footer-cols p{font-size:14px;line-height:1.7;color:#bcb999;margin:0 0 14px;}
.footer-cols ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:14px;}
.footer-cols ul a{color:#bcb999;transition:color .2s;}
.footer-cols ul a:hover{color:#fff;}
.newsletter{display:flex;gap:8px;margin-top:8px;}
.newsletter input{
  flex:1;padding:11px 14px;border-radius:999px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);color:#fff;font-size:13px;
}
.newsletter input::placeholder{color:#998f6c;}
.newsletter button{padding:11px 20px;border-radius:999px;background:var(--accent);color:#fff;font-weight:700;font-size:13px;font-family:Montserrat,sans-serif;}
.newsletter button:hover{background:#8b3f1f;}
.social{display:flex;gap:10px;margin-top:14px;}
.social a{
  width:38px;height:38px;border-radius:999px;background:rgba(255,255,255,.07);
  display:grid;place-items:center;transition:background .2s;
}
.social a:hover{background:var(--accent);}
.social svg{width:16px;height:16px;fill:#fff;}
.footer-bottom{
  margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#8e8466;flex-wrap:wrap;gap:10px;
}
@media(max-width:760px){.footer-cols{grid-template-columns:1fr;gap:32px;}.footer-bottom{flex-direction:column;align-items:flex-start;}}

/* === Animation (fade-up reveal) === */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease;}
.reveal.in{opacity:1;transform:translateY(0);}

/* === Misc === */
.kicker{
  font-family:Montserrat,sans-serif;font-size:11px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);
}
.divider{width:48px;height:3px;background:var(--accent);margin:18px 0;border-radius:2px;}
.center{text-align:center;}
:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:6px;}

@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important;}
}
