/* 자연음미 케이터링 — 공통/컴포넌트/레이아웃
   토큰은 tokens.css. 매직넘버 대신 간격 토큰 사용. */

/* ===== Reset / Base ===== */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);color:var(--ink);background:var(--ivory);
  line-height:1.7;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{line-height:1.25;color:var(--forest-deep);font-weight:800}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--s4)}
.section{padding:var(--s8) 0}
.section--cream{background:var(--cream)}
.center{text-align:center}
.divider{height:1px;background:var(--sand)}

.overline{
  font-family:var(--font-en);font-style:italic;font-size:20px;
  color:var(--honey);letter-spacing:.5px;display:block;margin-bottom:var(--s2)
}
.sec-title{font-family:var(--font-display);font-size:30px;letter-spacing:-.5px}
.sec-desc{color:var(--ink-soft);margin-top:var(--s2);max-width:640px}
.center .sec-desc{margin-left:auto;margin-right:auto}

/* ===== Buttons ===== */
.btn{
  font-family:var(--font-body);font-weight:600;font-size:15px;border:none;cursor:pointer;
  border-radius:var(--radius-pill);padding:13px 28px;display:inline-flex;align-items:center;
  gap:8px;transition:.2s;white-space:nowrap
}
.btn--primary{background:var(--forest);color:var(--ivory)}
.btn--primary:hover{background:var(--forest-deep)}
.btn--sage{background:var(--moss);color:#fff}
.btn--sage:hover{background:var(--forest)}
.btn--outline{background:transparent;color:var(--forest-deep);border:1.5px solid var(--forest)}
.btn--outline:hover{background:var(--forest);color:var(--ivory)}
/* 어두운 띠 위 고급 CTA */
.btn--gold{background:var(--gold);color:#241c0c}
.btn--gold:hover{background:#9a7a2f}
/* 어두운 사진 위 라이트 아웃라인(히어로 보조) */
.btn--outline-light{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.7)}
.btn--outline-light:hover{background:rgba(255,255,255,.18)}
/* 카카오 노랑은 '카카오톡 채널' 버튼 전용 */
.btn--kakao{background:#FEE500;color:#3C1E1E}
.btn--kakao:hover{filter:brightness(.96)}
.btn--block{width:100%;justify-content:center}
.btn--lg{padding:15px 34px;font-size:16px}

/* ===== Header / Nav ===== */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(250,247,239,.92);
  backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--sand)
}
.nav{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}
.nav__logo{font-family:var(--font-display);font-weight:800;font-size:23px;color:var(--forest-deep)}
.nav__logo small{font-family:var(--font-en);font-style:italic;font-weight:400;color:var(--honey);font-size:13px;margin-left:6px}
.nav__links{display:flex;align-items:center;gap:var(--s5)}
.nav__links a{font-size:15px;color:var(--ink);font-weight:500}
.nav__links a:hover,.nav__links a.is-active{color:var(--forest)}
/* 견적 문의: 다른 메뉴와 같은 크기 + 테두리만 있는 슬림 형태 */
.nav__cta{margin-left:var(--s4);font-size:15px;font-weight:600;line-height:1;
  border:1.5px solid var(--forest);border-radius:var(--radius-pill);padding:7px 18px;
  transition:background .2s,color .2s}
.nav__links a.nav__cta{color:var(--forest)}
.nav__links a.nav__cta:hover,.nav__links a.nav__cta.is-active{background:var(--forest);color:#fff}
.nav__toggle{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px;flex-direction:column;justify-content:center;gap:5px}
.nav__toggle span{display:block;height:2px;background:var(--forest-deep);border-radius:2px;transition:.25s}

/* ===== Hero ===== */
.hero{
  position:relative;color:var(--ivory);text-align:center;
  padding:var(--s8) var(--s4);
  background:linear-gradient(140deg,rgba(62,82,53,.86),rgba(44,58,37,.92)),
             var(--hero-img, linear-gradient(135deg,#7d8c5c,#3e5235));
  background-size:cover;background-position:center;
  min-height:62vh;display:flex;flex-direction:column;justify-content:center;align-items:center
}
.hero .overline{color:var(--honey-soft)}
.hero h1{font-family:var(--font-display);font-size:46px;letter-spacing:-1px;margin-bottom:var(--s3);color:#fff}
.hero p{opacity:.94;max-width:560px;font-size:17px}
.hero__cta{display:flex;gap:var(--s3);margin-top:var(--s5);flex-wrap:wrap;justify-content:center}
.hero__region{margin-top:var(--s4);font-family:var(--font-en);letter-spacing:2px;font-size:13px;
  border:1px solid rgba(228,211,166,.5);color:var(--honey-soft);border-radius:var(--radius-pill);padding:6px 18px}

/* ===== Grids ===== */
.grid{display:grid;gap:var(--s4)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}

/* ===== Service pillars ===== */
.pillar{background:var(--white);border:1px solid var(--sand);border-radius:var(--radius);
  padding:var(--s5) var(--s4);text-align:center;box-shadow:var(--shadow-sm);transition:.2s}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pillar__ico{width:60px;height:60px;border-radius:50%;background:var(--cream);display:flex;
  align-items:center;justify-content:center;margin:0 auto var(--s3);font-size:28px}
.pillar__en{font-family:var(--font-en);font-style:italic;color:var(--moss);font-size:18px}
.pillar h3{font-family:var(--font-body);font-size:19px;margin:var(--s1) 0 var(--s2);font-weight:700}
.pillar p{font-size:13px;color:var(--ink-soft)}

/* ===== Menu cards ===== */
.menu-cat{margin-top:var(--s7)}
.menu-cat__head{display:flex;align-items:baseline;gap:var(--s3);margin-bottom:var(--s4);flex-wrap:wrap}
.menu-cat__head h2{font-family:var(--font-display);font-size:26px}
.menu-cat__head .en{font-family:var(--font-en);font-style:italic;color:var(--honey);font-size:18px}
.menu-card{background:var(--white);border:1px solid var(--sand);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.menu-card__photo{aspect-ratio:16/10;background:linear-gradient(135deg,var(--sage),var(--forest));
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);font-size:12px;
  background-size:cover;background-position:center}
.menu-card__body{padding:var(--s4);display:flex;flex-direction:column;gap:var(--s2);flex:1}
.tag{display:inline-block;align-self:flex-start;background:var(--honey-soft);color:#6b5113;
  font-size:11px;font-weight:700;border-radius:var(--radius-pill);padding:3px 12px;letter-spacing:.5px}
.tag--green{background:#d7e0c6;color:var(--forest-deep)}
.menu-card h4{font-family:var(--font-body);font-size:18px;font-weight:700}
.menu-card__price{font-family:var(--font-display);font-size:24px;color:var(--forest);font-weight:800;margin-top:auto}
.menu-card__price small{font-size:13px;color:var(--ink-soft);font-weight:400;font-family:var(--font-body)}
.menu-card__desc{font-size:13.5px;color:var(--ink-soft);line-height:1.6}

/* ===== Info panels (menu extras) ===== */
.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s4);margin-top:var(--s5)}
.info-card{background:var(--white);border:1px solid var(--sand);border-radius:var(--radius);padding:var(--s5)}
.info-card h3{font-family:var(--font-body);font-size:18px;color:var(--forest-deep);margin-bottom:var(--s3);font-weight:700}
.info-card li{padding:7px 0;border-bottom:1px dashed var(--sand);font-size:14px;color:var(--ink-soft);display:flex;justify-content:space-between;gap:var(--s3)}
.info-card li:last-child{border-bottom:none}
.info-card li b{color:var(--ink);font-weight:600}

/* ===== Gallery ===== */
.filter{display:flex;gap:var(--s2);flex-wrap:wrap;justify-content:center;margin-top:var(--s5)}
.filter button{font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;
  border:1.5px solid var(--sand);background:var(--white);color:var(--ink-soft);
  border-radius:var(--radius-pill);padding:8px 20px;transition:.2s}
.filter button:hover{border-color:var(--sage)}
.filter button.is-active{background:var(--forest);color:var(--ivory);border-color:var(--forest)}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3);margin-top:var(--s5)}
.gallery__item{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
  cursor:pointer;aspect-ratio:4/3;background:linear-gradient(135deg,var(--sage),var(--forest-deep))}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gallery__item:hover img{transform:scale(1.06)}
.gallery__cap{position:absolute;left:0;right:0;bottom:0;padding:var(--s4) var(--s3) var(--s3);
  background:linear-gradient(transparent,rgba(44,46,39,.82));color:#fff;font-size:13px;font-weight:600}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(28,30,25,.9);display:none;align-items:center;
  justify-content:center;z-index:100;padding:var(--s4)}
.lightbox.is-open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:var(--radius)}
.lightbox__close{position:absolute;top:var(--s4);right:var(--s4);background:none;border:none;color:#fff;
  font-size:34px;cursor:pointer;line-height:1}

/* ===== Contact / Form ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:var(--s6);margin-top:var(--s6);align-items:start}
.contact-actions{display:flex;flex-direction:column;gap:var(--s3)}
.contact-actions .btn{justify-content:flex-start;font-size:16px;padding:15px 24px}
.contact-note{background:var(--cream);border-left:3px solid var(--moss);padding:var(--s3) var(--s4);
  border-radius:var(--radius-sm);font-size:13px;color:var(--ink-soft);margin-top:var(--s4)}
.form{background:var(--white);border:1px solid var(--sand);border-radius:var(--radius);padding:var(--s5);box-shadow:var(--shadow-sm)}
.field{margin-bottom:var(--s3)}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--ink)}
.field label .req{color:var(--honey)}
.field input,.field select,.field textarea{width:100%;font-family:var(--font-body);font-size:14px;
  padding:11px 14px;border:1px solid var(--sand);border-radius:var(--radius-sm);background:var(--ivory);color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sage);
  box-shadow:0 0 0 3px rgba(125,140,92,.22)}
.field .err{display:none;color:#b4452f;font-size:12px;margin-top:5px}
.field.is-invalid .err{display:block}
.field.is-invalid input,.field.is-invalid select,.field.is-invalid textarea{border-color:#cc6b54}
.form__msg{display:none;border-radius:var(--radius-sm);padding:var(--s3) var(--s4);font-size:14px;margin-bottom:var(--s3)}
.form__msg--ok{display:block;background:#e3ecd6;color:var(--forest-deep)}
.form__msg--ng{display:block;background:#f3ddd5;color:#9a3b22}
/* 가견적 빌더 */
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3)}
.field--inline{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink);
  font-weight:500;margin-bottom:6px;cursor:pointer}
