/* 꿈목장 site main styles
   제목: Cafe24Ssurround(써라운드) / 본문: Pretendard / 스토리: MaruBuri(마루부리)
   다국어는 body.lang-* 별 대표 폰트 유지 (JP=Noto Sans JP, CN=Noto Sans SC 등)        */

/* 한국어 전용 웹폰트 (상업용 무료, CSP 허용 cdn.jsdelivr.net) */
@font-face { font-family:'Cafe24Ssurround'; src:url('https://cdn.jsdelivr.net/gh/fonts-archive/Cafe24Ssurround/Cafe24Ssurround.woff2') format('woff2'); font-weight:400 800; font-display:swap; }
@font-face { font-family:'MaruBuri'; src:url('https://cdn.jsdelivr.net/gh/fonts-archive/MaruBuri/MaruBuri-Regular.woff2') format('woff2'); font-weight:400; font-display:swap; }
@font-face { font-family:'MaruBuri'; src:url('https://cdn.jsdelivr.net/gh/fonts-archive/MaruBuri/MaruBuri-Bold.woff2') format('woff2'); font-weight:700; font-display:swap; }

:root {
  --c-bg: #FFF8F0;
  --c-fg: #2A2620;
  --c-muted: #6E6A63;
  --c-line: #E8E0D5;
  --c-line-2: #F5EFE6;
  --c-primary: #2D5E27;
  --c-primary-2: #1F4419;
  --c-accent: #ffa700;
  --c-accent-2: #e69500;
  --c-danger: #d9333f;
  --c-ok: #2faa6c;
  --c-card: #ffffff;
  --c-tag: #EAF1E6;
  --c-brown: #6B4F2A;
  --radius: 16px;
  --radius-sm: 10px;
  --head: "NanumSquareRound", "Pretendard", system-ui, sans-serif;
  --display: "Cafe24Ssurround", "NanumSquareRound", sans-serif;
  --shadow-sm: 0 1px 3px rgba(10,20,40,.06), 0 1px 2px rgba(10,20,40,.04);
  --shadow-md: 0 10px 30px rgba(10,20,40,.08), 0 2px 6px rgba(10,20,40,.04);
  --header-h: 112px;
  --max-w: 1360px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  color: var(--c-fg);
  background: var(--c-bg);
  font-family: "Pretendard", system-ui, -apple-system, "Segoe UI", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
  font-size: 16px;
  word-break: keep-all;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Language-specific fonts — most-used safe family per region */
body.lang-jp {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "Meiryo", system-ui, sans-serif;
  font-weight: 400;
  --head: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", system-ui, sans-serif;
  --display: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", system-ui, sans-serif;
  --body: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", "Meiryo", system-ui, sans-serif;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
body.lang-cn {
  font-family: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", "Hiragino Sans GB", "Heiti SC", system-ui, sans-serif;
  font-weight: 400;
  --head: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", "Heiti SC", system-ui, sans-serif;
  --display: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", system-ui, sans-serif;
  --body: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", "Heiti SC", system-ui, sans-serif;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
body.lang-en {
  font-family: "Poppins", "Inter", "Roboto", system-ui, -apple-system, "Segoe UI", sans-serif;
  --head: "Poppins", "Inter", "Roboto", system-ui, sans-serif;
  --display: "Poppins", "Inter", "Roboto", system-ui, sans-serif;
  --body: "Inter", "Roboto", "Poppins", system-ui, sans-serif;
}
body.lang-kr {
  font-family: "Pretendard", "Poppins", system-ui, -apple-system, "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
}
body.lang-th {
  font-family: "Noto Sans Thai", "Sarabun", "Tahoma", system-ui, sans-serif;
  font-weight: 400;
}
body.lang-ru {
  font-family: "Pretendard", "Roboto", "Inter", "PT Sans", "Segoe UI", system-ui, sans-serif;
}
body.lang-vi {
  /* Vietnamese needs full Latin-Extended-Additional + tone marks support */
  font-family: "Pretendard", "Be Vietnam Pro", "Roboto", "Inter", system-ui, sans-serif;
}
body.lang-fr, body.lang-de, body.lang-es {
  /* Latin-script European languages — Pretendard handles diacritics well */
  font-family: "Pretendard", "Poppins", "Inter", "Roboto", system-ui, -apple-system, "Segoe UI", sans-serif;
}

a { color: var(--c-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; height: auto; display: block; }

h1, h2, h3, h4 { margin: 0 0 .5em; line-height: 1.3; letter-spacing: -.01em; font-family: var(--head); font-weight: 800; }
.muted { color: var(--c-muted); }

.container { max-width: var(--max-w); margin: 0 auto; padding: 0 20px; }
.narrow { max-width: 720px; }

/* Header */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: #fff;
  backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--c-line);
  transition: background .3s ease, box-shadow .25s ease, border-color .25s ease;
}
.site-header.scrolled { box-shadow: 0 2px 16px rgba(0,0,0,.06); }
body.home .site-header:not(.scrolled) { background: rgba(255,255,255,.35); border-bottom-color: transparent; }
.site-header .container {
  height: var(--header-h);
  display: flex; align-items: center; justify-content: space-between;
}
.logo {
  font-weight: 700; font-size: 20px; letter-spacing: -.02em;
  color: var(--c-fg) !important;
}
.primary-nav { display: flex; gap: 22px; }
.primary-nav a {
  color: var(--c-fg);
  font-weight: 500;
  font-size: 15px;
}
.primary-nav a:hover { color: var(--c-primary); text-decoration: none; }

.header-actions { display: flex; align-items: center; gap: 10px; }
.lang-switcher { position: relative; }
.lang-btn {
  background: var(--c-line-2); border: 1px solid var(--c-line);
  border-radius: var(--radius-sm); padding: 6px 12px; font-weight: 500;
  font-size: 14px; cursor: pointer; color: var(--c-fg);
}
.lang-switcher ul {
  position: absolute; right: 0; top: 100%; margin-top: 6px;
  list-style: none; padding: 6px; min-width: 140px;
  background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius);
  box-shadow: var(--shadow-md); display: none;
}
.lang-switcher:hover ul, .lang-switcher:focus-within ul { display: block; }
.lang-switcher li a { display: block; padding: 8px 10px; border-radius: 4px; color: var(--c-fg); }
.lang-switcher li a:hover { background: var(--c-line-2); text-decoration: none; }

.nav-toggle {
  display: none; background: transparent; border: 0;
  width: 36px; height: 36px; padding: 8px; flex-direction: column; gap: 4px; cursor: pointer;
}
.nav-toggle span { display: block; width: 100%; height: 2px; background: var(--c-fg); border-radius: 2px; }

/* Hero */
.hero {
  padding: 80px 0 64px;
  background: linear-gradient(160deg, #f1f5fd 0%, #fafbfe 60%);
  border-bottom: 1px solid var(--c-line);
}
.hero-title {
  font-size: clamp(34px, 5.5vw, 56px);
  font-weight: 700;
  letter-spacing: -.02em;
  background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-2) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero-subtitle { font-size: 18px; color: var(--c-muted); max-width: 640px; }
.hero-cta { display: flex; gap: 10px; margin-top: 24px; flex-wrap: wrap; }

/* Buttons */
.btn, .btn-primary, .btn-ghost, .btn-danger {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 10px 18px; font-size: 14px; font-weight: 500;
  border-radius: var(--radius-sm); border: 1px solid transparent;
  text-decoration: none; cursor: pointer;
  transition: transform .08s ease, box-shadow .15s, background .15s;
  font-family: inherit;
}
.btn { background: #fff; border-color: var(--c-line); color: var(--c-fg); }
.btn:hover { background: var(--c-line-2); text-decoration: none; }
.btn-primary { background: var(--c-primary); color: #fff; }
.btn-primary:hover { background: var(--c-primary-2); color: #fff; text-decoration: none; }
.btn-ghost { background: transparent; border-color: var(--c-primary); color: var(--c-primary); }
.btn-ghost:hover { background: var(--c-primary); color: #fff; text-decoration: none; }
.btn-danger { background: var(--c-danger); color: #fff; }
.btn-danger:hover { background: #b8262f; }
.btn.small { padding: 5px 10px; font-size: 12px; }

/* Cards / sections */
.two-col {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  padding: 56px 20px;
}
.card {
  background: var(--c-card); border: 1px solid var(--c-line);
  border-radius: var(--radius); padding: 24px;
  box-shadow: var(--shadow-sm);
}
.card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.card-head h2 { font-size: 20px; margin: 0; }
.link { color: var(--c-primary); font-size: 14px; font-weight: 500; }

.post-list { list-style: none; padding: 0; margin: 0; }
.post-list li {
  display: flex; justify-content: space-between; gap: 12px;
  padding: 10px 0; border-bottom: 1px solid var(--c-line-2);
}
.post-list li:last-child { border-bottom: 0; }
.post-list a { color: var(--c-fg); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.post-list time { color: var(--c-muted); font-size: 13px; flex-shrink: 0; }

.feature-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px;
  padding: 56px 20px 80px;
}
.feature-tile {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 28px 12px;
  background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius);
  color: var(--c-fg); transition: all .2s;
}
.feature-tile:hover {
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--c-primary);
}
.ft-icon { font-size: 28px; }
.ft-title { font-size: 13px; font-weight: 500; }

/* Footer */
.site-footer {
  border-top: 0;
  padding: 52px 0 36px;
  margin-top: 0;
  text-align: center;
  background: var(--c-primary-2);
  color: rgba(255,255,255,.82);
  font-size: 14px;
}
.footer-logo { width: 96px; height: auto; margin: 0 auto 16px; display: block; }
.footer-brand { font-family: var(--head); font-weight: 800; color: #fff; font-size: 21px; margin: 0; }
.footer-brand span { display: block; font-size: 12px; font-weight: 700; color: #cfe0c9; letter-spacing: .08em; margin-top: 5px; }
.footer-meta { margin: 5px 0; color: rgba(255,255,255,.78); }
.footer-divider { width: 40px; height: 2px; background: rgba(255,255,255,.25); border: 0; margin: 16px auto; }
.footer-links { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px 22px; margin: 18px 0 6px; }
.footer-links a { color: #fff; font-family: var(--head); font-weight: 700; margin: 0; }
.footer-links a:hover { color: var(--c-accent); text-decoration: none; }
.footer-copy { color: rgba(255,255,255,.55); font-size: 13px; margin: 16px 0 0; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.12); }

/* Board */
.board-page { padding: 40px 20px 80px; }
.board-head {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 16px;
  padding-bottom: 18px; margin-bottom: 24px;
  border-bottom: 2px solid var(--c-fg);
}
.board-title { font-size: 28px; margin: 0; font-weight: 700; }
.board-desc { margin: 0; color: var(--c-muted); }
.board-tools { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.search { display: flex; gap: 4px; }
.search input { padding: 7px 10px; border: 1px solid var(--c-line); border-radius: var(--radius-sm); }
.search button {
  padding: 7px 14px; background: var(--c-fg); color: #fff; border: 0;
  border-radius: var(--radius-sm); cursor: pointer; font-family: inherit;
}

.board-table { width: 100%; border-collapse: collapse; }
.board-table thead { background: var(--c-line-2); }
.board-table th, .board-table td {
  padding: 12px 8px; text-align: left; border-bottom: 1px solid var(--c-line);
  font-size: 14px;
}
.board-table th { font-weight: 600; font-size: 13px; color: var(--c-muted); text-transform: uppercase; letter-spacing: .04em; }
.board-table .num-col, .board-table .meta-col, .board-table .adm-col { width: 1%; white-space: nowrap; }
.board-table thead th:not(.subj),
.board-table tbody td:not(.subj) { white-space: nowrap; }
.board-table thead th:not(.subj),
.board-table tbody td:not(.subj) { padding-left: 16px; padding-right: 16px; }
.board-table .subj a { color: var(--c-fg); font-weight: 500; }
.board-table .subj a:hover { color: var(--c-primary); }
.board-table tbody tr:hover { background: #faf9f3; }
.board-table tr.notice-row { background: #fff8e8; }
.board-table .empty { text-align: center; color: var(--c-muted); padding: 40px 0; }
.badge { display: inline-block; padding: 1px 8px; border-radius: 999px; background: var(--c-tag); font-size: 11px; color: var(--c-primary); margin-left: 4px; }

.admin-bulk { margin-top: 14px; padding: 10px 14px; background: #fff8e8; border-radius: var(--radius-sm); display: flex; gap: 10px; align-items: center; }
.pager { display: flex; gap: 4px; justify-content: center; margin-top: 24px; flex-wrap: wrap; }
.pager a {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px; padding: 0 10px;
  border: 1px solid var(--c-line); border-radius: var(--radius-sm);
  color: var(--c-fg); font-size: 14px;
}
.pager a.on { background: var(--c-fg); color: #fff; border-color: var(--c-fg); }
.pager a:hover { background: var(--c-line-2); text-decoration: none; }

/* Photo grid */
.photo-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px;
}
.photo-card { position: relative; background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius); overflow: hidden; transition: all .2s; }
.photo-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--c-primary); }
.photo-check { position: absolute; top: 8px; left: 8px; z-index: 2; background: rgba(255,255,255,.9); border-radius: 4px; padding: 2px 4px; }
.photo-thumb {
  width: 100%; aspect-ratio: 4/3; background-size: cover; background-position: center;
  background-color: var(--c-line-2);
}
.photo-meta { padding: 12px; }
.photo-title { font-weight: 500; font-size: 14px; color: var(--c-fg); margin-bottom: 4px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.photo-sub { color: var(--c-muted); font-size: 12px; }

/* Calendar */
.calendar { width: 100%; border-collapse: separate; border-spacing: 2px; }
.calendar th { background: var(--c-line-2); padding: 8px; font-weight: 600; font-size: 13px; text-transform: uppercase; letter-spacing: .04em; }
.calendar th.sun { color: var(--c-danger); }
.calendar th.sat { color: var(--c-primary); }
.calendar td { background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius-sm); vertical-align: top; padding: 6px; min-height: 90px; height: 90px; position: relative; }
.calendar td.empty { background: var(--c-line-2); border: 0; }
.calendar td.today { background: #f0f6ff; border-color: var(--c-primary); }
.calendar td .d { display: inline-block; font-size: 13px; color: var(--c-muted); font-weight: 600; margin-bottom: 4px; }
.calendar td.sun .d { color: var(--c-danger); }
.calendar td.sat .d { color: var(--c-primary); }
.cal-event { display: block; background: var(--c-primary); color: #fff !important; padding: 2px 6px; border-radius: 3px; font-size: 11px; margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cal-event:hover { background: var(--c-primary-2); text-decoration: none; }
.cal-nav { display: flex; align-items: center; gap: 8px; font-weight: 600; }

/* Post view */
.post-view { padding: 40px 20px 80px; max-width: 900px; }
.crumbs { font-size: 13px; color: var(--c-muted); margin-bottom: 18px; }
.crumbs a { color: var(--c-muted); }
.post-head { padding-bottom: 20px; margin-bottom: 24px; border-bottom: 2px solid var(--c-fg); }
.post-head h1 { font-size: 30px; }
.post-meta { color: var(--c-muted); font-size: 14px; }
.event-bar { background: #fff8e8; padding: 10px 14px; border-radius: var(--radius-sm); margin: 0 0 16px; font-weight: 500; }
.post-body { font-size: 16px; line-height: 1.8; padding: 24px 0; min-height: 220px; }
.post-body img { border-radius: var(--radius-sm); margin: 12px 0; }
.attachments-block { background: var(--c-line-2); padding: 16px; border-radius: var(--radius); margin: 24px 0; }
.attachments-block h3 { font-size: 14px; margin: 0 0 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--c-muted); }
.att-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.att-list li { display: flex; align-items: center; gap: 10px; padding: 6px 0; }
.att-thumb { width: 40px; height: 40px; object-fit: cover; border-radius: 4px; }
.post-actions { display: flex; gap: 10px; margin: 24px 0; flex-wrap: wrap; }
.prev-next { display: flex; justify-content: space-between; gap: 12px; padding: 20px 0; border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); }
.prev-next a { color: var(--c-fg); font-size: 14px; }
.comments { margin-top: 40px; }
.comments ul { list-style: none; padding: 0; margin: 0; }
.comments li { padding: 14px 0; border-bottom: 1px solid var(--c-line-2); }
.comments li strong { margin-right: 8px; }
.comments p { margin: 8px 0 0; }
.comment-form { display: flex; flex-direction: column; gap: 8px; margin-top: 20px; }
.comment-form input, .comment-form textarea {
  width: 100%; padding: 10px 12px; border: 1px solid var(--c-line); border-radius: var(--radius-sm);
  font-family: inherit; font-size: 14px;
}

/* Write form — 새 디자인 (카드형) */
.post-write { padding: 50px 20px 100px; max-width: 1180px; margin: 0 auto; }
.post-write > .board-head { display: none; } /* 히어로에 이미 제목 있음 */
.write-form {
  display: flex; flex-direction: column; gap: 22px;
  background: #fff; border-radius: var(--radius);
  box-shadow: 0 10px 40px rgba(10,20,40,.06);
  border: 1px solid var(--c-line);
  padding: 38px 42px;
}
.write-form label {
  display: flex; flex-direction: column; gap: 9px;
  font-family: var(--head); font-weight: 700; font-size: 14.5px;
  color: var(--c-fg); letter-spacing: .01em;
}
.write-form input[type=text],
.write-form input[type=datetime-local],
.write-form textarea {
  padding: 13px 16px; border: 1.5px solid var(--c-line);
  border-radius: 10px;
  font-family: var(--body); font-size: 15px; font-weight: 400;
  background: #fff; color: var(--c-fg);
  transition: border-color .15s, box-shadow .15s, background .15s;
}
.write-form input:focus,
.write-form input:focus-visible,
.write-form textarea:focus {
  outline: none; border-color: var(--c-primary);
  box-shadow: 0 0 0 4px rgba(45,94,39,.10);
  background: #fdfcf7;
}
.write-form .row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.write-form fieldset.attachments {
  border: 2px dashed #d4d2c9; border-radius: 12px;
  padding: 22px 24px;
  background: #fbfaf5;
  margin: 0;
}
.write-form fieldset.attachments legend {
  font-family: var(--head); font-weight: 700; font-size: 13.5px;
  color: var(--c-muted); padding: 0 8px;
  letter-spacing: .02em;
}
.write-form .file-row { margin: 6px 0; }
.write-form fieldset.attachments small.muted {
  display: block; margin-top: 10px;
  color: var(--c-muted); font-size: 13px; font-weight: 400;
}
.write-form .form-actions {
  display: flex; gap: 12px; justify-content: flex-end;
  padding-top: 22px; margin-top: 4px;
  border-top: 1px solid var(--c-line);
}
.write-form .form-actions .btn-primary {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 48px; padding: 0 36px; border-radius: 999px;
  font-family: var(--head); font-weight: 700; font-size: 15px;
  background: linear-gradient(135deg,#ffbf00 0%,#ff7800 100%);
  color: #fff; border: none; cursor: pointer; text-decoration: none;
  transition: transform .15s, box-shadow .2s, background .2s;
}
.write-form .form-actions .btn-primary:hover {
  background: linear-gradient(135deg,#f2b000 0%,#ed6c00 100%);
  box-shadow: 0 8px 20px rgba(255,120,0,.28);
  color: #fff; text-decoration: none;
}
.write-form .form-actions .btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 48px; padding: 0 28px; border-radius: 999px;
  font-family: var(--head); font-weight: 700; font-size: 15px;
  background: transparent; color: var(--c-primary);
  border: 2px solid var(--c-primary); text-decoration: none;
  transition: background .2s, color .2s;
}
.write-form .form-actions .btn:hover { background: var(--c-primary); color: #fff; text-decoration: none; }
.write-form .sun-editor { border-radius: 10px; overflow: hidden; border: 1.5px solid var(--c-line); }
.write-form .sun-editor .se-toolbar { background: #fbfaf5; }
@media (max-width: 768px) {
  .post-write { padding: 30px 14px 70px; }
  .write-form { padding: 24px 20px; gap: 18px; }
  .write-form .row { grid-template-columns: 1fr; gap: 0; }
  .write-form .row > label + label { margin-top: 18px; }
  .write-form .form-actions { flex-direction: column-reverse; gap: 10px; }
  .write-form .form-actions .btn,
  .write-form .form-actions .btn-primary { width: 100%; }
}

.alert { padding: 10px 14px; border-radius: var(--radius-sm); margin: 12px 0; font-size: 14px; }
.alert.ok  { background: #e6f7ee; color: #145a36; }
.alert.err { background: #fde6e8; color: #921c25; }

/* ============================================================
   꿈목장 홈(랜딩) 전용 컴포넌트 — km-*
   ============================================================ */
.km-btn { display:inline-flex; align-items:center; justify-content:center; gap:6px;
  min-height:44px; padding:0 22px; border-radius:999px; font-family:var(--head);
  font-weight:700; font-size:15px; cursor:pointer; border:2px solid transparent;
  transition:transform .15s, background .2s, box-shadow .2s; white-space:nowrap; }
.km-btn:hover { text-decoration:none; }
.km-btn:active { transform:translateY(1px); }
.km-btn-accent { background:linear-gradient(135deg, #ffbf00 0%, #ff7800 100%); color:#fff; border:none; }
.km-btn-accent:hover { background:linear-gradient(135deg, #f2b000 0%, #ed6c00 100%); color:#fff; }
.km-btn-outline { background:transparent; color:var(--c-primary); border-color:var(--c-primary); }
.km-btn-outline:hover { background:var(--c-primary); color:#fff; }
.km-btn-ghost { background:rgba(255,255,255,.15); color:#fff; border-color:rgba(255,255,255,.7); backdrop-filter:blur(4px); }
.km-btn-ghost:hover { background:#fff; color:var(--c-primary); }
.km-btn-lg { min-height:54px; padding:0 32px; font-size:17px; }
.km-btn-block { width:100%; }

/* 히어로 */
.km-hero { position:relative; min-height:88vh; display:flex; align-items:center; color:#fff; overflow:hidden; }
.km-hero-slides { position:absolute; inset:0; z-index:0; background:linear-gradient(120deg,#4a7c3f,#1F4419); }
.km-slide { position:absolute; inset:0; background-position:center; background-size:cover; background-repeat:no-repeat; opacity:0; transition:opacity 1.4s ease; }
.km-slide.is-active { opacity:1; }
.km-hero-overlay { display:none; }
.km-hero-inner { position:relative; z-index:2; width:100%; max-width:var(--max-w); margin:0 auto; padding:120px 20px 84px; text-shadow:0 1px 10px rgba(0,0,0,.45); text-align:right; }
.km-hero-inner > * { max-width:680px; margin-left:auto; }
.km-hero-actions { justify-content:flex-end; }
.km-hero.km-hero--slide3 .km-hero-inner { text-shadow: 0 2px 18px rgba(0,0,0,.8), 0 1px 5px rgba(0,0,0,.55); }
.km-hero-dots { position:absolute; z-index:3; left:0; right:0; bottom:26px; display:flex; justify-content:center; gap:12px; }
.km-dot { width:13px; height:13px; padding:0; border-radius:50%; border:2px solid rgba(255,255,255,.9); background:transparent; cursor:pointer; transition:background .2s, transform .2s; }
.km-dot:hover { background:rgba(255,255,255,.55); }
.km-dot.is-active { background:#fff; transform:scale(1.15); }

/* ===== 햄버거 + 전체 메뉴 패널 ===== */
.km-burger { display:flex; flex-direction:column; justify-content:center; gap:5px; width:48px; height:48px; padding:12px; background:transparent; border:0; cursor:pointer; }
.km-burger span { display:block; height:2px; width:100%; background:var(--c-primary); border-radius:2px; transition:transform .25s, opacity .2s; }
.km-burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.km-burger.open span:nth-child(2){ opacity:0; }
.km-burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
.km-mega { position:absolute; left:0; right:0; top:100%; background:#fff; border-top:1px solid var(--c-line); box-shadow:var(--shadow-md); overflow:hidden; max-height:0; transition:max-height .35s ease; z-index:150; }
.km-mega.open { max-height:640px; }
.km-mega-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:28px; padding:32px 20px 40px; }
.km-mega-col { display:flex; flex-direction:column; gap:11px; align-items:flex-start; }
.km-mega-h { font-family:var(--head); font-weight:800; font-size:17px; color:var(--c-primary); padding-bottom:11px; border-bottom:2px solid var(--c-line); width:100%; }
.km-mega-col a:not(.km-mega-h){ font-size:15px; color:var(--c-fg); }
.km-mega-col a:not(.km-mega-h):hover{ color:var(--c-accent); text-decoration:none; }
.km-mega-h:hover{ color:var(--c-accent); text-decoration:none; }
@media (max-width:768px){
  .km-mega-grid{ grid-template-columns:1fr; gap:3px; padding:14px 16px 22px; }
  .km-mega.open{ max-height:82vh; overflow-y:auto; }
  .km-mega-h{ margin-top:12px; }
}

/* ===== 모바일 헤더 최적화 ===== */
@media (max-width: 768px) {
  :root { --header-h: 66px; }
  .site-header .container { align-items: center; padding-bottom: 0; max-width: 100%; }
  .site-header .logo img { height: 38px; }
  .site-header .primary-nav { margin-left: 0; }
  .site-header .header-actions { margin-left: auto; gap: 8px; }
  html { scroll-padding-top: 76px; }
  .km-hero-inner { padding-top: 80px; }
}
.km-eyebrow { font-family:var(--head); font-weight:700; letter-spacing:.12em; font-size:15px; opacity:.92; margin-bottom:18px; }
.km-hero h1 { font-family:var(--display); font-size:clamp(30px,6vw,56px); color:#fff; margin-bottom:20px; text-shadow:0 2px 20px rgba(0,0,0,.25); }
.km-hero .km-eyebrow, .km-hero-sub { font-family:"Pretendard", sans-serif; font-weight:600; }
.km-hero-sub { font-size:clamp(15px,2.4vw,20px); opacity:.95; margin-bottom:34px; }
.km-hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:26px; }
.km-badge { display:inline-flex; align-items:center; gap:6px; background:rgba(0,0,0,.28); padding:9px 18px; border-radius:999px; font-size:14px; font-weight:600; }

/* 신뢰 배지 띠 */
.km-trust { background:var(--c-primary-2); color:#fff; }
.km-trust .container { display:flex; flex-wrap:wrap; justify-content:center; gap:14px 32px; padding:18px 20px; }
.km-trust span { font-family:var(--head); font-weight:700; font-size:14px; opacity:.92; }

/* 섹션 */
.km-section { padding:88px 0; }
.km-section.alt { background:#fff; }
#diary { background:#e9f1e3; }
a.km-diary { display:block; color:inherit; text-decoration:none; }
.km-head { text-align:center; max-width:680px; margin:0 auto 48px; }
.km-eyebrow2 { font-family:var(--head); font-weight:600; color:var(--c-fg); letter-spacing:-.04em; font-size:19px; margin-bottom:12px; }
@media (max-width:768px){ .km-eyebrow2 { font-size:16px; margin-bottom:10px; } }
@media (max-width:480px){ .km-eyebrow2 { font-size:14.5px; margin-bottom:8px; } }
.km-title { font-family:var(--display); font-size:clamp(32px,5vw,50px); color:var(--c-primary); margin-bottom:16px; }
.km-desc { color:var(--c-muted); font-size:16px; }
.km-desc strong { color:var(--c-primary); }
.km-cta-center { text-align:center; margin-top:44px; }
@media (min-width:1024px){ #programs .km-head { max-width:1000px; } #programs .km-desc { white-space:nowrap; } }

/* 체험 프로그램 — 지그재그 에디토리얼 */
.km-zz { display:flex; flex-direction:column; gap:64px; max-width:1080px; margin:0 auto; }
.km-zz-row { display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center; }
.km-zz-row.reverse .km-zz-img { order:2; }
.km-zz-img { position:relative; }
.km-zz-img img { width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:var(--radius); box-shadow:var(--shadow-md); display:block; }
.km-zz-row .km-badge-best { top:16px; left:16px; right:auto; font-size:13px; padding:6px 14px; }
.km-zz-title { font-family:var(--head); font-weight:800; font-size:28px; color:var(--c-fg); margin-bottom:8px; }
.km-zz-price { font-family:var(--head); font-weight:800; font-size:32px; color:var(--c-primary); margin:0 0 16px; }
.km-zz-price small { font-size:17px; font-weight:700; }
.km-zz-meta { font-family:var(--body); font-size:15px; font-weight:600; color:var(--c-muted); margin-left:8px; white-space:nowrap; }
.km-zz-desc { font-family:var(--body); font-size:16px; line-height:1.7; color:var(--c-muted); margin:0 0 4px; }
.km-zz .km-list { margin-bottom:0; }
.km-zz-actions { display:flex; gap:10px; margin-top:20px; flex-wrap:wrap; }
@media (max-width:768px){
  .km-zz { gap:42px; }
  .km-zz-row { grid-template-columns:1fr; gap:20px; }
  .km-zz-row.reverse .km-zz-img { order:0; }
  .km-zz-title { font-size:23px; }
  .km-zz-price { font-size:28px; }
  .km-zz-meta { display:block; margin-left:0; margin-top:4px; }
}

/* 유제품 페이지 — 인트로 섹션 (2컬럼) */
.km-prod-intro { position:relative; padding:90px 0 80px; background:linear-gradient(135deg, #fff8e6 0%, #ffffff 50%, #e9f3e2 100%); overflow:hidden; }
.km-prod-intro .container { position:relative; z-index:1; }
.km-prod-intro-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:54px; align-items:center; }

.km-prod-intro-photo { position:relative; margin:0; aspect-ratio:5/4; }
.km-prod-intro-photo img { width:100%; height:100%; object-fit:cover; display:block; border-radius:22px; box-shadow:0 20px 40px rgba(10,20,40,.16); position:relative; z-index:1; }
.km-prod-intro-photo::after { content:""; position:absolute; left:-18px; bottom:-18px; width:calc(100% - 30px); height:calc(100% - 30px); border:2px solid var(--c-accent); border-radius:22px; opacity:.5; z-index:0; }
.km-prod-intro-photo-tag { position:absolute; left:18px; bottom:18px; padding:9px 18px; background:rgba(31,68,25,.92); color:#fff; font-family:var(--head); font-weight:700; font-size:13px; letter-spacing:.04em; border-radius:999px; backdrop-filter:blur(6px); z-index:2; }

.km-prod-intro-text { text-align:left; }
.km-prod-intro-text .km-eyebrow2 { margin:0 0 12px; }
.km-prod-intro-title { font-family:var(--head); font-weight:800; font-size:42px; color:var(--c-fg); line-height:1.22; margin:0 0 22px; letter-spacing:-.01em; }
.km-prod-pills { list-style:none; padding:0; margin:0 0 26px; display:flex; flex-wrap:wrap; gap:8px; }
.km-prod-pills li { display:inline-flex; align-items:center; padding:8px 16px; background:#fff; border:1.5px solid var(--c-accent); border-radius:999px; font-family:var(--head); font-weight:700; font-size:14px; color:var(--c-fg); box-shadow:0 3px 10px rgba(255,167,0,.10); transition:transform .2s ease, box-shadow .2s ease; }
.km-prod-pills li:hover { transform:translateY(-2px); box-shadow:0 8px 16px rgba(255,167,0,.20); }
.km-prod-intro-body { font-size:17px; line-height:1.85; color:var(--c-fg); }
.km-prod-intro-body p { margin:0 0 12px; }
.km-prod-intro-body p:last-child { margin-bottom:0; }
.km-prod-intro-body strong { color:var(--c-primary); font-weight:700; }
.km-prod-actions { display:flex; gap:12px; margin-top:26px; flex-wrap:wrap; }
.km-prod-actions .km-btn { flex:1 1 auto; min-width:180px; min-height:54px; padding:0 28px; font-size:16px; font-weight:700; border-width:2px; }

/* 구입매장 안내 페이지 */
.km-stores-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.km-store-card { display:flex; gap:16px; padding:22px 22px 20px; background:#fff; border:1px solid var(--c-line); border-radius:16px; box-shadow:0 4px 14px rgba(10,20,40,.06); transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.km-store-card:hover { transform:translateY(-4px); box-shadow:0 14px 28px rgba(10,20,40,.12); border-color:var(--c-primary); }
.km-store-card.is-home { background:linear-gradient(135deg,#fff8e6,#fff); border-color:var(--c-accent); }
.km-store-ic { flex:0 0 64px; width:64px; height:64px; border-radius:50%; overflow:hidden; background:#fafaf5; box-shadow:0 4px 10px rgba(10,20,40,.08); }
.km-store-ic img { width:100%; height:100%; object-fit:cover; display:block; }
.km-store-card.is-home .km-store-ic { box-shadow:0 4px 14px rgba(255,167,0,.30); }
.km-store-body { flex:1 1 auto; min-width:0; }
.km-store-name { font-family:var(--head); font-weight:800; font-size:17px; color:var(--c-primary); margin:0 0 8px; line-height:1.3; }
.km-store-addr { margin:0 0 6px; color:var(--c-fg); font-size:14px; line-height:1.5; }
.km-store-phone { display:inline-block; color:var(--c-primary); font-family:var(--head); font-weight:700; font-size:14.5px; text-decoration:none; letter-spacing:.02em; }
.km-store-phone:hover { text-decoration:underline; }
@media (max-width:1024px){ .km-stores-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .km-stores-grid { grid-template-columns:1fr; } .km-store-card { padding:18px; } .km-store-ic { flex:0 0 54px; width:54px; height:54px; } }

@media (max-width:1024px){
  .km-prod-intro-grid { grid-template-columns:1fr; gap:36px; }
  .km-prod-intro-photo { max-width:560px; margin:0 auto; aspect-ratio:16/10; }
  .km-prod-intro-text { text-align:center; max-width:720px; margin:0 auto; }
  .km-prod-intro-title { font-size:34px; }
  .km-prod-pills { justify-content:center; }
}
@media (max-width:768px){
  .km-prod-intro { padding:54px 0 44px; }
  .km-prod-intro-grid { gap:28px; }
  .km-prod-intro-photo { aspect-ratio:16/11; }
  .km-prod-intro-photo::after { display:none; }
  .km-prod-intro-photo img { border-radius:16px; }
  .km-prod-intro-title { font-size:26px; margin-bottom:18px; }
  .km-prod-intro-title br { display:none; }
  .km-prod-intro-body { font-size:15.5px; line-height:1.75; }
  .km-prod-pills li { padding:7px 13px; font-size:13px; }
}

/* 체험 페이지 — 인트로 섹션 (2컬럼 + 정보바 + 장식) */
.km-exp-intro { position:relative; padding:90px 0 80px; background:linear-gradient(135deg, #d0ffbb8c 0%, #ffffff 50%, #c2e3ffd6 100%); overflow:hidden; }
.km-exp-intro .container { position:relative; z-index:1; }
.km-exp-leaf { display:none; }
.km-exp-blob { display:none; }
.km-exp-intro-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:54px; align-items:center; margin-bottom:0; }

/* 좌측 이미지 */
.km-exp-intro-photo { position:relative; margin:0; aspect-ratio:5/4; }
.km-exp-intro-photo img { width:100%; height:100%; object-fit:cover; display:block; border-radius:22px; box-shadow:0 20px 40px rgba(10,20,40,.16); position:relative; z-index:1; }
.km-exp-intro-photo::after { content:""; position:absolute; left:-18px; bottom:-18px; width:calc(100% - 30px); height:calc(100% - 30px); border:2px solid var(--c-primary); border-radius:22px; opacity:.5; z-index:0; }
.km-exp-intro-photo-tag { position:absolute; left:18px; bottom:18px; padding:9px 18px; background:rgba(31,68,25,.92); color:#fff; font-family:var(--head); font-weight:700; font-size:13px; letter-spacing:.04em; border-radius:999px; backdrop-filter:blur(6px); z-index:2; }

/* 우측 텍스트 */
.km-exp-intro-text { text-align:left; }
.km-exp-intro-text .km-eyebrow2 { margin:0 0 12px; }
.km-exp-intro-title { font-family:var(--head); font-weight:800; font-size:42px; color:var(--c-fg); line-height:1.22; margin:0 0 24px; letter-spacing:-.01em; }
.km-exp-intro-body { font-size:17px; line-height:1.85; color:var(--c-fg); margin-bottom:28px; }
.km-exp-intro-body p { margin:0 0 12px; }
.km-exp-intro-body p:last-child { margin-bottom:0; }
.km-exp-intro-body strong { color:var(--c-primary); font-weight:700; }
.km-exp-intro-text .km-exp-info { margin:0; }
.km-exp-intro-text .km-exp-info-list { grid-template-columns:repeat(2,1fr); }
.km-exp-intro-text .km-exp-info-list li { padding:16px 18px; }
.km-exp-intro-text .km-exp-info-list li:nth-child(odd) { border-right:1px solid var(--c-line-2); }
.km-exp-intro-text .km-exp-info-list li:nth-last-child(-n+2) { border-bottom:none; }
.km-exp-intro-text .km-exp-info-ic { flex:0 0 38px; width:38px; height:38px; font-size:18px; }
.km-exp-intro-text .km-exp-info-val { font-size:14.5px; }
@media (max-width:560px){
  .km-exp-intro-text .km-exp-info-list { grid-template-columns:1fr; }
  .km-exp-intro-text .km-exp-info-list li { border-right:none !important; }
  .km-exp-intro-text .km-exp-info-list li:nth-last-child(-n+2) { border-bottom:1px solid var(--c-line-2); }
  .km-exp-intro-text .km-exp-info-list li:last-child { border-bottom:none; }
}

@media (max-width:1024px){
  .km-exp-intro-grid { grid-template-columns:1fr; gap:36px; }
  .km-exp-intro-photo { max-width:560px; margin:0 auto; aspect-ratio:16/10; }
  .km-exp-intro-text { text-align:center; max-width:720px; margin:0 auto; }
  .km-exp-intro-title { font-size:34px; }
}
@media (max-width:1024px){
  .km-exp-leaf-1 { width:130px; height:130px; }
  .km-exp-leaf-2 { width:100px; height:100px; }
}
@media (max-width:768px){
  .km-exp-intro { padding:60px 0 50px; }
  .km-exp-intro-grid { gap:28px; margin-bottom:0; }
  .km-exp-intro-photo { aspect-ratio:16/11; }
  .km-exp-intro-photo::after { display:none; }
  .km-exp-intro-photo img { border-radius:16px; }
  .km-exp-intro-title { font-size:26px; margin-bottom:18px; }
  .km-exp-intro-title br { display:none; }
  .km-exp-intro-body { font-size:15.5px; line-height:1.75; }
  .km-exp-leaf-1 { width:90px; height:90px; top:20px; right:-10px; }
  .km-exp-leaf-2 { display:none; }
  .km-exp-blob { display:none; }
}

/* 인트로 — 체험 안내 정보 박스 */
.km-exp-info { margin-top:0; background:#fff; border:1px solid var(--c-line); border-radius:18px; box-shadow:0 6px 18px rgba(10,20,40,.06); overflow:hidden; text-align:left; }
.km-exp-info-head { background:linear-gradient(135deg,#3a6b32 0%,#1F4419 100%); color:#fff; padding:14px 26px; font-family:var(--head); font-weight:800; font-size:16px; letter-spacing:.02em; }
.km-exp-info-list { list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(2,1fr); }
.km-exp-info-list li { display:flex; align-items:flex-start; gap:14px; padding:22px 26px; border-bottom:1px solid var(--c-line-2); }
.km-exp-info-list li:nth-child(odd) { border-right:1px solid var(--c-line-2); }
.km-exp-info-list li:nth-last-child(-n+2) { border-bottom:none; }
.km-exp-info-ic { flex:0 0 42px; width:42px; height:42px; border-radius:50%; background:#fafaf5; display:flex; align-items:center; justify-content:center; font-size:20px; line-height:1; }
.km-exp-info-list li > div { display:flex; flex-direction:column; gap:3px; min-width:0; }
.km-exp-info-label { font-family:var(--head); font-weight:700; font-size:12.5px; color:var(--c-muted); letter-spacing:.06em; text-transform:uppercase; }
.km-exp-info-val { font-size:16px; color:var(--c-fg); font-weight:600; line-height:1.4; word-break:keep-all; }
a.km-exp-info-val { color:var(--c-primary); text-decoration:none; }
a.km-exp-info-val:hover { text-decoration:underline; }
@media (max-width:768px){
  .km-exp-info { margin-top:30px; border-radius:14px; }
  .km-exp-info-head { padding:12px 18px; font-size:15px; }
  .km-exp-info-list { grid-template-columns:1fr; }
  .km-exp-info-list li { padding:16px 18px; border-right:none !important; }
  .km-exp-info-list li:nth-last-child(-n+2) { border-bottom:1px solid var(--c-line-2); }
  .km-exp-info-list li:last-child { border-bottom:none; }
  .km-exp-info-ic { flex:0 0 36px; width:36px; height:36px; font-size:18px; }
  .km-exp-info-val { font-size:15px; }
}

/* 체험 페이지 — 프로그램 카드 (지그재그 풀와이드) */
.km-progs { display:flex; flex-direction:column; gap:40px; max-width:1200px; margin:0 auto; }
.km-prog-d { display:grid; grid-template-columns:1.05fr 1fr; gap:0; background:#fff; border:1px solid var(--c-line); border-radius:20px; overflow:hidden; box-shadow:0 6px 18px rgba(10,20,40,.06); position:relative; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.km-prog-d:hover { transform:translateY(-4px); box-shadow:0 16px 36px rgba(10,20,40,.10); border-color:var(--c-primary); }
.km-prog-d.is-best { border-color:var(--c-accent); box-shadow:0 8px 28px rgba(255,167,0,.18); }
.km-prog-d.is-best:hover { box-shadow:0 18px 40px rgba(255,167,0,.26); }

/* 지그재그: 짝수번째는 이미지·본문 위치 반전 */
.km-prog-d:nth-child(even) .km-prog-d-media { order:2; }
.km-prog-d:nth-child(even) .km-prog-d-body { order:1; }

/* 이미지 영역 + 가격 배지 */
.km-prog-d-media { position:relative; overflow:hidden; min-height:360px; background:#eef3ea; }
.km-prog-d-img { width:100%; height:100%; min-height:0; object-fit:cover; display:block; transition:transform .5s ease; }
.km-prog-d:hover .km-prog-d-img { transform:scale(1.04); }
.km-prog-d-price { position:absolute; top:20px; left:20px; z-index:2; display:inline-flex; align-items:baseline; gap:3px; background:#fff; color:var(--c-primary); font-family:var(--head); font-weight:800; font-size:26px; padding:10px 20px; border-radius:999px; box-shadow:0 6px 16px rgba(10,20,40,.20); }
.km-prog-d-price small { font-size:15px; font-weight:700; opacity:.85; }
.km-prog-d.is-best .km-prog-d-price { background:linear-gradient(135deg,#ffbf00 0%,#ff7800 100%); color:#fff; }
.km-prog-d-media .km-badge-best { top:20px; right:20px; left:auto; z-index:3; font-size:13px; padding:6px 14px; box-shadow:0 4px 12px rgba(255,167,0,.35); }
.km-prog-d:nth-child(even) .km-prog-d-price { left:auto; right:20px; }
.km-prog-d:nth-child(even) .km-prog-d-media .km-badge-best { right:auto; left:20px; }

/* 본문 영역 */
.km-prog-d-body { padding:40px 44px; display:flex; flex-direction:column; justify-content:center; }
.km-prog-d-head { display:block; margin-bottom:10px; }
.km-prog-d-head h3 { font-family:var(--head); font-weight:800; font-size:30px; color:var(--c-fg); margin:0; line-height:1.2; }
.km-prog-d-meta { margin:0 0 22px; padding:0; border:none; color:var(--c-muted); font-size:16px; font-weight:600; letter-spacing:.01em; }
.km-list-2col { display:grid; grid-template-columns:1fr 1fr; gap:13px 24px; border-top:1px dashed var(--c-line); padding-top:22px; margin:0 0 26px; }
.km-list-2col li { margin-bottom:0; font-size:18px; color:var(--c-fg); padding-left:24px; position:relative; line-height:1.5; }
.km-list-2col li::before { content:""; position:absolute; left:2px; top:10px; width:10px; height:10px; border-radius:50%; background:var(--c-primary); opacity:.55; }
.km-prog-d.is-best .km-list-2col li::before { background:var(--c-accent); opacity:.8; }
.km-actions-row { display:flex; gap:12px; margin-top:auto; flex-wrap:wrap; }
.km-actions-row .km-btn { flex:1 1 0; min-width:140px; padding:0 28px; font-size:16px; min-height:52px; }

@media (max-width:900px){
  .km-prog-d { grid-template-columns:1fr; }
  .km-prog-d:nth-child(even) .km-prog-d-media { order:0; }
  .km-prog-d:nth-child(even) .km-prog-d-body { order:0; }
  .km-prog-d:nth-child(even) .km-prog-d-price { left:20px; right:auto; }
  .km-prog-d:nth-child(even) .km-prog-d-media .km-badge-best { left:auto; right:20px; }
  .km-prog-d-media { min-height:0; aspect-ratio:16/10; }
  .km-prog-d-body { padding:28px 26px 26px; }
  .km-prog-d-head h3 { font-size:24px; }
  .km-prog-d-price { font-size:22px; padding:8px 16px; }
  .km-list-2col { grid-template-columns:1fr; gap:10px; }
}
@media (max-width:480px){
  .km-progs { gap:28px; }
  .km-prog-d-body { padding:22px 20px 20px; }
  .km-prog-d-head h3 { font-size:21px; }
}

/* 카드 그리드 */
.km-grid { display:grid; gap:26px; }
.km-grid-3 { grid-template-columns:repeat(3,1fr); align-items:start; }
.km-grid-4 { grid-template-columns:repeat(4,1fr); }
.km-card { background:#fff; border:1px solid var(--c-line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); position:relative; transition:transform .2s, box-shadow .2s; }
.km-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); }
.km-thumb { width:100%; aspect-ratio:16/11; object-fit:cover; display:block; background:#eef3ea; }
.km-card-body { padding:22px; }
.km-card-title { font-size:20px; color:var(--c-fg); font-family:var(--head); font-weight:800; }

/* 프로그램 카드 */
.km-prog.is-best { border-color:var(--c-accent); box-shadow:0 10px 30px rgba(255,167,0,.18); }
.km-badge-best { position:absolute; top:14px; right:14px; z-index:2; background:var(--c-accent); color:#fff; font-family:var(--head); font-weight:800; font-size:12px; padding:5px 12px; border-radius:999px; }
.km-price { font-family:var(--head); font-weight:800; font-size:30px; color:var(--c-primary); margin:6px 0 2px; }
.km-price small { font-size:16px; font-weight:700; }
.km-meta { color:var(--c-muted); font-size:14px; margin-bottom:16px; }
.km-list { border-top:1px solid var(--c-line); padding:14px 0 0; margin:0 0 18px; list-style:none; }
.km-list li { position:relative; padding-left:22px; font-size:14.5px; margin-bottom:7px; }
.km-list li::before { content:"✓"; position:absolute; left:0; color:var(--c-primary); font-weight:800; }
.km-actions { display:flex; flex-direction:column; gap:8px; }

/* 메인 체험 프로그램 카드 (3열 나열) */
.km-progs-3 { align-items:stretch; }
.km-progs-3 .km-card { display:flex; flex-direction:column; }
.km-progs-3 .km-card-body { display:flex; flex-direction:column; flex:1 1 auto; padding:24px 26px; }
.km-progs-3 .km-card-title { font-size:28px; margin:0 0 2px; }
.km-prog-price { font-family:var(--head); font-weight:800; font-size:40px; color:var(--c-primary); margin:4px 0 2px; }
.km-prog-price small { font-size:21px; font-weight:700; }
.km-prog-meta { color:#000000; font-size:18px; font-weight:600; margin:0 0 14px; }
.km-prog-desc { font-family:var(--body); color:var(--c-muted); font-size:15px; line-height:1.65; margin:0 0 20px; flex:1 1 auto; }
.km-prog-actions { display:flex; gap:8px; }
.km-prog-actions .km-btn { flex:1 1 0; min-width:0; padding:0 12px; font-size:14.5px; }

/* 제품 카드 */
.km-prod .km-thumb { aspect-ratio:1/1; background:#fff; }
.km-tag { font-size:13px; color:var(--c-primary); font-weight:700; margin-bottom:4px; }
.km-prod .km-card-title { font-size:22px; }

/* 목장 일기 */
.km-date { font-size:13px; color:var(--c-brown); font-weight:700; margin-bottom:6px; }
.km-diary .km-card-title { font-size:18px; line-height:1.45; }

/* 이야기 */
.km-story { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.km-story-photo { width:100%; aspect-ratio:16/10; object-fit:cover; border-radius:var(--radius); box-shadow:var(--shadow-md); }
.km-story h2 { font-family:"Pretendard", sans-serif; font-weight:800; font-size:clamp(26px,4vw,38px); color:var(--c-primary); margin:8px 0 16px; }
.km-story p { font-family:"Pretendard", sans-serif; color:var(--c-muted); font-size:16.5px; margin-bottom:14px; }
.km-story .km-sign { color:var(--c-fg); font-size:16px; }
.km-story .km-sign b { color:var(--c-primary); font-size:18px; }

/* 찾아오시는 방법 — 교통 안내 카드 */
.km-howto { padding-bottom:120px; position:relative; }
.km-howto::after { content:""; position:absolute; left:0; right:0; bottom:0; height:80px; background:linear-gradient(180deg,#fff 0%,#fff 100%); z-index:0; }
.km-howto > .container { position:relative; z-index:1; }
.km-howto-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; max-width:1100px; margin:48px auto 0; }
.km-howto-card { position:relative; background:#fff; border:1px solid var(--c-line); border-radius:22px; padding:44px 28px 36px; text-align:center; box-shadow:0 6px 20px rgba(10,20,40,.05); transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease; overflow:hidden; }
.km-howto-card::before { content:""; position:absolute; top:-60px; right:-60px; width:160px; height:160px; border-radius:50%; opacity:.08; transition:transform .4s ease, opacity .3s ease; }
.km-howto-card:hover { transform:translateY(-8px); box-shadow:0 22px 40px rgba(10,20,40,.12); border-color:var(--c-primary); }
.km-howto-card:hover::before { transform:scale(1.4); opacity:.12; }
.km-howto-card[data-mode="car"]::before { background:radial-gradient(circle,var(--c-primary),transparent); }
.km-howto-card[data-mode="bus"]::before { background:radial-gradient(circle,#4a7c40,transparent); }
.km-howto-card[data-mode="park"]::before { background:radial-gradient(circle,var(--c-accent),transparent); }
.km-howto-ico { position:relative; z-index:1; width:88px; height:88px; margin:0 auto 22px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,#fafaf5,#fff); box-shadow:0 6px 18px rgba(45,94,39,.12), inset 0 0 0 2px var(--c-primary); transition:transform .3s ease; }
.km-howto-card[data-mode="bus"] .km-howto-ico { box-shadow:0 6px 18px rgba(74,124,64,.12), inset 0 0 0 2px #4a7c40; }
.km-howto-card[data-mode="park"] .km-howto-ico { box-shadow:0 6px 18px rgba(255,167,0,.16), inset 0 0 0 2px var(--c-accent); }
.km-howto-card:hover .km-howto-ico { transform:scale(1.08) rotate(-4deg); }
.km-howto-ico span { font-size:42px; line-height:1; filter:drop-shadow(0 2px 4px rgba(0,0,0,.10)); }
.km-howto-t { position:relative; z-index:1; font-family:var(--head); font-weight:800; font-size:22px; color:var(--c-primary); margin:0 0 14px; letter-spacing:-.01em; }
.km-howto-card[data-mode="park"] .km-howto-t { color:#cc7000; }
.km-howto-d { position:relative; z-index:1; margin:0; font-size:15.5px; line-height:1.65; color:var(--c-fg); }
.km-howto-d strong { color:var(--c-primary); font-weight:700; }

@media (max-width:1024px){
  .km-howto-grid { grid-template-columns:1fr; max-width:520px; gap:18px; }
  .km-howto-card { padding:36px 24px 30px; }
}
@media (max-width:768px){
  .km-howto { padding-bottom:80px; }
  .km-howto-grid { margin-top:32px; }
  .km-howto-ico { width:74px; height:74px; margin-bottom:18px; }
  .km-howto-ico span { font-size:36px; }
  .km-howto-t { font-size:19px; }
  .km-howto-d { font-size:14.5px; }
}

/* 오시는 길 */
.km-loc { display:grid; grid-template-columns:2fr 1fr; gap:48px; align-items:center; }
.km-map { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); background:#e7efe2; min-height:520px; border:1px solid var(--c-accent); }
.km-map .root_daum_roughmap { width:100% !important; }
.km-map .root_daum_roughmap .wrap_map { height:520px !important; }
.km-map .root_daum_roughmap .wrap_map .map { width:100% !important; }
/* 카카오맵 하단 주소·전화·길찾기 푸터 숨김 */
.km-map .root_daum_roughmap .wrap_controllers,
.km-map .root_daum_roughmap .map_border,
.km-map .root_daum_roughmap .roughmap_maker_label,
.km-map .root_daum_roughmap .roughmap_lander_information,
.km-map .root_daum_roughmap .roughmap_lander_box,
.km-map .root_daum_roughmap > *:not(.wrap_map):not(.wrap_btn_zoom):not(script) { display:none !important; }
@media (max-width:768px){ .km-map .root_daum_roughmap .wrap_map { height:380px !important; } .km-map { min-height:380px; } }
.km-info { list-style:none; padding:0; margin:22px 0 26px; }
.km-info li { display:flex; gap:16px; padding:12px 0; border-bottom:1px solid var(--c-line); }
.km-info li b { flex:0 0 72px; font-family:var(--head); color:var(--c-primary); }
.km-info a { color:var(--c-accent); font-weight:700; }

/* 모바일 플로팅 CTA */
.km-float-book { display:none; position:fixed; left:16px; right:16px; bottom:16px; z-index:90;
  background:linear-gradient(135deg, #ffbf00 0%, #ff7800 100%); color:#fff; text-align:center; font-family:var(--head);
  font-weight:800; font-size:17px; padding:16px; border-radius:14px; text-decoration:none;
  box-shadow:0 8px 28px rgba(255,167,0,.4); }
.km-float-book:hover { color:#fff; text-decoration:none; opacity:.95; }
.km-float-book.km-float-hidden { transform:translateY(120%); opacity:0; pointer-events:none; }
.km-float-book { transition:transform .25s ease, opacity .25s ease; }
@media (max-width:768px) {
  .km-float-book { display:block; }
  .site-footer { padding-bottom:96px; } /* 플로팅 버튼이 푸터 콘텐츠 가리지 않게 */
}

.km-float { display:none; position:fixed; left:16px; right:16px; bottom:16px; z-index:90;
  background:linear-gradient(135deg, #ffbf00 0%, #ff7800 100%); color:#fff; text-align:center; font-family:var(--head);
  font-weight:800; font-size:17px; padding:16px; border-radius:14px;
  box-shadow:0 8px 28px rgba(255,167,0,.4); }
.km-float:hover { color:#fff; text-decoration:none; }

@media (max-width:768px) {
  .km-section { padding:60px 0; }
  .km-grid-3 { grid-template-columns:1fr; max-width:420px; margin:0 auto; }
  .km-grid-4 { grid-template-columns:repeat(2,1fr); }
  .km-story { grid-template-columns:1fr; gap:28px; }
  .km-loc { grid-template-columns:1fr; gap:28px; }
  .km-hero { min-height:78vh; }
  .km-hero-inner { padding-bottom:104px; }
  .km-float { display:block; }
}
@media (max-width:480px) {
  .km-hero-actions { flex-direction:column; align-items:stretch; }
  .km-grid-4 { grid-template-columns:1fr; max-width:340px; margin:0 auto; }
  .km-trust .container { gap:10px 22px; }
  .km-trust span { font-size:12.5px; }
  .km-progs-3 .km-card-title { font-size:21px; }
  .km-prog-price { font-size:32px; }
  .km-prog-price small { font-size:17px; }
  .km-prog-meta { font-size:16px; }
  .km-prog-desc { font-size:14.5px; }
}

/* ===== 서브페이지 공통 ===== */
.km-pagehero { background:linear-gradient(120deg,#3a6b32,#1F4419); color:#fff; padding:66px 0 58px; min-height:280px; display:flex; align-items:center; }
.km-pagehero > .container { width:100%; }
@media (max-width:768px){ .km-pagehero { min-height:220px; padding:48px 0 40px; } }
.km-pagehero .km-eyebrow2 { color:#cfe0c9; }
.km-pagehero h1 { font-size:clamp(28px,4.5vw,42px); color:#fff; margin:0; }
.km-pagehero p { opacity:.92; margin-top:10px; max-width:680px; }

/* 서브 네비게이션 바 (히어로 아래) */
.km-subnav { background:#fff; border-bottom:1px solid var(--c-line); box-shadow:0 4px 14px rgba(10,20,40,.04); position:sticky; top:0; z-index:40; }
.km-subnav .container { display:flex; align-items:stretch; padding:0 20px; }
.km-subnav-home { display:flex; align-items:center; justify-content:center; width:56px; flex:0 0 auto; background:var(--c-primary); color:#fff; margin-left:-1px; }
.km-subnav-home svg { width:21px; height:21px; }
.km-subnav a { text-decoration:none; }
.km-subnav-list { display:flex; list-style:none; margin:0; padding:0; flex-wrap:wrap; }
.km-subnav-item { position:relative; }
.km-subnav-item > a { display:flex; align-items:center; justify-content:center; gap:10px; height:56px; min-width:170px; padding:0 20px; font-family:var(--head); font-weight:600; font-size:16px; color:var(--c-fg); border-right:1px solid var(--c-line); white-space:nowrap; }
.km-subnav-item.has-sub > a { justify-content:space-between; }
.km-subnav-item:first-child > a { border-left:1px solid var(--c-line); }
.km-subnav-item > a:hover { background:#f6f4ee; color:var(--c-primary); }
.km-subnav-item.is-active > a { color:var(--c-primary); box-shadow:inset 0 -3px 0 var(--c-primary); }
.km-subnav-caret { font-size:11px; opacity:.55; }
.km-subnav-sub { position:absolute; top:100%; left:0; min-width:100%; background:#fff; border:1px solid var(--c-line); border-top:none; box-shadow:var(--shadow-md); opacity:0; visibility:hidden; transform:translateY(6px); transition:opacity .18s, transform .18s, visibility .18s; z-index:45; }
.km-subnav-item:hover .km-subnav-sub { opacity:1; visibility:visible; transform:translateY(0); }
.km-subnav-sub a { display:block; padding:12px 22px; font-size:14.5px; color:var(--c-fg); white-space:nowrap; }
.km-subnav-sub a + a { border-top:1px solid var(--c-line); }
.km-subnav-sub a:hover { background:#f6f4ee; color:var(--c-primary); }
@media (max-width:768px){
  .km-subnav .container { padding:0; overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .km-subnav-list { flex-wrap:nowrap; }
  .km-subnav-home { width:48px; flex:0 0 48px; }
  .km-subnav-item { flex:0 0 auto; }
  .km-subnav-item > a { height:50px; min-width:0; padding:0 16px; font-size:14.5px; gap:6px; }
  .km-subnav-sub { display:none; }
}

.km-prose { max-width:820px; margin:0 auto; }
.km-prose p { font-size:16.5px; margin:0 0 16px; color:var(--c-fg); }
/* 시대별 필터 탭 */
.km-erafilter { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin:0 auto 36px; }
.km-erafilter-btn { background:#fff; border:1.5px solid var(--c-line); color:var(--c-fg); padding:10px 22px; border-radius:999px; font-family:var(--head); font-weight:600; font-size:14.5px; cursor:pointer; transition:background .15s, color .15s, border-color .15s, box-shadow .15s; }
.km-erafilter-btn small { font-family:var(--body); font-weight:500; font-size:12.5px; color:var(--c-muted); margin-left:4px; }
.km-erafilter-btn:hover { border-color:var(--c-primary); color:var(--c-primary); }
.km-erafilter-btn:hover small { color:inherit; opacity:.8; }
.km-erafilter-btn.is-active { background:var(--c-primary); color:#fff; border-color:var(--c-primary); box-shadow:0 4px 14px rgba(45,94,39,.2); }
.km-erafilter-btn.is-active small { color:rgba(255,255,255,.8); }
@media (max-width:560px) { .km-erafilter { gap:8px; } .km-erafilter-btn { padding:8px 16px; font-size:13.5px; } }

/* 연혁 타임라인 — 가운데 라인 + 좌우 교차 */
.km-timeline {
  max-width:1000px; margin:0 auto; padding:18px 0;
  list-style:none; position:relative;
}
.km-timeline::before {
  content:""; position:absolute; left:50%; top:18px; bottom:18px;
  width:2px; background:linear-gradient(180deg, var(--c-primary), #ffbf00);
  transform:translateX(-50%);
  z-index:1;
}
.km-timeline li {
  position:relative; width:calc(50% - 40px);
  display:flex; align-items:center; gap:20px;
  padding:18px 22px; margin-bottom:22px;
  background:#fff; border:1px solid var(--c-line); border-radius:14px;
  box-shadow:0 4px 12px rgba(10,20,40,.05);
  transition:transform .2s, box-shadow .2s, border-color .2s;
}
.km-timeline li:nth-child(odd) { margin-right:auto; margin-left:0; }
.km-timeline li:nth-child(even) { margin-left:auto; margin-right:0; }
.km-timeline li::before {
  content:""; position:absolute; top:50%;
  transform:translateY(-50%);
  width:16px; height:16px; border-radius:50%;
  background:var(--c-primary);
  border:none;
  box-shadow:0 0 0 4px #fff, 0 0 0 5px rgba(45,94,39,.25);
  z-index:3;
  transition:background .25s ease;
  animation:kmMarkerPulse 2.6s ease-in-out infinite;
}
@keyframes kmMarkerPulse {
  0%, 100% { box-shadow:0 0 0 4px #fff, 0 0 0 5px rgba(45,94,39,.30); }
  50%      { box-shadow:0 0 0 4px #fff, 0 0 0 14px rgba(255,191,0,0); }
}
.km-timeline li::after {
  content:""; position:absolute; top:50%;
  transform:translateY(-50%);
  width:33px; height:1px; background:var(--c-line);
}
.km-timeline li:nth-child(odd)::before { right:-48px; }
.km-timeline li:nth-child(even)::before { left:-48px; }
.km-timeline li:nth-child(odd)::after { right:-32px; }
.km-timeline li:nth-child(even)::after { left:-32px; }
.km-timeline li:hover {
  border-color:var(--c-primary);
  box-shadow:0 10px 24px rgba(45,94,39,.12);
}
.km-timeline li:hover::before { background:#ffbf00; }
.km-timeline .thumb {
  flex:0 0 140px; width:140px; height:106px;
  border-radius:10px; overflow:hidden; background:#eef3ea;
}
.km-timeline .thumb img {
  width:100%; height:100%; object-fit:cover; display:block;
}
.km-timeline .info { flex:1; min-width:0; }
.km-timeline .yr {
  display:block; font-family:var(--head); font-weight:800;
  font-size:22px; color:var(--c-primary);
  letter-spacing:.01em; margin-bottom:6px;
}
.km-timeline .body {
  display:block; font-family:var(--body);
  font-size:16px; line-height:1.55; color:var(--c-fg);
}
@media (max-width:720px) {
  /* 모바일: 1열 좌측 라인 */
  .km-timeline { padding-left:32px; }
  .km-timeline::before { left:6px; transform:none; }
  .km-timeline li,
  .km-timeline li:nth-child(odd),
  .km-timeline li:nth-child(even) {
    width:100%; margin:0 0 14px 0;
  }
  .km-timeline li:nth-child(odd)::before,
  .km-timeline li:nth-child(even)::before {
    left:-36px; right:auto;
  }
  .km-timeline li:nth-child(odd)::after,
  .km-timeline li:nth-child(even)::after {
    left:-26px; right:auto; width:22px;
  }
  .km-timeline .thumb { flex:0 0 90px; width:90px; height:72px; }
  .km-timeline .yr { font-size:18px; }
  .km-timeline .body { font-size:14.5px; }
}
.km-faclist { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.km-fac { background:#fff; border:1px solid var(--c-line); border-radius:var(--radius-sm); padding:18px 12px; text-align:center; font-family:var(--head); font-weight:700; color:var(--c-primary); }
.km-fac small { display:block; color:var(--c-muted); font-weight:500; font-family:var(--body); font-size:12.5px; margin-top:6px; }

/* 우리 우유 이야기 — 목장에서 식탁까지 (4단계 여정) */
.km-milkstory { position:relative; overflow:hidden; background:linear-gradient(180deg,#fafaf5 0%,#f0f4e8 100%); }
.km-milkstory-drop { position:absolute; font-size:80px; opacity:.08; pointer-events:none; z-index:0; }
.km-milkstory-drop-1 { top:40px; left:4%; transform:rotate(-10deg); }
.km-milkstory-drop-2 { bottom:60px; right:6%; transform:rotate(15deg); font-size:64px; opacity:.10; }
.km-milkstory .container { position:relative; z-index:1; }

.km-journey { position:relative; max-width:1400px; margin:48px auto 0; padding:0 20px; }
.km-journey-path { position:absolute; left:0; right:0; top:78px; height:80px; pointer-events:none; z-index:0; }
.km-journey-path svg { width:100%; height:100%; display:block; }
.km-journey-row { position:relative; z-index:1; display:grid; grid-template-columns:repeat(4,1fr); gap:32px; }

.km-journey-step { position:relative; background:#fff; border:1px solid var(--c-line); border-radius:24px; padding:40px 24px 32px; text-align:center; box-shadow:0 6px 18px rgba(10,20,40,.05); transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.km-journey-step:hover { transform:translateY(-8px); box-shadow:0 22px 36px rgba(10,20,40,.12); border-color:var(--c-primary); }
.km-journey-step::before { content:""; position:absolute; inset:0; border-radius:24px; background:radial-gradient(circle at 50% 0%, rgba(255,191,0,.10), transparent 60%); pointer-events:none; opacity:0; transition:opacity .3s ease; }
.km-journey-step:hover::before { opacity:1; }

.km-journey-ico { position:relative; width:96px; height:96px; margin:0 auto 22px; border-radius:50%; background:linear-gradient(135deg,#3a6b32 0%,#1F4419 100%); display:flex; align-items:center; justify-content:center; box-shadow:0 10px 24px rgba(45,94,39,.28), inset 0 -4px 0 rgba(0,0,0,.10); }
.km-journey-emoji { font-size:46px; line-height:1; filter:drop-shadow(0 2px 4px rgba(0,0,0,.15)); }
.km-journey-num { position:absolute; top:-8px; right:-8px; width:34px; height:34px; border-radius:50%; background:#fff; color:var(--c-primary); font-family:var(--head); font-weight:800; font-size:13px; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 10px rgba(10,20,40,.12); border:2px solid var(--c-primary); letter-spacing:.02em; }
.km-journey-step[data-step="2"] .km-journey-ico { background:linear-gradient(135deg,#4a7c40 0%,#2D5E27 100%); }
.km-journey-step[data-step="3"] .km-journey-ico { background:linear-gradient(135deg,#5a8c50 0%,#3a6b32 100%); }
.km-journey-step[data-step="4"] .km-journey-ico { background:linear-gradient(135deg,#ffbf00 0%,#ff7800 100%); box-shadow:0 10px 24px rgba(255,120,0,.32), inset 0 -4px 0 rgba(0,0,0,.10); }
.km-journey-step[data-step="4"] .km-journey-num { color:#ff7800; border-color:#ff7800; }

.km-journey-t { font-family:var(--head); font-weight:800; font-size:22px; color:var(--c-primary); margin:0 0 10px; line-height:1.3; letter-spacing:-.01em; }
.km-journey-step[data-step="4"] .km-journey-t { color:#ff7800; }
.km-journey-d { margin:0; font-size:15px; line-height:1.65; color:var(--c-fg); }

.km-milkstory-cta { text-align:center; margin-top:54px; padding-top:36px; border-top:1px dashed var(--c-line); }
.km-milkstory-cta .km-btn { padding:0 40px; font-size:17px; min-height:58px; }
.km-milkstory-note { margin:20px 0 0; font-size:15px; color:var(--c-muted); }
.km-milkstory-note strong { color:var(--c-primary); font-weight:700; }

@media (max-width:1024px){
  .km-journey-row { grid-template-columns:repeat(2,1fr); gap:24px; }
  .km-journey-path { display:none; }
}
@media (max-width:768px){
  .km-milkstory-drop { display:none; }
  .km-journey { margin-top:32px; padding:0; }
  .km-journey-row { gap:18px; }
  .km-journey-step { padding:32px 18px 26px; border-radius:20px; }
  .km-journey-ico { width:78px; height:78px; margin-bottom:18px; }
  .km-journey-emoji { font-size:36px; }
  .km-journey-num { width:28px; height:28px; font-size:11.5px; top:-6px; right:-6px; }
  .km-journey-t { font-size:18px; }
  .km-journey-d { font-size:14px; }
  .km-milkstory-cta { margin-top:36px; padding-top:28px; }
  .km-milkstory-cta .km-btn { padding:0 28px; font-size:15px; min-height:52px; }
  .km-milkstory-note { font-size:14px; }
}
@media (max-width:480px){
  .km-journey-row { grid-template-columns:1fr; max-width:340px; margin:0 auto; }
}

/* 제품 통합 카드 (products.php) */
#products .container { max-width:1600px; }
.km-prod-rich-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:28px; margin-top:32px; }
.km-prod-rich { display:flex; flex-direction:column; background:#fff; border:1px solid var(--c-line); border-radius:18px; overflow:hidden; box-shadow:0 4px 14px rgba(10,20,40,.06); transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.km-prod-rich:hover { transform:translateY(-6px); box-shadow:0 18px 34px rgba(10,20,40,.12); border-color:var(--c-primary); }
.km-prod-rich.is-soon { border-style:dashed; background:linear-gradient(135deg,#fafaf5,#fff); }
.km-prod-rich-media { position:relative; aspect-ratio:1/1; overflow:hidden; background:#eef3ea; }
.km-prod-rich-media img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s ease; }
.km-prod-rich:hover .km-prod-rich-media img { transform:scale(1.05); }
.km-prod-rich-tag { position:absolute; top:12px; left:12px; padding:6px 12px; background:rgba(45,94,39,.92); color:#fff; font-family:var(--head); font-weight:700; font-size:11.5px; letter-spacing:.02em; border-radius:999px; backdrop-filter:blur(6px); max-width:calc(100% - 24px); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.km-prod-rich-body { padding:22px 22px 24px; display:flex; flex-direction:column; gap:14px; flex:1 1 auto; }
.km-prod-rich-name { font-family:var(--head); font-weight:800; font-size:23px; color:var(--c-fg); margin:0; line-height:1.3; }
.km-prod-rich-name small { display:inline-block; margin-left:4px; padding:3px 8px; background:var(--c-accent); color:#fff; font-size:11px; font-weight:700; border-radius:999px; vertical-align:middle; }
.km-prod-rich-feat { margin:0; font-size:17px; line-height:1.6; color:#000000; flex:1 1 auto; }
.km-prod-rich-aud { display:flex; flex-direction:column; gap:4px; padding-top:14px; border-top:1px dashed var(--c-line); margin-top:auto; }
.km-prod-rich-aud-l { font-family:var(--head); font-weight:700; font-size:13px; color:var(--c-primary); letter-spacing:.06em; text-transform:uppercase; }
.km-prod-rich-aud-v { font-size:16px; color:var(--c-fg); font-weight:600; line-height:1.5; }
@media (max-width:1200px){ .km-prod-rich-grid { grid-template-columns:repeat(3,1fr); } }
@media (max-width:768px){ .km-prod-rich-grid { grid-template-columns:repeat(2,1fr); gap:14px; } .km-prod-rich-body { padding:16px 16px 18px; gap:10px; } .km-prod-rich-name { font-size:27px; } .km-prod-rich-feat { font-size:15px; } .km-prod-rich-aud-l { font-size:12px; } .km-prod-rich-aud-v { font-size:14.5px; } }
@media (max-width:480px){ .km-prod-rich-grid { grid-template-columns:1fr; max-width:420px; margin-left:auto; margin-right:auto; } }

/* 인증서 갤러리 (certs.php) */
.km-cert-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.km-cert-card { margin:0; background:#fff; border:1px solid var(--c-line); border-radius:14px; overflow:hidden; box-shadow:0 4px 14px rgba(10,20,40,.06); transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; display:flex; flex-direction:column; }
.km-cert-card:hover { transform:translateY(-4px); box-shadow:0 12px 28px rgba(10,20,40,.12); border-color:var(--c-primary); }
.km-cert-card img { width:100%; height:280px; object-fit:cover; object-position:center top; background:#f4f1ea; display:block; cursor:zoom-in; transition:transform .35s ease; }
.km-cert-card:hover img { transform:scale(1.03); }
.km-cert-card figcaption { padding:16px 18px 18px; text-align:center; border-top:1px solid var(--c-line-2); background:linear-gradient(180deg,#fafaf5,#fff); }
.km-cert-card figcaption strong { display:block; font-family:var(--head); font-weight:700; font-size:16px; color:var(--c-primary); line-height:1.3; }
.km-cert-card figcaption small { display:block; margin-top:6px; font-size:12.5px; color:var(--c-muted); letter-spacing:.01em; }
@media (max-width:1024px){ .km-cert-grid { grid-template-columns:repeat(3,1fr); } .km-cert-card img { height:260px; } }
@media (max-width:768px){ .km-cert-grid { grid-template-columns:repeat(2,1fr); gap:14px; } .km-cert-card img { height:220px; } .km-cert-card figcaption { padding:12px 12px 14px; } .km-cert-card figcaption strong { font-size:14.5px; } .km-cert-card figcaption small { font-size:11.5px; } }
@media (max-width:480px){ .km-cert-card img { height:200px; } }

/* 시설 분류 필터 (facilities.php) */
.km-facfilter { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin:0 auto 36px; }
.km-facfilter-btn { background:#fff; border:1.5px solid var(--c-line); color:var(--c-fg); padding:10px 22px; border-radius:999px; font-family:var(--head); font-weight:600; font-size:14.5px; cursor:pointer; transition:background .15s, color .15s, border-color .15s, box-shadow .15s; }
.km-facfilter-btn:hover { border-color:var(--c-primary); color:var(--c-primary); }
.km-facfilter-btn.is-active { background:var(--c-primary); color:#fff; border-color:var(--c-primary); box-shadow:0 4px 14px rgba(45,94,39,.2); }
@media (max-width:560px) { .km-facfilter { gap:8px; } .km-facfilter-btn { padding:8px 16px; font-size:13.5px; } }

/* 시설 이미지 그리드 (facilities.php) */
.km-facgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.km-fac-card { margin:0; background:#fff; border:1px solid var(--c-line); border-radius:14px; overflow:hidden; box-shadow:0 4px 14px rgba(10,20,40,.04); transition:transform .2s, box-shadow .2s, border-color .2s; }
.km-fac-card:hover { transform:translateY(-4px); box-shadow:0 12px 28px rgba(45,94,39,.12); border-color:var(--c-primary); }
.km-fac-card img { width:100%; aspect-ratio:3/2; object-fit:cover; display:block; background:#eef3ea; }
.km-fac-card figcaption { padding:16px 18px 18px; font-family:var(--head); font-weight:700; font-size:18px; color:var(--c-fg); }
.km-fac-card figcaption small { display:block; font-family:var(--body); font-weight:500; font-size:13.5px; color:var(--c-muted); margin-top:5px; }
@media (max-width:880px) { .km-facgrid { grid-template-columns:repeat(2,1fr); gap:16px; } }
@media (max-width:520px) { .km-facgrid { grid-template-columns:1fr; max-width:420px; margin:0 auto; } }

/* 라이트박스 (이미지 확대 보기) */
.km-lightbox { position:fixed; inset:0; background:rgba(255,248,240,.85); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); display:flex; align-items:center; justify-content:center; z-index:9999; cursor:zoom-out; padding:24px; animation:kmLbFade .18s ease-out; }
.km-lightbox[hidden] { display:none; }
.km-lightbox-frame {
  background:#fefdf6; border-radius:6px;
  padding:12px 12px 0; display:flex; flex-direction:column;
  max-width:min(1040px, 95vw); max-height:95vh;
  box-shadow:0 25px 70px rgba(45,94,39,.18), 0 0 0 1px rgba(0,0,0,.04);
  transition:opacity .18s ease, transform .18s ease;
  position:relative;
}
.km-lightbox-frame.is-fading { opacity:0; transform:scale(.985); }
.km-lightbox-frame img {
  width:min(1000px, calc(95vw - 24px)); height:auto;
  max-height:calc(95vh - 90px); object-fit:contain;
  background:#fff; display:block; border-radius:3px;
}
.km-lightbox-caption {
  display:flex; align-items:center; gap:10px;
  padding:14px 8px 16px;
  font-family:var(--head);
}
.km-lightbox-leaf {
  width:22px; height:22px; color:var(--c-primary);
  flex:0 0 22px;
}
.km-lightbox-title {
  font-weight:800; font-size:17px; color:var(--c-fg);
}
.km-lightbox-sub {
  font-family:var(--body); font-weight:500;
  font-size:14px; color:var(--c-muted);
  padding-left:12px; margin-left:4px;
  border-left:1px solid var(--c-line);
}
.km-lightbox-close { position:absolute; top:20px; right:24px; background:#fff; border:1px solid var(--c-line); color:var(--c-fg); width:48px; height:48px; border-radius:50%; font-size:26px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 12px rgba(10,20,40,.10); transition:transform .15s, background .15s; z-index:10; }
.km-lightbox-close:hover { background:var(--c-primary); color:#fff; border-color:var(--c-primary); transform:scale(1.05); }
.km-lightbox-nav { position:absolute; top:50%; transform:translateY(-50%); background:#fff; border:1px solid var(--c-line); color:var(--c-fg); width:54px; height:54px; border-radius:50%; font-size:34px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:0 6px 18px rgba(10,20,40,.12); transition:transform .15s, background .15s; padding-bottom:4px; z-index:10; }
.km-lightbox-prev { left:32px; }
.km-lightbox-next { right:32px; }
.km-lightbox-nav:hover { background:var(--c-primary); color:#fff; border-color:var(--c-primary); transform:translateY(-50%) scale(1.06); }
.km-lightbox-counter { position:absolute; bottom:28px; left:50%; transform:translateX(-50%); background:rgba(255,255,255,.95); color:var(--c-fg); padding:7px 18px; border-radius:999px; font-family:var(--head); font-weight:600; font-size:14px; box-shadow:0 4px 12px rgba(10,20,40,.08); border:1px solid var(--c-line); }
@media (max-width:640px) {
  .km-lightbox-nav { width:44px; height:44px; font-size:28px; }
  .km-lightbox-prev { left:12px; }
  .km-lightbox-next { right:12px; }
  .km-lightbox-close { top:14px; right:14px; width:42px; height:42px; font-size:22px; }
  .km-lightbox-counter { bottom:18px; padding:6px 14px; font-size:13px; }
}
@keyframes kmLbFade { from { opacity:0; } to { opacity:1; } }
.km-faq { max-width:820px; margin:0 auto; }
.km-faq details { background:#fff; border:1px solid var(--c-line); border-radius:var(--radius-sm); margin-bottom:10px; padding:0 18px; }
.km-faq summary { cursor:pointer; font-family:var(--head); font-weight:700; padding:16px 0; list-style:none; }
.km-faq summary::-webkit-details-marker { display:none; }
.km-faq summary::before { content:"Q  "; color:var(--c-accent); font-weight:800; }
.km-faq details[open] summary { border-bottom:1px solid var(--c-line-2); }
.km-faq .a { padding:14px 2px; color:var(--c-muted); }

/* FAQ 페이지 전용 */
.km-faq-page { max-width:880px; margin:0 auto; }
.km-faq-page details { padding:0 22px; margin-bottom:12px; border-radius:14px; box-shadow:0 3px 10px rgba(10,20,40,.04); transition:box-shadow .2s ease, border-color .2s ease; }
.km-faq-page details:hover { border-color:var(--c-primary); box-shadow:0 8px 20px rgba(10,20,40,.08); }
.km-faq-page details[open] { border-color:var(--c-primary); }
.km-faq-page summary { padding:22px 0; font-size:21px; display:flex; align-items:center; gap:16px; font-weight:700; }
.km-faq-page summary::before { content:"Q"; flex:0 0 36px; width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,#ffbf00,#ff7800); color:#fff; font-weight:800; display:inline-flex; align-items:center; justify-content:center; font-size:15px; }
.km-faq-page details[open] summary::before { background:linear-gradient(135deg,#3a6b32,#1F4419); }
.km-faq-page .a { padding:18px 0 22px 52px; position:relative; color:var(--c-fg); font-size:17.5px; line-height:1.8; }
.km-faq-page .a::before { content:"A"; position:absolute; left:0; top:16px; width:36px; height:36px; border-radius:50%; background:#fafaf5; color:var(--c-primary); font-family:var(--head); font-weight:800; font-size:15px; display:inline-flex; align-items:center; justify-content:center; border:1.5px solid var(--c-line); }
.km-faq-cta { position:relative; max-width:880px; margin:64px auto 0; padding:54px 32px 48px; text-align:center; background:linear-gradient(135deg,#fff8e6 0%,#fff 50%,#e8f1ff 100%); border:2px solid var(--c-accent); border-radius:22px; box-shadow:0 14px 36px rgba(255,167,0,.18); overflow:hidden; }
.km-faq-cta::before { content:"✦"; position:absolute; top:18px; left:50%; transform:translateX(-50%); font-size:24px; color:var(--c-accent); opacity:.7; }
.km-faq-cta::after { content:""; position:absolute; bottom:-60px; right:-60px; width:220px; height:220px; border-radius:50%; background:radial-gradient(circle, rgba(45,94,39,.10), transparent 70%); pointer-events:none; }
.km-faq-cta p { font-family:var(--head); font-weight:800; font-size:26px; color:var(--c-primary); margin:0 0 26px; letter-spacing:-.01em; line-height:1.3; position:relative; z-index:1; }
.km-faq-cta-actions { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; position:relative; z-index:1; }
.km-faq-cta-actions .km-btn { min-height:58px; padding:0 32px; font-size:17px; font-weight:700; border-width:2px; }

/* CTA 2열 행 */
.km-faq-cta-row { display:flex; justify-content:center; align-items:stretch; gap:14px; flex-wrap:wrap; position:relative; z-index:1; }
.km-faq-cta-row .km-faq-phone,
.km-faq-cta-row .km-faq-cta-btn { flex:0 1 auto; min-height:60px; }
.km-faq-cta-row .km-faq-cta-btn { display:inline-flex; align-items:center; padding:0 64px; font-size:17px; font-weight:700; border-width:2px; }

/* 전화번호 강조 */
.km-faq-phone { display:inline-flex; align-items:center; gap:12px; padding:0 24px; margin:0; background:#fff; border:2px solid var(--c-primary); border-radius:999px; color:var(--c-primary); text-decoration:none; box-shadow:0 6px 16px rgba(45,94,39,.12); transition:transform .2s ease, box-shadow .2s ease, background .2s ease; position:relative; z-index:1; }
.km-faq-phone:hover { transform:translateY(-2px); box-shadow:0 10px 22px rgba(45,94,39,.18); background:#fafaf5; text-decoration:none; }
.km-faq-phone-ic { display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,#3a6b32 0%,#1F4419 100%); color:#fff; font-size:16px; }
.km-faq-phone-num { font-family:var(--head); font-weight:800; font-size:24px; letter-spacing:.02em; line-height:1; color:var(--c-primary); }

@media (max-width:768px){
  .km-faq-cta { margin-top:48px; padding:40px 22px 36px; }
  .km-faq-cta p { font-size:21px; margin-bottom:22px; }
  .km-faq-cta-actions .km-btn { width:100%; min-height:52px; font-size:16px; padding:0 22px; }
  .km-faq-cta-row { gap:10px; }
  .km-faq-cta-row .km-faq-phone,
  .km-faq-cta-row .km-faq-cta-btn { flex:1 1 100%; min-height:52px; justify-content:center; }
  .km-faq-cta-row .km-faq-cta-btn { padding:0 22px; font-size:16px; }
  .km-faq-phone { gap:10px; padding:0 18px; }
  .km-faq-phone-ic { width:30px; height:30px; font-size:14px; }
  .km-faq-phone-num { font-size:20px; }
}
@media (max-width:768px){
  .km-faq-page summary { font-size:18.5px; padding:20px 0; gap:14px; }
  .km-faq-page summary::before { flex:0 0 32px; width:32px; height:32px; font-size:14px; }
  .km-faq-page .a { padding-left:46px; font-size:16px; }
  .km-faq-page .a::before { width:32px; height:32px; font-size:14px; top:14px; }
  .km-faq-cta { padding:24px 20px; }
  .km-faq-cta p { font-size:16px; }
}
.km-ptable { width:100%; border-collapse:collapse; max-width:960px; margin:0 auto; background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); }
.km-ptable th, .km-ptable td { padding:14px 14px; border-bottom:1px solid var(--c-line); text-align:left; font-size:15px; vertical-align:top; }
.km-ptable th { background:var(--c-tag); font-family:var(--head); color:var(--c-primary); white-space:nowrap; }
/* 예약 방법 — 4단계 플로우 */
.km-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; max-width:100%; margin:0 auto; counter-reset:step; position:relative; }
.km-steps::before { content:""; position:absolute; left:10%; right:10%; top:62px; height:2px; background:repeating-linear-gradient(to right, var(--c-primary) 0 8px, transparent 8px 16px); opacity:.35; z-index:0; }
.km-step { position:relative; background:#fff; border:1px solid var(--c-line); border-radius:22px; padding:44px 30px 38px; text-align:center; box-shadow:0 4px 14px rgba(10,20,40,.05); transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; z-index:1; }
.km-step:hover { transform:translateY(-6px); box-shadow:0 16px 32px rgba(10,20,40,.12); border-color:var(--c-primary); }
.km-step::before { counter-increment:step; content:counter(step); display:flex; align-items:center; justify-content:center; width:68px; height:68px; border-radius:50%; background:linear-gradient(135deg,#3a6b32 0%,#1F4419 100%); color:#fff; font-family:var(--head); font-weight:800; font-size:26px; margin:0 auto 22px; box-shadow:0 6px 16px rgba(45,94,39,.30); position:relative; z-index:2; }
.km-step::after { content:""; position:absolute; top:32px; left:50%; transform:translateX(-50%); width:92px; height:92px; border-radius:50%; background:radial-gradient(circle, rgba(255,191,0,.25) 0%, transparent 70%); z-index:0; pointer-events:none; }
.km-step .km-step-icon { display:flex; align-items:center; justify-content:center; width:52px; height:52px; margin:0 auto 16px; border-radius:50%; background:#fafaf5; color:var(--c-accent); font-size:28px; }
.km-step b { display:block; font-family:var(--head); font-weight:800; font-size:22px; color:var(--c-primary); margin-bottom:10px; line-height:1.3; }
.km-step small { display:block; color:var(--c-muted); font-size:15.5px; line-height:1.6; }
.km-step:nth-child(2)::before { background:linear-gradient(135deg,#4a7c40 0%,#2D5E27 100%); }
.km-step:nth-child(3)::before { background:linear-gradient(135deg,#5a8c50 0%,#3a6b32 100%); }
.km-step:nth-child(4)::before { background:linear-gradient(135deg,#ffbf00 0%,#ff7800 100%); box-shadow:0 6px 16px rgba(255,120,0,.35); }
@media (max-width:900px) {
  .km-steps { grid-template-columns:1fr 1fr; gap:18px; max-width:560px; }
  .km-steps::before { display:none; }
}
@media (max-width:480px) {
  .km-step { padding:24px 16px 22px; }
  .km-step::before { width:48px; height:48px; font-size:19px; margin-bottom:14px; }
  .km-step b { font-size:17px; }
  .km-step small { font-size:13.5px; }
}
@media (max-width:768px) {
  .km-pagehero { padding:48px 0 40px; }
  .km-faclist { grid-template-columns:repeat(2,1fr); }
  .km-ptable { display:block; overflow-x:auto; white-space:nowrap; }
}

/* ===== 헤더 폭/로고 ===== */
.site-header .container { max-width: 1440px; align-items: flex-end; padding-bottom: 18px; }
.site-header .primary-nav { margin-left: 24px; }
.site-header .header-actions { margin-left: 24px; }
@media (min-width: 769px) { .site-header .primary-nav a { padding-top: 0; padding-bottom: 0; } }
.site-header .logo { display: inline-flex; align-items: center; padding: 4px 0; }
.site-header .logo img { height: 66px; width: auto; display: block; }
@media (max-width: 768px) { .site-header .logo img { height: 50px; } }

/* ===== 드롭다운 네비게이션 ===== */
html { scroll-behavior: smooth; scroll-padding-top: 108px; }
.primary-nav { align-items: center; gap: 56px; }
.primary-nav > a, .primary-nav .nav-item > a { font-size: 19px; font-weight: 600; }
.primary-nav .nav-sub a { font-size: 15px; }
.primary-nav .nav-item { position: relative; }
.primary-nav .nav-item > a { display: inline-flex; align-items: center; }
.primary-nav .has-sub > a::after { content: "▾"; font-size: 10px; margin-left: 5px; opacity: .65; }
.nav-sub {
  position: absolute; top: 100%; left: 0; margin-top: 18px;
  min-width: 186px; background: #fff; border: 1px solid var(--c-line);
  border-radius: 12px; box-shadow: var(--shadow-md); padding: 8px;
  display: none; flex-direction: column; z-index: 200;
}
.nav-item:hover > .nav-sub, .nav-item:focus-within > .nav-sub { display: flex; }
.nav-item.has-sub::after { content: ""; position: absolute; left: 0; right: 0; top: 100%; height: 22px; } /* hover 갭 브리지 */
.primary-nav .nav-sub a { padding: 10px 12px; border-radius: 7px; font-size: 14.5px; color: var(--c-fg); white-space: nowrap; font-weight: 500; }
.primary-nav .nav-sub a:hover { background: var(--c-line-2); color: var(--c-primary); text-decoration: none; }

@media (max-width: 768px) {
  .primary-nav { align-items: stretch; }
  .primary-nav .nav-item { width: 100%; }
  .primary-nav > a,
  .primary-nav .nav-item > a { display: block; padding: 14px 20px; border-bottom: 1px solid var(--c-line-2); font-size: 16px; }
  .primary-nav .has-sub > a::after { float: right; }
  .primary-nav .nav-sub {
    position: static; display: flex; margin: 0; padding: 0;
    border: 0; border-radius: 0; box-shadow: none; background: var(--c-line-2); min-width: 0;
  }
  .primary-nav .nav-sub a { padding: 12px 20px 12px 40px; border-bottom: 1px solid rgba(0,0,0,.05); font-size: 15px; border-radius: 0; }
  .nav-item.has-sub::after { display: none; }
  /* 모바일: 헤더의 예약하기·언어선택 숨김 → 햄버거 메뉴 안으로 이동 */
  .site-header .header-actions > .km-btn-accent,
  .site-header .header-actions > .lang-switcher { display: none; }
}

/* 모바일 햄버거 메뉴 안의 예약하기·언어선택 (PC에선 숨김) */
.primary-nav .mobile-only-menu { display: none; }
@media (max-width: 768px) {
  .primary-nav { max-height: calc(100vh - var(--header-h)); overflow-y: auto; }
  .primary-nav .mobile-only-menu { display: block !important; padding: 18px 20px 24px; border-top: 1px solid var(--c-line); margin-top: 6px; background:#fafaf5; }
  .primary-nav .mobile-book-btn {
    display: flex !important; align-items: center; justify-content: center;
    min-height: 48px; width: 100%; padding: 0 20px !important;
    background: linear-gradient(135deg, #ffbf00 0%, #ff7800 100%) !important;
    color: #fff !important; border-radius: 999px !important;
    font-family: var(--head); font-weight: 700; font-size: 15px;
    text-decoration: none; border: none !important; border-bottom: none !important;
    margin-bottom: 20px;
  }
  .primary-nav .mobile-lang-label {
    display: block; font-family: var(--head); font-weight: 600;
    font-size: 13px; color: var(--c-muted); margin-bottom: 10px;
    letter-spacing: .02em; text-align: left;
  }
  .primary-nav .mobile-lang-list { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
  .primary-nav .mobile-lang-list a {
    display: block !important;
    padding: 10px 12px !important; border: 1px solid var(--c-line) !important;
    border-radius: 8px !important; text-align: center;
    font-family: var(--head); font-weight: 600; font-size: 14px;
    color: var(--c-fg); background: #fff;
  }
  .primary-nav .mobile-lang-list a:hover { border-color: var(--c-primary) !important; color: var(--c-primary); }
}
