/* =============================================================
   SNOW WORKSHOP / COMMON STYLESHEET
   Built from design-system.html (Atomic Design tokens & components)
   ============================================================= */

:root {
  /* Surface (Blizzard) */
  --surface-base:    #F4F7FA;
  --surface-card:    #FFFFFF;
  --surface-mist:    #E9EFF5;
  --surface-stone:   #D6DEE7;
  --surface-ink:     #1B2838;

  /* Ink (Warm Blue) */
  --ink-primary:     #1B2838;
  --ink-soft:        #4A5A6E;
  --ink-muted:       #8995A4;

  /* Neutral */
  --alu-light:       #BFC8D2;
  --alu-mid:         #94A0AD;
  --alu-shade:       #5A6473;

  /* Hairline */
  --line-strong:     #1B2838;
  --line-medium:     #B6BFC8;
  --line-hair:       #E0E6EC;

  /* Wood Brown (Accent) */
  --ember:           #B8431E;
  --ember-deep:      #8E331A;
  --ember-tint:      #FBEFE9;

  /* Type */
  --serif-jp:  'Noto Serif JP', 'Yu Mincho', serif;
  --sans-jp:   'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;
  --latin:     'Inter', sans-serif;

  /* Spacing */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px; --s-5: 24px;
  --s-6: 32px; --s-7: 48px; --s-8: 64px; --s-9: 96px; --s-10: 128px;

  --container: 1240px;
  --gutter: 40px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans-jp);
  background: var(--surface-base);
  color: var(--ink-primary);
  font-size: 15px;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }

.wrap { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.wrap--narrow { max-width: 880px; }

/* =============================================================
   ATOMS
   ============================================================= */

/* Button */
.btn {
  font-family: var(--sans-jp);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 14px 26px;
  border: 1px solid var(--line-strong);
  background: var(--ink-primary);
  color: var(--surface-card);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
  cursor: pointer;
}
.btn:hover { background: var(--ember); border-color: var(--ember); }
.btn--primary { background: var(--ember); border-color: var(--ember); color: #fff; }
.btn--primary:hover { background: var(--ember-deep); border-color: var(--ember-deep); }
.btn--ghost { background: transparent; color: var(--ink-primary); border-color: var(--line-strong); }
.btn--ghost:hover { background: var(--ink-primary); color: var(--surface-card); }
.btn--small { padding: 9px 16px; font-size: 12px; }
.btn .arrow { font-family: var(--latin); font-weight: 400; }

/* Tag */
.tag {
  font-family: var(--sans-jp);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  padding: 4px 10px;
  border: 1px solid var(--line-strong);
  display: inline-block;
  background: var(--surface-card);
}
.tag--tech { background: var(--ink-primary); color: var(--surface-card); border-color: var(--ink-primary); }
.tag--case { background: var(--ember); color: #fff; border-color: var(--ember); }
.tag--info { background: var(--surface-card); color: var(--ink-primary); }
.tag--alloy { background: var(--ember-tint); color: var(--ember-deep); border-color: var(--ember); }
.tag--soft { background: var(--surface-mist); color: var(--ink-soft); border-color: var(--line-hair); }

/* Input atoms */
.input, .textarea, .select {
  font-family: var(--sans-jp);
  font-size: 14px;
  background: var(--surface-card);
  border: 1px solid var(--line-medium);
  padding: 12px 14px;
  width: 100%;
  color: var(--ink-primary);
  transition: border-color 0.2s ease;
}
.input:focus, .textarea:focus, .select:focus {
  outline: none;
  border-color: var(--ember);
}
.textarea { min-height: 120px; resize: vertical; line-height: 1.7; }
.select {
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--ink-primary) 50%), linear-gradient(135deg, var(--ink-primary) 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 36px;
}

.checkbox-wrap, .radio-wrap { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; font-size: 13px; }
.checkbox, .radio {
  appearance: none;
  width: 18px;
  height: 18px;
  border: 1px solid var(--line-medium);
  background: var(--surface-card);
  cursor: pointer;
  position: relative;
  flex: none;
}
.radio { border-radius: 50%; }
.checkbox:checked { background: var(--ember); border-color: var(--ember); }
.checkbox:checked::after { content: ""; position: absolute; top: 2px; left: 6px; width: 4px; height: 9px; border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg); }
.radio:checked { border-color: var(--ember); }
.radio:checked::after { content: ""; position: absolute; top: 4px; left: 4px; width: 8px; height: 8px; border-radius: 50%; background: var(--ember); }

/* Link */
.link {
  font-family: var(--sans-jp);
  font-size: 14px;
  color: var(--ink-primary);
  text-decoration: none;
  border-bottom: 1px solid var(--ink-primary);
  padding-bottom: 1px;
  transition: color 0.2s ease, border-color 0.2s ease;
}
.link:hover { color: var(--ember); border-color: var(--ember); }
.link--latin { font-family: var(--latin); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ember); border-bottom-color: var(--ember); }

/* Dividers */
.div-hair { width: 100%; height: 1px; background: var(--line-hair); }
.div-medium { width: 100%; height: 1px; background: var(--line-medium); }
.div-strong { width: 100%; height: 1px; background: var(--line-strong); }
.div-ember { width: 28px; height: 4px; background: var(--ember); }

/* Icon */
.ico { width: 22px; height: 22px; stroke: var(--ink-primary); fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.ico--ember { stroke: var(--ember); }
.ico--white { stroke: #fff; }

/* Form label */
.lbl-form {
  font-family: var(--sans-jp);
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-primary);
  letter-spacing: 0.04em;
  display: block;
  margin-bottom: 6px;
}
.lbl-form .req { color: var(--ember); margin-left: 4px; font-size: 11px; }
.lbl-helper { font-size: 11px; color: var(--ink-muted); margin-top: 6px; line-height: 1.6; }

/* =============================================================
   MOLECULES
   ============================================================= */

/* Logo */
.mol-logo { display: inline-flex; align-items: center; text-decoration: none; }
.mol-logo__image { display: block; height: 48px; width: auto; }
.mol-logo--sm .mol-logo__image { height: 36px; }
.mol-logo--lg .mol-logo__image { height: 72px; }

/* Section head */
.mol-secthead {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--s-6);
  align-items: end;
  max-width: 1080px;
  margin-bottom: var(--s-6);
}
.mol-secthead__num {
  font-family: var(--latin);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--ember);
  font-weight: 600;
  text-transform: uppercase;
}
.mol-secthead__num::before { content: "— "; }
.mol-secthead__title {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 36px;
  line-height: 1.3;
}
.mol-secthead__title small {
  display: block;
  font-family: var(--latin);
  font-size: 13px;
  font-weight: 400;
  color: var(--ink-muted);
  margin-top: 8px;
  letter-spacing: 0.06em;
}

/* Nav item */
.mol-navitem {
  font-family: var(--sans-jp);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-primary);
  text-decoration: none;
  letter-spacing: 0.06em;
  padding-bottom: 6px;
  position: relative;
}
.mol-navitem:hover { color: var(--ember); }
.mol-navitem.is-active::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 2px; background: var(--ember); }

