/* ============================================================
   Foldica LP — clean rebuild
   Mobile-first (忠実再現) + Desktop (>=1024px) 拡張
   ============================================================ */
:root{
  --cream:#FFF8EB;
  --ink:#2c2a27;      /* 見出し(用途) */
  --charcoal:#545454; /* 見出し(静か) */
  --body:#6E665C;     /* 本文 */
  --tan:#b09d7f;      /* 英字キッカー */
  --terra:#cc4e00;    /* アクセント */
  --terra-deep:#b33f00;
  --dark:#1c1b19;     /* Before/After地 */
  --footer:#262522;
  --sans:'Zen Kaku Gothic New',sans-serif;
  --serif:'DM Serif Display',serif;
  --mincho:'Zen Old Mincho',serif;
  --quick:'Quicksand',sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--cream);color:var(--body);
  font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit}

/* ---------- 固定ヘッダー ---------- */
.hdr{position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;background:rgba(255,248,235,.9);backdrop-filter:blur(8px);
  opacity:0;pointer-events:none;transition:opacity .5s ease}
.hdr.is-visible{opacity:1;pointer-events:auto}
.hdr__logo{font:400 19px/1 var(--serif);color:var(--charcoal);text-decoration:none}
.hdr__cta{font:400 12px/1 var(--sans);color:#fff;background:var(--terra);
  padding:10px 16px;border-radius:3px;text-decoration:none;letter-spacing:.02em}

/* ---------- ヒーロー ---------- */
.hero{position:relative;height:100svh;min-height:600px;overflow:hidden;background:var(--ink)}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 50%;
  filter:grayscale(.7) sepia(.12) brightness(.55) contrast(1.05) blur(1px);
  opacity:0;transition:opacity 1.2s ease}
#hero-video{opacity:1}
.hero__scrim{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.34) 40%,rgba(0,0,0,0) 64%),
             linear-gradient(to bottom,rgba(0,0,0,.45) 0%,rgba(0,0,0,0) 30%)}
.hero__brand{position:absolute;top:30px;left:30px;font:400 20px/1 var(--serif);color:var(--cream)}
.hero__copy{position:absolute;left:30px;right:30px;bottom:96px}
.hero__eyebrow{font:400 .85rem/1.3 var(--sans);letter-spacing:.15em;color:var(--cream);margin-bottom:18px}
.hero__title{margin:0;font:400 52px/1.24 var(--serif);font-size:clamp(42px,12.8vw,52px);color:var(--cream);letter-spacing:.01em}
.hero__gloss{margin-top:22px;font:300 .95rem/1.7 var(--sans);letter-spacing:.1em;color:var(--cream)}
.hero__scroll{position:absolute;left:0;right:0;bottom:34px;display:flex;justify-content:center;animation:fhint 2.4s ease-in-out infinite}
.hero__scroll span{font:400 9px/1.6 var(--quick);letter-spacing:.24em;text-transform:uppercase;color:rgba(255,248,235,.55)}
@keyframes fhint{0%,100%{transform:translateY(0);opacity:.55}50%{transform:translateY(6px);opacity:.9}}

/* ---------- 用途セクション ---------- */
.uc{background:var(--cream);padding:92px 0 0}
.uc__body{padding:0 34px}
.uc__rule{display:block;width:24px;height:2px;background:var(--terra);margin-bottom:18px}
.uc__kicker{font:500 9px/1 var(--quick);letter-spacing:.24em;text-transform:uppercase;color:var(--tan);margin-bottom:16px}
.uc__title{margin:0;font:400 44px/1.22 var(--serif);color:var(--ink)}
.uc__text{margin:18px 0 0;max-width:300px;font:300 13px/2 var(--sans);color:var(--body)}
.uc__text--narrow{max-width:260px}
.uc--noimg{padding-bottom:40px}

