/* 채운 Budget — design.budget.md v1.0 구현
   "맑은 빛 상자 위의 색 카드" — 밝은 빛 면, 중앙 카드 스택, 빠른 호흡. */

/* ---------- 폰트 ---------- */
@font-face{
  font-family:'Wanted Sans';
  src:url('../assets/fonts/wanted-sans/ws-sub.woff2') format('woff2-variations');
  font-weight:100 900;
  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-card:#ffffff;
  --surface-tint:#f3f0ea;
  --text:#26211c;
  --text-soft:#675f56;
  --line:#e4ddd0;

  --mok:#7c9a6e;
  --hwa:#d4724f;
  --to:#d1a85f;
  --geum:#c3bcae;
  --su:#4a6076;

  /* 결과 공개 전 기본값 — 주인공 색은 런타임 주입 */
  --protagonist:#4a6076;

  --maxw:560px;
  --pad:18px;
  --radius:10px;
  --shadow-1:0 1px 3px rgba(38,33,28,.06),0 1px 2px rgba(38,33,28,.04);
  --shadow-lift:0 14px 30px -8px rgba(38,33,28,.22),0 4px 10px rgba(38,33,28,.10);
}

/* ---------- 베이스 ---------- */
html{font-size:100%}
body{
  font-family:'Wanted Sans','Hanken Grotesk',system-ui,sans-serif;
  font-weight:400;
  color:var(--text);
  background:var(--surface);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  letter-spacing:-0.005em;
}
/* 미세 그레인 — 거의 무텍스처 */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  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='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.015;
}

main,header,footer{position:relative;z-index:1}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

section{padding:54px 0}
.section--tint{background:var(--surface-tint)}

/* ---------- 한자 anchor ---------- */
.hanja{font-family:'CW Hanja Sans',serif;font-weight:400}

/* ---------- 공통 텍스트 ---------- */
.eyebrow{
  font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-soft);display:flex;align-items:center;gap:8px;margin-bottom:14px;
}
.eyebrow .hanja{font-size:.78rem;letter-spacing:0;color:var(--protagonist)}
.section-title{
  font-size:clamp(1.4rem,4vw,2.0rem);font-weight:600;line-height:1.3;
  letter-spacing:-0.02em;margin-bottom:12px;
}
.lede{color:var(--text-soft);font-size:1.0rem;max-width:46ch}
.caption{font-size:.78rem;font-weight:300;color:var(--text-soft)}

/* ---------- 五色 점 ---------- */
.dot-row{display:flex;gap:7px;align-items:center}
.dot{width:9px;height:9px;border-radius:50%;flex:none}
.dot.mok{background:var(--mok)} .dot.hwa{background:var(--hwa)}
.dot.to{background:var(--to)}  .dot.geum{background:var(--geum)}
.dot.su{background:var(--su)}

