/* 채운 Budget v4.0 — "맑은 빛 상자"
   Aesop 챕터 아키텍처 · 풀폭 밝은 톤 밴드 · 모던 산세리프 · 단색 원석 팔찌 */

/* ---- 폰트 ---- */
@font-face{font-family:'Wanted Sans';src:url('../assets/fonts/wanted-sans/ws-sub.woff2') format('woff2');font-weight:400 700;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../assets/fonts/hanken-grotesk/hanken-grotesk-v12-latin-regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../assets/fonts/hanken-grotesk/hanken-grotesk-v12-latin-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'CW Hanja Sans';src:url('../assets/fonts/hanja/sanskr.woff2') format('woff2');font-weight:400;font-display:swap}

/* ---- 토큰 ---- */
:root{
  --surface:#fbfaf7; --surface-deep:#f1ede5; --surface-warm:#f5f0e6; --surface-card:#fff;
  --text:#26211c; --text-soft:#675f56; --line:#e4ddd0;
  --tint-deep:#2c2722; --on-tint:#f1ede5; --on-tint-soft:#aaa093; --line-tint:#4b443c;
  --mok:#7c9a6e; --hwa:#d4724f; --to:#d1a85f; --geum:#c3bcae; --su:#4a6076;
  --stone:#4a6076; --stone-deep:#374a5c;
  --bar-h:56px;
  --sans:'Wanted Sans','Apple SD Gothic Neo',sans-serif;
  --latin:'Hanken Grotesk',sans-serif;
  --hanja:'CW Hanja Sans',sans-serif;
}

html,body{background:var(--surface)}
body{
  color:var(--text);font-family:var(--sans);
  font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;
  word-break:keep-all;overflow-wrap:break-word;padding-top:var(--bar-h);
}