/* News row */
.mol-newsrow {
  display: grid;
  grid-template-columns: 130px 100px 1fr 60px;
  gap: var(--s-5);
  padding: 22px 8px;
  border-bottom: 1px solid var(--line-hair);
  align-items: center;
  cursor: pointer;
  transition: background 0.2s ease;
  text-decoration: none;
  color: inherit;
}
.mol-newsrow:hover { background: var(--surface-mist); }
.mol-newsrow__date { font-family: var(--latin); font-size: 13px; color: var(--ink-soft); }
.mol-newsrow__title { font-family: var(--sans-jp); font-size: 14.5px; font-weight: 500; color: var(--ink-primary); }
.mol-newsrow__arrow { font-family: var(--latin); text-align: right; color: var(--ink-muted); font-size: 13px; }

/* Stat */
.mol-stat { display: flex; flex-direction: column; gap: 4px; padding: var(--s-4) var(--s-5); }
.mol-stat__label { font-family: var(--latin); font-size: 10px; letter-spacing: 0.18em; color: var(--ink-muted); text-transform: uppercase; }
.mol-stat__value { font-family: var(--serif-jp); font-weight: 700; font-size: 38px; line-height: 1; letter-spacing: -0.01em; }
.mol-stat__value sup { font-size: 13px; font-weight: 400; color: var(--ink-muted); margin-left: 4px; vertical-align: bottom; }
.mol-stat__hint { font-size: 11px; color: var(--ink-soft); margin-top: 4px; }

/* Pillar */
.mol-pillar { padding: var(--s-6) var(--s-5); }
.mol-pillar__no { font-family: var(--latin); font-size: 11px; letter-spacing: 0.18em; color: var(--ember); font-weight: 500; margin-bottom: var(--s-4); }
.mol-pillar__name { font-family: var(--serif-jp); font-weight: 700; font-size: 22px; line-height: 1.4; margin-bottom: var(--s-3); }
.mol-pillar__desc { font-size: 13.5px; line-height: 1.9; color: var(--ink-soft); }

/* Spec list */
.mol-speclist {
  border-top: 1px solid var(--line-hair);
  padding-top: 12px;
  margin-top: var(--s-3);
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 6px 12px;
  font-size: 12px;
}
.mol-speclist dt { color: var(--ink-muted); }
.mol-speclist dd { color: var(--ink-primary); font-weight: 500; }

/* Form field */
.mol-formfield { margin-bottom: var(--s-5); }
.mol-formfield.full { grid-column: 1 / -1; }

/* Breadcrumb */
.mol-breadcrumb { display: flex; gap: 6px; font-family: var(--latin); font-size: 12px; color: var(--ink-muted); align-items: center; flex-wrap: wrap; }
.mol-breadcrumb a { color: var(--ink-muted); text-decoration: none; }
.mol-breadcrumb a:hover { color: var(--ember); }
.mol-breadcrumb__sep { color: var(--line-medium); }
.mol-breadcrumb__current { color: var(--ink-primary); }

/* Kicker */
.mol-kicker {
  font-family: var(--latin);
  font-size: 12px;
  letter-spacing: 0.22em;
  color: var(--ember);
  text-transform: uppercase;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
}
.mol-kicker::before { content: ""; display: inline-block; width: 28px; height: 1px; background: var(--ember); margin-right: 14px; }
.mol-kicker--white { color: #fff; }
.mol-kicker--white::before { background: #fff; opacity: 0.7; }

/* Eyebrow (category/page label, placed ABOVE title) */
.mol-eyebrow {
  font-family: var(--latin);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--ember);
  font-weight: 600;
  text-transform: uppercase;
  display: block;
  margin-bottom: var(--s-3);
}

/* =============================================================
   ORGANISMS
   ============================================================= */

/* Site header */
.org-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 28px;
  background: var(--surface-card);
  border-bottom: 1px solid var(--line-hair);
  position: sticky;
  top: 0;
  z-index: 50;
}
.org-header__nav { display: flex; gap: 28px; align-items: center; list-style: none; flex-wrap: wrap; }
.org-header__nav li { display: flex; align-items: center; }
.org-header__menu-toggle { display: none; }

/* Hero */
.org-hero {
  min-height: 460px;
  background: var(--surface-ink);
  position: relative;
  overflow: hidden;
}
.org-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.org-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.org-hero__photo {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(105deg, rgba(19,19,19,0.72) 0%, rgba(19,19,19,0.4) 60%, rgba(19,19,19,0.15) 100%);
}
.org-hero__photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 78% 52%, rgba(184,67,30,0.22) 0%, transparent 45%);
  mix-blend-mode: screen;
}
.org-hero__inner {
  position: relative;
  z-index: 2;
  padding: 60px;
  min-height: 460px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: #fff;
}
.org-hero__title { font-family: var(--serif-jp); font-weight: 700; font-size: clamp(34px, 4vw, 52px); line-height: 1.25; margin: 18px 0 18px; max-width: 720px; }
.org-hero__sub { font-size: 14px; line-height: 1.9; max-width: 540px; color: rgba(255,255,255,0.85); }
.org-hero__plans {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: var(--s-7);
  border-top: 1px solid rgba(255,255,255,0.2);
}
.org-hero__plan {
  padding: 18px 22px;
  border-right: 1px solid rgba(255,255,255,0.15);
  color: #fff;
  text-decoration: none;
  transition: background 0.2s ease;
}
.org-hero__plan:last-child { border-right: none; }
.org-hero__plan:hover { background: rgba(255,255,255,0.06); }
.org-hero__plan-no { font-family: var(--latin); font-size: 10px; letter-spacing: 0.2em; color: var(--ember); font-weight: 600; text-transform: uppercase; }
.org-hero__plan-en { font-family: var(--serif-jp); font-weight: 700; font-size: 18px; margin: 6px 0 4px; }
.org-hero__plan-jp { font-size: 12px; color: rgba(255,255,255,0.75); line-height: 1.6; }

/* Stats row */
.org-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line-strong);
  background: var(--surface-card);
}
.org-stats > .mol-stat { border-right: 1px solid var(--line-hair); }
.org-stats > .mol-stat:last-child { border-right: none; }

/* Pillars 3-up */
.org-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--line-medium); border-bottom: 1px solid var(--line-medium); background: var(--surface-card); }
.org-pillars > .mol-pillar { border-right: 1px solid var(--line-hair); }
.org-pillars > .mol-pillar:last-child { border-right: none; }