/* ============ 헤더 ============ */
.site-header{
  position:sticky;top:0;z-index:20;
  background:rgba(251,250,247,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{
  display:flex;align-items:center;justify-content:space-between;
  height:56px;
}
.brand{display:flex;align-items:baseline;gap:8px;font-weight:600;font-size:1.05rem}
.brand .hanja{font-size:.95rem;color:var(--protagonist)}
.brand .line-tag{
  font-size:.66rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-soft);
}

/* ============ S0 Hero ============ */
.hero{padding:60px 0 50px;text-align:left}
.hero .dot-row{margin-bottom:22px}
.hero .dot{opacity:0}
.hero h1{
  font-size:clamp(2.0rem,6.5vw,3.4rem);font-weight:600;line-height:1.25;
  letter-spacing:-0.025em;margin-bottom:18px;
}
.hero h1 em{font-style:normal;color:var(--protagonist)}
.hero .sub{color:var(--text-soft);font-size:1.02rem;max-width:42ch;margin-bottom:26px}
.hero .hero-aside{
  display:flex;align-items:center;gap:9px;
  font-size:.8rem;color:var(--text-soft);
}
.hero .hero-aside .hanja{color:var(--protagonist);font-size:.9rem}

/* 페이드인 */
.fade-in{opacity:0;transform:translateY(10px)}
.fade-in.in{opacity:1;transform:none;transition:opacity .6s ease,transform .6s ease}

/* ============ S1 3단계 설명 ============ */
.steps{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.step-card{
  background:var(--surface-card);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 18px;display:flex;gap:14px;align-items:flex-start;
  box-shadow:var(--shadow-1);
  opacity:0;transform:translateX(-14px);
}
.step-card.in{opacity:1;transform:none;transition:opacity .5s ease,transform .5s ease}
.step-num{
  flex:none;width:30px;height:30px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--surface-tint);color:var(--protagonist);
  font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:.92rem;
}
.step-card h3{font-size:1.0rem;font-weight:600;margin-bottom:3px}
.step-card p{font-size:.9rem;color:var(--text-soft)}

/* ============ S2 읽기 입력 ============ */
.input-card{
  background:var(--surface-card);border:1px solid var(--line);border-radius:14px;
  padding:24px 20px;box-shadow:var(--shadow-1);margin-top:8px;
}
.input-card .field-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px;
}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.76rem;font-weight:600;color:var(--text-soft)}
.field select{
  font:inherit;font-size:.92rem;
  min-height:46px;padding:0 12px;
  border:1px solid var(--line);border-radius:8px;
  background:var(--surface);color:var(--text);
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a7268' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
}
.field select:focus-visible{outline:2px solid var(--protagonist);outline-offset:1px}
.hour-row{
  display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap;
}
.hour-row .field{flex:1;min-width:130px}
.hour-unknown{
  display:flex;align-items:center;gap:8px;font-size:.86rem;color:var(--text-soft);
  min-height:44px;
}
.hour-unknown input{width:18px;height:18px;accent-color:var(--protagonist)}
.btn{
  font:inherit;font-weight:600;font-size:.98rem;
  min-height:50px;padding:0 22px;
  border-radius:var(--radius);
  background:var(--protagonist);color:#fff;
  box-shadow:var(--shadow-1);
  transition:filter .15s ease,transform .1s ease;
  width:100%;
}
.btn:hover{filter:brightness(1.06)}
.btn:active{transform:translateY(1px)}
.btn:disabled{
  background:var(--surface-tint);color:var(--text-soft);
  box-shadow:none;cursor:not-allowed;filter:none;
}
.btn:disabled:hover{filter:none}
.btn:disabled:active{transform:none}
.btn--ghost{
  background:var(--surface-card);color:var(--text);
  border:1px solid var(--line);
}
.input-note{font-size:.78rem;font-weight:300;color:var(--text-soft);margin-top:10px}

/* ============ S3 결과 — 색 카드 스택 ============ */
.result{display:none}
.result.shown{display:block}
.result-summary{
  font-size:1.05rem;line-height:1.6;margin-bottom:8px;max-width:40ch;
}
.result-summary b{font-weight:600;color:var(--protagonist)}
.result-sub{font-size:.86rem;color:var(--text-soft);margin-bottom:24px}

.card-stack{
  display:flex;justify-content:center;gap:10px;flex-wrap:wrap;
  margin:0 auto 22px;
}
.color-card{
  flex:none;width:104px;
  background:var(--surface-card);
  border:1px solid var(--line);border-radius:12px;
  padding:14px 12px 13px;
  display:flex;flex-direction:column;align-items:center;gap:7px;
  box-shadow:var(--shadow-1);
  transform:translateY(0) scale(.97);opacity:.86;
  transition:transform .45s cubic-bezier(.2,.7,.2,1),opacity .45s ease,box-shadow .45s ease;
}
.color-card .swatch{
  width:48px;height:48px;border-radius:10px;flex:none;
  display:grid;place-items:center;
}
.color-card .swatch .hanja{
  font-size:1.1rem;color:#fff;
  text-shadow:0 1px 2px rgba(0,0,0,.28);
}
.color-card .cc-name{font-size:.82rem;font-weight:600}
.color-card .cc-tag{font-size:.68rem;color:var(--text-soft)}
.color-card.is-protagonist{
  transform:translateY(-14px) scale(1.04);opacity:1;
  box-shadow:var(--shadow-lift);
  border-color:var(--protagonist);
  cursor:pointer;
}
.color-card.is-protagonist .cc-tag{color:var(--protagonist);font-weight:600}
.color-card.is-protagonist.tilt{
  transform:translateY(-14px) scale(1.04) rotate(-2.2deg);
}

/* 주인공 공유 카드 (4:5) */
.share-card{
  max-width:300px;margin:0 auto;
  aspect-ratio:4/5;
  background:var(--surface-card);
  border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-lift);
  padding:26px 24px;
  display:flex;flex-direction:column;
}
.share-card .sc-top{
  display:flex;align-items:center;justify-content:space-between;
  font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-soft);
}
.share-card .sc-top .hanja{color:var(--protagonist);font-size:.8rem}
.share-card .sc-swatch{
  margin:22px auto 16px;width:96px;height:96px;border-radius:18px;
  background:var(--protagonist);
  display:grid;place-items:center;
  box-shadow:0 8px 20px -6px color-mix(in srgb,var(--protagonist) 55%,transparent);
}
.share-card .sc-swatch .hanja{font-size:2.2rem;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3)}
.share-card .sc-label{text-align:center;font-size:.8rem;color:var(--text-soft)}
.share-card .sc-color-name{
  text-align:center;font-size:1.5rem;font-weight:600;color:var(--protagonist);
  margin-top:2px;line-height:1.2;
}
.share-card .sc-line{
  margin-top:auto;font-size:.82rem;line-height:1.55;color:var(--text);
}
.share-card .sc-guard{
  margin-top:10px;font-size:.7rem;font-weight:300;color:var(--text-soft);
  border-top:1px solid var(--line);padding-top:10px;
}
.result-disclaim{
  font-size:.8rem;font-weight:300;color:var(--text-soft);
  text-align:center;margin-top:18px;max-width:36ch;margin-left:auto;margin-right:auto;
}

