:root {
  /* Design Tokens (v1.0 LOCKED) */
  --color-brand: #3B7A57;
  --color-accent: #D9C7A3;
  --color-text: #1F2937;
  --color-text-muted: #6B7280;
  --color-bg-canvas: #F8FAF9;
  --color-bg-panel: #FFFFFF;
  --color-border: #E5E7EB;
  --radius-md: 14px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.06);
  --shadow-md: 0 4px 12px rgba(0,0,0,.08);
  --container: 1200px;

  /* (옵션) 히어로 배경 변수 */
  --hero-color: #6FA884;
  --hero-image: url("https://mysan.kr/images/hero/hero_03_2400.png");
}

html { font-size: 16px; }
body {
  margin: 0;
  font-family: Pretendard, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "맑은 고딕", sans-serif;
  line-height: 1.7;
  color: var(--color-text);
  background: var(--color-bg-canvas);

  /* 디버깅용 – 적용 확인 후 지워도 됨 */
  outline: 3px dashed magenta;
}

a { color: var(--color-brand); text-decoration-thickness: 2px; }
a:hover { filter: brightness(.95); }
img { max-width: 100%; height: auto; display: block; }
.card-img { width: 100%; height: auto; aspect-ratio: 16/9; object-fit: cover; border-radius: 10px; margin-bottom: 10px; box-shadow: var(--shadow-sm); }

.container { max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.skip { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
.skip:focus { position: static; width: auto; height: auto; padding: .5rem .75rem; background: var(--color-accent); border-radius: 8px; }

header { background: var(--color-bg-panel); border-bottom: 1px solid var(--color-border); position: sticky; top: 0; z-index: 50; }
.nav { display: flex; align-items: center; justify-content: space-between; padding: .75rem 0; }
.nav .menu { display: flex; gap: 16px; }
.brand { color: var(--color-brand); font-weight: 700; }

.hero { position: relative; overflow: hidden; }
.hero .bg { position: absolute; inset: 0; background: var(--hero-color) var(--hero-image) center/cover no-repeat; }
.hero .panel { position: relative; padding: 80px 0 96px; }

h1 { font-size: 2.25rem; line-height: 1.25; font-weight: 700; margin: 0; }
h2 { font-size: 2rem; line-height: 1.3; font-weight: 700; }
h3 { font-size: 1.5rem; line-height: 1.35; font-weight: 600; }

.pill { display: inline-flex; align-items: center; gap: 8px; padding: 6px 10px; background: color-mix(in oklab, var(--color-accent) 80%, white); border-radius: 999px; box-shadow: var(--shadow-sm); font-size: .75rem; }
.lead { color: var(--color-text-muted); max-width: 720px; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; height: 44px; padding: 0 16px; border-radius: var(--radius-md); font-weight: 600; border: 1px solid transparent; cursor: pointer; }
.btn-primary { background: var(--color-brand); color: #fff; box-shadow: var(--shadow-md); }
.btn-outline { background: #fff; color: var(--color-brand); border-color: var(--color-brand); }

.section { padding: 56px 0; }
.card { background: var(--color-bg-panel); border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); padding: 16px; }

.grid { display: grid; gap: 16px; }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.tag { display: inline-block; padding: 4px 10px; border-radius: 999px; background: var(--color-accent); color: var(--color-text); font-size: .8rem; }

footer { border-top: 1px solid var(--color-border); padding: 24px 0; color: var(--color-text-muted); }

/* 반응형 */
@media (max-width: 1024px) {
  .grid-4 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .grid-4, .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .hero .panel { padding: 56px 0 72px; }
  h1 { font-size: 1.75rem; }
}

@media (max-width: 560px) {
  /* << 모바일 여백 축소 핵심 */
  .container { padding: 0 18px; }
  .grid { gap: 12px; }
  .card { padding: 12px; }
  .section { padding: 40px 0; }
  .grid-4, .grid-3 { grid-template-columns: 1fr; }
}
/* 배지 공통 */
.meta{display:flex;flex-wrap:wrap;gap:8px;margin:4px 0 8px;}
.badge, .tag{
  display:inline-flex;align-items:center;gap:6px;
  height:24px;padding:0 10px;border-radius:9999px;
  background:var(--color-accent);color:var(--color-text);
  font-size:.8rem;font-weight:600;box-shadow:var(--shadow-sm);
}

/* 카드 본문 리스트: 들여쓰기 최소화 + 모바일 가독성 */
#grasses .card .ul-compact{
  list-style: disc;
  list-style-position: inside; /* bullet을 상자 안쪽으로 → 여백 축소 */
  padding-left: 0;             /* 기본 들여쓰기 제거 */
  margin: 8px 0 0;
  line-height: 1.6;
} 

/* 배지(메타) 라인 */
#grasses .card .meta{
  display:flex; flex-wrap:wrap; gap:6px;
  margin:4px 0 8px;
}
#grasses .card .badge{
  display:inline-block; padding:2px 8px; border-radius:999px;
  background: var(--color-accent); color: var(--color-text);
  font-size:.8rem;
}