.field--inline input{width:auto}
.estimate{background:var(--cream);border:1px solid var(--sand);border-radius:var(--radius-sm);
  padding:var(--s4);margin-bottom:var(--s3)}
.estimate__row{display:flex;justify-content:space-between;gap:var(--s3);font-size:13px;
  color:var(--ink-soft);padding:3px 0}
.estimate__total{display:flex;justify-content:space-between;align-items:baseline;gap:var(--s3);
  border-top:1px solid var(--sand);margin-top:var(--s2);padding-top:var(--s3)}
.estimate__total b{font-family:var(--font-display);font-size:25px;color:var(--forest);font-weight:800}
.estimate__note{font-size:12px;color:var(--ink-soft);margin-top:var(--s2);line-height:1.6}
.consent{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--ink-soft);line-height:1.55}
.consent input{width:auto;margin-top:3px;flex:0 0 auto}

/* ===== Trust / stats ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s4);margin-top:var(--s6)}
.stat{text-align:center}
.stat__num{font-family:var(--font-display);font-size:38px;color:var(--forest);font-weight:800}
.stat__label{font-size:13px;color:var(--ink-soft);margin-top:var(--s1)}

/* ===== CTA band ===== */
.cta-band{background:linear-gradient(140deg,var(--forest),var(--forest-deep));color:var(--ivory);
  text-align:center;border-radius:var(--radius);padding:var(--s7) var(--s4);margin:var(--s8) auto var(--s8)}