/* ============ S4 제품 구조 ============ */
.bead-diagram{
  background:var(--surface-card);border:1px solid var(--line);border-radius:14px;
  padding:24px 20px;box-shadow:var(--shadow-1);margin-bottom:14px;
}
.bead-row{
  display:flex;justify-content:center;align-items:flex-end;gap:9px;
  margin-bottom:18px;
}
.bead{
  width:22px;height:22px;border-radius:50%;flex:none;
}
.bead.base{opacity:.5}
.bead.hero-bead{
  width:34px;height:34px;
  box-shadow:0 6px 14px -4px color-mix(in srgb,var(--protagonist) 50%,transparent);
  position:relative;
}
.bead-caption{display:flex;justify-content:space-between;gap:14px;font-size:.84rem}
.bead-caption div{flex:1}
.bead-caption .bc-title{font-weight:600;margin-bottom:2px}
.bead-caption p{color:var(--text-soft);font-size:.82rem}
.price-teaser{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-size:.9rem;color:var(--text-soft);
  background:var(--surface-tint);border-radius:var(--radius);
  padding:13px 16px;
}
.price-teaser .pt-num{
  font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:1.05rem;
  color:var(--text);
}

/* ============ S5 소재 proof ============ */
.proof-list{display:flex;flex-direction:column;gap:12px}
.proof-card{
  background:var(--surface-card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-1);
}
.proof-card .proof-body{padding:16px 18px}
.proof-card h3{font-size:1.0rem;font-weight:600;margin-bottom:5px}
.proof-card p{font-size:.88rem;color:var(--text-soft)}