.uc__media{margin:36px 0 0;position:relative;width:100%}
.ar-16-9{aspect-ratio:16/9}
.ar-16-10{aspect-ratio:16/10}
.uc__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feather{
  -webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 13%,#000 87%,transparent 100%),linear-gradient(to right,transparent 0,#000 7%,#000 93%,transparent 100%);
  -webkit-mask-composite:source-in;
  mask-image:linear-gradient(to bottom,transparent 0,#000 13%,#000 87%,transparent 100%),linear-gradient(to right,transparent 0,#000 7%,#000 93%,transparent 100%);
  mask-composite:intersect}
/* カフェ クロスフェード */
.xfade{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.xfade--a{animation:xfadeA 8s ease-in-out infinite}
.xfade--b{opacity:0;animation:xfadeB 8s ease-in-out infinite}
@keyframes xfadeA{0%,42%{opacity:1}50%,92%{opacity:0}100%{opacity:1}}
@keyframes xfadeB{0%,42%{opacity:0}50%,92%{opacity:1}100%{opacity:0}}

/* ---------- Before/After ---------- */
.ba{background:var(--dark);display:flex;flex-direction:column;gap:6px;padding:6px 0;overflow:hidden}
.ba__cell{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden}
.ba__cell--before{background:#3a3633}
.ba__cell--after{background:#c2b7a4}
.ba__cell img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba__cell--before img{filter:sepia(.65) saturate(.6) contrast(.88) brightness(1.07) hue-rotate(-6deg)}
.ba__veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.68),rgba(0,0,0,0) 52%)}

/* ---------- CRAFT ---------- */
.craft{background:var(--cream);padding:96px 34px 0}
.craft__title{margin:0;font:400 38px/1.4 var(--mincho);font-size:clamp(30px,8.6vw,38px);color:var(--charcoal)}
.craft__made{display:inline-flex;align-items:center;margin-top:18px;
  font:500 9px/1 var(--quick);letter-spacing:.2em;text-transform:uppercase;color:var(--charcoal)}
.craft__dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--terra);margin-right:9px}
.craft__text{margin:22px 0 0;max-width:320px;font:300 13px/2 var(--sans);color:var(--body)}

/* ---------- 正直な位置づけ ---------- */
.honest{background:var(--cream);padding:72px 34px 0}
.honest__title{margin:0;font:400 22px/1.5 var(--serif);color:var(--charcoal)}
.honest__text{margin:18px 0 0;max-width:320px;font:300 13px/2 var(--sans);color:var(--body)}

/* ---------- CTA ---------- */
.cta{background:var(--cream);padding:96px 34px 90px;text-align:center}
.cta__kicker{font:400 10px/1 var(--quick);letter-spacing:.3em;text-transform:uppercase;color:var(--tan);margin-bottom:26px}
.cta__kicker--left{margin-bottom:20px}
.cta__title{margin:0;font:400 36px/1.4 var(--serif);color:var(--charcoal)}
.cta__lead{margin:24px auto 0;max-width:290px;font:300 13px/2 var(--sans);color:var(--body);text-align:left}
.cta__note{margin-top:16px;font:400 11px/1 var(--quick);letter-spacing:.08em;color:var(--tan)}
.cta__fine{margin:22px auto 0;max-width:300px;font:300 11px/1.8 var(--sans);color:var(--body);text-align:left}

.btn{display:inline-flex;align-items:center;justify-content:center;
  font:400 14px/1 var(--sans);color:#fff;text-decoration:none;letter-spacing:.02em;
  padding:17px 30px;border-radius:3px}
.btn--primary{background:var(--terra);margin-top:34px}
.btn--deep{background:var(--terra-deep);padding:17px 34px}

/* ---------- 価格 ---------- */
.price{background:var(--cream);padding:64px 34px}
.price__title{margin:0;font:400 26px/1.5 var(--serif);color:var(--charcoal)}
.price__lead{margin:16px 0 0;max-width:300px;font:300 13px/2 var(--sans);color:var(--body)}
.price__figure{margin:30px 0 0;padding:22px 0 0;border-top:1px solid rgba(84,84,84,.16)}
.price__label{font:400 10px/1 var(--quick);letter-spacing:.22em;text-transform:uppercase;color:var(--terra);margin-bottom:10px}
.price__amount{font:400 22px/1.4 var(--serif);color:var(--charcoal)}
.price__unit{font:300 14px/1 var(--sans);color:var(--body)}
.price__cols{margin:24px 0 0;display:flex;flex-direction:column;gap:14px;max-width:320px}
.price__k{font:500 11px/1 var(--sans);letter-spacing:.08em;color:var(--charcoal);margin-bottom:6px}
.price__v{font:300 12.5px/1.8 var(--sans);color:var(--body)}
.price__fine{margin:20px 0 0;max-width:320px;font:300 11px/1.9 var(--sans);color:var(--body)}

.cta-band{background:var(--cream);padding:8px 34px 60px;text-align:center}
.cta-band--last{padding-bottom:84px}

