/* =========================================
   ペット雑誌メーカー — 共通スタイル
   ========================================= */

:root{
  --bg:#17121a;
  --bg-2:#211923;
  --panel:#241d29;
  --panel-2:#2d2432;
  --line:#4a3a50;
  --line-2:#5b4862;
  --ink:#fff7fb;
  --ink-soft:#d7bdcc;
  --ink-dim:#9f8495;
  --red:#ff6f9f;
  --red-deep:#d44c7c;
  --blue:#2fae91;
  --blue2:#8f6bdc;
  --active-bg:#33202b;
  --glow-a:rgba(255,111,159,.15);
  --glow-b:rgba(47,174,145,.12);
  --radius:18px;
  --shadow:0 12px 30px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.3);
  --font-ui:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1100px 700px at 8% -8%, var(--glow-a), transparent 55%),
    radial-gradient(900px 600px at 108% 4%, var(--glow-b), transparent 55%),
    var(--bg);
  color:var(--ink);
  font-family:var(--font-ui);
  font-weight:500;
  line-height:1.5;
  min-height:100dvh;
  padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  -webkit-text-size-adjust:100%;
}
body.page-doc{ line-height:1.75; }

.wrap{ max-width:920px; margin:0 auto; padding:18px 14px 44px; }
body.page-doc .wrap{ max-width:760px; }

/* ---------------- Header ---------------- */
header{ text-align:center; margin:10px 0 20px; }
header .crumb{
  display:inline-block;
  font-size:12px;
  color:var(--ink-soft);
  margin-bottom:8px;
  font-weight:700;
  letter-spacing:.04em;
}
header .crumb a{
  color:var(--red);
  text-decoration:none;
  border-bottom:1px dotted var(--red);
}
header h1{
  font-size:clamp(22px,5.6vw,34px);
  margin:0 0 6px;
  font-weight:800;
  letter-spacing:.01em;
  color:#fff;
  text-transform:uppercase;
}
header h1 .badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--red);
  color:#fff;
  padding:4px 12px 5px;
  border-radius:4px;
  margin-right:10px;
  font-size:.52em;
  font-weight:800;
  line-height:1;
  letter-spacing:.12em;
  vertical-align:middle;
  transform:translateY(-3px);
}
header h1 .pop{ color:var(--red); }
header p,
header p.lead{
  margin:0;
  color:var(--ink-soft);
  font-size:13px;
  font-weight:500;
}
header p.lead{ font-size:14px; margin-top:6px; }

/* ---------------- Card ---------------- */
.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px;
  margin-bottom:14px;
  box-shadow:var(--shadow);
}
.card h2{
  margin:0 0 12px;
  font-size:12px;
  color:var(--ink-soft);
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  display:flex;
  align-items:center;
  gap:9px;
}
.card h2 .step{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;height:22px;
  border-radius:4px;
  background:var(--red);
  color:#fff;
  font-size:12px;
  font-weight:800;
  padding:0 5px;
}