/* Product grid */
.org-products { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-4); }
.org-products--two { grid-template-columns: repeat(2, 1fr); }
.org-card { background: var(--surface-card); border: 1px solid var(--line-hair); overflow: hidden; transition: border-color 0.25s ease, transform 0.25s ease; display: flex; flex-direction: column; }
.org-card:hover { border-color: var(--ink-primary); transform: translateY(-2px); }
.org-card__img {
  aspect-ratio: 4/3;
  background: radial-gradient(circle at 30% 30%, var(--alu-light), var(--alu-mid));
  display: flex;
  align-items: flex-end;
  padding: 14px;
  color: rgba(255,255,255,0.85);
  font-family: var(--latin);
  font-size: 11px;
  letter-spacing: 0.16em;
}
.org-card__img--accent { background: radial-gradient(circle at 30% 30%, #d8b58a 0%, #a26a3d 50%, #6b4628 100%); }
.org-card__img--alu { background: linear-gradient(135deg, #d6dde6 0%, #94a0ad 50%, #5a6473 100%); }
.org-card__img--shadow { background: linear-gradient(180deg, #1b2838 0%, #2d3d52 60%, #0e1722 100%); }
.org-card__body { padding: 22px 22px 24px; flex: 1; display: flex; flex-direction: column; }
.org-card__cat { font-family: var(--latin); font-size: 11px; letter-spacing: 0.14em; color: var(--ember); font-weight: 500; margin-bottom: 8px; text-transform: uppercase; }
.org-card__title { font-family: var(--serif-jp); font-weight: 700; font-size: 18px; line-height: 1.5; margin-bottom: 10px; }
.org-card__lead { font-size: 13px; color: var(--ink-soft); line-height: 1.85; margin-bottom: 16px; }
.org-card__meta { font-family: var(--latin); font-size: 11px; color: var(--ink-muted); letter-spacing: 0.06em; margin-bottom: 12px; }

/* Approach dark section */
.org-dx {
  background-color: var(--surface-ink);
  background-image: linear-gradient(rgba(27,40,56,0.86), rgba(27,40,56,0.92)), url('images/why-zero-yen.webp');
  background-size: cover;
  background-position: center;
  color: #fff;
  padding: var(--s-9) 0;
}
.org-dx__inner {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: var(--s-7);
  align-items: center;
}
.org-dx__title { font-family: var(--serif-jp); font-weight: 700; font-size: 36px; line-height: 1.3; margin: 14px 0 8px; }
.org-dx__title small { display: block; font-family: var(--latin); font-size: 12px; font-weight: 400; color: var(--alu-light); margin-top: 8px; letter-spacing: 0.06em; }
.org-dx__lead { font-size: 14px; line-height: 2; color: var(--alu-light); margin-bottom: var(--s-5); }
.org-dx__lead strong { color: #fff; }
.org-dx-stack { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.1); }
.org-dx-stack__item { background: var(--surface-ink); padding: 22px 18px; }
.org-dx-stack__item .label { font-family: var(--latin); font-size: 9px; letter-spacing: 0.2em; color: var(--ember); margin-bottom: 8px; text-transform: uppercase; font-weight: 600; }
.org-dx-stack__item .name { font-family: var(--serif-jp); font-weight: 700; font-size: 15px; color: #fff; margin-bottom: 6px; }
.org-dx-stack__item .desc { font-size: 11px; color: var(--alu-light); line-height: 1.7; }

/* CTA */
.org-cta { padding: var(--s-9) var(--s-7); background: var(--surface-mist); text-align: center; }
.org-cta__title { font-family: var(--serif-jp); font-weight: 700; font-size: 34px; line-height: 1.35; margin: 14px 0 var(--s-4); }
.org-cta__lead { font-size: 14px; line-height: 1.95; color: var(--ink-soft); max-width: 520px; margin: 0 auto var(--s-6); }
.org-cta__buttons { display: flex; gap: var(--s-3); justify-content: center; flex-wrap: wrap; }
.org-cta .mol-kicker { justify-content: center; }

/* Footer */
.org-footer { background: var(--surface-ink); color: #fff; padding: var(--s-8) var(--s-6) var(--s-5); margin-top: var(--s-9); }
.org-footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--s-7); padding-bottom: var(--s-6); border-bottom: 1px solid rgba(255,255,255,0.1); max-width: var(--container); margin: 0 auto; }
.org-footer h5 { font-family: var(--latin); font-size: 11px; font-weight: 600; letter-spacing: 0.18em; color: var(--ember); text-transform: uppercase; margin-bottom: var(--s-4); }
.org-footer__brand { font-family: var(--serif-jp); font-weight: 700; font-size: 18px; margin-bottom: 8px; }
.org-footer__addr { font-size: 12px; color: var(--alu-light); line-height: 1.85; }
.org-footer__list { list-style: none; }
.org-footer__list li { margin-bottom: 8px; }
.org-footer__list a { color: var(--alu-light); text-decoration: none; font-size: 13px; }
.org-footer__list a:hover { color: #fff; }
.org-footer__bottom { margin-top: var(--s-5); display: flex; justify-content: space-between; font-family: var(--latin); font-size: 11px; color: var(--alu-mid); letter-spacing: 0.08em; max-width: var(--container); margin-left: auto; margin-right: auto; padding-top: var(--s-3); flex-wrap: wrap; gap: 12px; }
.org-footer__copy { font-size: 12px; color: var(--alu-light); margin-top: var(--s-5); padding-top: var(--s-4); border-top: 1px solid rgba(255,255,255,0.08); max-width: var(--container); margin-left: auto; margin-right: auto; text-align: center; line-height: 1.8; }

/* Page head — order: breadcrumb → eyebrow (small) → title → lead */
.org-pagehead { padding: var(--s-8) var(--s-6) var(--s-7); background: var(--surface-mist); border-bottom: 1px solid var(--line-hair); }
.org-pagehead__inner { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.org-pagehead__title {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 44px;
  line-height: 1.25;
  margin: var(--s-5) 0 var(--s-4);
  letter-spacing: 0.005em;
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-start;
}
.org-pagehead__title small {
  font-family: var(--latin);
  font-size: 11px;
  font-weight: 600;
  color: var(--ember);
  letter-spacing: 0.22em;
  margin-bottom: var(--s-3);
  text-transform: uppercase;
}
.org-pagehead__lead { font-size: 14.5px; line-height: 1.95; color: var(--ink-soft); max-width: 760px; }
.org-pagehead__lead strong { color: var(--ink-primary); font-weight: 700; }

/* Editorial variant — centered, narrow column. Use for brand-heavy pages
   (about, future blog/article pages) where right-side whitespace should
   read as intentional breathing rather than orphaned content. */
.org-pagehead--editorial { padding: var(--s-9) var(--s-6) var(--s-8); }
.org-pagehead--editorial .org-pagehead__inner { max-width: 720px; text-align: center; }
.org-pagehead--editorial .mol-breadcrumb { justify-content: center; }
.org-pagehead--editorial .org-pagehead__title {
  align-items: center;
  font-size: clamp(32px, 4vw, 48px);
  margin: var(--s-5) 0 var(--s-5);
}
.org-pagehead--editorial .org-pagehead__lead {
  max-width: 560px;
  margin: 0 auto;
  padding-bottom: var(--s-6);
  border-bottom: 1px solid var(--line-medium);
}

/* Contact form */
.org-form { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-5); background: var(--surface-card); border: 1px solid var(--line-hair); padding: var(--s-7); }
.org-form .full { grid-column: 1 / -1; }
.org-form__submit { grid-column: 1 / -1; display: flex; justify-content: flex-end; gap: var(--s-3); padding-top: var(--s-3); border-top: 1px solid var(--line-hair); }
.org-form .radio-group { display: flex; flex-wrap: wrap; gap: var(--s-4); padding: 4px 0; }

/* =============================================================
   PAGE-LEVEL UTILITIES (built on the design tokens)
   ============================================================= */

/* Section block (chapter wrapper) */
.section-block { padding: var(--s-9) 0; border-bottom: 1px solid var(--line-hair); }
.section-block:last-child { border-bottom: none; }
.section-block--mist { background: var(--surface-mist); }
.section-block--card { background: var(--surface-card); }

/* Prose block (long-form text body) */
.prose { max-width: 760px; }
.prose p { font-size: 15px; line-height: 2; color: var(--ink-soft); margin-bottom: var(--s-5); }
.prose p strong { color: var(--ink-primary); font-weight: 700; }
.prose p:last-child { margin-bottom: 0; }
.prose h3 {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 20px;
  line-height: 1.55;
  margin: var(--s-7) 0 var(--s-3);
  color: var(--ink-primary);
}
.prose h3:first-child { margin-top: 0; }
.prose h4 {
  font-family: var(--sans-jp);
  font-weight: 700;
  font-size: 15px;
  margin: var(--s-5) 0 var(--s-3);
  color: var(--ink-primary);
}
.prose ul, .prose ol { margin: 0 0 var(--s-5) 22px; }
.prose ul li, .prose ol li { font-size: 14.5px; line-height: 1.95; color: var(--ink-soft); margin-bottom: 6px; }
.prose a { color: var(--ember); border-bottom: 1px solid var(--ember); text-decoration: none; }
.prose a:hover { color: var(--ember-deep); border-color: var(--ember-deep); }
.prose blockquote {
  border-left: 2px solid var(--ember);
  padding: var(--s-3) var(--s-5);
  margin: var(--s-5) 0;
  font-size: 14px;
  color: var(--ink-soft);
  background: var(--surface-mist);
  font-style: normal;
}
.prose blockquote p { margin-bottom: 8px; font-size: 14px; }
.prose blockquote p:last-child { margin-bottom: 0; }

/* Problem list (✓ checks) */
.problem-list { list-style: none; margin: var(--s-5) 0; padding: 0; }
.problem-list li {
  position: relative;
  padding: 10px 0 10px 32px;
  border-bottom: 1px dashed var(--line-hair);
  font-size: 14.5px;
  line-height: 1.85;
  color: var(--ink-primary);
}
.problem-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 10px;
  width: 20px;
  height: 20px;
  background: var(--ember);
  color: #fff;
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
}

/* Data table */
.content-table { width: 100%; border-collapse: collapse; margin: var(--s-5) 0; font-size: 14px; background: var(--surface-card); }
.content-table th, .content-table td { padding: 14px 18px; text-align: left; vertical-align: middle; border: none; border-bottom: 1px solid var(--line-hair); line-height: 1.7; }
.content-table thead th { background: var(--ember-tint); font-weight: 700; font-family: var(--sans-jp); font-size: 12px; color: var(--ink-soft); letter-spacing: 0.08em; text-transform: uppercase; border-bottom: 2px solid var(--ink-primary); }
.content-table tbody th { background: transparent; font-family: var(--serif-jp); font-weight: 700; color: var(--ink-primary); width: 200px; }
.content-table tbody tr:last-child > * { border-bottom: none; }
.content-table td strong { color: var(--ember-deep); }
.content-table--narrow th, .content-table--narrow td { padding: 10px 14px; }

/* Steps table */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-3); margin: var(--s-6) 0; }
.steps__item { background: var(--surface-card); border: 1px solid var(--line-hair); padding: var(--s-5) var(--s-5); position: relative; }
.steps__no { font-family: var(--latin); font-size: 11px; letter-spacing: 0.2em; color: var(--ember); font-weight: 600; margin-bottom: var(--s-3); display: block; text-transform: uppercase; }
.steps__title { font-family: var(--serif-jp); font-weight: 700; font-size: 16px; line-height: 1.45; margin-bottom: var(--s-3); }
.steps__desc { font-size: 13px; color: var(--ink-soft); line-height: 1.85; }

/* Spec/feature card (deliverables) */
.spec-card {
  background: var(--surface-card);
  border: 1px solid var(--line-hair);
  padding: var(--s-6);
  margin-bottom: var(--s-5);
}
.spec-card__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px solid var(--line-hair);
  padding-bottom: var(--s-4);
  margin-bottom: var(--s-5);
  flex-wrap: wrap;
  gap: var(--s-3);
}
.spec-card__title { font-family: var(--serif-jp); font-weight: 700; font-size: 22px; line-height: 1.4; }
.spec-card__price {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 24px;
  color: var(--ember);
}
.spec-card__price small { font-size: 12px; font-weight: 400; color: var(--ink-muted); margin-left: 6px; }
.spec-card__lead { font-size: 14px; line-height: 1.95; color: var(--ink-soft); margin-bottom: var(--s-5); }
.spec-card__lead strong { color: var(--ink-primary); font-weight: 700; }
.spec-card h4 {
  font-family: var(--latin);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--ember);
  font-weight: 600;
  text-transform: uppercase;
  margin: var(--s-5) 0 var(--s-3);
}
.spec-card h4:first-of-type { margin-top: 0; }
.spec-card ul { list-style: none; padding: 0; margin: 0; }
.spec-card li {
  padding: 10px 0 10px 24px;
  position: relative;
  font-size: 14px;
  line-height: 1.85;
  color: var(--ink-primary);
  border-bottom: 1px solid var(--line-hair);
}
.spec-card li:last-child { border-bottom: none; }
.spec-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 18px;
  width: 12px;
  height: 1px;
  background: var(--ember);
}
.spec-card__meta {
  margin-top: var(--s-5);
  padding-top: var(--s-4);
  border-top: 1px solid var(--line-hair);
  font-size: 12px;
  color: var(--ink-muted);
  font-family: var(--latin);
  letter-spacing: 0.04em;
  line-height: 1.85;
}
.spec-card__meta strong { color: var(--ink-primary); font-weight: 700; font-family: var(--sans-jp); }

/* Note / warning box */
.note-card {
  background: var(--ember-tint);
  border-left: 3px solid var(--ember);
  padding: var(--s-5) var(--s-6);
  margin: var(--s-5) 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--ink-primary);
}
.note-card h4 { font-family: var(--serif-jp); font-weight: 700; font-size: 15px; margin-bottom: var(--s-3); color: var(--ember-deep); }
.note-card ul { margin: var(--s-3) 0 var(--s-3) 22px; }
.note-card li { font-size: 13.5px; line-height: 1.85; color: var(--ink-soft); }
.note-card strong { color: var(--ember-deep); }