/* ---------- FAQ ---------- */
.faq{background:var(--cream);padding:8px 34px 72px}
.faq__item{border-top:1px solid rgba(84,84,84,.16)}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:none;border:none;padding:20px 0;cursor:pointer;text-align:left;font:inherit}
.faq__q>span:first-child{font:400 15px/1.6 var(--sans);color:var(--charcoal)}
.faq__sign{flex:none;font:300 22px/1 var(--serif);color:var(--terra)}
.faq__a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .32s ease}
.faq__item.is-open .faq__a{grid-template-rows:1fr}
.faq__a>p{overflow:hidden;margin:0;max-width:320px;font:300 13px/2 var(--sans);color:var(--body)}
.faq__item.is-open .faq__a>p{padding:0 0 22px}
.faq__fine{margin:26px 0 0;font:300 10.5px/1.8 var(--sans);color:var(--body)}

/* ---------- フッター ---------- */
.ft{background:var(--footer);padding:54px 34px;text-align:center}
.ft__logo{font:400 22px/1 var(--serif);color:var(--cream)}
.ft__tag{margin-top:14px;font:500 8.5px/1 var(--quick);letter-spacing:.28em;text-transform:uppercase;color:rgba(255,248,235,.45)}
.ft__link{display:inline-block;margin-top:22px;font:400 11px/1.6 var(--sans);color:rgba(255,248,235,.6);text-decoration:underline;text-underline-offset:3px}

@media (prefers-reduced-motion:reduce){
  .xfade--a,.xfade--b,.hero__scroll{animation:none}
  .xfade--b{opacity:1}
}

/* ============================================================
   DESKTOP  >=1024px
   ============================================================ */
@media (min-width:1024px){
  .hdr{opacity:1;pointer-events:auto;padding:20px 48px;background:rgba(255,248,235,.86)}
  .hdr__logo{font-size:22px}
  .hdr__cta{font-size:13px;padding:12px 22px}

  /* ヒーロー */
  .hero{height:100vh}
  .hero__brand{top:0;left:0;opacity:0;pointer-events:none} /* ヘッダーにロゴがあるため隠す */
  .hero__copy{left:0;right:0;bottom:12vh;max-width:1280px;margin:0 auto;padding:0 64px}
  .hero__eyebrow{font-size:1.05rem;margin-bottom:24px}
  .hero__title{font-size:104px;line-height:1.16}
  .hero__gloss{font-size:1.25rem;margin-top:30px}

  /* 中央寄せの器 */
  .uc,.craft,.honest,.cta,.price,.faq,.cta-band{
    max-width:1280px;margin-left:auto;margin-right:auto}

  /* 用途 = 2カラム分割（画像↔テキスト左右交互） */
  .uc{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:64px;
    padding:120px 64px}
  .uc__body{padding:0}
  .uc__title{font-size:72px;line-height:1.18}
  .uc__text{font-size:15px;max-width:420px}
  .uc__text--narrow{max-width:420px}
  .uc__media{margin:0}
  /* 既定：テキスト左・画像右 */
  .uc__body{order:1}
  .uc__media{order:2}
  /* 交互（JSが付与）：画像左・テキスト右 */
  .uc--right .uc__media{order:1}
  .uc--right .uc__body{order:2}
  .uc--noimg{display:block;text-align:center;padding:120px 64px 90px}
  .uc--noimg .uc__rule{margin-left:auto;margin-right:auto}
  .uc--noimg .uc__text{margin-left:auto;margin-right:auto}

  /* Before/After = 横並び */
  .ba{flex-direction:row;gap:8px;padding:8px}

  /* CRAFT / 正直 / CTA / 価格 / FAQ = 中央1カラム・可読幅 */
  .craft{padding:140px 64px 0;text-align:center}
  .craft .uc__rule,.craft__made{margin-left:auto;margin-right:auto}
  .craft__title{font-size:56px}
  .craft__text{font-size:15px;max-width:560px;margin-left:auto;margin-right:auto}

  .honest{padding:110px 64px 0;text-align:center}
  .honest__title{font-size:32px}
  .honest__text{font-size:15px;max-width:560px;margin-left:auto;margin-right:auto}

  .cta{padding:140px 64px 120px}
  .cta__title{font-size:56px}
  .cta__lead,.cta__fine{max-width:440px}

  .price{padding:100px 64px;max-width:760px}
  .price__title{font-size:36px}
  .price__cols{flex-direction:row;gap:48px;max-width:none}
  .price__figure,.price__lead,.price__fine{max-width:none}

  .faq{max-width:820px;padding:8px 64px 100px}
  .faq__q>span:first-child{font-size:16px}
  .faq__a>p{max-width:none;font-size:14px}

  .ft{padding:72px 64px}
}

