/* ============================================================
   채운(彩運) — fake-door · 한지 에디토리얼
   ============================================================ */

/* ---- fonts ---- */
@font-face{font-family:'Pretendard';font-weight:400;font-display:swap;
  src:url('../fonts/Pretendard-Regular.woff2') format('woff2');}
@font-face{font-family:'Pretendard';font-weight:500;font-display:swap;
  src:url('../fonts/Pretendard-Medium.woff2') format('woff2');}
@font-face{font-family:'Pretendard';font-weight:600;font-display:swap;
  src:url('../fonts/Pretendard-SemiBold.woff2') format('woff2');}
@font-face{font-family:'Gowun Batang';font-weight:400;font-display:swap;
  src:url('../fonts/GowunBatang-Regular.woff2') format('woff2');}
@font-face{font-family:'Gowun Batang';font-weight:700;font-display:swap;
  src:url('../fonts/GowunBatang-Bold.woff2') format('woff2');}

/* ---- tokens ---- */
:root{
  --paper:#f1ebdd;
  --paper-raise:#f7f2e6;
  --paper-deep:#e9e1cf;
  --ink:#262019;
  --ink-soft:#5d544734;
  --ink-mid:#6c6253;
  --ink-faint:#9c9279;
  --hair:#cdc2a8;
  --hair-soft:#dcd3bd;

  --wood:#4d6a55;   /* 木 */
  --fire:#ab4a31;   /* 火 */
  --earth:#bb8a2c;  /* 土 */
  --metal:#b6ab8e;  /* 金 */
  --water:#33506e;  /* 水 */

  --accent:#33506e;
  --serif:'Gowun Batang',serif;
  --sans:'Pretendard',-apple-system,sans-serif;

  --wrap:680px;
  --gutter:24px;
  --ease:cubic-bezier(.2,.7,.2,1);
}
html[data-line="budget"]{
  --paper:#f3efe6;
  --paper-raise:#faf6ed;
  --paper-deep:#ebe5d6;
  --accent:#ab4a31;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.85;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* paper grain */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.32'/%3E%3C/svg%3E");
}
img{display:block;max-width:100%;height:auto}
a{color:inherit}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}

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

/* ---- scroll progress (五色) ---- */
.cw-progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:60;
  background:linear-gradient(90deg,var(--wood),var(--fire),var(--earth),var(--metal),var(--water));
  transition:width .12s linear}

/* ---- nav ---- */
.cw-nav{position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:15px var(--gutter);
  background:color-mix(in srgb,var(--paper) 86%,transparent);
  backdrop-filter:blur(9px);
  border-bottom:1px solid transparent;transition:border-color .3s}
.cw-nav.is-scrolled{border-bottom-color:var(--hair-soft)}
.cw-brand{font-family:var(--serif);font-size:20px;letter-spacing:.04em;font-weight:700}
.cw-brand .hanja{color:var(--accent)}
.cw-nav-cta{font-size:13px;font-weight:600;letter-spacing:.02em;
  padding:8px 16px;border:1px solid var(--ink);border-radius:999px;
  transition:background .25s,color .25s}
.cw-nav-cta:hover{background:var(--ink);color:var(--paper-raise)}

/* ---- layout ---- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gutter)}
.wrap-wide{max-width:1080px;margin:0 auto;padding:0 var(--gutter)}
section{padding:88px 0}

.eyebrow{display:flex;align-items:center;gap:9px;
  font-size:12px;font-weight:600;letter-spacing:.16em;
  color:var(--ink-mid);text-transform:uppercase;margin-bottom:22px}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;
  background:var(--accent);flex:0 0 auto}
.eyebrow .ko{text-transform:none;letter-spacing:.04em;font-size:13px}

h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.26;
  letter-spacing:-.018em;word-break:keep-all}
h2{font-size:clamp(1.62rem,5.4vw,2.32rem);margin-bottom:20px;line-height:1.24}
h3{font-size:1.16rem;line-height:1.5}
.lead{font-size:1.04rem;color:var(--ink);line-height:1.92}
p+p{margin-top:1.05em}
.muted{color:var(--ink-mid)}
.hanja{font-family:var(--serif)}

/* ---- hero ---- */
.hero{padding:120px 0 70px;text-align:center;overflow:hidden}
.hero-mark{font-family:var(--serif);font-size:15px;letter-spacing:.42em;
  color:var(--accent);margin-bottom:30px;padding-left:.42em}
.hero h1{font-size:clamp(2.4rem,9.4vw,4.05rem);line-height:1.14;
  letter-spacing:-.026em;margin-bottom:24px}