/* Use-case cards */
.use-cases { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-4); margin: var(--s-6) 0; }
.use-case {
  background: var(--surface-card);
  border: 1px solid var(--line-hair);
  padding: var(--s-6);
}
.use-case__no { font-family: var(--latin); font-size: 10px; letter-spacing: 0.2em; color: var(--ember); font-weight: 600; text-transform: uppercase; margin-bottom: var(--s-3); display: block; }
.use-case__title { font-family: var(--serif-jp); font-weight: 700; font-size: 18px; line-height: 1.45; margin-bottom: var(--s-3); }
.use-case__quote { font-size: 13.5px; line-height: 1.95; color: var(--ink-soft); border-left: 2px solid var(--line-hair); padding-left: var(--s-4); }

/* Door (CTA dual) */
.door-pair { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-4); margin-top: var(--s-6); }
.door {
  background: var(--surface-card);
  border: 1px solid var(--line-hair);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.25s ease, transform 0.25s ease;
}
.door:hover { border-color: var(--ink-primary); transform: translateY(-2px); }
.door__no { font-family: var(--latin); font-size: 10px; letter-spacing: 0.2em; color: var(--ember); font-weight: 600; text-transform: uppercase; margin-bottom: var(--s-3); }
.door__title { font-family: var(--serif-jp); font-weight: 700; font-size: 20px; line-height: 1.45; margin-bottom: var(--s-3); }
.door__lead { font-size: 13.5px; line-height: 1.9; color: var(--ink-soft); margin-bottom: var(--s-4); flex: 1; }
.door__cta { font-family: var(--latin); font-size: 12px; letter-spacing: 0.14em; color: var(--ember); font-weight: 500; text-transform: uppercase; }
.door__cta::after { content: " →"; }