.price__example{margin:10px 0 0;font:300 13.5px/1.8 var(--sans);color:var(--charcoal)}

/* ---------- Custom（仕立て）セクション ---------- */
.custom{background:var(--cream);padding:96px 34px 0}
.custom__title{margin:0;font:400 40px/1.3 var(--serif);color:var(--ink)}
.custom__text{margin:22px 0 0;max-width:330px;font:300 13px/2 var(--sans);color:var(--body)}
.custom__link{display:inline-block;margin-top:20px;font:400 12.5px/1 var(--sans);color:var(--terra);text-decoration:none;border-bottom:1px solid rgba(204,78,0,.4);padding-bottom:4px}
.swatches{display:flex;flex-wrap:wrap;gap:20px 26px;margin:28px 0 0}
.swatch{display:flex;flex-direction:column;align-items:center;gap:9px}
.swatch__chip{width:38px;height:38px;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
.swatch__chip--light{box-shadow:inset 0 0 0 1px rgba(84,84,84,.25)}
.swatch__name{font:400 10px/1 var(--sans);letter-spacing:.06em;color:var(--body)}

/* ---------- Specs ページ ---------- */
.specs-body{background:var(--cream)}
.sp{max-width:760px;margin:0 auto;padding:110px 34px 90px}
.sp__head{margin-bottom:26px}
.sp__title{margin:14px 0 0;font:400 40px/1.3 var(--serif);color:var(--ink)}
.sp__lead{margin:18px 0 0;font:300 13px/2 var(--sans);color:var(--body)}
.sp__sec{margin-top:64px}
.sp__h2{margin:0 0 6px;font:400 24px/1.4 var(--serif);color:var(--charcoal);padding-top:18px;border-top:1px solid rgba(84,84,84,.16)}
.sp__note{margin:8px 0 0;font:300 12px/1.9 var(--sans);color:var(--body)}
.sp__text{margin:12px 0 0;font:300 13px/2 var(--sans);color:var(--body)}
.tile{margin-top:30px;padding:24px 26px;background:rgba(255,255,255,.55);border:1px solid rgba(84,84,84,.1);border-radius:4px}
.tile__name{font:400 21px/1.2 var(--serif);color:var(--ink)}
.tile__name b{font-weight:400;color:var(--terra)}
.tile__yomi{margin-left:10px;font:400 10px/1 var(--quick);letter-spacing:.18em;color:var(--tan)}
.tile__copy{margin:10px 0 0;font:400 14px/1.6 var(--sans);color:var(--charcoal)}
.tile__text{margin:8px 0 0;font:300 12.5px/1.9 var(--sans);color:var(--body)}
.tile__fit{margin:12px 0 0;font:400 11px/1.6 var(--sans);color:var(--tan)}
.sp__table{width:100%;border-collapse:collapse;margin-top:14px}
.sp__table th{width:32%;text-align:left;vertical-align:top;padding:12px 10px 12px 0;font:500 12px/1.8 var(--sans);color:var(--charcoal);border-bottom:1px solid rgba(84,84,84,.12)}
.sp__table td{padding:12px 0;font:300 12.5px/1.8 var(--sans);color:var(--body);border-bottom:1px solid rgba(84,84,84,.12)}
.sp__fine{font:300 11px/1.9 var(--sans);color:var(--body)}
.sp__cta{margin-top:26px}
.sp__sec--last{margin-top:70px}
@media (min-width:1024px){
  .custom{max-width:1280px;margin:0 auto;padding:130px 64px 0;text-align:center}
  .custom .uc__rule,.custom .swatches{margin-left:auto;margin-right:auto}
  .custom .swatches{justify-content:center}
  .custom__title{font-size:56px}
  .custom__text{max-width:560px;margin-left:auto;margin-right:auto;font-size:15px}
  .sp{padding:150px 64px 110px}
  .sp__title{font-size:52px}
}
@media print{
  .hdr,.sp__cta,.ft__link{display:none!important}
  .specs-body{background:#fff}
  .sp{padding:20px 0}
  .tile{break-inside:avoid}
}