.cta-band h2{color:#fff;font-family:var(--font-display);font-size:30px;margin-bottom:var(--s3)}
.cta-band p{opacity:.9;margin-bottom:var(--s5)}

/* ===== Footer ===== */
.site-footer{background:var(--forest-deep);color:#cdd6c0;padding:var(--s7) 0 var(--s5)}
.site-footer .ft-top{display:flex;justify-content:space-between;gap:var(--s5);flex-wrap:wrap}
.site-footer .ft-en{font-family:var(--font-en);font-style:italic;font-size:24px;color:var(--honey-soft)}
.site-footer .ft-brand{font-family:var(--font-display);font-size:22px;color:#fff;margin-top:var(--s2)}
.site-footer a:hover{color:#fff}
.site-footer .ft-links{display:flex;gap:var(--s5);flex-wrap:wrap;font-size:14px}
.site-footer .ft-info{font-size:13px;opacity:.8;line-height:1.9;margin-top:var(--s4)}
.site-footer .ft-region b{color:#fff}
.site-footer .ft-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:var(--s5);padding-top:var(--s4);
  font-size:12px;opacity:.7;display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--s2)}

/* ===== Responsive ===== */
@media (max-width:960px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .hero h1{font-size:38px}
}
@media (max-width:640px){
  .section{padding:var(--s7) 0}
  .nav__links{position:fixed;inset:var(--header-h) 0 auto 0;background:var(--ivory);
    flex-direction:column;align-items:stretch;gap:0;padding:var(--s2) var(--s4) var(--s4);
    border-bottom:1px solid var(--sand);box-shadow:var(--shadow);transform:translateY(-130%);
    transition:.3s;visibility:hidden}
  .nav__links.is-open{transform:translateY(0);visibility:visible}
  .nav__links a{padding:var(--s3) 0;border-bottom:1px dashed var(--sand)}
  .nav__cta{margin:var(--s3) 0 0}
  .nav__toggle{display:flex}
  .nav__toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__toggle.is-open span:nth-child(2){opacity:0}
  .nav__toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .grid--3,.grid--2,.info-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .hero h1{font-size:32px}
  .hero p{font-size:15px}
  .sec-title{font-size:25px}
}

/* ============================================================
   PREMIUM REFINEMENTS — 고급감 향상 레이어 (override)
   ※ 색 토큰(--gold/--gold-soft)은 tokens.css 단일 소스
   ============================================================ */
body{letter-spacing:-.01em}

/* 헤더/로고 정제 */
.site-header{border-bottom:1px solid rgba(94,74,51,.14)}
.nav__logo{letter-spacing:.5px}
.nav__links a{letter-spacing:.2px}

/* 오버라인 — 골드 + 와이드 트래킹 */
.overline{font-size:15px;letter-spacing:3px;text-transform:uppercase;color:var(--gold)}
.hero .overline{color:var(--gold-soft)}
.pillar__en,.menu-cat__head .en{color:var(--gold)}

/* 섹션 타이틀 — 중앙 골드 룰 */
.center .sec-title{position:relative;padding-bottom:var(--s3)}
.center .sec-title::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  width:48px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}

/* 버튼 — 트래킹 + 정제된 인터랙션 */
.btn{letter-spacing:.4px;transition:transform .2s,box-shadow .2s,background .2s,color .2s,filter .2s}
.btn--lg{letter-spacing:.6px}
.btn--primary{box-shadow:0 6px 18px rgba(44,58,37,.16)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(44,58,37,.24)}
.btn--gold{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#3a2c10;
  box-shadow:0 6px 18px rgba(176,141,62,.3)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(176,141,62,.42);filter:brightness(1.03)}

/* 히어로 — 풀블리드 선명 슬라이드쇼 (사진 그대로, 텍스트는 하단 스크림 위) */
.hero{position:relative;min-height:88vh;overflow:hidden;display:flex;align-items:flex-end;
  color:#fff;background:#1a2216;padding:0}
.hero__slides{position:absolute;inset:0;z-index:0}
.hero__slide{position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.8s ease-in-out;will-change:opacity}
.hero__slide.is-active{opacity:1}
/* 사진은 위쪽 선명 유지, 하단 텍스트 영역은 확실히 어둡게(가독성) */
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,.22) 0%,rgba(0,0,0,0) 26%,rgba(6,10,5,.45) 50%,rgba(6,10,5,.7) 72%,rgba(6,10,5,.92) 100%)}
.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--s4) var(--s8)}
/* 텍스트를 감싸는 반투명 패널 — 어떤 사진 위에서도 글자 또렷 */
.hero__text{text-align:left;max-width:560px;
  background:rgba(8,12,6,.46);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);
  border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);
  padding:var(--s5) var(--s6);box-shadow:0 20px 50px rgba(0,0,0,.3)}
