/* =================================================
   ZINE-KEN ruler.css ⌁ 実寸ルーラー（判型ビューア）
   ================================================= */

.ruler-hero h1 .pink{ color: var(--riso-pink); }

/* ---------- 較正バナー ---------- */
.calib-banner{
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  align-items: center;
  background: var(--ink);
  color: var(--paper);
  border-radius: 12px;
  padding: 22px 24px;
  margin: 28px 0 32px;
  position: relative;
  overflow: hidden;
}
@media (min-width: 720px){ .calib-banner{ grid-template-columns: auto 1fr auto; gap: 28px; } }
.calib-banner::before{
  content:""; position: absolute; width: 360px; height: 360px;
  top: -160px; right: -120px;
  background: radial-gradient(circle, var(--riso-pink) 0%, transparent 60%);
  mix-blend-mode: screen; opacity: 0.5; pointer-events: none;
}
.calib-banner > *{ position: relative; z-index: 2; }
.cb-state{ display: flex; align-items: center; gap: 12px; }
.cb-dot{
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--riso-yellow); box-shadow: 0 0 0 5px rgba(255,200,60,.18);
  flex-shrink: 0;
}
.cb-dot.ok{ background: var(--riso-mint); box-shadow: 0 0 0 5px rgba(111,211,176,.22); animation: pulse 2.6s ease-in-out infinite; }
.cb-label{ font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(242,238,224,0.6); }
.cb-val{ font-family: var(--sans-display); font-weight: 700; font-variation-settings:"opsz" 36; font-size: 19px; letter-spacing:-0.01em; }
.cb-val small{ font-family: var(--mono); font-weight: 400; font-size: 12px; color: rgba(242,238,224,0.6); margin-left: 6px; }
.cb-desc{ font-family: var(--sans-body); font-size: 13px; line-height: 1.5; color: rgba(242,238,224,0.8); max-width: 42ch; }
.btn-calib{
  justify-self: start; background: var(--riso-pink); color: var(--ink);
  border: none; padding: 13px 22px; border-radius: 999px; cursor: pointer;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  transition: background .2s, transform .2s; white-space: nowrap;
}
.btn-calib:hover{ background: var(--riso-yellow); transform: translateX(3px); }

/* ---------- ツールバー＋フル幅ステージ ---------- */
.rt-toolbar{
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: 14px 24px; margin-bottom: 16px;
}
.rt-tab{
  padding: 7px 13px; border-radius: 999px; cursor: pointer; border: 1.5px solid var(--ink-ghost);
  background: var(--paper); color: var(--ink-soft);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; transition: all .15s;
}
.rt-tab:hover{ border-color: var(--ink); color: var(--ink); }
.rt-tab.active{ background: var(--ink); color: var(--paper); border-color: var(--ink); }

.rt-chips{ display: flex; flex-wrap: wrap; gap: 8px; }
.rt-chip{
  display: flex; flex-direction: column; align-items: flex-start; gap: 2px;
  padding: 11px 18px; border-radius: 10px; cursor: pointer;
  background: var(--paper-2); border: 1.5px solid var(--ink-ghost); color: var(--ink);
  font-family: var(--sans-display); font-weight: 700; font-size: 17px; letter-spacing: -0.01em;
  transition: all .15s; min-width: 84px;
}
.rt-chip small{ font-family: var(--mono); font-weight: 400; font-size: 10px; letter-spacing: 0.02em; color: var(--ink-soft); }
.rt-chip:hover{ border-color: var(--ink); }
.rt-chip.active{ background: var(--ink); color: var(--paper); border-color: var(--ink); }
.rt-chip.active small{ color: rgba(242,238,224,0.7); }

.rt-field label{ display: block; font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 5px; }
.rt-field input{
  width: 100%; padding: 9px 11px; border: 1.5px solid var(--ink-ghost); border-radius: 6px;
  background: var(--paper); font-family: var(--mono); font-size: 15px; color: var(--ink); outline: none; transition: border-color .15s;
}
.rt-field input:focus{ border-color: var(--riso-pink); }

