:root{
  /* Reference palette (beige/cream + forest green) */
  --bg: #F5F3EF;
  --bg2:#F7F5F1;
  --card:#FFFFFF;
  --text:#1F2421;
  --muted:#5C635E;
  --line: rgba(44,85,48,.18);

  --green:#2C5530;         /* primary accent */
  --green2:#3A5F3E;        /* hover */
  --greenSoft:#E6EFE7;     /* soft accent */
  --shadow: 0 18px 50px rgba(25, 33, 28, .10);
  --shadow2: 0 10px 26px rgba(25, 33, 28, .10);

  --radius: 18px;
  --radius2: 22px;
  --container: 1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Noto Sans KR", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color:var(--text);
  background: var(--bg);
  line-height:1.55;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}

.skip{position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden}
.skip:focus{left:16px; top:16px; width:auto; height:auto; padding:10px 12px; background:var(--card); border:1px solid var(--line); border-radius:12px; z-index:9999}

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

/* Header */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(245,243,239,.72);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:14px 0}
.brand{display:flex; align-items:center; gap:12px}
.brand-mark{width:36px; height:36px; border-radius:12px; background:radial-gradient(circle at 30% 30%, #4D7A52 0%, var(--green) 55%, #1F4024 100%);
  box-shadow:0 12px 22px rgba(44,85,48,.22);
}
.brand-text strong{display:block; font-weight:800; letter-spacing:-0.02em}
.brand-text small{display:block; color:var(--muted); font-size:12px; margin-top:2px}

.site-nav{display:flex; align-items:center; gap:18px}
.site-nav a{font-size:14px; color:var(--muted)}
.site-nav a:hover{color:var(--green)}

.nav-toggle{display:none; border:1px solid var(--line); background:var(--card); border-radius:14px; padding:10px; box-shadow:var(--shadow2)}
.nav-toggle span{display:block; width:20px; height:2px; background:var(--green); margin:4px 0; border-radius:2px}

/* Buttons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 16px; border-radius:999px; font-weight:700; font-size:14px; border:1px solid transparent; transition:.2s ease}
.btn-primary{background:var(--green); color:#fff; box-shadow:0 16px 30px rgba(44,85,48,.22)}
.btn-primary:hover{background:var(--green2); transform:translateY(-1px)}
.btn-ghost{background:transparent; border-color:var(--line); color:var(--green)}
.btn-ghost:hover{background:var(--greenSoft)}

/* Typography */
.h1,.h2{font-family:"Noto Sans KR", system-ui, -apple-system, Segoe UI, Roboto, sans-serif; letter-spacing:-0.03em}
.h1{font-size:44px; line-height:1.15; margin:8px 0 12px}
.h1 .sub{display:block; font-family:"Noto Sans KR"; font-size:16px; color:var(--muted); margin-top:10px; letter-spacing:-0.02em; font-weight:500}
.h2{font-size:34px; line-height:1.2; margin:0 0 10px}
.h3{margin:0 0 6px; font-size:18px}
.lead{font-size:16px; color:var(--muted); margin:0 0 18px}
.muted{color:var(--muted)}
.eyebrow{display:inline-flex; gap:8px; align-items:center; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--green); margin:0}

