/* ============================================================
   Cham&Deul Hwangto Nongwon — page theme (editorial / organic)
   Loaded after company-base.css. Reset/.reveal/.home-btn live in base.
   ============================================================ */
:root {
  --forest: #1b4527;
  --forest-900: #11301b;
  --forest-700: #2a6038;
  --moss: #5b9e6b;
  --moss-soft: #e7efe4;
  --clay: #b07d3a;
  --clay-deep: #8a5e26;
  --clay-soft: #f1e6d1;
  --paper: #f7f3ea;
  --paper-2: #efe7d6;
  --card: #fffdf7;
  --ink: #1f271d;
  --ink-2: #3d473a;
  --muted: #717869;
  --line: rgba(27, 69, 39, 0.14);
  --line-2: rgba(27, 69, 39, 0.08);
  --shadow: 0 30px 70px -32px rgba(17, 48, 27, 0.45);
  --shadow-sm: 0 16px 36px -20px rgba(17, 48, 27, 0.34);
  --serif: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  --sans: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}
body {
  margin: 0; overflow-x: hidden; color: var(--ink);
  background: var(--paper);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  font-family: var(--sans); line-height: 1.65; -webkit-font-smoothing: antialiased;
}
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
h1, h2, h3, p { margin-top: 0; }
svg { display: block; }
.container { width: min(1240px, calc(100% - 48px)); margin: 0 auto; }

h1, h2 { font-family: var(--serif); font-weight: 500; letter-spacing: -0.4px; color: var(--forest-900); line-height: 1.04; }
h1 { font-size: clamp(40px, 5.6vw, 80px); }
h2 { font-size: clamp(30px, 3.9vw, 54px); }
h1 em, h2 em { font-style: italic; font-weight: 500; color: var(--clay); }

.klabel {
  display: inline-flex; align-items: center; gap: 10px; font-family: var(--sans);
  font-size: 11px; font-weight: 700; letter-spacing: 2.4px; text-transform: uppercase; color: var(--clay-deep);
}
.klabel::before { width: 26px; height: 1.5px; background: var(--clay); content: ""; }
.klabel.light { color: var(--clay-soft); }
.ko { font-family: var(--serif); font-style: italic; color: var(--moss); }