.hero h1 .br{display:block}
.hero-sub{max-width:430px;margin:0 auto 38px;color:var(--ink-mid);
  font-size:1.03rem;line-height:1.9}
.hero-figure{position:relative;margin:8px auto 0;max-width:540px}
.hero-figure img{width:100%;border-radius:3px;
  box-shadow:0 30px 60px -32px rgba(38,32,25,.5)}
.hero-figure .corner{position:absolute;width:26px;height:26px;
  border:1px solid var(--hair)}
.hero-figure .c-tl{top:-11px;left:-11px;border-right:0;border-bottom:0}
.hero-figure .c-br{bottom:-11px;right:-11px;border-left:0;border-top:0}

/* price line */
.priceline{display:inline-flex;flex-direction:column;align-items:center;
  gap:7px;margin-bottom:34px}
.priceline .amt{font-family:var(--serif);font-size:1.6rem;font-weight:700;
  letter-spacing:.01em}
.priceline .amt small{font-size:.96rem;font-weight:400;color:var(--ink-mid);
  margin-left:3px}
.priceline .note{font-size:12.5px;color:var(--ink-faint);letter-spacing:.01em}
.priceline .edition{font-size:11.5px;font-weight:600;letter-spacing:.13em;
  text-transform:uppercase;color:var(--accent)}

/* ---- CTA ---- */
.cta{display:inline-flex;align-items:center;gap:10px;
  font-size:15.5px;font-weight:600;letter-spacing:.01em;
  padding:16px 30px;border-radius:999px;
  background:var(--ink);color:var(--paper-raise);
  transition:transform .25s var(--ease),box-shadow .25s;
  box-shadow:0 10px 26px -14px rgba(38,32,25,.7)}
.cta:hover{transform:translateY(-2px);box-shadow:0 16px 32px -14px rgba(38,32,25,.7)}
.cta:active{transform:translateY(0)}
.cta .arr{transition:transform .25s var(--ease)}
.cta:hover .arr{transform:translateX(4px)}
.cta-ghost{background:transparent;color:var(--ink);
  border:1px solid var(--ink);box-shadow:none}
.cta-ghost:hover{background:var(--ink);color:var(--paper-raise)}

/* ---- philosophy ---- */
.philo{text-align:center}
.philo .big{font-family:var(--serif);font-weight:700;
  font-size:clamp(1.5rem,5.6vw,2.1rem);line-height:1.5;margin-bottom:26px}
.philo .big em{font-style:normal;color:var(--accent)}
.philo p{max-width:520px;margin-left:auto;margin-right:auto;color:var(--ink-mid)}
.divider{width:1px;height:54px;background:var(--hair);margin:0 auto}

/* ---- five colors ---- */
.colors{background:var(--paper-deep)}
.colors .five-fig{margin:30px 0 8px;border-radius:3px;overflow:hidden;
  box-shadow:0 20px 44px -30px rgba(38,32,25,.55)}
.color-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;
  margin-top:28px}
.color-cell{text-align:center}
.color-dot{display:block;width:34px;height:34px;border-radius:50%;margin:0 auto 10px;
  box-shadow:inset 0 0 0 1px rgba(38,32,25,.12)}
.color-cell .cj{font-family:var(--serif);font-size:1.18rem;font-weight:700;
  display:block;line-height:1}
.color-cell .cn{font-size:11.5px;color:var(--ink-mid);margin-top:5px;
  letter-spacing:.02em}
.d-wood{background:var(--wood)}.d-fire{background:var(--fire)}
.d-earth{background:var(--earth)}.d-metal{background:var(--metal)}
.d-water{background:var(--water)}

/* ---- craft / spec ---- */
.craft-fig{border-radius:3px;overflow:hidden;margin-bottom:34px;
  box-shadow:0 22px 46px -30px rgba(38,32,25,.55)}
.spec{border-top:1px solid var(--hair)}
.spec-row{display:grid;grid-template-columns:104px 1fr;gap:18px;
  padding:17px 0;border-bottom:1px solid var(--hair-soft)}
.spec-row dt{font-size:12px;font-weight:600;letter-spacing:.1em;
  color:var(--ink-mid);text-transform:uppercase;padding-top:2px}
.spec-row dd{font-size:15px;line-height:1.7}
.spec-row dd .sub{display:block;font-size:13px;color:var(--ink-faint);
  margin-top:2px}