.section{padding:64px 0}
.section-soft{background: var(--bg2); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section-head{margin-bottom:22px}

/* Hero - 좌우 폭 조정: .hero에 style="--hero-copy-fr: 1.1fr; --hero-media-fr: 0.9fr" 처럼 지정 */
.hero{position:relative; padding:68px 0 56px; overflow:hidden; --hero-copy-fr: 1.05fr; --hero-media-fr: 0.95fr}
.hero-grid{display:grid; grid-template-columns: var(--hero-copy-fr) var(--hero-media-fr); gap:34px; align-items:center}
.hero-copy{position:relative; z-index:2}
.hero-cta{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}

.chips{display:flex; flex-wrap:wrap; gap:8px; margin:14px 0}
.chip{padding:8px 10px; border-radius:999px; background:rgba(255,255,255,.75); border:1px solid var(--line); color:var(--green); font-weight:700; font-size:13px}

.trust-row{display:flex; gap:14px; margin-top:18px; flex-wrap:wrap}
.trust{background:rgba(255,255,255,.70); border:1px solid var(--line); border-radius:16px; padding:10px 12px; min-width:140px}
.trust strong{display:block; font-size:18px; color:var(--green)}
.trust span{font-size:12px; color:var(--muted)}

.hero-media .media-card{background:var(--card); border-radius:var(--radius2); border:1px solid var(--line); overflow:hidden; box-shadow:var(--shadow)}
.hero-media img{height:420px; width:100%; object-fit:cover}
.media-badge{display:flex; gap:8px; padding:12px; flex-wrap:wrap}
.badge{font-size:12px; font-weight:800; background:var(--greenSoft); color:var(--green); border-radius:999px; padding:7px 10px; border:1px solid rgba(44,85,48,.18)}
.badge-outline{background:transparent}

.hero-bg{display:none}

/* About */
.about-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.about-card{background:rgba(255,255,255,.78); border:1px solid var(--line); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow2)}

/* About with images */
.about-grid-media{gap:14px}
.about-card-media{padding:0; overflow:hidden}
.about-media{height:120px; overflow:hidden; border-bottom:1px solid rgba(44,85,48,.12)}
.about-media img{width:100%; height:100%; object-fit:cover; filter:saturate(1.05) contrast(1.02)}
.about-body{padding:16px 16px 18px}

/* Signals */
.signals-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.signal-card{background:rgba(255,255,255,.78); border:1px solid var(--line); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow2)}
.signal-head{display:flex; align-items:center; gap:10px; margin-bottom:10px}
.signal-ico{width:36px; height:36px; display:inline-flex; align-items:center; justify-content:center; border-radius:12px; background:var(--greenSoft); border:1px solid rgba(44,85,48,.18)}
.check{display:flex; align-items:center; gap:10px; margin:10px 0; color:var(--muted); font-size:14px}
.check input{width:16px; height:16px; accent-color: var(--green)}
.tip{margin-top:14px; border-radius:16px; padding:12px 14px; border:1px solid rgba(44,85,48,.18); background:rgba(44,85,48,.06); color:var(--muted)}
.tip strong{color:var(--green)}

/* Points redesigned: premium feature blocks (kept) */
.points-grid{display:grid; gap:16px}
.feature{
  display:grid; grid-template-columns: .9fr 1.1fr;
  border:1px solid var(--line);
  border-radius:26px;
  overflow:hidden;
  background:rgba(255,255,255,.78);
  box-shadow:var(--shadow);
  transition: transform .2s ease;
}
.feature-reverse{grid-template-columns: 1.1fr .9fr}
.feature-media img{height:320px; width:100%; object-fit:cover; filter:saturate(1.05) contrast(1.02)}
.feature-body{padding:22px 22px 20px}
.kicker{display:inline-flex; align-items:center; gap:8px; font-weight:900; letter-spacing:.12em; font-size:12px; color:var(--green); text-transform:uppercase}
.kicker::before{content:""; width:10px; height:10px; border-radius:3px; background:var(--green)}
.feature-title{margin:10px 0 10px; font-size:22px; letter-spacing:-0.02em}
.feature-desc{margin:0 0 12px; color:var(--muted)}
.feature-desc strong{color:var(--text)}
.feature-bullets{margin:0; padding:0 0 0 18px; color:var(--muted)}
.feature-bullets li{margin:6px 0}
.feature:hover{transform:translateY(-2px)}

.points-mini{display:flex; flex-wrap:wrap; gap:10px; margin-top:16px}
.mini-pill{display:inline-flex; align-items:center; gap:10px; padding:10px 12px; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.72); color:var(--green); font-weight:800; font-size:13px}
.mini-pill .dot{width:10px; height:10px; border-radius:999px; background:var(--green)}