.hero__text .overline{color:var(--gold-soft);text-shadow:0 1px 8px rgba(0,0,0,.8)}
.hero h1{font-family:var(--font-display);font-size:60px;letter-spacing:-1.2px;line-height:1.1;
  color:#fff;margin-bottom:var(--s3);font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.6),0 4px 26px rgba(0,0,0,.6)}
.hero p{font-size:18px;color:#fff;max-width:520px;line-height:1.7;
  text-shadow:0 1px 3px rgba(0,0,0,.75),0 2px 14px rgba(0,0,0,.55)}
.hero__region{text-shadow:0 1px 6px rgba(0,0,0,.6)}
.hero__cta{display:flex;gap:var(--s3);margin-top:var(--s5);flex-wrap:wrap;justify-content:flex-start}
.hero__region{display:inline-block;margin-top:var(--s4);font-family:var(--font-en);letter-spacing:2px;
  font-size:13px;border:1px solid rgba(217,194,138,.55);color:var(--gold-soft);
  border-radius:var(--radius-pill);padding:6px 18px;background:rgba(10,14,8,.28)}
@media(max-width:860px){
  .hero{min-height:82vh}
  .hero__inner{padding:0 var(--s4) var(--s7)}
  .hero__text{padding:var(--s4) var(--s4)}
  .hero h1{font-size:40px}
  .hero p{font-size:16px}
}

/* 카드 — 부드러운 경계 + 골드틴 호버 */
.pillar,.menu-card,.info-card,.form,.review,.faq details{border-color:rgba(94,74,51,.12)}
.menu-card{transition:transform .25s,box-shadow .25s}
.menu-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(44,58,37,.16)}
.pillar__ico{background:linear-gradient(135deg,var(--cream),#fff);border:1px solid rgba(176,141,62,.25)}

/* 구분선/CTA 정제 */
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--sand),transparent)}
.cta-band{border:1px solid rgba(217,194,138,.18);box-shadow:0 20px 50px rgba(44,58,37,.2)}