/* Compare two-column */
.compare2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--line-hair); border: 1px solid var(--line-hair); margin: var(--s-5) 0; }
.compare2__col { background: var(--surface-card); padding: var(--s-6); }
.compare2__col h4 { font-family: var(--serif-jp); font-weight: 700; font-size: 18px; margin-bottom: var(--s-3); }
.compare2__col p { font-size: 13.5px; color: var(--ink-soft); line-height: 1.9; }
.compare2__col--accent { background: var(--ember-tint); }
.compare2__col--accent h4 { color: var(--ember-deep); }

/* Plan filter chips */
.filter-bar { display: flex; flex-wrap: wrap; gap: var(--s-2); margin-bottom: var(--s-3); align-items: center; }
.filter-bar__label { font-family: var(--latin); font-size: 11px; letter-spacing: 0.16em; color: var(--ink-muted); text-transform: uppercase; margin-right: var(--s-3); }
.chip {
  font-family: var(--sans-jp);
  font-size: 12px;
  font-weight: 500;
  padding: 6px 14px;
  border: 1px solid var(--line-medium);
  background: var(--surface-card);
  color: var(--ink-primary);
  cursor: pointer;
  transition: all 0.2s ease;
}
.chip:hover { border-color: var(--ember); color: var(--ember); }
.chip.is-active { background: var(--ink-primary); border-color: var(--ink-primary); color: #fff; }

/* Portfolio card */
.portfolio-card {
  background: var(--surface-card);
  border: 1px solid var(--line-hair);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
}
.portfolio-card__media {
  aspect-ratio: 4/3;
  background-color: var(--alu-light);
  background-size: cover;
  background-position: center;
  margin: calc(var(--s-6) * -1) calc(var(--s-6) * -1) var(--s-5);
  border-bottom: 1px solid var(--line-hair);
}
.portfolio-card__tags { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: var(--s-3); }
.portfolio-card__title { font-family: var(--serif-jp); font-weight: 700; font-size: 18px; line-height: 1.45; margin-bottom: var(--s-2); }
.portfolio-card__meta { font-family: var(--latin); font-size: 11px; color: var(--ink-muted); letter-spacing: 0.06em; margin-bottom: var(--s-4); padding-bottom: var(--s-3); border-bottom: 1px solid var(--line-hair); }
.portfolio-card__row { margin-bottom: var(--s-4); }
.portfolio-card__row:last-child { margin-bottom: 0; }
.portfolio-card__rowlabel { font-family: var(--latin); font-size: 10px; letter-spacing: 0.2em; color: var(--ember); font-weight: 600; text-transform: uppercase; margin-bottom: 6px; display: block; }
.portfolio-card__rowtext { font-size: 13.5px; line-height: 1.9; color: var(--ink-soft); }

/* Principles (about page) */
.principles { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-4); margin: var(--s-5) 0; }
.principle {
  background: var(--surface-card);
  border: 1px solid var(--line-hair);
  padding: var(--s-6);
}
.principle__no { font-family: var(--latin); font-size: 11px; letter-spacing: 0.2em; color: var(--ember); font-weight: 600; text-transform: uppercase; margin-bottom: var(--s-3); }
.principle__title { font-family: var(--serif-jp); font-weight: 700; font-size: 18px; line-height: 1.45; margin-bottom: var(--s-3); }
.principle__desc { font-size: 13.5px; line-height: 1.9; color: var(--ink-soft); }

/* Colophon table */
.colophon { background: var(--surface-card); border: 1px solid var(--line-hair); margin: var(--s-5) 0; }
.colophon dl { display: grid; grid-template-columns: 200px 1fr; }
.colophon dt {
  background: var(--surface-mist);
  padding: 14px 18px;
  font-family: var(--latin);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--ink-soft);
  text-transform: uppercase;
  border-bottom: 1px solid var(--line-hair);
  font-weight: 600;
}
.colophon dd {
  padding: 14px 18px;
  font-size: 14px;
  color: var(--ink-primary);
  border-bottom: 1px solid var(--line-hair);
  border-left: 1px solid var(--line-hair);
}
.colophon dl > div:last-child dt,
.colophon dl > div:last-child dd { border-bottom: none; }

/* =============================================================
   SECTION LAYOUTS (subset: L02 Asymmetric Split, L05 Sticky Title)
   ============================================================= */