/* Goweunsan */
.goweunsan-grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:14px; align-items:start}
.icon-row{display:flex; gap:12px; align-items:flex-start; padding:16px; border:1px solid var(--line); border-radius:18px; background:rgba(255,255,255,.78); box-shadow:var(--shadow2); margin-bottom:12px}
.icon-badge{width:42px; height:42px; border-radius:14px; display:flex; align-items:center; justify-content:center; background:var(--greenSoft); color:var(--green); border:1px solid rgba(44,85,48,.18)}
.small{font-size:12px}

/* New: Goweunsan features with images (routine guide removed) */
.goweunsan-features{display:grid; gap:14px}
.gs-feature{display:grid; grid-template-columns:.9fr 1.1fr; background:rgba(255,255,255,.78); border:1px solid var(--line); border-radius:24px; overflow:hidden; box-shadow:var(--shadow); transition:transform .2s ease}
.gs-feature:hover{transform:translateY(-2px)}
.gs-feature-rev{grid-template-columns:1.1fr .9fr}
.gs-media img{width:100%; height:240px; object-fit:cover; filter:saturate(1.05) contrast(1.02)}
.gs-body{padding:18px 20px}

/* Why (Herbal Ingredients) */
.herb-hero{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:14px}
.herb-pill{display:flex; gap:12px; align-items:center; padding:14px; border-radius:18px; border:1px solid var(--line); background:rgba(255,255,255,.78); box-shadow:var(--shadow2)}
.herb-illu{width:44px; height:44px; border-radius:16px; display:flex; align-items:center; justify-content:center; background:var(--greenSoft); border:1px solid rgba(44,85,48,.18); color:var(--green); font-size:18px}
.latin{font-size:12px; color:var(--muted); font-weight:600}

.herb-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.herb-card{background:rgba(255,255,255,.78); border:1px solid var(--line); border-radius:18px; padding:18px; box-shadow:var(--shadow2)}
.herb-head{display:flex; flex-direction:column; gap:4px; padding-bottom:10px; margin-bottom:10px; border-bottom:1px solid rgba(44,85,48,.12)}
.herb-name{margin:0; font-size:18px; letter-spacing:-0.02em}
.hanja{color:var(--green); font-weight:800}
.herb-list{margin:0; padding:0 0 0 18px; color:var(--muted)}
.herb-list li{margin:8px 0}

/* Reviews */
.reviews-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.review{background:rgba(255,255,255,.78); border:1px solid var(--line); border-radius:18px; padding:18px; box-shadow:var(--shadow2)}
.stars{color:#C9A34D; letter-spacing:2px; font-size:14px; margin-bottom:10px}
.review-text{margin:0 0 10px; color:var(--text)}
.review-meta{margin:0; font-size:12px}

/* Products */
.products-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.product{background:rgba(255,255,255,.78); border:1px solid var(--line); border-radius:18px; padding:18px; box-shadow:var(--shadow2)}
.product-media{height:140px; border-radius:14px; border:1px solid rgba(44,85,48,.12);
  background: rgba(230,239,231,.65);
}
.bullets{margin:10px 0 0; padding:0 0 0 18px; color:var(--muted)}
.bullets li{margin:6px 0}

.compat{margin-top:14px; border:1px solid rgba(44,85,48,.14); border-radius:18px; background:rgba(255,255,255,.72); padding:16px; box-shadow:var(--shadow2)}
.compat-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:12px}
.compat-card{border:1px solid var(--line); border-radius:16px; padding:12px; background:rgba(255,255,255,.78); display:flex; flex-direction:column; gap:6px}