/* ---- ritual ---- */
.ritual-grid{display:grid;grid-template-columns:1fr;gap:34px;align-items:center}
.ritual-fig{border-radius:3px;overflow:hidden;
  box-shadow:0 24px 50px -32px rgba(38,32,25,.6)}
.moment{padding:16px 0;border-bottom:1px solid var(--hair-soft)}
.moment:last-child{border-bottom:0}
.moment .mt{font-family:var(--serif);font-weight:700;font-size:1.04rem;
  display:flex;align-items:baseline;gap:10px}
.moment .mt .idx{font-size:12px;color:var(--accent);font-weight:600}
.moment p{font-size:14.5px;color:var(--ink-mid);margin-top:5px}

/* ---- offering ---- */
.offering{background:var(--paper-deep);text-align:center}
.incl{display:flex;flex-direction:column;gap:1px;margin:30px 0 8px;
  border:1px solid var(--hair);border-radius:4px;overflow:hidden;text-align:left}
.incl-item{display:flex;gap:14px;padding:16px 18px;background:var(--paper-raise)}
.incl-item .ic{font-family:var(--serif);color:var(--accent);font-weight:700;
  font-size:14px;flex:0 0 auto}
.incl-item .it{font-size:14.5px}
.incl-item .it b{font-weight:600}
.incl-item .it span{display:block;color:var(--ink-faint);font-size:13px}
.offer-price{margin:34px 0 26px}

/* ---- maker note ---- */
.maker{background:var(--ink);color:var(--paper)}
.maker .eyebrow{color:#b8ad95}
.maker .eyebrow::before{background:var(--metal)}
.maker h2{color:var(--paper-raise)}
.maker-fig{border-radius:3px;overflow:hidden;margin-bottom:30px;
  filter:saturate(.92)}
.maker p{color:#c9bea6}
.maker .sign{font-family:var(--serif);font-style:italic;
  color:var(--metal);margin-top:24px;font-size:15px}

/* ---- faq ---- */
.faq details{border-bottom:1px solid var(--hair-soft)}
.faq details:first-of-type{border-top:1px solid var(--hair)}
.faq summary{list-style:none;cursor:pointer;padding:19px 30px 19px 0;
  position:relative;font-weight:600;font-size:15px;line-height:1.55}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";position:absolute;right:4px;top:24px;
  width:9px;height:9px;border-right:1.5px solid var(--ink-mid);
  border-bottom:1.5px solid var(--ink-mid);transform:rotate(45deg);
  transition:transform .3s var(--ease)}
.faq details[open] summary::after{transform:rotate(-135deg)}
.faq .ans{padding:0 30px 22px 0;font-size:14.5px;color:var(--ink-mid);
  line-height:1.82}

/* ---- footer ---- */
.cw-footer{background:var(--paper-deep);padding:60px 0 44px;
  border-top:1px solid var(--hair)}
.foot-mark{font-family:var(--serif);font-size:17px;font-weight:700;
  letter-spacing:.04em;margin-bottom:8px}
.foot-mark .hanja{color:var(--accent)}
.foot-line{font-size:13px;color:var(--ink-mid);margin-bottom:26px}
.cross-line{display:inline-flex;align-items:center;gap:8px;
  font-size:13.5px;font-weight:600;padding:11px 18px;
  border:1px solid var(--hair);border-radius:999px;
  transition:border-color .25s,background .25s}
.cross-line:hover{border-color:var(--ink);background:var(--paper-raise)}
.biz{margin-top:30px;font-size:11.5px;color:var(--ink-faint);
  line-height:1.95;letter-spacing:.01em}
.biz span{white-space:nowrap}

/* ---- sticky CTA ---- */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:45;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:12px 16px;background:color-mix(in srgb,var(--paper-raise) 95%,transparent);
  backdrop-filter:blur(10px);border-top:1px solid var(--hair);
  transform:translateY(110%);transition:transform .4s var(--ease)}
.sticky-cta.is-on{transform:translateY(0)}
.sticky-cta .sp{display:flex;flex-direction:column;line-height:1.3}
.sticky-cta .sp .a{font-family:var(--serif);font-weight:700;font-size:1.04rem}
.sticky-cta .sp .b{font-size:11px;color:var(--ink-faint);letter-spacing:.04em}
.sticky-cta .cta{padding:13px 22px;font-size:14px}

/* ============================================================
   의향 서랍 (intent drawer)
   ============================================================ */
.drawer-scrim{position:fixed;inset:0;z-index:70;
  background:rgba(30,25,19,.46);backdrop-filter:blur(2px);
  opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s}
.drawer-scrim.is-open{opacity:1;visibility:visible}