/* L02 — Asymmetric Split (text 1.4 : media 1) */
.l02-split {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--s-8);
  align-items: center;
  margin-top: var(--s-6);
}
.l02-split--reverse { grid-template-columns: 1fr 1.4fr; }
.l02-split--reverse .l02-split__media { order: -1; }
.l02-split__copy h3 {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.5;
  margin-bottom: var(--s-4);
}
.l02-split__media {
  aspect-ratio: 4/5;
  border: 1px solid var(--line-hair);
  background: linear-gradient(135deg, var(--alu-light) 0%, var(--alu-mid) 60%, var(--alu-shade) 100%);
  position: relative;
  overflow: hidden;
}
.l02-split__media::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(45deg, rgba(255,255,255,0.04) 0 8px, transparent 8px 16px);
}
.l02-split__media--mist   { background: linear-gradient(180deg, #d6dde6 0%, #94a0ad 100%); }
.l02-split__media--shop   { background: linear-gradient(180deg, #1b2838 0%, #2d3d52 60%, #0e1722 100%); }
.l02-split__media--molten { background: radial-gradient(circle at 50% 60%, #d8b58a 0%, #a26a3d 30%, #6b4628 70%, #2c1c10 100%); }
.l02-split__cap {
  position: absolute;
  left: 14px;
  bottom: 12px;
  color: #fff;
  font-family: var(--latin);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-shadow: 0 1px 2px rgba(0,0,0,0.4);
  z-index: 1;
}

/* L07 — Index Table (横罫線リスト) */
.l07-table { border-top: 1px solid var(--line-strong); }
.l07-row {
  display: grid;
  grid-template-columns: 110px 130px 1fr 24px;
  gap: var(--s-4);
  align-items: center;
  padding: 22px 8px;
  border-bottom: 1px solid var(--line-hair);
  text-decoration: none;
  color: inherit;
  transition: background 0.15s ease;
}
.l07-row:hover { background: var(--surface-mist); }
.l07-row__date {
  font-family: var(--latin);
  font-size: 13px;
  color: var(--ink-soft);
}
.l07-row__cat {
  font-family: var(--sans-jp);
  font-size: 11px;
  color: var(--ink-primary);
  letter-spacing: 0.04em;
}
.l07-row__cat::before { content: "/ "; color: var(--ink-muted); margin-right: 4px; }
.l07-row__title {
  font-family: var(--sans-jp);
  font-size: 14.5px;
  font-weight: 500;
  line-height: 1.7;
}
.l07-row__arrow {
  font-family: var(--latin);
  color: var(--ink-muted);
  font-size: 13px;
  text-align: right;
}

/* L05 — Sticky Title × Scroll Body */
.l05-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--s-8);
  align-items: start;
}
.l05-grid__title { position: sticky; top: 96px; }
.l05-grid__title .num {
  font-family: var(--latin);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--ember);
  font-weight: 600;
  display: block;
  margin-bottom: var(--s-3);
}
.l05-grid__title h2 {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 30px;
  line-height: 1.4;
}
.l05-grid__title h2 small {
  display: block;
  font-family: var(--latin);
  font-size: 12px;
  font-weight: 400;
  color: var(--ink-muted);
  letter-spacing: 0.06em;
  margin-top: 8px;
}
.l05-block + .l05-block {
  margin-top: var(--s-7);
  padding-top: var(--s-7);
  border-top: 1px solid var(--line-hair);
}
.l05-block h3 {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 18px;
  margin-bottom: 10px;
}
.l05-block p {
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.95;
}

/* Pillars custom (for technology page) */
.feature-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-4); margin: var(--s-5) 0; }
.feature {
  background: var(--surface-card);
  border: 1px solid var(--line-hair);
  padding: var(--s-6);
}
.feature__title { font-family: var(--serif-jp); font-weight: 700; font-size: 18px; margin-bottom: var(--s-3); line-height: 1.45; }
.feature__desc { font-size: 13.5px; line-height: 1.9; color: var(--ink-soft); }

/* =============================================================
   PRICING (organism) — tier comparison
   2-up entry tier + 1 separated enterprise tier
   ============================================================= */
.org-pricing { margin: var(--s-5) 0; }
.org-pricing__entry {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-4);
}
.org-pricing__divider {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--s-4);
  align-items: center;
  margin: var(--s-7) 0 var(--s-5);
}
.org-pricing__divider::before,
.org-pricing__divider::after { content: ""; height: 1px; background: var(--line-medium); }
.org-pricing__divider span {
  font-family: var(--latin);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--ink-muted);
  text-transform: uppercase;
  font-weight: 600;
}
.org-pricing__enterprise { display: grid; grid-template-columns: 1fr; }
.org-pricing__card {
  background: var(--surface-card);
  border: 1px solid var(--line-hair);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  position: relative;
}
.org-pricing__card--featured {
  border: 1px solid var(--ink-primary);
  border-top: 3px solid var(--ember);
}
.org-pricing__card--enterprise {
  background: var(--surface-ink);
  color: #fff;
  border-color: var(--surface-ink);
}
.org-pricing__badge {
  position: absolute;
  top: -10px;
  left: var(--s-5);
  background: var(--ember);
  color: #fff;
  font-family: var(--latin);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 4px 10px;
}
.org-pricing__cat {
  font-family: var(--latin);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--ember);
  font-weight: 600;
  text-transform: uppercase;
  margin-bottom: var(--s-3);
}
.org-pricing__card--enterprise .org-pricing__cat { color: var(--ember-tint); }
.org-pricing__name {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.4;
  margin-bottom: var(--s-2);
}
.org-pricing__purpose {
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--ink-soft);
  margin-bottom: var(--s-5);
}
.org-pricing__card--enterprise .org-pricing__purpose { color: var(--alu-light); }
.org-pricing__price {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 32px;
  line-height: 1;
  color: var(--ink-primary);
  margin-bottom: var(--s-2);
  padding-top: var(--s-4);
  border-top: 1px solid var(--line-hair);
}
.org-pricing__card--enterprise .org-pricing__price { color: #fff; border-top-color: rgba(255,255,255,0.15); }
.org-pricing__price small {
  font-family: var(--sans-jp);
  font-size: 12px;
  font-weight: 400;
  color: var(--ink-muted);
  margin-left: 8px;
  letter-spacing: 0.04em;
}
.org-pricing__card--enterprise .org-pricing__price small { color: var(--alu-light); }
.org-pricing__features {
  list-style: none;
  padding: 0;
  margin: var(--s-4) 0 var(--s-5);
  font-size: 13px;
  flex: 1;
}
.org-pricing__features li {
  position: relative;
  padding: 6px 0 6px 18px;
  line-height: 1.7;
  color: var(--ink-soft);
}
.org-pricing__features li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 14px;
  width: 10px;
  height: 1px;
  background: var(--ember);
}
.org-pricing__card--enterprise .org-pricing__features li { color: var(--alu-light); }
.org-pricing__cta {
  font-family: var(--sans-jp);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 10px 16px;
  border: 1px solid var(--ink-primary);
  background: transparent;
  color: var(--ink-primary);
  text-decoration: none;
  text-align: center;
  display: inline-flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  transition: background 0.2s ease, color 0.2s ease;
  margin-top: auto;
}
.org-pricing__cta:hover { background: var(--ink-primary); color: #fff; }
.org-pricing__card--featured .org-pricing__cta { background: var(--ember); border-color: var(--ember); color: #fff; }
.org-pricing__card--featured .org-pricing__cta:hover { background: var(--ember-deep); border-color: var(--ember-deep); }
.org-pricing__card--enterprise .org-pricing__cta { background: transparent; border-color: rgba(255,255,255,0.4); color: #fff; }
.org-pricing__card--enterprise .org-pricing__cta:hover { background: #fff; color: var(--surface-ink); }

/* Pricing footnote callout (note above/below the cards) */
.pricing-note {
  margin-top: var(--s-5);
  padding: var(--s-4) var(--s-5);
  border-left: 3px solid var(--ember);
  background: var(--surface-card);
  font-size: 13px;
  line-height: 1.85;
  color: var(--ink-soft);
}
.pricing-note strong { color: var(--ink-primary); font-weight: 700; }

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width: 960px) {
  :root { --gutter: 20px; }
  .org-header { padding: 14px 20px; flex-wrap: wrap; }
  .org-header__nav { gap: 14px; font-size: 12px; width: 100%; justify-content: flex-start; padding-top: var(--s-3); border-top: 1px solid var(--line-hair); margin-top: var(--s-3); }
  .org-header__nav li { margin-bottom: 4px; }
  .org-hero__inner { padding: 32px 20px; }
  .org-hero__plans { grid-template-columns: 1fr; }
  .org-hero__plan { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.15); }
  .org-stats { grid-template-columns: repeat(2, 1fr); }
  .org-stats > .mol-stat:nth-child(2) { border-right: none; }
  .org-stats > .mol-stat:nth-child(1), .org-stats > .mol-stat:nth-child(2) { border-bottom: 1px solid var(--line-hair); }
  .org-pillars { grid-template-columns: 1fr; }
  .org-pillars > .mol-pillar { border-right: none; border-bottom: 1px solid var(--line-hair); }
  .org-products, .org-products--two { grid-template-columns: 1fr; }
  .org-dx { padding: var(--s-7) 0; }
  .org-dx__inner { grid-template-columns: 1fr; }
  .org-footer__grid { grid-template-columns: 1fr; gap: var(--s-5); }
  .org-form { grid-template-columns: 1fr; padding: var(--s-5); }
  .mol-newsrow { grid-template-columns: 1fr; gap: 6px; padding: 14px 4px; }
  .mol-secthead { grid-template-columns: 1fr; gap: var(--s-3); }
  .mol-secthead__title { font-size: 28px; }
  .org-pagehead { padding: var(--s-7) var(--s-4); }
  .org-pagehead__title { font-size: 32px; }
  .steps { grid-template-columns: 1fr; }
  .use-cases { grid-template-columns: 1fr; }
  .door-pair { grid-template-columns: 1fr; }
  .compare2 { grid-template-columns: 1fr; }
  .principles { grid-template-columns: 1fr; }
  .feature-grid { grid-template-columns: 1fr; }
  .colophon dl { grid-template-columns: 1fr; }
  .colophon dt { border-left: none; }
  .colophon dd { border-left: none; padding-top: 4px; }
  .content-table { display: block; overflow-x: auto; }
  .spec-card__head { flex-direction: column; align-items: flex-start; gap: var(--s-2); }
  .spec-card__price { font-size: 22px; }
  .org-cta { padding: var(--s-7) var(--s-5); }
  .org-cta__title { font-size: 24px; }
  .org-pricing__entry { grid-template-columns: 1fr; }
  .org-pricing__divider { grid-template-columns: 1fr; gap: var(--s-2); text-align: center; }
  .org-pricing__divider::before, .org-pricing__divider::after { display: none; }
  .l02-split, .l02-split--reverse { grid-template-columns: 1fr; gap: var(--s-6); }
  .l02-split--reverse .l02-split__media { order: 0; }
  .l05-grid { grid-template-columns: 1fr; gap: var(--s-5); }
  .l05-grid__title { position: static; }
  .l07-row { grid-template-columns: 90px 1fr 24px; }
  .l07-row__cat { display: none; }
}
@media (max-width: 600px) {
  .l07-row { grid-template-columns: 76px 1fr; }
  .l07-row__arrow { display: none; }
}

/* =============================================================
   INTERACTION: mobile menu / form status
   ============================================================= */

/* Mobile menu hamburger button */
.org-header__menu-toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--line-medium);
  width: 40px;
  height: 40px;
  cursor: pointer;
  position: relative;
  padding: 0;
}
.org-header__menu-toggle span,
.org-header__menu-toggle span::before,
.org-header__menu-toggle span::after {
  display: block;
  width: 18px;
  height: 1.5px;
  background: var(--ink-primary);
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  transition: transform 0.2s ease, opacity 0.2s ease, top 0.2s ease;
}
.org-header__menu-toggle span { top: 50%; margin-top: -1px; }
.org-header__menu-toggle span::before {
  content: "";
  top: -7px;
  left: 0;
  transform: none;
}
.org-header__menu-toggle span::after {
  content: "";
  top: 7px;
  left: 0;
  transform: none;
}
.org-header__menu-toggle.is-open span { background: transparent; }
.org-header__menu-toggle.is-open span::before { top: 0; transform: rotate(45deg); }
.org-header__menu-toggle.is-open span::after { top: 0; transform: rotate(-45deg); }