/* ============ S6 데일리·공유 ============ */
.daily-grid{display:flex;flex-direction:column;gap:14px}
.share-preview{
  background:var(--surface-card);border:1px solid var(--line);border-radius:14px;
  padding:20px 18px;box-shadow:var(--shadow-1);
}
.share-preview h3{font-size:1.0rem;font-weight:600;margin-bottom:6px}
.share-preview p{font-size:.88rem;color:var(--text-soft);margin-bottom:14px}
.mini-cards{display:flex;gap:10px}
.mini-card{
  flex:1;border:1px solid var(--line);border-radius:10px;
  padding:14px 12px;text-align:center;background:var(--surface);
}
.mini-card .mc-swatch{
  width:40px;height:40px;border-radius:9px;margin:0 auto 8px;
  display:grid;place-items:center;
}
.mini-card .mc-swatch .hanja{color:#fff;font-size:.95rem;text-shadow:0 1px 2px rgba(0,0,0,.28)}
.mini-card .mc-name{font-size:.82rem;font-weight:600}
.mini-card .mc-tag{font-size:.68rem;color:var(--text-soft)}
.share-actions{margin-top:14px}
.share-btn{
  font:inherit;font-size:.86rem;font-weight:600;
  min-height:44px;padding:0 16px;width:100%;
  border:1px solid var(--line);border-radius:var(--radius);
  background:var(--surface);color:var(--text);
}
.share-btn:hover{background:var(--surface-tint)}

/* ============ S7 가격·제작 안내 ============ */
.price-block{
  background:var(--surface-card);border:1px solid var(--line);border-radius:14px;
  padding:26px 22px;box-shadow:var(--shadow-1);
}
.price-main{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}
.price-main .pm-num{
  font-family:'Hanken Grotesk',sans-serif;font-weight:600;
  font-size:2.6rem;letter-spacing:-0.01em;line-height:1;
}
.price-main .pm-won{font-size:1.1rem;font-weight:600}
.price-label{font-size:.84rem;color:var(--text-soft);margin-bottom:18px}
.price-incl{
  list-style:none;display:flex;flex-direction:column;gap:9px;
  border-top:1px solid var(--line);padding-top:16px;
}
.price-incl li{
  display:flex;gap:9px;align-items:flex-start;font-size:.9rem;
}
.price-incl li .tick{
  flex:none;width:18px;height:18px;border-radius:50%;
  background:var(--protagonist);color:#fff;
  display:grid;place-items:center;font-size:.62rem;margin-top:2px;
}
.price-incl li b{font-weight:600}
.price-incl li span{color:var(--text-soft)}
.make-info{
  margin-top:16px;border-top:1px solid var(--line);padding-top:16px;
  font-size:.84rem;color:var(--text-soft);
}
.make-info dt{font-weight:600;color:var(--text);margin-top:8px}
.make-info dt:first-child{margin-top:0}
.daily-spend{
  font-size:.82rem;color:var(--text-soft);margin-top:14px;
}

/* ============ S8 제작 요청 CTA ============ */
.cta-block{text-align:center}
.cta-block .section-title{margin-bottom:8px}
.cta-block .lede{margin:0 auto 22px}
.cta-block .btn{max-width:340px;margin:0 auto}
.cta-disabled-note{
  font-size:.78rem;color:var(--text-soft);margin-top:12px;
}

/* ============ FAQ ============ */
.faq-list{display:flex;flex-direction:column;gap:0;margin-top:8px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:16px 2px;font-weight:600;font-size:.94rem;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  min-height:44px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";font-family:'Hanken Grotesk',sans-serif;font-weight:400;
  font-size:1.2rem;color:var(--text-soft);flex:none;
}
.faq-item[open] summary::after{content:"–"}
.faq-item p{
  padding:0 2px 16px;font-size:.88rem;color:var(--text-soft);
}

/* ============ 푸터 ============ */
.site-footer{
  border-top:1px solid var(--line);
  padding:34px 0 44px;text-align:center;
}
.site-footer .hanja{font-size:1.1rem;color:var(--protagonist)}
.site-footer .foot-line{font-size:.86rem;color:var(--text-soft);margin-top:10px}
.site-footer .foot-fine{font-size:.74rem;font-weight:300;color:var(--text-soft);margin-top:14px}

/* ============ 이메일 모달 ============ */
.modal{
  border:none;padding:0;background:transparent;max-width:none;max-height:none;
  width:100%;height:100%;
}
.modal::backdrop{background:rgba(38,33,28,.46);backdrop-filter:blur(2px)}
.modal-inner{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:calc(100vw - 36px);max-width:420px;
  background:var(--surface-card);border-radius:16px;
  box-shadow:0 24px 60px -12px rgba(38,33,28,.4);
  padding:26px 22px 24px;
}
.modal-close{
  position:absolute;top:10px;right:10px;
  width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;color:var(--text-soft);font-size:1.2rem;
}
.modal-close:hover{background:var(--surface-tint)}
.modal h2{font-size:1.2rem;font-weight:600;margin-bottom:8px;padding-right:28px}
.modal .modal-body{font-size:.88rem;color:var(--text-soft);margin-bottom:16px}
.modal-color-chip{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.8rem;font-weight:600;color:var(--text);
  background:var(--surface-tint);border-radius:20px;
  padding:5px 12px 5px 6px;margin-bottom:14px;
}
.modal-color-chip .mcc-dot{
  width:18px;height:18px;border-radius:50%;background:var(--protagonist);
}
.email-field{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.email-field label{font-size:.78rem;font-weight:600;color:var(--text-soft)}
.email-field input{
  font:inherit;font-size:.95rem;min-height:48px;padding:0 14px;
  border:1px solid var(--line);border-radius:8px;
  background:var(--surface);color:var(--text);
}
.email-field input:focus-visible{outline:2px solid var(--protagonist);outline-offset:1px}
.modal .privacy{font-size:.74rem;font-weight:300;color:var(--text-soft);margin:8px 0 16px}
.modal .btn{margin-top:2px}

/* post-click disclosure */
.disclosure{display:none;text-align:center}
.disclosure.shown{display:block}
.disclosure .disc-mark{
  width:54px;height:54px;border-radius:50%;margin:0 auto 14px;
  background:var(--surface-tint);display:grid;place-items:center;
}
.disclosure .disc-mark .hanja{font-size:1.5rem;color:var(--protagonist)}
.disclosure h2{margin-bottom:10px}
.disclosure p{font-size:.9rem;color:var(--text-soft);margin-bottom:8px}
.disclosure .disc-fine{font-size:.74rem;font-weight:300}
.modal-form.hide{display:none}

/* ============ 반응형 ============ */
@media (min-width:600px){
  .field select{font-size:.9rem}
  .card-stack{gap:12px}
  .color-card{width:112px}
}
@media (max-width:380px){
  .input-card .field-grid{grid-template-columns:1fr 1fr}
  .mini-cards{flex-direction:column}
}

@media (prefers-reduced-motion:reduce){
  .fade-in,.step-card,.color-card{opacity:1!important;transform:none!important}
}
