/* Spica site — shared stylesheet（全ページ共通）。
   フォント：Latin は IBM Plex を自前ホスト（/fonts/・外部依存なし）、
   日本語はシステムフォント（Hiragino / Yu Gothic / Noto）にフォールバック＝DLゼロ・軽量・堅牢。 */

/* ---- self-hosted Latin IBM Plex ---- */
@font-face{font-family:"IBM Plex Sans";font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/plex-sans-400.woff2") format("woff2")}
@font-face{font-family:"IBM Plex Sans";font-style:normal;font-weight:500;font-display:swap;src:url("/fonts/plex-sans-500.woff2") format("woff2")}
@font-face{font-family:"IBM Plex Sans";font-style:normal;font-weight:600;font-display:swap;src:url("/fonts/plex-sans-600.woff2") format("woff2")}
@font-face{font-family:"IBM Plex Sans";font-style:normal;font-weight:700;font-display:swap;src:url("/fonts/plex-sans-700.woff2") format("woff2")}
@font-face{font-family:"IBM Plex Serif";font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/plex-serif-400.woff2") format("woff2")}
@font-face{font-family:"IBM Plex Serif";font-style:normal;font-weight:500;font-display:swap;src:url("/fonts/plex-serif-500.woff2") format("woff2")}
@font-face{font-family:"IBM Plex Mono";font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/plex-mono-400.woff2") format("woff2")}
@font-face{font-family:"IBM Plex Mono";font-style:normal;font-weight:500;font-display:swap;src:url("/fonts/plex-mono-500.woff2") format("woff2")}

/* ---- tokens（brand/tokens.json ミラー） ---- */
:root{
  --spica-50:#eef4ff;--spica-500:#1f5fe6;--spica-600:#1549c4;--starlight:#b9d2ff;
  --paper-0:#faf8f3;--paper-1:#fff;--paper-2:#f3f0e8;
  --ink-900:#14161d;--text-body:#3a3e49;--text-muted:#696e7b;--text-faint:#9a9ea8;
  --line:#e7e3d8;--line-soft:#f0ece2;
  --night-950:#0b0d14;--night-900:#0f121b;--night-850:#141826;
  --on-night-900:#f2f4f9;--on-night-700:#c3c9d8;--on-night-500:#8b93a7;--on-night-line:#2a3144;
  --ok-500:#2e9e6b;
  --bg-page:var(--paper-0);--surface-card:var(--paper-1);--surface-sunken:var(--paper-2);
  --accent:var(--spica-500);--accent-hover:var(--spica-600);
  --radius-md:8px;--radius-lg:12px;--radius-pill:999px;
  --shadow-xs:0 1px 1px rgba(20,22,29,.04);
  --shadow-md:0 4px 12px rgba(20,22,29,.07),0 1px 3px rgba(20,22,29,.05);
  --dur:200ms;--ease:cubic-bezier(.22,.61,.36,1);
  /* Latin=自前Plex / 日本語=システム（Plex JPは重いため不採用） */
  --font-sans:"IBM Plex Sans","Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic","Noto Sans JP",system-ui,sans-serif;
  --font-serif:"IBM Plex Serif","Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic","Noto Sans JP",Georgia,serif;
  --font-mono:"IBM Plex Mono",ui-monospace,"SFMono-Regular",Menlo,monospace;
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;background:var(--bg-page);color:var(--text-body);font-family:var(--font-sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;color:var(--ink-900);letter-spacing:-.018em;line-height:1.15}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
.eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted)}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;border-radius:var(--radius-md);padding:12px 18px;min-height:44px;border:1px solid transparent;cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.btn-light{background:#fff;color:var(--ink-900)}
.btn-light:hover{background:var(--starlight)}
.btn-outline{background:transparent;color:var(--on-night-900);border-color:var(--on-night-line)}
.btn-outline:hover{background:rgba(255,255,255,.06)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-hover)}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:13px;padding:5px 12px;border-radius:var(--radius-pill);border:1px solid}
.pill-night{color:var(--on-night-700);border-color:var(--on-night-line);background:rgba(255,255,255,.03)}
.pill-ok{color:var(--ok-500);border-color:var(--ok-500);background:transparent}
.pill-accent{color:var(--accent);border-color:var(--accent);background:var(--spica-50)}
.pill-neutral{color:var(--text-muted);border-color:var(--line);background:var(--surface-sunken)}
:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 45%,transparent);outline-offset:2px}