/* Form status (contact submit feedback) */
.form-status {
  display: none;
  grid-column: 1 / -1;
  padding: var(--s-4) var(--s-5);
  border-left: 3px solid var(--line-medium);
  background: var(--surface-mist);
  font-size: 14px;
  line-height: 1.85;
  color: var(--ink-soft);
  margin-bottom: var(--s-5);
}
.form-status.is-visible { display: block; }
.form-status--success {
  border-left-color: #4f7a3a;
  background: #f0f5ee;
  color: #2f5524;
}
.form-status--error {
  border-left-color: var(--ember);
  background: var(--ember-tint);
  color: var(--ember-deep);
}
.form-status strong { font-weight: 700; }

/* Filter chip filtered-out card hidden state */
[data-filterable].is-filtered-out { display: none !important; }

/* Mobile menu open/close on small screens */
@media (max-width: 960px) {
  .org-header__menu-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .org-header__nav {
    display: none;
    width: 100%;
    margin-top: var(--s-3);
    padding-top: var(--s-3);
    border-top: 1px solid var(--line-hair);
  }
  .org-header__nav.is-open { display: flex; flex-direction: column; align-items: flex-start; gap: var(--s-3); }
  .org-header__nav li { width: 100%; }
}

/* =============================================================
   BLOG LAYOUT (news.html)
   ============================================================= */
.blog-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: var(--s-7);
  align-items: start;
}
.blog-main { min-width: 0; }

/* Lead summary */
.blog-lead {
  background: var(--surface-card);
  border: 1px solid var(--line-hair);
  padding: var(--s-5) var(--s-6);
  font-size: 14px;
  line-height: 1.95;
  color: var(--ink-soft);
  margin-bottom: var(--s-6);
}

