/* 無名人インタビュー ─ 共有スタイル（白基調・明朝見出し・赤 #CC2936） */
:root{
  --serif:'Shippori Mincho',serif;
  --sans:'Noto Sans JP',sans-serif;
  --accent:#CC2936;
  --accent-soft:rgba(204,41,54,.09);
  --accent-glow:rgba(204,41,54,.26);
  --bg:#fff; --bg-elev:#fafafa;
  --ink:#0a0a0a; --ink-2:#555; --ink-3:#8a8a8a;
  --line:rgba(0,0,0,.08);
  --maxw:440px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;line-height:1.7;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button{font-family:inherit}
::selection{background:var(--accent-soft)}

/* ─ アプリの器（中央スマホ幅・縦フレックス） ─ */
.app{
  display:flex;flex-direction:column;
  height:100dvh;max-width:var(--maxw);margin:0 auto;
  background:var(--bg);position:relative;overflow:hidden;
}
@media(min-width:1000px){
  body{background:#fff}
  .app{border-left:1px solid var(--line);border-right:1px solid var(--line)}
}

/* ─ 上部ブランドバー ─ */
.brandbar{
  flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;
  padding:calc(env(safe-area-inset-top) + 12px) 16px 12px;
  border-bottom:1px solid var(--line);background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:30;
}
.brand{display:inline-flex;align-items:center;gap:7px;color:var(--ink)}
.brand-name{font-family:var(--serif);font-weight:700;font-size:16px;letter-spacing:.04em}
.brand svg{color:var(--ink-3)}
.line-btn{
  display:inline-flex;align-items:center;gap:5px;color:var(--ink-2);
  border:1px solid var(--line);border-radius:100px;padding:7px 13px;
  font-size:12px;font-weight:600;min-height:34px;
}

/* ─ スクロール領域 ─ */
.screen{
  flex:1 1 auto;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  padding:18px 20px calc(env(safe-area-inset-bottom) + 96px);
}
.screen::-webkit-scrollbar{display:none}
.screen{scrollbar-width:none}

/* ─ 下部タブバー ─ */
.tabbar{
  flex:0 0 auto;display:flex;justify-content:space-around;align-items:flex-end;
  padding:8px 4px calc(env(safe-area-inset-bottom) + 10px);
  border-top:1px solid var(--line);background:rgba(255,255,255,.96);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:40;
}
.tab{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;
  color:var(--ink-3);padding:4px 0;min-height:48px;justify-content:center;
}
.tab span{font-size:10px;font-weight:500;letter-spacing:.02em}
.tab.is-active{color:var(--accent)}
.tab.is-active span{font-weight:700}

/* ─ 汎用見出し ─ */
.h-serif{font-family:var(--serif)}
.eyebrow{
  font-size:10.5px;font-weight:700;letter-spacing:.26em;color:var(--accent);
  text-transform:uppercase;
}
.crumbs{
  display:flex;flex-wrap:wrap;align-items:center;gap:6px;
  font-size:11.5px;color:var(--ink-3);margin-bottom:14px;line-height:1.5;
}
.crumbs a{color:var(--ink-2)}
.crumbs a:hover{color:var(--accent)}
.crumbs .sep{color:var(--ink-3)}
.crumbs [aria-current]{color:var(--ink-3)}

/* ─ チップ ─ */
.chips{display:flex;flex-wrap:wrap;gap:7px;margin:12px 0}
.chips-scroll{flex-wrap:nowrap;overflow-x:auto;margin:0 -20px 6px;padding:0 20px 4px}
.chips-scroll::-webkit-scrollbar{display:none}
.chips-wrap{flex-wrap:wrap}
.chip{
  display:inline-flex;align-items:center;gap:6px;white-space:nowrap;
  font-size:12.5px;font-weight:500;padding:7px 13px;border-radius:100px;
  border:1px solid var(--line);color:var(--ink-2);background:transparent;min-height:32px;
}
.chip:hover{border-color:var(--accent);color:var(--accent)}
.chip.is-active{background:var(--accent);border-color:var(--accent);color:#fff}
.chip-plain{color:var(--ink-3)}
.chip-plain:hover{border-color:var(--line);color:var(--ink-3)}
.chip-n{font-size:10.5px;color:var(--ink-3)}
.chip.is-active .chip-n{color:rgba(255,255,255,.7)}

/* ─ インタビュー・カード ─ */
.cards{display:flex;flex-direction:column;gap:13px;margin-top:8px}
.card{
  display:block;background:var(--bg-elev);border:1px solid var(--line);
  border-radius:18px;padding:17px 18px;transition:transform .15s,border-color .15s;
}
.card:hover{border-color:var(--accent);transform:translateY(-1px)}
.card-q{font-family:var(--serif);font-weight:600;color:var(--ink);
  font-size:15.5px;line-height:1.6;text-wrap:pretty}
.card-foot{display:flex;align-items:center;justify-content:space-between;
  margin-top:12px;padding-top:11px;border-top:1px solid var(--line)}
.card-who{font-size:11.5px;color:var(--ink-2)}
.card-go{display:inline-flex;align-items:center;gap:4px;font-size:12px;
  color:var(--accent);font-weight:600;flex-shrink:0}

/* ─ 個別ページ ─ */
.iv-title{font-weight:800;font-size:1.7rem;line-height:1.34;color:var(--ink);
  margin:2px 0 10px;text-wrap:balance}
.iv-meta{font-size:12.5px;color:var(--ink-2);margin-bottom:4px}
.quote-hero{
  font-family:var(--serif);font-weight:600;color:var(--ink);
  font-size:1.32rem;line-height:1.7;text-wrap:pretty;
  border-left:3px solid var(--accent);padding:4px 0 4px 16px;margin:20px 0 8px;
}
.iv-body{margin-top:8px}
.act{margin:24px 0}
.act-h{font-size:1.04rem;font-weight:700;color:var(--accent);margin-bottom:9px;
  letter-spacing:.02em}
.act-p{font-size:17px;line-height:1.95;color:var(--ink);text-wrap:pretty}
.act-q{font-family:var(--serif);font-weight:500;color:var(--ink-2);
  font-size:1.06rem;line-height:1.75;border-left:2px solid var(--line);
  padding-left:14px;margin-top:12px;text-wrap:pretty}
.turning{background:var(--accent-soft);border-radius:14px;padding:15px 17px;margin:18px 0}
.turning-l{font-family:var(--serif);font-weight:700;color:var(--accent);
  font-size:12.5px;letter-spacing:.1em}
.turning p{font-size:14.5px;line-height:1.8;color:var(--ink);margin-top:6px}

/* ─ CTA ─ */
.cta-note,.cta-ghost{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;border-radius:14px;padding:15px 20px;margin-top:18px;
  font-weight:700;font-size:15px;min-height:48px;
}
.cta-note{background:var(--accent);color:#fff;box-shadow:0 6px 18px var(--accent-glow)}
.cta-note:hover{filter:brightness(1.05)}
.cta-ghost{background:transparent;color:var(--ink);border:1px solid var(--line);
  box-shadow:none;margin-top:10px;font-weight:600}
.cta-ghost:hover{border-color:var(--accent);color:var(--accent)}

/* ─ 近い物語 ─ */
.related{margin-top:34px;padding-top:26px;border-top:1px solid var(--line)}
.rel-h{font-size:1.18rem;font-weight:700;color:var(--ink);margin:4px 0 14px}
.rel-more{display:inline-block;margin-top:16px;font-size:13px;font-weight:600;color:var(--accent)}

/* ─ 読む ─ */
.read-title{font-weight:800;font-size:1.75rem;line-height:1.35;margin:8px 0 6px}
.read-sub{font-size:12px;color:var(--ink-3);margin-bottom:16px;line-height:1.7}
.search-box{display:flex;align-items:center;gap:10px;background:var(--bg-elev);
  border:1.5px solid var(--line);border-radius:14px;padding:13px 16px;
  margin-bottom:10px;color:var(--ink-3)}
.search-box input{flex:1;border:none;background:none;outline:none;
  font-family:var(--sans);font-size:15px;color:var(--ink);min-width:0}
.filters{display:flex;gap:10px;margin-bottom:14px}
.filters select{
  flex:1;min-width:0;appearance:none;-webkit-appearance:none;
  background:var(--bg-elev);border:1px solid var(--line);border-radius:11px;
  padding:12px 30px 12px 13px;font-family:var(--sans);font-size:13.5px;font-weight:500;
  color:var(--ink);cursor:pointer;outline:none;min-height:44px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8a8a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right 11px center;
}
.result-count{font-size:12px;color:var(--ink-3);margin:12px 0 6px}
.ghost{display:block;width:100%;background:var(--bg-elev);border:1px solid var(--line);
  border-radius:14px;padding:14px;font-size:14px;font-weight:600;color:var(--ink-2);
  cursor:pointer;margin-top:6px;min-height:48px}
.ghost:hover{border-color:var(--accent);color:var(--accent)}
.watch{margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}
.watch-h{font-size:1.15rem;font-weight:700;margin:4px 0 14px}
.row-link{display:flex;flex-direction:column;gap:2px;background:var(--bg-elev);
  border:1px solid var(--line);border-radius:16px;padding:15px 18px;margin-top:10px}
.row-link:hover{border-color:var(--accent)}
.row-link b{font-family:var(--serif);font-weight:700;font-size:14.5px;color:var(--ink)}
.row-link span{font-size:11.5px;color:var(--ink-3)}

/* ─ ホーム ─ */
.hero{padding:14px 0 6px}
.hero-h{font-weight:800;font-size:2.05rem;line-height:1.32;margin:10px 0 8px;letter-spacing:.01em}
.hero-p{color:var(--ink-2);font-size:1.05rem;margin-bottom:10px}
.hero-sub{font-size:12.5px;color:var(--ink-3);line-height:1.8}
.gateway{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin:20px 0 10px}
.gateway-2{grid-template-columns:1fr 1fr}
.gate{display:flex;flex-direction:column;gap:6px;background:var(--bg-elev);
  border:1px solid var(--line);border-radius:16px;padding:16px 16px 15px;
  transition:transform .15s,border-color .15s;min-height:96px;justify-content:center}
.gate:hover{border-color:var(--accent);transform:translateY(-1px)}
.gate-i{color:var(--accent)}
.gate-l{font-weight:700;font-size:15px;color:var(--ink)}
.gate-s{font-size:10.5px;color:var(--ink-3);line-height:1.5}
.block{margin-top:30px}
.block-h{font-size:1.18rem;font-weight:700;margin:4px 0 14px}
.foot{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px;padding-top:20px;
  border-top:1px solid var(--line);font-size:11.5px;color:var(--ink-3)}
.foot a:hover{color:var(--accent)}

/* ─ タグハブ / 固定ページ見出し ─ */
.hub-title,.page-h{font-weight:800;font-size:1.85rem;line-height:1.3;margin:6px 0 6px;color:var(--ink)}
.hub-sub,.page-lead{font-size:13px;color:var(--ink-3);margin-bottom:18px;line-height:1.7}
.hub-more{font-size:12.5px;color:var(--ink-3);margin-top:14px;text-align:center}
.hub-more a{color:var(--accent);font-weight:600}
.page-p{font-size:15.5px;line-height:1.95;color:var(--ink);margin:14px 0;text-wrap:pretty}

/* ─ About 沿革 ─ */
.hist-wrap{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.hist{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.hist-y{font-weight:700;font-size:15px;color:var(--accent);flex:0 0 46px}
.hist-b b{font-size:14px;color:var(--ink);display:block;margin-bottom:3px}
.hist-b p{font-size:13px;color:var(--ink-2);line-height:1.7}

/* ─ Produce ─ */
.case{display:flex;gap:14px;background:var(--bg-elev);border:1px solid var(--line);
  border-radius:16px;padding:16px;margin-bottom:11px}
.seal{flex:0 0 44px;width:44px;height:44px;border-radius:50%;background:var(--accent);
  color:#fff;display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:600;font-size:19px;
  box-shadow:0 4px 14px var(--accent-glow)}
.case-b b{font-size:14.5px;color:var(--ink);display:block}
.case-who{font-size:11px;color:var(--ink-3);display:block;margin:2px 0 6px}
.case-b p{font-size:13px;color:var(--ink-2);line-height:1.75}
.price{width:100%;border-collapse:collapse;margin:6px 0}
.price td{padding:12px 6px;border-bottom:1px solid var(--line);font-size:13.5px;color:var(--ink)}
.price-c{text-align:right;font-weight:700;color:var(--accent);white-space:nowrap}
.price-note{font-size:12px;color:var(--ink-3);line-height:1.8;margin-top:10px}
.price-note a{color:var(--ink-2);text-decoration:underline}

/* ─ ソフトナビ遷移 ─ */
.screen.is-entering{animation:slideIn .26s ease}
.screen.is-back{animation:slideBack .26s ease}
@keyframes slideIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:none}}
@keyframes slideBack{from{opacity:0;transform:translateX(-18px)}to{opacity:1;transform:none}}

/* ─ ローディング ─ */
.spin{width:30px;height:30px;border-radius:50%;border:3px solid var(--line);
  border-top-color:var(--accent);animation:spin .8s linear infinite;margin:40px auto}
@keyframes spin{to{transform:rotate(360deg)}}
.loading{text-align:center;color:var(--ink-3);font-family:var(--serif);padding:30px}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition:none!important}
}
/* キーボードフォーカス可視化 */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{
  outline:2px solid var(--accent);outline-offset:2px;border-radius:6px;
}

/* ═══ v1.1 追加分 ═══ */
/* ─ ホーム画像（A-1：ゲートのサムネ／note・YouTube行のサムネ／創設者ブロック） ─ */
.gateway-home .gate-photo{padding:0;overflow:hidden;min-height:0;gap:0;justify-content:flex-start}
.gateway-home .gate-thumb{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--bg-elev)}
.gateway-home .gate-thumb img{width:100%;height:100%;object-fit:cover}
.gateway-home .gate-photo .gate-l{margin:11px 14px 0}
.gateway-home .gate-photo .gate-s{margin:3px 14px 14px}
.row-link.has-thumb{flex-direction:row;align-items:center;gap:13px}
.row-link.has-thumb .row-thumb{flex:0 0 92px;width:92px;aspect-ratio:16/10;border-radius:10px;overflow:hidden;background:var(--bg-elev)}
.row-link.has-thumb .row-thumb img{width:100%;height:100%;object-fit:cover}
.row-link.has-thumb .row-body{display:flex;flex-direction:column;gap:2px;min-width:0}
.founder-row{display:flex;align-items:center;gap:15px;background:var(--bg-elev);border:1px solid var(--line);border-radius:18px;padding:16px}
.founder-ph{flex:0 0 84px;width:84px;height:84px;border-radius:50%;overflow:hidden;background:var(--bg)}
.founder-ph img{width:100%;height:100%;object-fit:cover}
.founder-b b{font-size:15px;color:var(--ink);display:block;margin-bottom:4px}
.founder-b p{font-size:12.5px;color:var(--ink-2);line-height:1.7}
.founder-link{display:inline-block;margin-top:8px;font-size:12.5px;font-weight:600;color:var(--accent)}

/* ─ タグ・ページネーション（B-2） ─ */
.pager{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:7px;margin:22px 0 6px}
.pager-n,.pager-arw{display:inline-flex;align-items:center;justify-content:center;min-width:38px;min-height:38px;padding:0 12px;border:1px solid var(--line);border-radius:10px;font-size:13px;font-weight:600;color:var(--ink-2)}
.pager-n:hover,.pager-arw:hover{border-color:var(--accent);color:var(--accent)}
.pager-n.is-cur{background:var(--accent);border-color:var(--accent);color:#fff}