/* 데스크톱 전용 타이포 확대 (모바일 미디어쿼리 보존) */
@media(min-width:961px){
  .hero h1{font-size:54px;letter-spacing:-1px}
  .hero p{font-size:18px}
  .sec-title{font-size:34px}
}

/* ===== 폼 단일 컬럼 ===== */
.form-shell{max-width:640px;margin:0 auto}

/* ===== FAQ 아코디언 ===== */
.faq{max-width:760px;margin:var(--s6) auto 0;text-align:left}
.faq details{background:var(--white);border:1px solid var(--sand);border-radius:var(--radius-sm);
  margin-bottom:var(--s2);padding:0 var(--s4);box-shadow:var(--shadow-sm)}
.faq summary{list-style:none;cursor:pointer;padding:var(--s3) 0;font-weight:600;
  color:var(--forest-deep);display:flex;justify-content:space-between;align-items:center;gap:var(--s3)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:22px;color:var(--gold);line-height:1;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details > p{margin:0 0 var(--s3);color:var(--ink-soft);font-size:14px;line-height:1.7}

/* ===== 견적 전송 완료 박스 ===== */
.thanks{background:linear-gradient(160deg,#fff,var(--cream));border:1px solid var(--sand);
  border-radius:var(--radius);padding:var(--s7) var(--s5);text-align:center;box-shadow:var(--shadow)}
.thanks__ico{width:64px;height:64px;border-radius:50%;margin:0 auto var(--s4);display:flex;
  align-items:center;justify-content:center;font-size:32px;color:#fff;
  background:linear-gradient(135deg,var(--sage),var(--forest));box-shadow:0 10px 24px rgba(62,82,53,.32)}
.thanks h2{font-family:var(--font-display);font-size:24px;color:var(--forest-deep);margin-bottom:var(--s3)}
.thanks p{color:var(--ink-soft);font-size:15px;line-height:1.8;margin-bottom:var(--s5)}

/* ===== 후기 ===== */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4);margin-top:var(--s6);text-align:left}
.review{background:var(--white);border:1px solid var(--sand);border-radius:var(--radius);
  padding:var(--s5);box-shadow:var(--shadow-sm)}