.grain{
  position:fixed;inset:0;pointer-events:none;z-index:80;opacity:.02;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.skip-link{
  position:fixed;top:8px;left:8px;z-index:120;
  background:var(--text);color:var(--surface);padding:8px 16px;border-radius:6px;
  font-size:.86rem;transform:translateY(-160%);transition:transform .2s ease;
}
.skip-link:focus{transform:none}

/* ============ 상단 헤더 ============ */
.topbar{
  position:fixed;top:0;left:0;right:0;height:var(--bar-h);z-index:70;
  background:color-mix(in srgb,var(--surface) 88%,transparent);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar-in{
  height:100%;max-width:1300px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(18px,4vw,40px);
}
.wordmark{display:flex;align-items:baseline;gap:9px;text-decoration:none}
.wm-hanja{font-family:var(--hanja);font-size:.92rem;color:var(--text-soft);letter-spacing:.12em}
.wm-ko{font-size:1.05rem;font-weight:700;color:var(--text);letter-spacing:.02em}
.ohaeng-index{display:flex;gap:clamp(10px,2.4vw,22px)}
.idx-item{
  font-family:var(--hanja);font-size:.86rem;color:var(--text-soft);
  opacity:.38;transition:opacity .5s ease,color .5s ease,text-shadow .6s ease;
}
.idx-item.is-active{opacity:.85;color:var(--text)}
.idx-item.is-stone{
  opacity:1;color:var(--stone-deep);
  text-shadow:0 0 9px color-mix(in srgb,var(--stone) 55%,transparent);
}

/* ============ 챕터 골격 ============ */
.chapter{position:relative;padding:clamp(80px,10vh,132px) 0}
.band-paper{background:var(--surface)}
.band-deep{background:var(--surface-deep)}
.band-warm{background:var(--surface-warm)}
.band-tint{background:var(--tint-deep);color:var(--on-tint)}
.container{max-width:1100px;margin:0 auto;padding:0 clamp(20px,5vw,56px)}
.container.narrow{max-width:620px}
.container.center{text-align:center}
.container.center .input-card,
.container.center .price-incl,
.container.center .ship-info{text-align:left}

/* ============ 공통 타이포 ============ */
.seal,.seal-sm{
  font-family:var(--hanja);color:var(--text-soft);
  border:1px solid var(--line);border-radius:5px;
}
.seal{
  display:inline-flex;align-items:center;line-height:1;
  font-size:.72rem;letter-spacing:.18em;padding:9px 12px 9px 14px;
}
.seal-sm{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:25px;height:25px;padding:0 7px;line-height:1;
  font-size:.7rem;letter-spacing:.04em;flex:none;border-radius:6px;
}
.eyebrow,.section-eyebrow{
  display:flex;align-items:center;gap:12px;
  font-size:.82rem;color:var(--text-soft);letter-spacing:.04em;
  margin-bottom:22px;font-weight:600;
}
.center-eyebrow{justify-content:center}
.section-title{
  font-size:clamp(1.8rem,3vw,2.6rem);font-weight:700;line-height:1.32;
  letter-spacing:-.018em;margin-bottom:20px;
}
.section-lead{
  color:var(--text-soft);font-size:1.06rem;line-height:1.72;
  max-width:42ch;margin-bottom:36px;
}
.center-lead{margin-left:auto;margin-right:auto}

/* ---- 버튼 ---- */
.btn{
  display:inline-block;font-family:var(--sans);font-size:1rem;font-weight:700;
  border-radius:4px;padding:16px 36px;letter-spacing:.01em;text-decoration:none;
  background:var(--text);color:var(--surface-card);border:1px solid var(--text);
  transition:background .3s ease,color .3s ease,opacity .3s ease,transform .15s ease;
}
.btn:hover{background:#100d09;border-color:#100d09}
.btn:active{transform:translateY(1px)}
.btn:disabled{
  background:var(--surface-deep);color:var(--text-soft);
  border-color:var(--line);cursor:not-allowed;
}
.band-tint .btn{background:var(--on-tint);color:var(--tint-deep);border-color:var(--on-tint)}
.band-tint .btn:hover{background:#fff;border-color:#fff}
.band-tint .btn:disabled{background:transparent;color:var(--on-tint-soft);border-color:var(--line-tint)}

/* ============ C0 Hero ============ */
.hero{
  padding:0;min-height:calc(100vh - var(--bar-h));
  display:grid;grid-template-columns:1fr 1.02fr;align-items:stretch;
}
.hero-copy{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(52px,7vh,100px) clamp(28px,5vw,80px);
  max-width:660px;margin-left:auto;
}
.hero-title{
  font-size:clamp(2.4rem,5.6vw,4.2rem);font-weight:700;line-height:1.22;
  letter-spacing:-.026em;margin:6px 0 24px;
}
.hero-title em{
  font-style:normal;color:var(--text);position:relative;padding-left:.64em;
}
.hero-title em::before{
  content:"";position:absolute;left:0;top:.52em;width:.42em;height:2px;
  background:var(--stone-deep);
}
.hero-sub{
  color:var(--text-soft);font-size:1.06rem;line-height:1.7;
  max-width:38ch;margin-bottom:26px;
}
.hero-price{
  display:flex;flex-direction:column;gap:3px;margin-bottom:26px;
  padding-top:22px;border-top:1px solid var(--line);
}
.hp-num{font-size:1.5rem;font-weight:700;color:var(--text)}
.hp-num .num{font-family:var(--latin)}
.hp-desc{font-size:.88rem;color:var(--text-soft)}
.hero-cta{align-self:flex-start;margin-bottom:32px}
.step-strip{
  list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0;
  border-top:1px solid var(--line);
}
.step-strip li{
  display:flex;align-items:center;gap:14px;
  padding:13px 0;border-bottom:1px solid var(--line);
  font-size:.94rem;color:var(--text-soft);
}
.ss-num{
  flex:none;width:24px;height:24px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--latin);font-size:.8rem;font-weight:600;
  background:var(--surface-deep);color:var(--text);
}
.hero-figure{margin:0;position:relative;overflow:hidden;background:var(--surface-deep)}
.hero-figure img{width:100%;height:100%;object-fit:cover;display:block}
.hero-figure::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to right,var(--surface) 0%,transparent 12%);
}

/* ============ C1 입력 카드 ============ */
.input-card{
  max-width:460px;margin:6px auto 0;text-align:left;
  background:var(--surface-card);border:1px solid var(--line);border-radius:14px;
  padding:32px 30px;box-shadow:0 20px 46px -38px rgba(38,33,28,.5);
}
.field-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:12px;margin-bottom:14px}
.hour-row{display:flex;gap:14px;align-items:flex-end;margin-bottom:8px;flex-wrap:wrap}
.hour-row .field{flex:1;min-width:140px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.8rem;color:var(--text-soft);font-weight:600}
.field select{
  font-family:var(--sans);font-size:1rem;color:var(--text);
  background:var(--surface);border:1px solid var(--line);border-radius:9px;
  padding:13px 12px;width:100%;min-height:48px;
}
.field select:focus-visible{outline:none;border-color:var(--stone)}
.hour-unknown{
  display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--text-soft);
  padding-bottom:13px;cursor:pointer;
}
.hour-unknown input{width:18px;height:18px;accent-color:var(--stone)}
.input-card .btn{width:100%;margin-top:10px}
.input-note{font-size:.82rem;color:var(--text-soft);margin-top:14px;line-height:1.6}

