:root{
  --bg:#211714;
  --bg-soft:#2b1f1a;
  --panel:#33251f;
  --line:rgba(255,255,255,.12);
  --text:#f7f2ee;
  --muted:rgba(247,242,238,.78);
  --accent:#c49a5a;
  --accent-dark:#a37b3f;
  --shadow:0 20px 50px rgba(0,0,0,.28);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Noto Sans KR',sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
}
img{display:block;max-width:100%}
a{color:inherit}
.wrap{width:min(1120px, calc(100% - 40px)); margin:0 auto}

.site-header{
  position:fixed;
  inset:0 0 auto 0;
  z-index:20;
  background:linear-gradient(to bottom, rgba(18,12,10,.75), rgba(18,12,10,0));
}
.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 0;
}
.brand{
  font-family:'Noto Serif KR',serif;
  font-size:1.15rem;
  font-weight:700;
  text-decoration:none;
  letter-spacing:.02em;
}
.nav-actions{display:flex; gap:18px; align-items:center}
.nav-link{text-decoration:none; color:var(--muted); font-size:.95rem}
.nav-link:hover{color:var(--text)}

.hero{
  position:relative;
  min-height:100svh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background:url('images/hero-view.jpg') center center/cover no-repeat;
  transform:scale(1.04);
}
.hero-shade{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(14,10,9,.45), rgba(14,10,9,.58) 45%, rgba(14,10,9,.86));
}
.hero-inner{
  position:relative;
  z-index:1;
  padding:160px 0 100px;
  max-width:820px;
  text-align:center;
}
.eyebrow,.section-label{
  margin:0 0 10px;
  color:#e6c48d;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:.8rem;
  font-weight:700;
}
.section-label.center, h2.center{text-align:center}
.hero h1{
  margin:0;
  font-family:'Noto Serif KR',serif;
  font-size:clamp(2.5rem, 7vw, 4.6rem);
  line-height:1.18;
  letter-spacing:-.02em;
}
.hero-copy{
  margin:22px auto 0;
  max-width:720px;
  color:var(--muted);
  font-size:1.08rem;
}
.hero-cta{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:32px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:168px;
  padding:14px 22px;
  border-radius:999px;
  font-weight:700;
  text-decoration:none;
  transition:.2s ease;
  border:1px solid transparent;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--accent); color:#1b120f; box-shadow:var(--shadow)}
.btn-primary:hover{background:#d2ab72}
.btn-secondary{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.22)}

.section{padding:100px 0}
.intro{background:linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%)}
.intro-grid,
.service-grid,
.location-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:44px;
  align-items:center;
}

h2{
  margin:0 0 16px;
  font-family:'Noto Serif KR',serif;
  font-size:clamp(1.9rem, 3vw, 2.7rem);
  line-height:1.3;
}
.lead{color:var(--muted); margin:0 0 18px; font-size:1.02rem}
.feature-list{
  margin:22px 0 0;
  padding:0;
  list-style:none;
  color:var(--muted);
}
.feature-list li{padding:8px 0; border-bottom:1px solid var(--line)}
.intro-card,
.map-card,
.service-photo,
.room-card{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.intro-card img,
.service-photo img,
.room-card img,
.map-card img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.rooms{background:var(--bg)}
.room-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  margin-top:36px;
}
.room-card img{aspect-ratio:4/3}
.room-body{padding:24px}
.room-body h3{
  margin:0 0 10px;
  font-family:'Noto Serif KR',serif;
  font-size:1.5rem;
}
.room-body p{margin:0; color:var(--muted)}

.service-band{background:var(--bg-soft)}
.service-photo img{aspect-ratio:4/5}
.service-items{display:grid; gap:14px; margin-top:24px}
.service-item{
  padding:18px 20px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.03);
}
.service-item strong{display:block; margin-bottom:4px; font-size:1.02rem}
.service-item span{color:var(--muted); font-size:.97rem}

.location-box{
  display:grid;
  gap:14px;
  margin-top:24px;
}
.location-box p{
  margin:0;
  padding:18px 20px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.03);
}
.location-box a{color:#f1d6a5; text-decoration:none}

.cta-bottom{padding-top:0}
.cta-panel{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  padding:34px;
  border:1px solid var(--line);
  border-radius:28px;
  background:linear-gradient(135deg, rgba(196,154,90,.14), rgba(255,255,255,.04));
  box-shadow:var(--shadow);
}
.cta-panel p{margin:0; color:var(--muted)}
.cta-right{margin-top:0; justify-content:flex-end}

.footer{
  border-top:1px solid var(--line);
  padding:30px 0 50px;
  background:#180f0d;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  gap:24px;
  color:var(--muted);
  font-size:.95rem;
}
.footer p{margin:.35rem 0 0}

@media (max-width: 900px){
  .intro-grid,.service-grid,.location-grid,.room-grid,.cta-panel,.footer-inner{
    grid-template-columns:1fr;
    display:grid;
  }
  .footer-inner{display:grid}
  .cta-right{justify-content:flex-start}
}

@media (max-width: 640px){
  .wrap{width:min(1120px, calc(100% - 24px))}
  .nav{padding:14px 0}
  .nav-actions{gap:12px}
  .nav-link{font-size:.88rem}
  .hero-inner{padding:140px 0 84px}
  .hero-copy br{display:none}
  .section{padding:78px 0}
  .intro-card,.map-card,.service-photo,.room-card,.cta-panel{border-radius:20px}
  .room-body,.cta-panel{padding:22px}
  .btn{width:100%}
  .hero-cta{gap:10px}
}


/* minor responsive polish */
.nav{flex-wrap:wrap}
.nav-actions{flex-wrap:wrap}
@media (max-width: 640px){
  .service-item,
  .location-box p{padding:16px 16px}
  .hero h1{font-size:clamp(2.2rem, 10vw, 3.2rem)}
}