.review__stars{color:var(--gold);letter-spacing:2px;font-size:14px}
.review__text{margin:var(--s2) 0 var(--s3);font-family:var(--font-display);font-size:16px;line-height:1.7;color:var(--ink)}
.review__who{font-size:13px;color:var(--ink-soft)}
@media(max-width:860px){.reviews{grid-template-columns:1fr}}

/* ===== 한글 줄바꿈: 어절 단위로 끊기 + 제목 균형 ===== */
body{word-break:keep-all}
.sec-title,.hero h1,.page-hero h1{text-wrap:balance}
.sec-desc,.hero p,.page-hero p{text-wrap:pretty}

/* ===== 공용 페이지 헤더 — 단일 선명 사진 + 옅은 스크림 (배경은 main.js 주입) ===== */
.page-hero{position:relative;text-align:center;color:#fff;padding:var(--s8) var(--s4);overflow:hidden;
  background:#2c3a25;background-size:cover;background-position:center}
.page-hero::before{content:"";position:absolute;inset:0;
  background:linear-gradient(rgba(10,14,8,.30),rgba(10,14,8,.58))}
.page-hero .wrap{position:relative;z-index:1}
.page-hero .overline{color:var(--gold-soft)}
.page-hero h1{font-family:var(--font-display);color:#fff;font-size:32px;letter-spacing:-.3px;
  text-shadow:0 2px 16px rgba(0,0,0,.55)}
.page-hero p{color:rgba(255,255,255,.95);max-width:560px;margin:var(--s3) auto 0;
  text-shadow:0 1px 10px rgba(0,0,0,.5)}
@media(min-width:961px){.page-hero h1{font-size:42px}}

/* ===== 견적 폼: 필수/추가정보 구분 ===== */
.form-sec{margin-bottom:var(--s4)}
.form-sec__head{display:flex;align-items:center;gap:var(--s2);margin-bottom:var(--s1)}
.form-sec__head h3{font-family:var(--font-body);font-size:16px;color:var(--forest-deep);font-weight:700}
.form-sec__desc{font-size:13px;color:var(--ink-soft);margin-bottom:var(--s3)}
.badge{display:inline-block;font-size:11px;font-weight:700;border-radius:var(--radius-pill);
  padding:2px 11px;letter-spacing:.5px;background:var(--cream);color:var(--ink-soft)}
.badge--req{background:var(--honey-soft);color:#6b5113}
.more{border:1px solid var(--sand);border-radius:var(--radius-sm);margin-bottom:var(--s4);
  background:var(--ivory);overflow:hidden}
.more__summary{position:relative;list-style:none;cursor:pointer;padding:var(--s3) var(--s5) var(--s3) var(--s4);
  background:var(--cream);display:flex;flex-direction:column;gap:2px}
.more__summary::-webkit-details-marker{display:none}
.more__summary::after{content:"＋";position:absolute;right:var(--s4);top:50%;transform:translateY(-50%);
  font-size:20px;color:var(--gold);line-height:1}
.more[open] .more__summary::after{content:"－"}
.more[open] .more__summary{border-bottom:1px solid var(--sand)}
.more__main{font-weight:700;color:var(--forest-deep);display:flex;align-items:center;gap:8px}
.more__hint{font-size:12px;color:var(--ink-soft);font-weight:400}
.more__body{padding:var(--s4)}

/* 메뉴 복수 선택 행 */
.menu-line{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px;align-items:center}
.menu-line select,.menu-line input{font-family:var(--font-body);font-size:13px;padding:9px 10px;
  border:1px solid var(--sand);border-radius:var(--radius-sm);background:var(--ivory);color:var(--ink)}
.menu-line .ml-cat,.menu-line .ml-set{flex:1 1 130px;min-width:0}
.menu-line .ml-qty{flex:0 0 72px;width:72px;text-align:center}
.menu-line .ml-remove{flex:0 0 34px;width:34px;height:36px;background:none;border:1px solid var(--sand);
  border-radius:var(--radius-sm);color:var(--ink-soft);cursor:pointer;font-size:18px;line-height:1}
.menu-line .ml-remove:hover{background:#f3ddd5;color:#9a3b22;border-color:#cc6b54}
.btn--sm{padding:8px 16px;font-size:13px}
#add-menu{margin-top:2px}
/* 옵션 숫자칸 높이를 메뉴 수량칸과 동일하게 */
#opt-hours,#opt-beer,#opt-beer-im,#opt-glass,#opt-fruit{
  padding:9px 10px;font-size:13px;text-align:center;width:56px;flex:0 0 56px}
/* 수량형 옵션 2열 그리드 */
.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;margin-top:10px}
.opt-qty{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink)}
.opt-qty small{color:var(--ink-soft);font-size:11px}
@media(max-width:520px){.opt-grid{grid-template-columns:1fr}}
/* 안내 문구 */
.form-note{font-size:13px;color:var(--ink-soft);line-height:1.6;
  background:var(--ivory);border-left:3px solid var(--gold);
  padding:9px 12px;border-radius:var(--radius-sm);margin-bottom:var(--s4)}