/* about/license: section title */
.step-title{
  margin:0 0 10px;
  font-size:17px;
  font-weight:800;
  display:flex;
  align-items:center;
  gap:10px;
  color:#fff;
}
.step-title .num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:30px;height:30px;
  border-radius:6px;
  background:var(--red);
  color:#fff;
  font-weight:800;
  font-size:14px;
  padding:0 7px;
  flex:none;
}
.step-title.alt .num{ background:var(--blue2); }
.step-title.alt2 .num{ background:var(--blue); color:#fff; }
.step-title.alt3 .num{ background:#9aa0ac; color:#1a1d23; }

.card p{ margin:0 0 12px; font-size:14px; font-weight:500; color:var(--ink); }
.card ul{ margin:0 0 12px 0; padding-left:1.1em; }
.card li{ margin:5px 0; font-size:14px; font-weight:500; color:var(--ink); }
.card strong{ font-weight:800; color:var(--red); }

.card a:not(.btn):not(.btn-pill),
.tip a{
  color:var(--red);
  text-decoration:none;
  border-bottom:1px dotted var(--red);
  padding-bottom:1px;
  font-weight:700;
  transition:color .12s, border-color .12s;
}
.card a:not(.btn):not(.btn-pill):hover,
.tip a:hover{ color:#fff; border-bottom-color:#fff; }

code, kbd{
  background:#0c0d10;
  border:1px solid var(--line);
  color:#ff7b86;
  padding:1px 7px;
  border-radius:5px;
  font-size:12.5px;
  font-family:"JetBrains Mono",Consolas,Menlo,monospace;
  font-weight:600;
}
kbd{ background:var(--panel-2); border-color:var(--line-2); color:var(--ink); }

/* ---------------- Template selector ---------------- */
.tpl-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
@media (max-width:520px){ .tpl-grid{ grid-template-columns:1fr 1fr; } }
.tpl{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-width:0;
  border:2px solid var(--line);
  border-radius:10px;
  background:var(--panel-2);
  padding:10px 8px 9px;
  cursor:pointer;
  text-align:left;
  transition:border-color .14s, transform .06s, background .14s;
  -webkit-tap-highlight-color:transparent;
}
.tpl:active{ transform:translateY(1px); }
.tpl.active{ border-color:var(--red); background:var(--active-bg); }
.tpl .mini{
  display:block;
  width:30px;
  flex:0 0 30px;
  aspect-ratio:3/4;
  border-radius:6px;
  overflow:hidden;
  position:relative;
  background:#0c0d10;
  border:1px solid var(--line);
}
.tpl .mini i{ position:absolute; display:block; }
.tpl .tpl-label{ display:inline-flex; align-items:baseline; white-space:nowrap; min-width:0; }
.tpl .name{ font-size:12px; font-weight:800; color:var(--ink); letter-spacing:.06em; display:inline; }
.tpl .sep{ color:var(--ink-dim); font-size:11px; margin:0 4px; }
.tpl .desc{ font-size:10px; color:var(--ink-dim); display:inline; }
.tpl.active .name{ color:#fff; }
@media (max-width:520px){ .tpl .mini{ display:none; } }

/* カラーテーマ スウォッチ */
.themes{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.theme{
  width:42px;height:42px;
  border-radius:8px;
  border:2px solid var(--line);
  cursor:pointer;
  padding:0;
  position:relative;
  transition:transform .06s, border-color .14s;
  -webkit-tap-highlight-color:transparent;
}
.theme:active{ transform:translateY(1px); }
.theme.active{ border-color:#fff; box-shadow:0 0 0 2px rgba(255,255,255,.35); }
.theme.active::after{
  content:"✓";
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:18px; font-weight:900;
  text-shadow:0 1px 3px rgba(0,0,0,.6);
}
.theme.rainbow{
  background:conic-gradient(from 0deg,#ff3b30,#ff9500,#ffcc00,#34c759,#00c7be,#0a84ff,#5e5ce6,#bf5af2,#ff3b30);
}
.theme.rainbow{ overflow:hidden; display:inline-block; }
.theme.rainbow::before{
  content:"＋";
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:18px; font-weight:900;
  text-shadow:0 1px 3px rgba(0,0,0,.55);
  pointer-events:none;
}
.theme.rainbow.active::after{ content:"✓"; }
/* 実体の color input をスウォッチ全面に重ね、実タップで開く（スマホ対応） */
.theme.rainbow input[type=color]{
  position:absolute; inset:0;
  width:100%; height:100%;
  margin:0; padding:0; border:0;
  opacity:0; cursor:pointer; z-index:2;
  -webkit-appearance:none; appearance:none;
}

/* mini thumb building blocks */
.mini .ph{ inset:0; background:linear-gradient(135deg,#3a3f4a,#23262e); }
.mini .bar-red{ background:var(--red); }
.mini .bar-navy{ background:#2fae91; }
.mini .bar-blue{ background:#8f6bdc; }
.mini .bar-w{ background:#fff; }
.mini .bar-d{ background:rgba(0,0,0,.6); }

/* ---------------- Drop zone ---------------- */
.drop{
  position:relative;
  border:2px dashed var(--line-2);
  border-radius:12px;
  background:var(--panel-2);
  padding:22px 14px;
  text-align:center;
  transition:border-color .15s, background .15s, transform .1s;
  cursor:pointer;
}
.drop:hover{ background:#262a33; }
.drop:active{ transform:scale(.99); }
.drop.drag{ border-color:var(--red); background:var(--active-bg); }
.drop p{ margin:6px 0 0; color:var(--ink-soft); font-size:13px; }
.drop strong{ color:#fff; font-size:15px; font-weight:800; }
.drop .ico{
  display:inline-flex;align-items:center;justify-content:center;
  width:46px;height:46px;border-radius:8px;
  background:var(--red);
  color:#fff;font-size:24px;font-weight:800;
  margin-bottom:8px;
  margin-right:10px;
  vertical-align:middle;
}
.drop input[type=file]{ display:none; }

/* ---------------- Controls ---------------- */
.row{ display:grid; grid-template-columns:1fr; gap:12px; }
@media (min-width:560px){
  .row.cols-2{ grid-template-columns:1fr 1fr; }
}
label{
  display:block;
  font-size:11px;
  color:var(--ink-soft);
  margin-bottom:5px;
  font-weight:700;
  letter-spacing:.04em;
}
input[type=text],
textarea{
  width:100%;
  background:var(--panel-2);
  color:var(--ink);
  border:1px solid var(--line-2);
  border-radius:8px;
  padding:10px 12px;
  font-size:16px; /* prevent iOS zoom */
  font-family:inherit;
  font-weight:600;
  appearance:none;
  -webkit-appearance:none;
  transition:border-color .12s, box-shadow .12s;
}
input[type=text]:focus,
textarea:focus{
  outline:none;
  border-color:var(--red);
  box-shadow:0 0 0 3px rgba(230,0,18,.22);
}
textarea{
  resize:none;
  overflow:hidden;
  line-height:1.3;
  min-height:42px;
}
input[type=range]{ width:100%; accent-color:var(--red); }

.field{ margin-bottom:12px; }
.field:last-child{ margin-bottom:0; }

/* フィールド見出し行（ラベル＋書体ミニトグル） */
.fhead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:5px;
}
.fhead label{ margin:0; }
.flabel{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:5px 8px;
  min-width:0;
}
.field-note{
  color:var(--ink-dim);
  font-size:10px;
  font-weight:600;
  line-height:1.35;
  letter-spacing:0;
}
.fctrls{
  display:flex;
  align-items:center;
  gap:8px;
  flex:none;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.fontseg{
  display:flex;
  background:var(--panel-2);
  border:1px solid var(--line-2);
  border-radius:7px;
  overflow:hidden;
  padding:2px;
  gap:2px;
  flex:none;
}
.fontseg button{
  background:transparent;
  color:var(--ink-soft);
  border:0;
  padding:5px 11px;
  font-size:12px;
  font-weight:800;
  font-family:inherit;
  cursor:pointer;
  border-radius:5px;
  transition:background .12s, color .12s;
  -webkit-tap-highlight-color:transparent;
}
.fontseg button.active{ background:var(--red); color:#fff; }
.fontseg.colseg{ margin-left:0; }
.fontseg.colseg .sw{
  position:relative;
  display:inline-block;
  width:26px; height:26px;
  min-width:26px;
  padding:0;
  border-radius:6px;
  border:1px solid var(--line-2);
  background-clip:padding-box;
  box-sizing:border-box;
}
.fontseg.colseg .sw.active{
  border-color:var(--red);
  box-shadow:0 0 0 2px var(--red);
}
.fontseg.colseg .sw.rainbow{
  overflow:hidden;
  background:conic-gradient(from 0deg,#ff3b30,#ff9500,#ffcc00,#34c759,#00c7be,#0a84ff,#5e5ce6,#bf5af2,#ff3b30);
}
.fontseg.colseg .sw.rainbow::after{
  content:"＋";
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:900; font-size:13px;
  text-shadow:0 1px 2px rgba(0,0,0,.55);
  pointer-events:none;
}
/* 実体の color input をスウォッチ全面に重ね、実タップで開く（スマホ対応） */
.fontseg.colseg .sw.rainbow input[type=color]{
  position:absolute; inset:0;
  width:100%; height:100%;
  margin:0; padding:0; border:0;
  opacity:0; cursor:pointer; z-index:2;
  -webkit-appearance:none; appearance:none;
}

.range-row{ display:flex; align-items:center; gap:10px; }
.range-row .v{
  min-width:46px; text-align:right;
  font-variant-numeric:tabular-nums;
  color:var(--ink-soft); font-size:13px; font-weight:700;
}

.card .tip{ margin:28px 2px 0; font-size:11.5px; color:var(--ink-dim); font-weight:600; line-height:1.5; }

/* ---------------- Preview ---------------- */
.preview-wrap{
  position:relative;
  background:#000;
  border-radius:0;            /* 雑誌モチーフのため角丸なし */
  overflow:hidden;
  border:1px solid var(--line);
  aspect-ratio:3/4;
  display:flex; align-items:center; justify-content:center;
  max-width:520px; margin:0 auto;
}
.preview-wrap .placeholder{
  color:var(--ink-soft);
  font-size:14px; text-align:center; padding:24px;
  font-weight:600;
}
#outImg{
  display:block; width:100%; height:auto;
  user-select:none; -webkit-user-select:none;
  -webkit-touch-callout:default;
}
.save-hint{
  margin:12px auto 0; max-width:520px;
  padding:11px 14px;
  border-radius:8px;
  background:#241417;
  border:1px solid var(--red-deep);
  color:#ffb3ba;
  font-size:13px; text-align:center; font-weight:700; line-height:1.55;
}
.save-hint .em{
  display:inline-block;
  background:var(--red); color:#fff;
  padding:1px 9px; border-radius:4px; margin:0 2px;
}

/* ---------------- Buttons ---------------- */
.btn-row{ display:flex; gap:10px; margin-top:14px; margin-bottom:12px; flex-wrap:wrap; max-width:520px; margin-left:auto; margin-right:auto; }
.btn{
  flex:1 1 auto; min-width:140px;
  background:var(--red);
  color:#fff; border:0; border-radius:8px;
  padding:14px 16px; font-size:15px; font-weight:800;
  font-family:inherit; cursor:pointer; text-decoration:none; text-align:center;
  letter-spacing:.04em;
  -webkit-tap-highlight-color:transparent;
  transition:transform .04s, background .14s;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
}
.btn:hover{ background:var(--red-deep); }
.btn:active{ transform:translateY(1px); }
.btn.secondary{
  background:var(--panel-2); color:var(--ink); border:1px solid var(--line-2);
}
.btn.secondary:hover{ background:#2a2e38; }
.btn[disabled]{ opacity:.45; cursor:not-allowed; }

.cta{ display:flex; flex-wrap:wrap; gap:10px; margin-top:20px; justify-content:center; }
.about-cta{ text-align:center; margin:20px 0 12px; }
.btn-pill{
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  background:transparent; color:var(--ink-soft);
  text-decoration:none;
  border:1px solid var(--line-2); border-radius:999px;
  padding:9px 20px; font-size:13px; font-weight:700; letter-spacing:.05em;
  transition:border-color .14s, color .14s;
  -webkit-tap-highlight-color:transparent;
}
.btn-pill:hover{ border-color:var(--red); color:#fff; }

/* ---------------- Magazine Series ---------------- */
.mag-series{
  margin:18px 0 10px;
  padding:16px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--panel);
  box-shadow:var(--shadow);
}
.mag-series-kicker{
  margin:0 0 4px;
  color:var(--red);
  font-size:11px;
  font-weight:800;
  letter-spacing:.14em;
  text-align:center;
}
.mag-series h2{
  margin:0 0 12px;
  color:#fff;
  font-size:16px;
  font-weight:800;
  text-align:center;
}
.mag-series-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(132px,1fr));
  gap:8px;
}
@media (min-width:761px){
  .page-doc .mag-series-grid{ grid-template-columns:repeat(3,minmax(0,1fr)); }
}

.mag-series-link{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:3px;
  min-height:66px;
  padding:10px 9px;
  border:1px solid var(--line-2);
  border-radius:8px;
  background:var(--panel-2);
  color:var(--ink);
  text-align:center;
  text-decoration:none;
  transition:border-color .14s, background .14s, color .14s, transform .06s;
}
.mag-series-link:hover,
.mag-series-link[aria-current="page"]{
  border-color:var(--red);
  color:#fff;
}
.mag-series-link:active{ transform:translateY(1px); }
.mag-series-link[aria-current="page"]{ background:var(--active-bg); }
.mag-series-link strong{
  display:block;
  font-size:12px;
  font-weight:800;
  line-height:1.28;
}
.mag-series-link span{
  display:block;
  color:var(--ink-dim);
  font-size:10.5px;
  font-weight:700;
  line-height:1.25;
}
.mag-series-link[aria-current="page"] span,
.mag-series-link:hover span{ color:var(--ink-soft); }
@media (max-width:760px){
  .mag-series-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:380px){
  .mag-series{ padding:14px; }
  .mag-series-grid{ grid-template-columns:1fr; }
}


/* ---------------- about/license bits ---------------- */
.callout{
  background:#241417; border:1px solid var(--red-deep);
  border-radius:10px; padding:12px 14px;
  color:#ffb3ba; font-size:13.5px; font-weight:700; margin:6px 0 14px;
}
.callout.blue{ background:#0e2030; border-color:#1f6fb0; color:#9fd0ff; }
.callout.gray{ background:var(--panel-2); border-color:var(--line-2); color:var(--ink-soft); }

details{
  border:1px solid var(--line-2); border-radius:10px;
  padding:10px 14px; margin:8px 0; background:var(--panel-2);
}
details[open]{ border-color:var(--red); }
details > summary{
  font-weight:800; cursor:pointer; list-style:none; color:#fff;
  padding:4px 0; position:relative; padding-right:24px;
}
details > summary::-webkit-details-marker{ display:none; }
details > summary::after{
  content:"+"; position:absolute; right:4px; top:50%;
  transform:translateY(-50%); color:var(--red); font-weight:800; font-size:18px;
}
details[open] > summary::after{ content:"\2212"; }
details p{ margin:8px 0 4px; font-size:14px; color:var(--ink); }

.lic{
  padding:14px 16px; border:1px solid var(--line-2);
  border-radius:10px; background:var(--panel-2); margin:0 0 12px;
}
.lic:last-child{ margin-bottom:0; }
.lic-name{ font-size:15px; font-weight:800; color:#fff; margin-bottom:6px; }
.lic-meta{ display:flex; flex-wrap:wrap; gap:6px 8px; margin-bottom:8px; }
.lic-meta span{
  display:inline-block; font-size:11px; font-weight:700;
  color:var(--ink-soft); background:#0c0d10;
  border:1px solid var(--line); border-radius:999px; padding:2px 10px;
}
.lic-desc{ margin:0; font-size:13px; font-weight:500; color:var(--ink); line-height:1.6; }

/* ---------------- Footer ---------------- */
footer{
  text-align:center; color:var(--ink-dim);
  font-size:11px; margin-top:20px; font-weight:600;
}
footer .credits{
  margin-top:8px;
  display:flex; flex-wrap:wrap; gap:6px 10px;
  align-items:center; justify-content:center; font-size:11px;
}
footer .credits a{
  color:var(--ink-dim); text-decoration:none;
  border-bottom:1px dotted var(--ink-dim); padding-bottom:1px;
  transition:color .12s, border-color .12s;
}
footer .credits a:hover{ color:var(--red); border-bottom-color:var(--red); }
footer .credits .sep{ opacity:.5; }

/* ---------------- Helpers ---------------- */
#canvas{ display:none; }
.visually-hidden{
  position:absolute;width:1px;height:1px;
  margin:-1px;padding:0;overflow:hidden;
  clip:rect(0 0 0 0);border:0;
}

/* Genre tuning */
header h1 .badge,.card h2 .step,.drop .ico,.step-title .num{border-radius:999px}.tpl,.card,.drop,input[type=text],textarea{border-radius:18px}.tpl .name{letter-spacing:.04em}