/* Tabs (新着 / 人気) */
.blog-tabs {
  display: flex;
  border-bottom: 2px solid var(--line-hair);
  margin-bottom: var(--s-6);
}
.blog-tab {
  flex: 1;
  padding: 14px 24px;
  background: var(--surface-mist);
  border: 1px solid var(--line-hair);
  border-bottom: none;
  font-family: var(--sans-jp);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-soft);
  cursor: pointer;
  text-align: center;
  position: relative;
  margin-right: -1px;
  transition: background 0.15s ease, color 0.15s ease;
}
.blog-tab:hover { color: var(--ink-primary); }
.blog-tab.is-active {
  background: var(--ember-deep);
  color: #fff;
  border-color: var(--ember-deep);
  z-index: 1;
}
.blog-tab.is-active::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -10px;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--ember-deep);
}

/* Active filter badges row */
.blog-active-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: var(--s-5);
  font-size: 12px;
  color: var(--ink-soft);
  align-items: center;
  min-height: 28px;
}
.blog-active-filters[hidden] { display: none; }
.blog-active-filters__label {
  font-family: var(--latin);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-size: 10px;
  margin-right: 4px;
}
.blog-active-filters__chip {
  background: var(--ember-tint);
  border: 1px solid var(--ember);
  color: var(--ember-deep);
  padding: 4px 10px;
  font-size: 12px;
  cursor: pointer;
}
.blog-active-filters__chip::after { content: " ✕"; font-size: 10px; }
.blog-active-filters__chip:hover { background: var(--ember); color: #fff; }
.blog-active-filters__clear {
  background: transparent;
  border: 1px solid var(--line-medium);
  color: var(--ink-soft);
  padding: 4px 10px;
  font-size: 11px;
  cursor: pointer;
  margin-left: auto;
}
.blog-active-filters__clear:hover { color: var(--ember); border-color: var(--ember); }

/* Article cards list */
.blog-articles {
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
  min-height: 70vh; /* prevent page-collapse jump when filter narrows results */
}

.blog-card {
  background: var(--surface-card);
  border: 1px solid var(--line-hair);
  transition: border-color 0.25s ease, transform 0.25s ease;
}
.blog-card:hover { border-color: var(--ink-primary); transform: translateY(-2px); }

.blog-card__inner {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: var(--s-5);
  padding: var(--s-5) var(--s-6);
  text-decoration: none;
  color: inherit;
}

.blog-card__date {
  font-family: var(--latin);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding-top: 6px;
  border-right: 1px solid var(--line-hair);
}
.blog-card__year { color: var(--ink-muted); font-size: 12px; letter-spacing: 0.04em; }
.blog-card__day {
  font-size: 18px;
  font-weight: 600;
  color: var(--ink-primary);
  letter-spacing: 0.02em;
}

.blog-card__body { display: flex; flex-direction: column; gap: var(--s-3); min-width: 0; }
.blog-card__title {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink-primary);
}
.blog-card__desc {
  font-size: 13px;
  line-height: 1.85;
  color: var(--ink-soft);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.blog-card__thumb {
  aspect-ratio: 16 / 9;
  background-color: var(--alu-light);
  background-size: cover;
  background-position: center;
  position: relative;
  margin-top: var(--s-2);
}
.blog-card__thumb-cat {
  position: absolute;
  top: 12px;
  right: 12px;
  background: var(--ember-deep);
  color: #fff;
  font-family: var(--latin);
  font-size: 10px;
  letter-spacing: 0.18em;
  padding: 4px 12px;
  font-weight: 600;
  text-transform: uppercase;
}
.blog-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: var(--s-2);
}
.blog-card__tag {
  font-family: var(--sans-jp);
  font-size: 11px;
  color: var(--ink-soft);
  background: var(--surface-mist);
  padding: 3px 9px;
  letter-spacing: 0.02em;
}

.blog-empty {
  padding: var(--s-8) var(--s-6);
  text-align: center;
  color: var(--ink-muted);
  background: var(--surface-card);
  border: 1px dashed var(--line-medium);
  font-size: 13.5px;
}

/* Sidebar widgets */
.blog-sidebar { display: flex; flex-direction: column; gap: var(--s-6); position: sticky; top: 96px; }

.blog-search {
  display: flex;
  border: 1px solid var(--line-medium);
  background: var(--surface-card);
}
.blog-search input {
  flex: 1;
  border: none;
  padding: 12px 14px;
  font-family: var(--sans-jp);
  font-size: 14px;
  outline: none;
  min-width: 0;
  background: transparent;
}
.blog-search input:focus { background: var(--surface-card); }
.blog-search__btn {
  background: var(--ember-deep);
  color: #fff;
  border: none;
  padding: 0 18px;
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.blog-search__btn:hover { background: var(--ink-primary); }

.blog-widget__title {
  font-family: var(--serif-jp);
  font-weight: 700;
  font-size: 15px;
  border-bottom: 2px solid var(--ember-deep);
  padding-bottom: 8px;
  margin-bottom: var(--s-4);
  color: var(--ink-primary);
  display: flex;
  align-items: center;
  gap: 8px;
}
.blog-widget__title::before {
  content: "▼";
  font-size: 9px;
  color: var(--ember-deep);
}

.blog-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.blog-tags__item {
  font-family: var(--sans-jp);
  font-size: 12px;
  padding: 5px 12px;
  border: 1px solid var(--line-medium);
  background: var(--surface-card);
  color: var(--ink-soft);
  cursor: pointer;
  transition: all 0.15s ease;
}
.blog-tags__item:hover { border-color: var(--ember); color: var(--ember); }
.blog-tags__item.is-active {
  background: var(--ember-deep);
  border-color: var(--ember-deep);
  color: #fff;
}
.blog-tags__count {
  display: inline-block;
  margin-left: 4px;
  font-size: 10px;
  color: var(--ink-muted);
}
.blog-tags__item.is-active .blog-tags__count { color: rgba(255,255,255,0.7); }

.blog-categories { list-style: none; padding: 0; margin: 0; }
.blog-categories li { border-bottom: 1px solid var(--line-hair); }
.blog-categories button {
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  padding: 12px 4px;
  font-family: var(--sans-jp);
  font-size: 13px;
  color: var(--ink-soft);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: color 0.15s ease;
}
.blog-categories button::before {
  content: "▶";
  font-size: 9px;
  color: var(--ember);
  margin-right: 8px;
}
.blog-categories button:hover { color: var(--ink-primary); }
.blog-categories button.is-active { color: var(--ember-deep); font-weight: 600; }
.blog-categories__count {
  font-family: var(--latin);
  font-size: 11px;
  color: var(--ink-muted);
}

@media (max-width: 960px) {
  .blog-layout { grid-template-columns: 1fr; }
  .blog-sidebar { position: static; }
  .blog-card__inner { grid-template-columns: 80px 1fr; padding: var(--s-4) var(--s-5); }
  .blog-card__title { font-size: 16px; }
}
@media (max-width: 600px) {
  .blog-card__inner { grid-template-columns: 1fr; gap: var(--s-3); }
  .blog-card__date { flex-direction: row; border-right: none; border-bottom: 1px solid var(--line-hair); padding: 0 0 8px; }
  .blog-tab { padding: 12px 16px; font-size: 12px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; }
}