/* 필요하면 아주 살짝 들여쓰기 버전 */
#grasses .card .ul-compact.indent-sm{
  list-style-position: outside;
  padding-left: 12px; /* 약간만 들여쓰기 */
}

/* 전체 섹션 기본 간격을 살짝 축소 */
.section{ padding: 40px 0; } /* 기존 56px → 48px 정도로 조정 */
/* 특정 구간만 더 타이트하게: About ↔ 대표 리스트 */
#about.section{  padding-bottom: 28px; }  /* 아래쪽만 줄임 */
#grasses.section{ padding-top: 24px; }    /* 윗쪽만 줄임 */
/* 다른 섹션들도 타이트하게 보이길 원하면 */
#use-cases.section,
#care.section,
#contact.section{ padding-top: 24px; padding-bottom: 28px; }
/* 모바일에서 한 번 더 조밀하게 */
@media (max-width: 560px){
  .section{ padding: 32px 0; }
  #about.section{  padding-bottom: 20px; }
  #grasses.section{ padding-top: 20px; }
}

/* 홈 > 대표 리스트 카드: 블릿~첫 단어 간격 타이트 */
#grasses .card .ul-compact {
  list-style: none;          /* 기본 마커 제거 */
  margin: 0;
  padding: 0;
}
#grasses .card .ul-compact li {
  position: relative;
  padding-left: 12px;        /* ← 원하는 간격값(예: 10~14px로 조절) */
  margin: 2px 0;
  line-height: 1.6;          /* 카드 높이에 맞게 */
}
#grasses .card .ul-compact li::before {
  content: "•";              /* 커스텀 블릿 */
  position: absolute;
  left: 0;
  top: 0.05em;               /* 수직 정렬 미세조정(0~0.2em 사이 조절) */
  font-size: 0.9em;          /* 블릿 크기 살짝 축소 (옵션) */
  color: var(--color-text, #1F2937);
}

/* Compact list — 기본 블릿 유지 + 간격/크기 살짝 축소 */
.ul-compact{
  list-style: disc;
  list-style-position: inside;     /* 텍스트와 같은 줄에 마커 표시 */
  margin: 4px 0 0;
  padding-left: .75rem;            /* 전체 들여쓰기(필요 시 더 줄이기) */
}
.ul-compact > li{
  margin: 2px 0;
  text-indent: -0.25rem;           /* 블릿과 첫 단어 사이 간격 살짝 좁힘 */
}
.ul-compact > li::marker{
  font-size: .80em;                /* 블릿 크기만 살짝 축소 */
}

/* 모바일에서 더 타이트하게 보이도록(선택) */
@media (max-width: 560px){
  .ul-compact{ padding-left: .6rem; }
  .ul-compact > li{ text-indent: -0.20rem; }
}

/* 모든 페이지 카드 이미지: 크기 유지 + 둥근 모서리 */
.card > img{
  display:block;
  width:100%;
  height:auto;
  border-radius:10px;
  margin-bottom:10px;
  box-shadow: var(--shadow-sm);
}
/* 브랜드 아이콘 추가 */
.brand{
  display:flex; align-items:center; gap:8px;
  font-weight:700; color:var(--color-brand);
  text-decoration:none;
}
.brand-mark{ height:24px; width:auto; display:block; }
@media (max-width:560px){ .brand-mark{ height:20px; } }

/* Footer (pages 공통) */
.site-footer{
  background: var(--color-bg-panel, var(--panel, #FFFFFF));
  border-top: 1px solid var(--color-border, var(--border, #E5E7EB));
  color: var(--color-text-muted, var(--muted, #6B7280));
  padding: 24px 0;
}
.footer-grid{
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.footer-line{
  margin: 0;
  font-size: .95rem;
  line-height: 1.6;
}
.site-footer a{ color: inherit; text-decoration: underline; text-underline-offset: 2px; }

/* 반응형 */
@media (max-width: 900px){
  .footer-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .site-footer{ padding: 20px 0; }
  .footer-grid{ grid-template-columns: 1fr; gap: 6px; }
  .footer-line{ font-size: .92rem; }
}
/* 지도 임베드 카드 스타일 (크기 유지 + 둥근 모서리) */
.map-embed{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;                 /* 비율 고정 */
  border-radius: var(--radius-md, 10px); /* 사이트 토큰 있으면 사용 */
  overflow: hidden;
  box-shadow: var(--shadow-sm, 0 1px 2px rgba(0,0,0,.06));
  margin-top: 8px;
}
.map-embed iframe{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
}