/* ===== 접근성: 스킵링크 · 포커스 ===== */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--forest);color:#fff;
  padding:10px 16px;border-radius:0 0 var(--radius-sm) 0;font-weight:600;font-size:14px}
.skip-link:focus{left:0}
.btn:focus-visible,.nav__links a:focus-visible,.filter button:focus-visible,
.faq summary:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

/* ===== 초소형 화면: 2열 입력 → 1열 ===== */
@media(max-width:440px){.field-row{grid-template-columns:1fr}}

/* ===== 개인정보 동의: 가운데 정렬 ===== */
#consent-field{text-align:center}
#consent-field .consent{justify-content:center}

/* ===== 이용 절차 타임라인 ===== */
.steps{max-width:720px;margin:var(--s7) auto 0;text-align:left}
.step{position:relative;display:grid;grid-template-columns:auto 1fr;gap:var(--s4);padding-bottom:var(--s5)}
.step:last-child{padding-bottom:0}
.step__num{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:20px;font-weight:800;color:#fff;
  background:linear-gradient(135deg,var(--sage),var(--forest));box-shadow:0 6px 16px rgba(62,82,53,.3);z-index:1}
.step:not(:last-child)::before{content:"";position:absolute;left:22px;top:50px;bottom:-2px;width:2px;
  background:linear-gradient(var(--sage),var(--sand))}
.step__body{padding-top:5px}
.step__body h3{font-family:var(--font-body);font-size:17px;color:var(--forest-deep);font-weight:700;margin-bottom:5px}
.step__body p{font-size:14px;color:var(--ink-soft);line-height:1.7}
.step__tag{display:inline-block;margin-top:8px;font-size:12px;font-weight:700;color:#6b5113;
  background:var(--honey-soft);border-radius:var(--radius-pill);padding:3px 11px;letter-spacing:.3px}

/* ===== Motion 최소화 존중 ===== */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