/* ============ C2 결과 ============ */
.result-empty{
  text-align:center;font-size:1.06rem;color:var(--text-soft);line-height:1.7;
  padding:clamp(20px,5vh,52px) 0;max-width:34ch;margin:0 auto;
}
.result[hidden]{display:none}
.result{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.result.shown{opacity:1;transform:none}
.result-summary{margin-bottom:10px}
.result-summary b{color:var(--stone-deep)}
.result-sub{font-size:1rem;color:var(--text-soft);max-width:46ch;margin-bottom:36px}

.ohaeng-dots{margin-bottom:44px;border-top:1px solid var(--line)}
.od-caption{font-size:.84rem;color:var(--text-soft);letter-spacing:.02em;margin:16px 0 6px}
.od-row{display:flex;flex-direction:column}
.od-item{
  display:flex;align-items:center;gap:clamp(14px,2.4vw,24px);
  padding:16px 2px;border-bottom:1px solid var(--line);
}
.od-glyph{
  flex:none;width:24px;text-align:center;
  font-family:var(--hanja);font-size:1rem;color:var(--text-soft);
}
.od-name{flex:none;width:30px;font-size:.92rem;font-weight:600;color:var(--text)}
.od-track{flex:1;height:3px;background:var(--surface-deep);overflow:hidden}
.od-fill{display:block;height:100%;width:0;background:#b9b1a3}
.od-strength{flex:none;width:62px;text-align:right;font-size:.82rem;color:var(--text-soft)}
.od-item.is-need .od-glyph,
.od-item.is-need .od-name{color:var(--stone-deep)}
.od-item.is-need .od-strength{color:var(--stone-deep);font-weight:600}

/* 결과 스테이지 — 색 카드 + 팔찌 2-up */
.result-stage{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(20px,3vw,40px);
  align-items:stretch;margin-bottom:28px;
}
.result-color-card{
  display:flex;flex-direction:column;
  background:var(--surface-card);border:1px solid var(--line);border-radius:14px;
  overflow:hidden;cursor:pointer;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease;
  box-shadow:0 16px 36px -32px rgba(38,33,28,.5);
}
.result-color-card.tilt{transform:rotate(-1.5deg) scale(1.015);box-shadow:0 26px 52px -34px rgba(38,33,28,.5)}
.rcc-swatch{
  position:relative;flex:1;min-height:248px;
  display:flex;align-items:flex-end;padding:22px;
  background:
    radial-gradient(58% 48% at 30% 24%, color-mix(in srgb,var(--stone) 52%,#fff) 0%, transparent 72%),
    radial-gradient(72% 66% at 82% 86%, var(--stone-deep) 0%, transparent 74%),
    var(--stone);
}
.rcc-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;z-index:1;
}
.rcc-swatch .hanja{
  position:relative;z-index:2;
  font-family:var(--hanja);font-size:2.3rem;color:rgba(255,255,255,.94);
  text-shadow:0 2px 18px rgba(0,0,0,.55);line-height:1;
}
.rcc-meta{padding:20px 24px 24px;display:flex;flex-direction:column;gap:3px}
.rcc-kicker{font-size:.74rem;color:var(--text-soft);letter-spacing:.05em;margin-bottom:7px}
.rcc-color-name{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}
.rcc-element{font-size:.9rem;color:var(--stone-deep)}

.stone-bracelet{
  display:flex;flex-direction:column;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  overflow:hidden;
}
.sb-img{width:100%;height:auto;display:block}
.sb-caption{font-size:.92rem;color:var(--text);text-align:center;margin:0;padding:16px 24px 0}
.sb-legend{display:flex;flex-direction:column;gap:8px;padding:12px 24px 22px}
.sb-legend>div{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--text-soft)}
.sb-key{flex:none;border-radius:50%}
.sb-key.stone{width:16px;height:16px;background:var(--stone)}
.sb-key.charm{width:18px;height:11px;border-radius:50%;
  background:linear-gradient(128deg,#e8e4dc,#9a958c)}
.sb-line{font-size:1rem;color:var(--text);line-height:1.7;max-width:48ch;margin:0 0 16px}
.result-disclaim{font-size:.88rem;color:var(--text-soft);font-style:italic;margin-bottom:24px}

/* ============ C3 색과 그릇 ============ */
.duo{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,64px);align-items:center}
.duo-text p{font-size:1.04rem;color:var(--text);line-height:1.74;margin-bottom:12px}
.duo-text .duo-line{
  margin-top:18px;padding-top:18px;border-top:1px solid var(--line);
  font-weight:700;color:var(--text);
}
.vessel-pair{
  background:var(--surface-card);border:1px solid var(--line);border-radius:14px;
  padding:28px 28px;box-shadow:0 18px 42px -38px rgba(38,33,28,.5);
}
.vp-item{display:flex;flex-direction:column;gap:4px}
.vp-rule{height:1px;background:var(--line);margin:20px 0}
.vp-glyph{margin-bottom:8px}
.vp-variable{
  width:40px;height:40px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,
    color-mix(in srgb,var(--stone) 70%,#fff),var(--stone) 46%,var(--stone-deep));
}
.vp-constant{
  width:44px;height:27px;border-radius:50%;
  background:linear-gradient(128deg,#e8e4dc,#c2bdb3 42%,#9a958c 66%,#bdb8ae);
}
.vp-term{font-size:1.02rem;font-weight:700;color:var(--text)}
.vp-sub{font-size:.88rem;color:var(--text-soft);line-height:1.55}

/* ============ C4 거대 타이포 ============ */
.typeband{
  text-align:center;display:flex;flex-direction:column;
  align-items:center;justify-content:center;min-height:42vh;
}
.typeband-line{
  font-size:clamp(2rem,4.4vw,3.4rem);font-weight:700;line-height:1.28;
  letter-spacing:-.03em;color:var(--on-tint);
}
.typeband-sub{margin-top:14px;font-size:1.02rem;
  color:color-mix(in srgb,var(--on-tint) 72%,var(--on-tint-soft))}

/* ============ C5 소재 ============ */
.proof-row{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px);
  align-items:center;margin-top:clamp(36px,5vh,60px);
}
.proof-rev .proof-fig{order:2}
.proof-fig{margin:0}
.proof-fig img{
  width:100%;height:auto;border-radius:12px;display:block;
  aspect-ratio:5/4;object-fit:cover;
  box-shadow:0 22px 48px -40px rgba(38,33,28,.55);
}
.proof-h{font-size:1.2rem;font-weight:700;margin-bottom:10px;letter-spacing:-.012em}
.proof-text p{font-size:1rem;color:var(--text-soft);line-height:1.72}

/* ============ C6 데일리 — 풀블리드 ============ */
.dailyscene{
  padding:0;display:grid;grid-template-columns:1.05fr .95fr;align-items:stretch;
}
.daily-figure{margin:0;overflow:hidden}
.daily-figure img{width:100%;height:100%;min-height:460px;object-fit:cover;display:block}
.daily-copy{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(56px,8vh,116px) clamp(28px,5vw,76px);
}
.gift-strip{
  background:var(--surface-card);border:1px solid var(--line);border-radius:12px;
  padding:18px 20px;margin-bottom:20px;
}
.gift-strip p{font-size:.96rem;color:var(--text-soft);line-height:1.66}
.gift-strip b{color:var(--text)}
.share-line p{font-size:.96rem;color:var(--text-soft);line-height:1.66;margin-bottom:14px}
.share-btn{
  font-family:var(--sans);font-size:.92rem;font-weight:600;color:var(--stone-deep);
  border:1px solid var(--stone);border-radius:9px;padding:11px 22px;background:transparent;
  transition:background .25s ease,color .25s ease;
}
.share-btn:hover{background:var(--stone);color:#fff}

/* ============ C7 가격 ============ */
.price-block{
  background:var(--surface-card);border:1px solid var(--line);border-radius:16px;
  padding:36px 34px;text-align:left;box-shadow:0 22px 50px -42px rgba(38,33,28,.5);
}
.price-main{display:flex;align-items:baseline;gap:5px;justify-content:center;margin-bottom:8px}
.pm-num{font-family:var(--latin);font-size:clamp(2.4rem,5vw,3.2rem);font-weight:600;color:var(--text)}
.pm-won{font-size:1.3rem;color:var(--text)}
.price-label{font-size:.92rem;color:var(--text-soft);text-align:center;margin-bottom:24px}
.price-incl{list-style:none;padding:0;margin:0 0 8px;border-top:1px solid var(--line)}
.price-incl li{
  display:flex;gap:14px;align-items:flex-start;
  padding:18px 0;border-bottom:1px solid var(--line);
}
.pi-mark{
  flex:none;width:30px;height:30px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--hanja);font-size:.76rem;color:var(--stone-deep);
  border:1px solid var(--line);background:var(--surface);
}
.price-incl li>div{display:flex;flex-direction:column;gap:3px}
.price-incl b{font-size:.96rem;font-weight:700;color:var(--text)}
.price-incl li span{font-size:.86rem;color:var(--text-soft);line-height:1.55}
.ship-info{margin:18px 0 0}
.ship-info>div{padding:14px 0;border-bottom:1px solid var(--line)}
.ship-info>div:last-child{border-bottom:0;padding-bottom:0}
.ship-info dt{font-size:.8rem;color:var(--text-soft);font-weight:600;margin-bottom:5px}
.ship-info dd{margin:0;font-size:.92rem;color:var(--text);line-height:1.62}

/* ============ C8 주문 ============ */
.orderscene .btn{margin-top:4px}
.cta-note{font-size:.9rem;color:var(--on-tint-soft);margin-top:14px;font-style:italic}
.orderscene.is-ready .cta-note{display:none}

/* ============ FAQ ============ */
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-item summary{
  font-size:1.02rem;font-weight:700;color:var(--text);
  padding:18px 32px 18px 0;cursor:pointer;list-style:none;position:relative;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";position:absolute;right:2px;top:15px;
  font-size:1.3rem;color:var(--text-soft);transition:transform .3s ease;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{font-size:.96rem;color:var(--text-soft);line-height:1.7;padding:0 0 20px;max-width:48ch}

/* ============ Footer ============ */
.foot{padding:clamp(56px,7vh,92px) 0}
.foot-mark{font-family:var(--hanja);font-size:1.05rem;color:var(--text-soft);
  letter-spacing:.1em;display:block;margin-bottom:14px}
.foot-line{font-size:1.05rem;color:var(--text);font-weight:600;margin-bottom:8px}
.foot-fine{font-size:.86rem;color:var(--text-soft);line-height:1.7;max-width:50ch}

/* ============ Sticky 주문 바 ============ */
.sticky-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:60;
  display:flex;justify-content:center;padding:12px 18px;
  background:color-mix(in srgb,var(--surface) 92%,transparent);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border-top:1px solid var(--line);
  transform:translateY(110%);transition:transform .4s cubic-bezier(.2,.7,.2,1);
}
.sticky-bar.is-shown{transform:none}
.sticky-btn{
  font-family:var(--sans);font-size:.98rem;font-weight:700;
  padding:14px 30px;border-radius:4px;text-decoration:none;text-align:center;
  max-width:420px;width:100%;
}
.sticky-pre{background:transparent;color:var(--text);border:1px solid var(--text);display:block}
.sticky-post{background:var(--text);color:var(--surface-card);border:1px solid var(--text)}

/* ============ 모달 ============ */
.modal{
  border:none;padding:0;background:transparent;
  max-width:440px;width:calc(100% - 36px);margin:auto;color:var(--text);
}
.modal::backdrop{background:rgba(38,33,28,.55)}
.modal-inner{
  position:relative;background:var(--surface-card);
  border:1px solid var(--line);border-radius:16px;padding:40px 32px 34px;
}
.modal-close{position:absolute;top:14px;right:16px;font-size:1.2rem;color:var(--text-soft);line-height:1;padding:4px}
.modal-seal{font-family:var(--hanja);font-size:1.1rem;color:var(--text-soft);letter-spacing:.1em;margin-bottom:12px}
.modal-title{font-size:1.3rem;font-weight:700;line-height:1.4;margin-bottom:14px}
.modal-summary{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;margin-bottom:14px;
  background:var(--surface-deep);border-radius:10px;
}
.ms-swatch{
  flex:none;width:38px;height:38px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  background:var(--stone);
}
.ms-swatch .hanja{font-family:var(--hanja);font-size:.92rem;color:#fff}
.ms-text{font-size:.94rem;color:var(--text)}
.ms-text b{font-weight:700}
.modal-body{font-size:.94rem;color:var(--text-soft);line-height:1.7;margin-bottom:18px}
.modal-label{display:block;font-size:.8rem;color:var(--text-soft);font-weight:600;margin-bottom:7px}
.email-field input{
  font-family:var(--sans);font-size:1rem;color:var(--text);width:100%;
  background:var(--surface);border:1px solid var(--line);border-radius:9px;
  padding:13px 12px;min-height:48px;
}
.email-field input:focus-visible{outline:none;border-color:var(--stone)}
.modal-privacy{font-size:.8rem;color:var(--text-soft);margin:14px 0;line-height:1.6}
.modal-form .btn{width:100%}
.modal-form.hide{display:none}
.disclosure{display:none;text-align:left}
.disclosure.shown{display:block}
.disclosure .btn{width:100%;margin-top:8px}

/* ============ 모션 ============ */
.fade-in{opacity:0;transform:translateY(12px)}
.fade-in.in{opacity:1;transform:none;transition:opacity .6s ease,transform .6s ease}
.reveal{opacity:0;transform:translateY(16px)}
.reveal.is-in{opacity:1;transform:none;transition:opacity .6s ease,transform .6s ease}

@media (prefers-reduced-motion:reduce){
  .fade-in,.reveal,.result{opacity:1!important;transform:none!important}
  .sticky-bar{transition:none}
}

/* ============ 반응형 ============ */
@media (max-width:1023px){
  .hero{grid-template-columns:1fr 1fr}
  .hero-copy{padding:clamp(44px,6vh,80px) clamp(24px,4vw,48px)}
  .duo{grid-template-columns:1fr;gap:32px}
  .dailyscene{grid-template-columns:1fr}
  .daily-figure{order:-1}
  .daily-figure img{min-height:320px}
  .result-stage{grid-template-columns:1fr}
}
@media (max-width:767px){
  body{font-size:15.5px}
  .chapter{padding:clamp(60px,8vh,92px) 0}
  .hero{grid-template-columns:1fr;min-height:auto;padding:0}
  .hero-figure{order:-1;aspect-ratio:4/3;max-height:54vh}
  .hero-figure::after{background:linear-gradient(to bottom,transparent 72%,var(--surface) 100%)}
  .hero-copy{padding:36px 20px 52px;margin:0;max-width:none}
  .hero-sub{max-width:none}
  .hero-cta{align-self:stretch;text-align:center}
  .container{padding:0 20px}
  .input-card{padding:26px 20px}
  .field-grid{grid-template-columns:1fr 1fr 1fr;gap:10px}
  .od-row{gap:12px}
  .od-item{min-width:calc(50% - 6px)}
  .proof-row{grid-template-columns:1fr;gap:18px;margin-top:40px}
  .proof-rev .proof-fig{order:0}
  .daily-figure img{min-height:260px}
  .price-block{padding:28px 20px}
  .modal-inner{padding:34px 22px 28px}
}
@media (max-width:380px){
  .container{padding:0 16px}
  .field select{padding:12px 8px}
}

/* ============ C5b 다섯 오행의 색 ============ */
.rcc-note{font-size:.9rem;color:var(--text-soft);line-height:1.66;margin-top:9px}
.stone-grid{
  list-style:none;padding:0;margin:44px 0 0;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(186px,1fr));gap:14px;
}
.stone-card{
  display:flex;flex-direction:column;
  background:var(--surface-card);border:1px solid var(--line);border-radius:14px;overflow:hidden;
}
.stone-swatch{
  position:relative;aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;
  background:var(--surface-deep);border-bottom:1px solid var(--line);
}
.stone-img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.stone-hanja{
  position:absolute;top:10px;left:13px;
  font-family:var(--hanja);font-size:1rem;color:var(--text);opacity:.5;
  text-shadow:0 1px 3px rgba(251,250,247,.8);
}
.stone-info{padding:17px 18px 21px;display:flex;flex-direction:column;gap:4px;flex:1}
.stone-color{font-size:1.14rem;font-weight:700;letter-spacing:-.02em;line-height:1.3}
.stone-element{font-size:.82rem;color:var(--text-soft);margin-bottom:9px}
.stone-meaning{font-size:.92rem;color:var(--text);line-height:1.68;margin-bottom:8px}
.stone-note{font-size:.85rem;color:var(--text-soft);line-height:1.64}
.stones-foot{
  margin:30px auto 0;max-width:48ch;text-align:center;
  font-size:.86rem;color:var(--text-soft);line-height:1.7;
}
@media (max-width:767px){
  .stone-grid{grid-template-columns:1fr 1fr;gap:10px;margin-top:36px}
  .stone-info{padding:14px 15px 17px}
  .stones-foot{text-align:left}
}
@media (max-width:380px){
  .stone-grid{grid-template-columns:1fr}
}