/* nav（home・night） */
.nav{position:sticky;top:0;z-index:20;background:rgba(11,13,20,.72);backdrop-filter:blur(12px);border-bottom:1px solid var(--on-night-line)}
.nav .wrap{height:66px;display:flex;align-items:center;justify-content:space-between}
.nav nav{display:flex;align-items:center;gap:30px;font-size:14.5px;color:var(--on-night-700)}
@media(max-width:680px){.nav nav a:not(.btn){display:none}}

/* topbar（コンテンツ系ページ・light） */
.topbar{border-bottom:1px solid var(--line);background:var(--bg-page);position:sticky;top:0;z-index:20}
.topbar .wrap{height:60px;display:flex;align-items:center;justify-content:space-between}
.topbar .home{display:flex;align-items:center;gap:8px}
.topbar nav{display:flex;gap:22px;font-size:14px;color:var(--text-muted)}
@media(max-width:680px){.topbar nav a{display:none}}

/* hero */
.hero{position:relative;overflow:hidden;color:var(--on-night-900);
  background:radial-gradient(120% 90% at 72% -10%,rgba(31,95,230,.22) 0%,transparent 58%),linear-gradient(180deg,var(--night-950),var(--night-900) 62%,var(--night-850))}
.starfield{position:absolute;inset:0;opacity:.5;background-image:
  radial-gradient(1.4px 1.4px at 12% 28%,#fff 50%,transparent),radial-gradient(1px 1px at 78% 18%,#cfe0ff 50%,transparent),
  radial-gradient(1.6px 1.6px at 64% 62%,#fff 50%,transparent),radial-gradient(1px 1px at 32% 72%,#aebfff 50%,transparent),
  radial-gradient(1.2px 1.2px at 88% 78%,#fff 50%,transparent),radial-gradient(1px 1px at 46% 36%,#dfe9ff 50%,transparent)}
.hero .star{position:absolute;top:-40px;right:8%;width:120px;height:120px;opacity:.9;filter:drop-shadow(0 4px 22px rgba(31,95,230,.5))}
.hero .wrap{position:relative;padding:118px 32px 104px}
.hero h1{font-family:var(--font-serif);font-weight:500;font-size:62px;line-height:1.12;color:#fff;margin:22px 0 0}
.hero p.lead{font-size:19px;line-height:1.7;color:var(--on-night-700);margin:26px 0 0;max-width:600px}
.hero .ctas{display:flex;gap:12px;margin-top:36px;flex-wrap:wrap}
.hero .pills{display:flex;gap:10px;margin-top:40px;flex-wrap:wrap}
@media(max-width:680px){.hero h1{font-size:40px}.hero .wrap{padding:80px 32px 72px}}

/* sections */
.section{border-bottom:1px solid var(--line)}
.spine .wrap{padding:92px 32px;display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.spine h2{font-family:var(--font-serif);font-weight:500;font-size:38px;line-height:1.25;margin:16px 0 0}
.spine p{font-size:17px;line-height:1.85;margin:0;max-width:60ch;color:var(--text-body)}
.stats{display:flex;gap:28px;margin-top:6px;flex-wrap:wrap}
.stats .n{font-family:var(--font-mono);font-size:30px;font-weight:500;color:var(--accent);letter-spacing:-.02em}
.stats .l{font-size:13px;color:var(--text-muted);margin-top:2px}
@media(max-width:760px){.spine .wrap{grid-template-columns:1fr;gap:28px}}

.apps{background:var(--surface-sunken)}
.apps .wrap{padding:88px 32px}
.apps .head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px}
.apps h2{font-family:var(--font-serif);font-weight:500;font-size:36px;margin:14px 0 0}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:38px}
.card{display:flex;flex-direction:column;height:100%;background:var(--surface-card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px;box-shadow:var(--shadow-xs);transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease)}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.card .top{display:flex;align-items:flex-start;justify-content:space-between}
.card .ic{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:var(--radius-md);background:var(--spica-50);color:var(--spica-600)}
.card h3{font-size:21px;font-weight:600;margin:20px 0 0;display:flex;align-items:baseline;gap:8px}
.card h3 .tt{font-size:12px;font-weight:400;color:var(--text-faint)}
.card p{font-size:14.5px;line-height:1.7;color:var(--text-body);margin:10px 0 0;flex:1}
.meta{border-top:1px solid var(--line-soft);margin-top:20px;padding-top:16px;display:grid;grid-template-columns:auto 1fr;gap:7px 14px;font-size:13px}
.meta .k{color:var(--text-faint)}.meta .v{color:var(--text-body)}.meta .price{font-family:var(--font-mono);color:var(--ink-900)}

/* workflow */
.flowsec .wrap{padding:84px 32px}
.flowsec h2{font-family:var(--font-serif);font-weight:500;font-size:36px;margin:14px 0 0}
.flowsec .intro{font-size:17px;line-height:1.85;color:var(--text-body);margin:14px 0 0;max-width:64ch}
.flab{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-top:34px}
.flow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:14px}
.flow .step{flex:1 1 150px;background:var(--surface-card);border:1px solid var(--line);border-radius:var(--radius-md);padding:14px 16px;box-shadow:var(--shadow-xs)}
.flow .step.ext{background:transparent;border-style:dashed;box-shadow:none}
.flow .step .ph{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--text-faint)}
.flow .step .ap{font-weight:600;color:var(--ink-900);font-size:15px;margin-top:4px}
.flow .step.ext .ap{color:var(--text-muted);font-weight:500}
.flow .arrow{flex:0 0 auto;color:var(--accent);font-size:18px;font-weight:600}
@media(max-width:700px){.flow{flex-direction:column;align-items:stretch}.flow .arrow{transform:rotate(90deg);align-self:center}}

/* promise */
.promise{background:var(--bg-page)}
.promise .wrap{padding:88px 32px}
.promise .cols{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:30px}
.promise .col{border-top:2px solid var(--accent);padding-top:22px}
.promise h3{font-size:19px;font-weight:600;margin:16px 0 0}
.promise p{font-size:15px;line-height:1.75;color:var(--text-body);margin:9px 0 0}
@media(max-width:760px){.promise .cols{grid-template-columns:1fr}}

/* content / legal / LP pages */
.page{max-width:760px;margin:0 auto;padding:56px 32px 96px}
.page h1{font-family:var(--font-serif);font-weight:500;font-size:34px;margin:0 0 8px}
.page .lead{color:var(--text-muted);margin:0 0 8px;font-size:15px}
.page .updated{font-family:var(--font-mono);font-size:12px;color:var(--text-faint);margin:0 0 28px}
.page h2{font-size:20px;margin:34px 0 10px}
.page p,.page li{font-size:15px;line-height:1.85;color:var(--text-body)}
.page ul{padding-left:1.3em;margin:8px 0}
.page strong{color:var(--ink-900)}
.page .note{background:var(--surface-sunken);border:1px solid var(--line);border-radius:var(--radius-md);padding:14px 16px;font-size:13.5px;color:var(--text-muted);margin:24px 0}
.page table{border-collapse:collapse;width:100%;font-size:14px;margin:14px 0}
.page th,.page td{border:1px solid var(--line);padding:9px 12px;text-align:left;vertical-align:top}
.page th{background:var(--surface-sunken);white-space:nowrap;width:34%}
.backlink{display:inline-block;margin-top:24px;color:var(--accent);font-size:14px}
.codeblock{font-family:var(--font-mono);font-size:13.5px;background:var(--night-900);color:var(--on-night-900);border-radius:var(--radius-md);padding:14px 16px;overflow-x:auto;margin:14px 0}
.codeblock .c{color:var(--on-night-500)}
.note-lg{background:var(--surface-sunken);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--radius-md);padding:18px 20px;margin:18px 0}

/* footer */
.foot{background:var(--night-900);color:var(--on-night-700)}
.foot .wrap{padding:56px 32px 40px}
.foot .row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:32px}
.foot .cols{display:flex;gap:56px;flex-wrap:wrap}
.foot .h{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--on-night-500)}
.foot .links{display:flex;flex-direction:column;gap:9px;margin-top:14px;font-size:14px;color:var(--on-night-700)}
.foot .bot{border-top:1px solid var(--on-night-line);margin-top:44px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12.5px;color:var(--on-night-500)}
.foot .bot .mono{font-family:var(--font-mono)}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}