.drawer{position:fixed;left:0;right:0;bottom:0;z-index:71;
  background:var(--paper-raise);
  border-radius:18px 18px 0 0;
  box-shadow:0 -22px 50px -20px rgba(30,25,19,.5);
  transform:translateY(102%);transition:transform .42s var(--ease);
  max-height:92vh;overflow-y:auto;
  padding:10px var(--gutter) calc(34px + env(safe-area-inset-bottom))}
.drawer.is-open{transform:translateY(0)}
.drawer-inner{max-width:460px;margin:0 auto}
.drawer-handle{width:42px;height:4px;border-radius:999px;
  background:var(--hair);margin:0 auto 22px}
.drawer-close{position:absolute;top:14px;right:14px;
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:19px;color:var(--ink-mid);
  background:var(--paper-deep);transition:background .2s}
.drawer-close:hover{background:var(--hair-soft)}

.drawer-panel{display:none;animation:panelin .42s var(--ease)}
.drawer-panel.is-active{display:block}
@keyframes panelin{from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}}

.drawer-mark{font-family:var(--serif);font-size:13px;letter-spacing:.34em;
  color:var(--accent);text-align:center;margin-bottom:18px;padding-left:.34em}
.drawer h3{font-size:1.34rem;line-height:1.32;margin-bottom:14px;
  text-align:center}
.drawer .d-body{font-size:14.5px;color:var(--ink-mid);line-height:1.85;
  text-align:center;margin-bottom:24px}

/* price chips */
.chips{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.chip{display:flex;align-items:center;gap:13px;width:100%;text-align:left;
  padding:15px 17px;border:1px solid var(--hair);border-radius:12px;
  background:var(--paper);font-size:14.5px;font-weight:500;line-height:1.5;
  transition:border-color .2s,background .2s,transform .12s}
.chip:hover{border-color:var(--accent);background:var(--paper-raise)}
.chip:active{transform:scale(.99)}
.chip .mk{width:22px;height:22px;border-radius:50%;flex:0 0 auto;
  border:1px solid var(--hair);display:flex;align-items:center;
  justify-content:center;font-size:12px;color:var(--accent)}
.chip .mk::after{content:"";width:8px;height:8px;border-radius:50%;
  background:var(--accent);opacity:0;transition:opacity .15s}
.chip.is-pick{border-color:var(--accent);background:var(--paper-raise)}
.chip.is-pick .mk::after{opacity:1}
.skip-link{display:block;width:100%;text-align:center;font-size:13px;
  color:var(--ink-faint);text-decoration:underline;text-underline-offset:3px;
  padding:8px}

/* email form */
.d-field{margin-bottom:14px}
.d-field input{width:100%;font-family:inherit;font-size:15px;
  padding:15px 16px;border:1px solid var(--hair);border-radius:11px;
  background:var(--paper);color:var(--ink)}
.d-field input:focus{outline:none;border-color:var(--accent)}
.d-field input::placeholder{color:var(--ink-faint)}
.d-consent{display:flex;gap:9px;align-items:flex-start;
  font-size:12.5px;color:var(--ink-mid);line-height:1.65;margin-bottom:18px}
.d-consent input{width:16px;height:16px;flex:0 0 auto;margin-top:2px;
  accent-color:var(--accent)}
.d-submit{width:100%;justify-content:center}
.d-reassure{font-size:12.5px;color:var(--ink-faint);text-align:center;
  line-height:1.7;margin-top:14px}
.d-err{font-size:12.5px;color:var(--fire);text-align:center;
  margin-top:8px;min-height:1.2em}

/* thanks */
.d-thanks{text-align:center;padding:12px 0 6px}
.d-thanks .seal{font-family:var(--serif);font-size:2.4rem;color:var(--accent);
  margin-bottom:12px}
.d-thanks h3{margin-bottom:10px}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);
  transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.is-in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ---- desktop ---- */
@media(min-width:760px){
  body{font-size:17px}
  section{padding:120px 0}
  .hero{padding:160px 0 96px}
  .ritual-grid{grid-template-columns:1fr 1fr;gap:48px}
  .color-dot{width:44px;height:44px}
  .drawer{border-radius:20px;left:50%;right:auto;
    transform:translate(-50%,102%);width:520px;
    bottom:0;max-height:90vh}
  .drawer.is-open{transform:translate(-50%,0)}
  .sticky-cta{padding:14px 28px}
  .sticky-cta .cta{font-size:14.5px}
  .incl{flex-direction:row;flex-wrap:wrap}
  .incl-item{flex:1 1 46%}
}
