:root {
  --bg: #f8f4ec;
  --bg-soft: #efe7da;
  --text: #17130f;
  --muted: #70665b;
  --line: rgba(23, 19, 15, 0.12);
  --card: rgba(255, 252, 246, 0.82);
  --dark: #15130f;
  --dark-soft: #211d18;
  --accent: #b98b55;
  --accent-deep: #7a5634;
  --white: #ffffff;
  --shadow: 0 24px 80px rgba(38, 26, 12, 0.12);
  --radius-lg: 32px;
  --radius-md: 22px;
  --radius-sm: 14px;
  --container: 1120px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Pretendard", "Apple SD Gothic Neo", "Noto Sans KR", sans-serif;
  color: var(--text);
  background: var(--bg);
  line-height: 1.65;
  word-break: keep-all;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, a { -webkit-tap-highlight-color: transparent; }
.container { width: min(calc(100% - 40px), var(--container)); margin: 0 auto; }
.narrow { max-width: 860px; }
.skip-link { position: absolute; left: 20px; top: -100px; z-index: 999; padding: 10px 14px; background: var(--dark); color: var(--white); border-radius: 999px; }
.skip-link:focus { top: 20px; }
.site-header { position: fixed; left: 0; right: 0; top: 0; z-index: 100; transition: background 0.25s ease, box-shadow 0.25s ease, backdrop-filter 0.25s ease; }
.site-header.scrolled { background: rgba(248, 244, 236, 0.86); backdrop-filter: blur(18px); box-shadow: 0 10px 30px rgba(23, 19, 15, 0.08); }
.header-inner { min-height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.logo { display: inline-flex; align-items: center; gap: 12px; font-weight: 800; letter-spacing: -0.03em; }
.logo img { width: 38px; height: 38px; }
.logo span { font-size: 18px; }
.site-nav { display: flex; align-items: center; gap: 8px; }
.site-nav a { padding: 10px 14px; color: rgba(23, 19, 15, 0.76); font-weight: 700; font-size: 15px; border-radius: 999px; transition: background 0.2s ease, color 0.2s ease; }
.site-nav a:hover, .site-nav a:focus-visible { color: var(--text); background: rgba(23, 19, 15, 0.07); outline: none; }
.site-nav .language-link { border: 1px solid var(--line); background: rgba(255,255,255,.42); }
.nav-toggle { display: none; width: 44px; height: 44px; border: 1px solid var(--line); background: rgba(255, 255, 255, 0.45); border-radius: 999px; padding: 0; cursor: pointer; }
.nav-toggle span { display: block; width: 18px; height: 2px; margin: 4px auto; background: var(--text); border-radius: 999px; }
.section { padding: 112px 0; }
.hero { min-height: 100vh; display: flex; align-items: center; padding-top: 130px; background: radial-gradient(circle at 78% 18%, rgba(185, 139, 85, 0.28), transparent 36%), radial-gradient(circle at 20% 72%, rgba(70, 50, 38, 0.13), transparent 32%), linear-gradient(135deg, #f9f4ea 0%, #efe6d7 100%); overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.04fr 0.96fr; gap: 70px; align-items: center; }
.eyebrow { margin: 0 0 16px; font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 800; color: var(--accent-deep); }
h1, h2, h3, p { margin-top: 0; }
h1 { margin-bottom: 24px; font-size: clamp(42px, 7vw, 76px); line-height: 1.03; letter-spacing: -0.07em; }
h1 span { color: var(--accent-deep); }
h2 { margin-bottom: 20px; font-size: clamp(30px, 4.2vw, 52px); line-height: 1.16; letter-spacing: -0.055em; }
h3 { letter-spacing: -0.035em; }
.hero-text { max-width: 650px; color: var(--muted); font-size: 19px; }
.hero-actions, .contact-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 34px; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 0 22px; border-radius: 999px; font-weight: 800; transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease; }
.button:hover, .button:focus-visible { transform: translateY(-2px); outline: none; }
.button.primary { color: var(--white); background: var(--dark); box-shadow: 0 14px 35px rgba(23, 19, 15, 0.2); }
.button.secondary { color: var(--text); background: rgba(255, 255, 255, 0.52); border: 1px solid var(--line); }
.hero-panel { position: relative; min-height: 520px; border-radius: 46px; background: linear-gradient(150deg, rgba(255,255,255,0.64), rgba(255,255,255,0.22)); box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,0.6); overflow: hidden; }
.hero-panel::before { content: ""; position: absolute; inset: 18px; border: 1px solid rgba(23,19,15,0.1); border-radius: 34px; }
.orb { position: absolute; border-radius: 50%; filter: blur(1px); }
.orb-one { width: 300px; height: 300px; right: -70px; top: -60px; background: radial-gradient(circle, rgba(185,139,85,0.58), rgba(185,139,85,0.08) 66%); }
.orb-two { width: 240px; height: 240px; left: 36px; bottom: 28px; background: radial-gradient(circle, rgba(41,33,25,0.18), rgba(41,33,25,0.02) 66%); }
.panel-card, .mini-card { position: absolute; border: 1px solid rgba(255,255,255,0.55); background: rgba(255, 252, 246, 0.72); backdrop-filter: blur(18px); box-shadow: 0 24px 70px rgba(38, 26, 12, 0.12); }
.main-card { left: 50%; top: 50%; width: min(78%, 380px); padding: 34px; border-radius: 28px; transform: translate(-50%, -50%); }
.panel-label { display: inline-flex; margin-bottom: 14px; font-size: 12px; font-weight: 900; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-deep); }
.main-card strong { display: block; font-size: 34px; line-height: 1.12; letter-spacing: -0.05em; }
.main-card p { margin: 16px 0 0; color: var(--muted); }
.mini-card { padding: 14px 18px; border-radius: 999px; font-weight: 800; color: rgba(23,19,15,0.78); }
.card-one { left: 38px; top: 88px; }
.card-two { right: 38px; bottom: 92px; }
.stats { margin-top: -42px; position: relative; z-index: 3; }
.stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); background: var(--dark); color: var(--white); border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 24px 70px rgba(23, 19, 15, 0.2); }
.stats-grid div { padding: 30px 34px; border-right: 1px solid rgba(255,255,255,0.12); }
.stats-grid div:last-child { border-right: 0; }
.stats-grid strong { display: block; margin-bottom: 4px; font-size: 28px; letter-spacing: -0.04em; }
.stats-grid span { color: rgba(255,255,255,0.68); }
.split-grid, .detail-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: 74px; align-items: start; }
.about-copy { padding-top: 40px; color: var(--muted); font-size: 18px; }
.about-copy p + p { margin-top: 22px; }
.about-note { margin-top: 30px; padding: 18px 20px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.45); }
.about-note strong { display: block; color: var(--text); margin-bottom: 4px; }
.brands { background: var(--dark); color: var(--white); }
.center { text-align: center; max-width: 760px; margin: 0 auto 54px; }
.section-subtitle { color: var(--muted); font-size: 18px; }
.brands .section-subtitle { color: rgba(255,255,255,0.68); }
.brands .eyebrow { color: #d9b486; }
.brand-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.brand-card { min-height: 520px; display: flex; flex-direction: column; padding: 22px; border-radius: var(--radius-lg); background: linear-gradient(160deg, rgba(255,255,255,0.12), rgba(255,255,255,0.05)); border: 1px solid rgba(255,255,255,0.14); }
.brand-visual { width: 100%; border-radius: 22px; aspect-ratio: 1.35 / 1; object-fit: cover; margin-bottom: 24px; box-shadow: 0 18px 50px rgba(0,0,0,.16); }
.brand-topline { width: fit-content; margin-bottom: 16px; padding: 8px 12px; border-radius: 999px; background: rgba(255,255,255,0.1); color: #e2c49e; font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.12em; }
.brand-card h3 { margin: 0 0 14px; font-size: 38px; line-height: 1; }
.brand-card p { color: rgba(255,255,255,0.68); }
.brand-links { display: flex; flex-wrap: wrap; gap: 14px; margin-top: auto; padding-top: 16px; }
.brand-card a, .text-link { width: fit-content; color: #f3d7b5; font-weight: 800; border-bottom: 1px solid rgba(243,215,181,0.45); }
.business-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 42px; }
.business-item { padding: 30px; border: 1px solid var(--line); border-radius: var(--radius-md); background: rgba(255,255,255,0.38); }
.business-item span { display: inline-flex; margin-bottom: 34px; color: var(--accent-deep); font-weight: 900; }
.business-item h3 { margin-bottom: 12px; font-size: 24px; }
.business-item p { color: var(--muted); }
.global-section { padding-top: 0; }
.global-card, .cta-card { display: flex; justify-content: space-between; align-items: center; gap: 40px; padding: 42px; border-radius: var(--radius-lg); background: linear-gradient(135deg, rgba(255,255,255,.66), rgba(255,255,255,.34)); box-shadow: 0 18px 60px rgba(38, 26, 12, 0.08); border: 1px solid rgba(255,255,255,.68); }
.global-card p:not(.eyebrow), .cta-card p:not(.eyebrow) { color: var(--muted); margin-bottom: 0; }
.values { padding-top: 0; }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.value-card { padding: 34px; border-radius: var(--radius-lg); background: var(--card); box-shadow: 0 18px 60px rgba(38, 26, 12, 0.08); }
.value-card h3 { margin-bottom: 14px; font-size: 32px; }
.value-card p { margin-bottom: 0; color: var(--muted); }
.contact { background: radial-gradient(circle at 88% 20%, rgba(185, 139, 85, 0.24), transparent 30%), var(--bg-soft); }
.contact-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 64px; align-items: center; }
.contact-card { padding: 38px; border-radius: var(--radius-lg); background: rgba(255,255,255,0.58); box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,0.72); }
.contact-card dl { margin: 0; }
.contact-card dl > div { display: grid; grid-template-columns: 110px 1fr; gap: 20px; padding: 18px 0; border-bottom: 1px solid var(--line); }
.contact-card dt { color: var(--muted); font-weight: 800; }
.contact-card dd { margin: 0; font-weight: 800; }
.sub-hero, .page-hero { padding-top: 150px; background: radial-gradient(circle at 78% 18%, rgba(185, 139, 85, 0.24), transparent 34%), linear-gradient(135deg, #f9f4ea 0%, #efe6d7 100%); }
.sub-hero-grid { display: grid; grid-template-columns: .86fr 1.14fr; gap: 64px; align-items: center; }
.sub-visual img { border-radius: 36px; box-shadow: var(--shadow); }
.detail-section { background: var(--bg); }
.info-band { padding-top: 0; }
.two-card-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.info-card { padding: 36px; border-radius: var(--radius-lg); background: var(--card); border: 1px solid rgba(255,255,255,.74); box-shadow: 0 18px 60px rgba(38, 26, 12, 0.08); }
.info-card h3 { font-size: 30px; margin-bottom: 18px; }
ul { padding-left: 1.2em; }
.info-card li, .policy-card li { margin: 8px 0; color: var(--muted); }
.contact-lite { padding-top: 0; }
.stacked-actions { display: flex; flex-direction: column; align-items: flex-end; gap: 14px; }
.policy-date { display: inline-flex; margin-top: 18px; padding: 8px 12px; border-radius: 999px; background: rgba(255,255,255,.56); color: var(--accent-deep); font-weight: 800; }
.policy-section { padding-top: 0; }
.policy-card { padding: 46px; border-radius: var(--radius-lg); background: rgba(255,255,255,.62); box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.72); }
.policy-card h2 { margin-top: 36px; margin-bottom: 12px; font-size: 26px; letter-spacing: -0.04em; }
.policy-card h2:first-child { margin-top: 0; }
.policy-card p { color: var(--muted); }
.policy-card a { color: var(--accent-deep); font-weight: 800; }
.site-footer { padding: 34px 0; color: rgba(255,255,255,0.68); background: var(--dark); }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.footer-inner p { margin: 0; }
.footer-meta { margin-top: 6px !important; font-size: 14px; color: rgba(255,255,255,.48); }
.footer-links { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 14px; }
.footer-inner a { font-weight: 800; color: var(--white); }
.reveal { opacity: 0; transform: translateY(22px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (max-width: 920px) {
  .nav-toggle { display: inline-block; }
  .site-nav { position: absolute; left: 20px; right: 20px; top: 72px; display: none; flex-direction: column; align-items: stretch; padding: 12px; background: rgba(248,244,236,0.96); border: 1px solid var(--line); border-radius: 24px; box-shadow: 0 18px 60px rgba(23,19,15,0.14); }
  .site-nav.open { display: flex; }
  .site-nav a { padding: 14px 16px; }
  .hero-grid, .split-grid, .contact-grid, .sub-hero-grid, .detail-grid { grid-template-columns: 1fr; gap: 42px; }
  .hero { min-height: auto; }
  .hero-panel { min-height: 430px; }
  .stats-grid, .brand-grid, .business-grid, .values-grid, .two-card-grid { grid-template-columns: 1fr; }
  .stats-grid div { border-right: 0; border-bottom: 1px solid rgba(255,255,255,0.12); }
  .stats-grid div:last-child { border-bottom: 0; }
  .about-copy { padding-top: 0; }
  .global-card, .cta-card { align-items: flex-start; flex-direction: column; }
  .stacked-actions { align-items: flex-start; }
}

@media (max-width: 640px) {
  .container { width: min(calc(100% - 28px), var(--container)); }
  .section { padding: 78px 0; }
  .hero { padding-top: 108px; }
  .sub-hero, .page-hero { padding-top: 118px; }
  .header-inner { min-height: 68px; }
  .logo span { font-size: 16px; }
  .hero-actions, .contact-actions { flex-direction: column; }
  .button { width: 100%; }
  .hero-panel { min-height: 360px; border-radius: 32px; }
  .main-card { width: calc(100% - 54px); padding: 26px; }
  .main-card strong { font-size: 28px; }
  .mini-card { display: none; }
  .brand-card { min-height: auto; }
  .brand-links { flex-direction: column; }
  .contact-card, .policy-card { padding: 26px; }
  .contact-card dl > div { grid-template-columns: 1fr; gap: 4px; }
  .footer-inner { flex-direction: column; align-items: flex-start; }
  .footer-links { justify-content: flex-start; }
}