/* FAQ */
.faq-list{display:grid; gap:10px}
.faq-item{border:1px solid var(--line); border-radius:16px; background:rgba(255,255,255,.78); box-shadow:var(--shadow2); padding:2px 12px}
.faq-item summary{cursor:pointer; padding:12px 4px; font-weight:700; color:var(--text)}
.faq-item summary::marker{color:var(--green)}
.faq-body{padding:0 4px 12px}
.faq-cta{margin-top:14px; border:1px solid rgba(44,85,48,.18); border-radius:18px; background:rgba(44,85,48,.06); padding:16px; display:flex; align-items:center; justify-content:space-between; gap:12px}

/* Process width helper */
.steps-wide{grid-template-columns:repeat(6,1fr)}

/* Compare */
.compare-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.compare-card{background:rgba(255,255,255,.78); border:1px solid var(--line); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow2)}
.compare-card-accent{border-color:rgba(44,85,48,.35)}
.bar{margin:12px 0}
.bar-head{display:flex; justify-content:space-between; gap:10px; font-size:13px; color:var(--muted)}
.bar-head strong{color:var(--green)}
.bar-track{height:10px; border-radius:999px; background:rgba(44,85,48,.10); overflow:hidden; border:1px solid rgba(44,85,48,.14)}
.bar-fill{height:100%; width:var(--w); background:var(--green); border-radius:999px}

/* Steps */
.steps-grid{display:grid; grid-template-columns:repeat(6,1fr); gap:10px}
.step{background:rgba(255,255,255,.78); border:1px solid var(--line); border-radius:16px; padding:14px 12px; text-align:center; box-shadow:var(--shadow2)}
.step-no{display:inline-flex; width:34px; height:34px; border-radius:999px; align-items:center; justify-content:center; background:var(--greenSoft); color:var(--green); font-weight:900; border:1px solid rgba(44,85,48,.22)}
.step h3{margin:10px 0 4px; font-size:14px}
.step p{margin:0; font-size:12px; color:var(--muted)}

/* CTA */
.cta{padding:56px 0; background: var(--bg2);}
.cta-inner{display:flex; align-items:center; justify-content:space-between; gap:14px; border:1px solid rgba(44,85,48,.22); background:rgba(255,255,255,.70); border-radius:26px; padding:22px; box-shadow:var(--shadow)}
.cta-actions{display:flex; gap:10px; flex-wrap:wrap}

/* Footer */
.footer{padding:26px 0 44px; border-top:1px solid var(--line)}
.footer-inner p{margin:6px 0}

/* Reveal animation */
.reveal{opacity:0; transform:translateY(12px); transition:opacity .7s ease, transform .7s ease}
.reveal.is-in{opacity:1; transform:none}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr; gap:18px}
  .hero-media img{height:360px}
  .about-grid{grid-template-columns:1fr}
  .signals-grid{grid-template-columns:1fr}
  .goweunsan-grid{grid-template-columns:1fr}
  .gs-feature, .gs-feature-rev{grid-template-columns:1fr}
  .gs-media img{height:200px}
  .herb-hero{grid-template-columns:1fr}
  .herb-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .products-grid{grid-template-columns:1fr}
  .compat-grid{grid-template-columns:1fr}
  .compare-grid{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:repeat(3,1fr)}
  .feature, .feature-reverse{grid-template-columns:1fr}
  .feature-media img{height:240px}
}

@media (max-width: 820px){
  .site-nav{position:fixed; left:16px; right:16px; top:68px; background:rgba(255,255,255,.92); border:1px solid var(--line); border-radius:18px; padding:12px; flex-direction:column; align-items:stretch; gap:8px; box-shadow:var(--shadow); display:none}
  .site-nav.is-open{display:flex}
  .site-nav a{padding:10px 12px; border-radius:14px}
  .site-nav a:hover{background:var(--greenSoft)}
  .nav-toggle{display:inline-block}
  .h1{font-size:38px}
}

@media (max-width: 420px){
  .h1{font-size:34px}
  .trust{min-width: 46%}
}