.btn {
  display: inline-flex; align-items: center; gap: 11px; min-height: 54px; padding: 0 26px;
  border-radius: 999px; border: 1.5px solid var(--forest); background: var(--forest); color: var(--paper);
  font-family: var(--sans); font-size: 13.5px; font-weight: 600; letter-spacing: 0.2px; cursor: pointer;
  transition: 240ms cubic-bezier(.22,.61,.36,1);
}
.btn:hover { transform: translateY(-3px); box-shadow: 0 18px 34px -16px rgba(27, 69, 39, 0.6); }
.btn.ghost { background: transparent; color: var(--forest); }
.btn.ghost:hover { background: rgba(27, 69, 39, 0.05); box-shadow: none; }
.btn.clay { background: var(--clay); border-color: var(--clay); color: #fff; }
.btn.clay:hover { box-shadow: 0 18px 34px -16px rgba(176, 125, 58, 0.7); }
.btn.light { background: var(--paper); border-color: var(--paper); color: var(--forest-900); }
.btn svg { width: 17px; height: 17px; }

section { padding: clamp(74px, 9vw, 124px) 0; }
.lead { max-width: 640px; color: var(--ink-2); font-size: 17px; }
.shead { max-width: 760px; margin-bottom: 52px; }
.shead.mid { margin-inline: auto; text-align: center; }
.shead h2 { margin: 14px 0 16px; }
.shead p { margin: 0; color: var(--muted); font-size: 16.5px; }

/* index numeral */
.ix { font-family: var(--serif); font-weight: 500; font-size: 13px; color: var(--clay); letter-spacing: 1px; }

/* ---------------- NAV ---------------- */
.nav { position: sticky; top: 0; z-index: 60; background: rgba(247, 243, 234, 0.82); backdrop-filter: saturate(150%) blur(16px); border-bottom: 1px solid var(--line); }
.nav-in { display: flex; align-items: center; justify-content: space-between; min-height: 78px; gap: 24px; }
.brand { display: flex; align-items: center; gap: 13px; }
.brand img { width: 42px; height: 42px; }
.brand .bt { line-height: 1.1; }
.brand .bt b { font-family: var(--serif); font-weight: 600; font-size: 17px; color: var(--forest-900); display: block; letter-spacing: -0.2px; }
.brand .bt span { font-size: 9.5px; font-weight: 600; letter-spacing: 1.6px; text-transform: uppercase; color: var(--muted); }
.nav-links { display: flex; align-items: center; gap: 28px; }
.nav-links a:not(.btn) { font-size: 13.5px; font-weight: 500; color: var(--ink-2); transition: color 0.2s; }
.nav-links a:not(.btn):hover { color: var(--clay-deep); }
.nav-links .btn { min-height: 44px; padding: 0 20px; font-size: 12.5px; }
.burger { display: none; width: 46px; height: 46px; border: 1px solid var(--line); border-radius: 12px; background: var(--card); cursor: pointer; align-items: center; justify-content: center; }
.burger svg { width: 22px; height: 22px; color: var(--forest); }

/* ---------------- HERO ---------------- */
.hero { position: relative; overflow: hidden; padding-top: clamp(40px, 5vw, 70px); }
.hero::before { content: ""; position: absolute; top: -160px; right: -160px; width: 540px; height: 540px; border-radius: 50%; background: radial-gradient(circle, rgba(176, 125, 58, 0.16), transparent 66%); pointer-events: none; }
.hero-grid { position: relative; display: grid; grid-template-columns: 1.02fr 0.98fr; gap: 56px; align-items: center; }
.hero-ko { font-family: var(--serif); font-style: italic; font-size: 19px; color: var(--moss); margin: 14px 0 18px; }
.hero h1 { margin-bottom: 24px; }
.hero-lead { max-width: 540px; color: var(--ink-2); font-size: 17.5px; margin-bottom: 30px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 13px; }
.hero-stats { display: flex; flex-wrap: wrap; gap: 0 40px; margin-top: 50px; padding-top: 30px; border-top: 1px solid var(--line); }
.hero-stat strong { font-family: var(--serif); font-weight: 600; font-size: 30px; color: var(--forest); display: block; line-height: 1; }
.hero-stat span { font-size: 11.5px; color: var(--muted); font-weight: 500; }
/* hero visual */
.hero-art { position: relative; }
.hero-frame { border-radius: 220px 220px 26px 26px; overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow); background: #f9c9d4; }
.hero-frame img { width: 100%; height: 540px; object-fit: cover; object-position: center 38%; }
.hero-seal {
  position: absolute; left: -26px; top: 38px; width: 116px; height: 116px; border-radius: 50%;
  background: var(--card); border: 1px solid var(--line); box-shadow: var(--shadow-sm);
  display: grid; place-items: center; animation: spin 26s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.hero-seal img { width: 58px; height: 58px; }
.hero-tag {
  position: absolute; right: -14px; bottom: 30px; display: flex; align-items: center; gap: 10px;
  background: var(--forest); color: var(--paper); padding: 13px 18px; border-radius: 14px; box-shadow: var(--shadow-sm);
}
.hero-tag svg { width: 22px; height: 22px; color: var(--clay-soft); }
.hero-tag b { font-size: 13px; display: block; }
.hero-tag span { font-size: 11px; color: rgba(247, 243, 234, 0.7); }

/* ---------------- MARQUEE / MARKETS ---------------- */
.markets { background: var(--forest-900); color: rgba(247, 243, 234, 0.82); }
.markets .container { padding-top: 30px; padding-bottom: 30px; display: flex; flex-wrap: wrap; align-items: center; gap: 18px 30px; justify-content: center; }
.markets .lbl { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--clay-soft); }
.markets .ms { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.markets .ms span { padding: 8px 16px; border: 1px solid rgba(247, 243, 234, 0.2); border-radius: 999px; font-size: 13px; }
.markets .ms .vn { background: var(--clay); border-color: var(--clay); color: #fff; font-weight: 600; }

/* ---------------- VALUES ---------------- */
.values { position: relative; }
.val-row {
  display: grid; grid-template-columns: 80px 1fr 1.1fr; gap: 30px; align-items: start;
  padding: 38px 0; border-top: 1px solid var(--line);
}
.val-row:last-child { border-bottom: 1px solid var(--line); }
.val-num { font-family: var(--serif); font-weight: 500; font-size: 40px; color: var(--clay); line-height: 1; }
.val-h { display: flex; align-items: center; gap: 14px; }
.val-h .ic { display: grid; place-items: center; width: 46px; height: 46px; border-radius: 13px; background: var(--moss-soft); color: var(--forest); flex: 0 0 auto; }
.val-h .ic svg { width: 24px; height: 24px; }
.val-h h3 { font-family: var(--serif); font-weight: 600; font-size: 24px; margin: 0; color: var(--forest-900); }
.val-row p { margin: 0; color: var(--ink-2); font-size: 15.5px; }
.val-ko { display: block; font-family: var(--serif); font-style: italic; color: var(--moss); font-size: 13px; margin-top: 4px; }

/* ---------------- NFC FEATURE ---------------- */
.nfc { background: var(--forest); color: var(--paper); position: relative; overflow: hidden; }
.nfc::after { content: ""; position: absolute; bottom: -180px; left: -120px; width: 460px; height: 460px; border-radius: 50%; background: radial-gradient(circle, rgba(91, 158, 107, 0.3), transparent 66%); }
.nfc-grid { position: relative; display: grid; grid-template-columns: 0.95fr 1.05fr; gap: 56px; align-items: center; }
.nfc h2 { color: var(--paper); }
.nfc h2 em { color: var(--clay-soft); }
.nfc .lead { color: rgba(247, 243, 234, 0.82); }
.nfc-img { border-radius: 26px; overflow: hidden; border: 1px solid rgba(247, 243, 234, 0.16); box-shadow: var(--shadow); }
.nfc-img img { width: 100%; height: 420px; object-fit: cover; }
.nfc-list { display: grid; gap: 16px; margin-top: 28px; }
.nfc-item { display: flex; gap: 15px; align-items: flex-start; }
.nfc-item .ic { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 12px; background: rgba(247, 243, 234, 0.1); color: var(--clay-soft); flex: 0 0 auto; }
.nfc-item .ic svg { width: 22px; height: 22px; }
.nfc-item b { display: block; font-size: 15.5px; }
.nfc-item span { font-size: 13.5px; color: rgba(247, 243, 234, 0.66); }

/* ---------------- PRODUCTS LOOKBOOK ---------------- */
.prod { background: var(--paper); }
.prod-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 22px; }
.pcard {
  position: relative; overflow: hidden; border-radius: 22px; background: var(--card);
  border: 1px solid var(--line); box-shadow: var(--shadow-sm); display: flex; flex-direction: column;
  transition: 280ms cubic-bezier(.22,.61,.36,1);
}
.pcard:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.pcard .pic { overflow: hidden; aspect-ratio: 1200 / 849; background: var(--paper-2); display: grid; place-items: center; }
.pcard .pic img { width: 100%; height: 100%; object-fit: contain; }
.pcard .body { padding: 22px 24px 24px; display: flex; flex-direction: column; flex: 1; }
.pcard .ix { margin-bottom: 9px; }
.pcard h3 { font-family: var(--serif); font-weight: 600; font-size: 22px; margin: 0 0 7px; color: var(--forest-900); }
.pcard p { margin: 0 0 16px; font-size: 13.5px; color: var(--muted); }
.pcard .foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding-top: 14px; border-top: 1px solid var(--line-2); }
.pcard .price { font-size: 13px; font-weight: 600; color: var(--clay-deep); }
.pcard .price small { color: var(--muted); font-weight: 400; }
.pcard .cnt { font-size: 11.5px; color: var(--muted); }
/* feature sizing */
.pcard.feature { grid-column: span 6; }
.pcard.feature .body { padding: 26px 28px 28px; }
.pcard.feature h3 { font-size: 26px; }
.pcard.half { grid-column: span 6; }
.pcard.third { grid-column: span 4; }
.prod-more { margin-top: 24px; display: flex; flex-wrap: wrap; gap: 10px; }
.chip { padding: 9px 16px; border-radius: 999px; border: 1px dashed var(--line); background: var(--card); font-size: 13px; color: var(--ink-2); }
.chip b { color: var(--forest); font-weight: 600; }

/* ---------------- QUALITY ---------------- */
.quality { background: var(--paper-2); }
.q-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
.q-points { display: grid; gap: 14px; margin-top: 28px; }
.q-point { display: flex; gap: 14px; align-items: flex-start; }
.q-point .ic { display: grid; place-items: center; width: 44px; height: 44px; border-radius: 12px; background: var(--clay-soft); color: var(--clay-deep); flex: 0 0 auto; }
.q-point .ic svg { width: 22px; height: 22px; }
.q-point b { display: block; font-size: 15px; color: var(--forest-900); }
.q-point span { font-size: 13.5px; color: var(--muted); }
.certs { margin-top: 30px; padding: 22px 24px; border-radius: 18px; background: var(--card); border: 1px solid var(--line); display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.certs .seal { display: grid; place-items: center; width: 50px; height: 50px; border-radius: 50%; background: var(--moss-soft); color: var(--forest); flex: 0 0 auto; }
.certs .seal svg { width: 26px; height: 26px; }
.certs b { font-family: var(--serif); font-size: 18px; color: var(--forest-900); }
.certs span { font-size: 13px; color: var(--muted); }
.q-collage { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; gap: 14px; }
.q-collage img { width: 100%; border-radius: 18px; object-fit: cover; box-shadow: var(--shadow-sm); }
.q-collage img:nth-child(1) { grid-column: 1 / 3; height: 230px; }
.q-collage img:nth-child(2), .q-collage img:nth-child(3) { height: 190px; }

/* ---------------- PRICING ---------------- */
.pricing { background: var(--paper); }
.price-wrap { border: 1px solid var(--line); border-radius: 22px; overflow: hidden; background: var(--card); box-shadow: var(--shadow-sm); }
.price-cat { display: grid; grid-template-columns: 1.7fr 1fr 0.7fr 0.5fr; gap: 14px; padding: 14px 26px; background: var(--forest); color: var(--paper); font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
.price-cat span:nth-child(2) { text-align: center; }
.price-cat span:nth-child(3) { text-align: right; }
.price-cat span:nth-child(4) { text-align: right; }
.price-sub { padding: 13px 26px; background: var(--moss-soft); font-family: var(--serif); font-weight: 600; font-size: 15px; color: var(--forest-900); }
.prow { display: grid; grid-template-columns: 1.7fr 1fr 0.7fr 0.5fr; gap: 14px; align-items: center; padding: 14px 26px; border-top: 1px solid var(--line-2); }
.prow strong { font-size: 14px; font-weight: 500; color: var(--ink); }
.prow .spec { text-align: center; font-size: 12.5px; color: var(--muted); }
.prow .pp { text-align: right; font-size: 15px; font-weight: 700; color: var(--clay-deep); font-family: var(--serif); }
.prow .moq { text-align: right; font-size: 12px; color: var(--muted); }
.price-note { margin-top: 18px; color: var(--muted); font-size: 12.5px; max-width: 800px; }
.price-cta { margin-top: 26px; display: flex; flex-wrap: wrap; gap: 12px; }

/* ---------------- PARTNERSHIP ---------------- */
.partner { background: var(--forest-900); color: var(--paper); position: relative; overflow: hidden; }
.partner::before { content: ""; position: absolute; top: -140px; right: -120px; width: 460px; height: 460px; border-radius: 50%; background: radial-gradient(circle, rgba(176,125,58,.22), transparent 66%); }
.partner-grid { position: relative; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
.partner h2 { color: var(--paper); }
.partner h2 em { color: var(--clay-soft); }
.partner p { color: rgba(247,243,234,.8); }
.partner-ways { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 26px; }
.way { display: flex; gap: 13px; align-items: center; padding: 15px 16px; border: 1px solid rgba(247,243,234,.16); border-radius: 14px; background: rgba(247,243,234,.04); }
.way .ic { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 10px; background: rgba(176,125,58,.22); color: var(--clay-soft); flex: 0 0 auto; }
.way .ic svg { width: 20px; height: 20px; }
.way b { font-size: 13.5px; }
.partner-media { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.partner-media img { width: 100%; height: 100%; object-fit: cover; border-radius: 18px; box-shadow: var(--shadow); }
.partner-media img:first-child { grid-row: span 2; }

/* ---------------- CATALOGUE ---------------- */
.cata { background: var(--paper-2); }
.cata-pages { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; margin-bottom: 34px; }
.cata-pages a { border-radius: 12px; overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow-sm); transition: 0.25s; background: var(--card); }
.cata-pages a:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.cata-pages img { width: 100%; aspect-ratio: 3/4.2; object-fit: cover; }
.dls { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.dl { display: flex; align-items: center; gap: 15px; padding: 22px 24px; border-radius: 16px; background: var(--card); border: 1px solid var(--line); box-shadow: var(--shadow-sm); transition: 0.22s; }
.dl:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.dl .ic { display: grid; place-items: center; width: 46px; height: 46px; border-radius: 13px; background: var(--clay-soft); color: var(--clay-deep); flex: 0 0 auto; }
.dl .ic svg { width: 23px; height: 23px; }
.dl b { display: block; font-size: 14.5px; color: var(--forest-900); }
.dl span { font-size: 12px; color: var(--muted); }

/* ---------------- CONTACT ---------------- */
.contact { background: var(--paper); padding-bottom: 64px; }
.contact-card { display: grid; grid-template-columns: 1.05fr 0.95fr; overflow: hidden; border-radius: 28px; background: var(--forest); color: var(--paper); box-shadow: var(--shadow); }
.contact-main { padding: 56px; }
.contact-main .klabel { color: var(--clay-soft); }
.contact-main .klabel::before { background: var(--clay-soft); }
.contact-main h2 { color: var(--paper); }
.contact-main p { color: rgba(247,243,234,.78); max-width: 440px; margin-bottom: 28px; }
.contact-detail { padding: 48px; background: rgba(17,48,27,.4); display: grid; align-content: start; gap: 18px; }
.cl { padding-bottom: 16px; border-bottom: 1px solid rgba(247,243,234,.14); }
.cl:last-child { padding-bottom: 0; border-bottom: 0; }
.cl small { display: block; color: var(--clay-soft); font-size: 10px; font-weight: 700; letter-spacing: 1.4px; text-transform: uppercase; margin-bottom: 6px; }
.cl span, .cl a { display: block; color: rgba(247,243,234,.92); font-size: 13.5px; }
.cl a:hover { color: var(--clay-soft); }
.foot { display: flex; justify-content: space-between; gap: 14px; padding-top: 30px; color: var(--muted); font-size: 12.5px; }


@media (max-width: 1024px) {
  .hero-grid, .nfc-grid, .q-grid, .partner-grid, .contact-card { grid-template-columns: 1fr; }
  .pcard.feature { grid-column: span 12; }
  .pcard.half { grid-column: span 6; }
  .pcard.third { grid-column: span 6; }
  .cata-pages { grid-template-columns: repeat(3, 1fr); }
  .hero-frame img { height: 460px; }
}
@media (max-width: 760px) {
  .nav-links { position: fixed; inset: 0 0 0 30%; z-index: 70; flex-direction: column; align-items: stretch; gap: 16px; padding: 96px 30px; background: var(--paper); border-left: 1px solid var(--line); transform: translateX(100%); transition: transform 0.28s ease; }
  .menu-open .nav-links { transform: none; }
  .burger { display: inline-flex; z-index: 71; }
  .val-row { grid-template-columns: 1fr; gap: 14px; }
  .pcard.half, .pcard.third { grid-column: span 12; }
  .partner-ways, .dls, .q-collage { grid-template-columns: 1fr; }
  .partner-media { grid-template-columns: 1fr; }
  .partner-media img:first-child { grid-row: auto; }
  .price-cat, .prow { grid-template-columns: 1.5fr 0.9fr 0.7fr; }
  .price-cat span:nth-child(4), .prow .moq { display: none; }
  .contact-main, .contact-detail { padding: 36px 26px; }
  .foot { flex-direction: column; }
}
@media (max-width: 480px) {
  .cata-pages { grid-template-columns: repeat(2, 1fr); }
  .price-cat, .prow { grid-template-columns: 1.6fr 0.7fr; }
  .price-cat span:nth-child(2), .prow .spec { display: none; }
}
@media (prefers-reduced-motion: reduce) { .hero-seal { animation: none; }  }