.rt-orient{ display: flex; gap: 8px; }
.rt-orient .rt-tab{ text-align: center; padding: 10px 20px; }

.rt-note{ font-family: var(--sans-body); font-size: 11.5px; line-height: 1.65; color: var(--ink-soft); margin: 14px 0 80px; }

/* ステージ（机）⌁ 画面いっぱいに使う */
.rt-stage{
  position: relative; border-radius: 12px; overflow: auto;
  height: calc(100vh - 170px); min-height: 480px;
  width: calc(100vw - 32px); margin-left: calc(50% - 50vw + 16px);
  border: 1.5px solid var(--ink-ghost);
  background:
    radial-gradient(140% 120% at 50% -10%, rgba(255,255,255,.4), transparent 55%),
    var(--paper-2);
  background-image:
    radial-gradient(var(--ink-ghost) 1px, transparent 1.4px);
  background-size: 16px 16px;
  display: flex;
}
/* margin:auto 中央寄せ：シートがステージより大きい時も上端がスクロール到達可能 */
.rt-stage-inner{ padding: 56px; margin: auto; display: grid; place-items: center; }

.sheet{
  position: relative; background: var(--paper);
  box-shadow: 10px 10px 0 var(--riso-pink), 20px 20px 0 var(--riso-mint), 0 2px 0 rgba(22,33,62,.06);
  transition: width .35s cubic-bezier(.2,.8,.2,1), height .35s cubic-bezier(.2,.8,.2,1);
  outline: 1.5px solid var(--ink);
}
.sheet-label{
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  text-align: center; pointer-events: none; user-select: none; width: 92%;
}
.sheet-label .name{
  font-family: var(--sans-display); font-weight: 800; font-variation-settings:"opsz" 96;
  font-size: clamp(22px, 5vw, 52px); line-height: 1; letter-spacing: -0.03em; color: var(--ink);
  position: relative; display: inline-block;
}
/* ズレ刷り（misregistration） */
.sheet-label .name::before,
.sheet-label .name::after{
  content: attr(data-name); position: absolute; top: 0; left: 0; right: 0;
  z-index: -1; mix-blend-mode: multiply;
}
.sheet-label .name::before{ color: var(--riso-pink); transform: translate(-2.5px, 1.5px); }
.sheet-label .name::after{ color: var(--riso-mint); transform: translate(2.5px, -1.5px); }
.sheet-label .dim{ margin-top: 8px; font-family: var(--mono); font-size: 13px; color: var(--ink-soft); letter-spacing: 0.06em; }
.sheet-label .actual{
  margin-top: 14px; display: inline-block; font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; border: 1.5px solid var(--riso-pink); color: var(--riso-pink); border-radius: 999px; padding: 4px 12px;
}

/* 目盛り */
.ruler-edge{ position: absolute; background: var(--paper); border: 1px solid var(--ink); overflow: hidden; }
.ruler-edge.top{ top: -25px; left: 0; height: 23px; border-bottom: none; }
.ruler-edge.left{ left: -25px; top: 0; width: 23px; border-right: none; }
.tick{ position: absolute; background: var(--ink); }
.tick.major{ opacity: 0.85; } .tick.minor{ opacity: 0.32; }
.tick-num{ position: absolute; font-family: var(--mono); font-size: 8px; color: var(--ink-soft); }

.rt-badge{
  position: absolute; left: 50%; bottom: 14px; transform: translateX(-50%);
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap; justify-content: center;
  padding: 8px 16px; border-radius: 999px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
  background: var(--paper); border: 1.5px solid var(--ink-ghost); color: var(--ink-soft);
  box-shadow: 0 8px 22px -14px rgba(22,33,62,.5);
}
.rt-badge .warn{ color: var(--riso-red); font-weight: 500; }
.scale-sw{ display: flex; gap: 3px; background: var(--paper-2); padding: 3px; border-radius: 999px; }
.scale-sw button{
  padding: 5px 12px; border-radius: 999px; cursor: pointer; border: none; background: transparent;
  color: var(--ink-soft); font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.08em; transition: all .15s;
}
.scale-sw button.on{ background: var(--ink); color: var(--paper); }

/* ---------- 較正モーダル ---------- */
.overlay{
  position: fixed; inset: 0; z-index: 2000; display: none; place-items: center;
  background: rgba(22,33,62,.5); backdrop-filter: blur(4px); padding: 20px;
}
.overlay.show{ display: grid; }
.modal{
  width: min(560px, 96vw); max-height: 92vh; overflow: auto;
  background: var(--paper); border: 1.5px solid var(--ink); border-radius: 14px; padding: 30px 28px 26px;
  box-shadow: 14px 14px 0 var(--riso-pink);
}
.modal h2{ font-family: var(--sans-display); font-weight: 800; font-variation-settings:"opsz" 60; font-size: 26px; letter-spacing: -0.02em; margin-bottom: 6px; }
.modal h2 .pink{ color: var(--riso-pink); }
.modal .m-lede{ font-family: var(--sans-body); font-size: 13.5px; line-height: 1.7; color: var(--ink-soft); margin-bottom: 20px; }
.meth{ display: flex; gap: 7px; margin-bottom: 20px; flex-wrap: wrap; }
.meth .rt-tab{ flex: 1; text-align: center; padding: 9px 6px; }

.card-stage{ position: relative; height: 188px; display: grid; place-items: center; margin-bottom: 14px; border-radius: 10px; background: var(--paper-2); background-image: repeating-linear-gradient(90deg, var(--ink-ghost) 0 1px, transparent 1px 13px); }
.cc{ position: relative; height: 54px; border-radius: 9px; background: linear-gradient(135deg, var(--riso-blue), var(--ink)); box-shadow: 0 12px 24px -12px rgba(22,33,62,.6); color: var(--paper); overflow: hidden; outline: 1px solid var(--ink); }
.cc .strip{ position: absolute; top: 11px; left: 0; right: 0; height: 11px; background: rgba(0,0,0,.4); }
.cc .chip-ic{ position: absolute; top: 30px; left: 14px; width: 22px; height: 16px; border-radius: 3px; background: linear-gradient(135deg, var(--riso-yellow), #d99b1f); }
.cc .num{ position: absolute; bottom: 6px; left: 12px; font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em; opacity: 0.85; }
.cc .mm{ position: absolute; bottom: 6px; right: 10px; font-family: var(--mono); font-weight: 500; font-size: 10px; }
.slider-row{ display: flex; align-items: center; gap: 12px; margin-bottom: 6px; }
input[type=range]{ flex: 1; accent-color: var(--riso-pink); height: 4px; }
.range-read{ font-family: var(--mono); font-size: 13px; min-width: 70px; text-align: right; }
.hint{ font-family: var(--sans-body); font-size: 12px; line-height: 1.7; color: var(--ink-soft); margin: 6px 0 18px; }
.kbd{ font-family: var(--mono); background: var(--paper-2); padding: 1px 6px; border-radius: 5px; font-size: 11px; border: 1px solid var(--ink-ghost); }

.meth-block{ display: none; }
.meth-block.show{ display: block; }
.ruler-line{ height: 18px; border-radius: 4px; background: var(--riso-pink); position: relative; margin-bottom: 10px; outline: 1px solid var(--ink); }
.ruler-line::before, .ruler-line::after{ content:""; position: absolute; top: -4px; bottom: -4px; width: 2px; background: var(--ink); }
.ruler-line::before{ left: 0; } .ruler-line::after{ right: 0; }
.manual-row{ display: flex; gap: 12px; align-items: end; }
.manual-row .rt-field{ flex: 1; }

.dpi-out{ font-family: var(--mono); font-size: 12px; color: var(--ink-soft); text-align: center; margin: 14px 0; }
.dpi-out b{ color: var(--ink); }
.modal-actions{ display: flex; gap: 10px; }
.modal-actions .btn{ flex: 1; justify-content: center; }
