/* components.css ― aiojt.jp UIコンポーネント（BEM風）。tokens/base/layout の後。 */

/* ── グローバルヘッダー ── */
.site-top{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--c-surface) 88%,transparent);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--c-line)}
.site-top__in{display:flex;align-items:center;gap:var(--sp-4);padding-block:var(--sp-3)}
.brand{display:flex;align-items:center;gap:var(--sp-2);font-weight:800;font-size:var(--fs-20);color:var(--c-text);text-decoration:none;letter-spacing:-.02em}
.brand:hover{text-decoration:none}
.brand__mark{width:28px;height:28px;border-radius:8px;background:var(--grad-agent);box-shadow:var(--sh-1)}
.site-top__spacer{flex:1}
.site-top__nav{display:flex;align-items:center;gap:var(--sp-2)}
@media(max-width:900px){.site-top__hideSp{display:none}}

/* レンズ切替（セグメント） */
.lens{display:inline-flex;background:var(--c-surface-2);border:1px solid var(--c-line);border-radius:var(--r-pill);padding:3px}
.lens a{font-size:var(--fs-14);font-weight:600;color:var(--c-text-sub);padding:.4em .9em;border-radius:var(--r-pill);text-decoration:none;display:inline-flex;gap:.4em;align-items:center}
.lens a[aria-current="true"]{background:var(--c-surface);color:var(--c-text);box-shadow:var(--sh-1)}

/* 個人⇄法人トグル */
.persona{display:inline-flex;border:1px solid var(--c-line);border-radius:var(--r-pill);overflow:hidden}
.persona button{background:none;border:0;padding:.45em 1em;font-size:var(--fs-14);font-weight:700;cursor:pointer;color:var(--c-text-sub)}
.persona button[aria-pressed="true"]:first-child{background:var(--c-accent-person-soft);color:var(--c-accent-person)}
.persona button[aria-pressed="true"]:last-child{background:var(--c-accent-biz-soft);color:var(--c-accent-biz)}

/* テーマトグル */
.icon-btn{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--c-line);background:var(--c-surface);border-radius:var(--r-md);cursor:pointer;color:var(--c-text)}
.icon-btn:hover{border-color:var(--c-primary)}

/* ── ボタン ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:700;font-size:var(--fs-14);
  padding:.7em 1.2em;border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;text-decoration:none;
  transition:transform var(--mo-fast) var(--ease),background var(--mo-fast),border-color var(--mo-fast),box-shadow var(--mo-fast)}
.btn:hover{text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--c-primary);color:var(--c-primary-ink)}
.btn--primary:hover{box-shadow:var(--sh-2)}
.btn--ghost{background:var(--c-surface);color:var(--c-text);border-color:var(--c-line)}
.btn--ghost:hover{border-color:var(--c-primary);color:var(--c-primary)}
.btn--agent{background:var(--grad-energy);background-size:240% 240%;color:#fff;border:0;animation:fx-flow 6s linear infinite;box-shadow:0 6px 22px rgba(230,0,51,.28)}
.btn--agent:hover{box-shadow:var(--glow-strong);transform:translateY(-2px)}
@media (prefers-reduced-motion:reduce){.btn--agent{animation:none}}
.btn--lg{font-size:var(--fs-16);padding:.85em 1.5em}
.btn--block{width:100%}
.btn--pill{border-radius:var(--r-pill)}

/* ── チップ／バッジ ── */
.chip{display:inline-flex;align-items:center;gap:.4em;font-size:var(--fs-12);font-weight:700;padding:.3em .8em;border-radius:var(--r-pill);border:1px solid var(--c-line);color:var(--c-text-sub);background:var(--c-surface)}
.chip--demo{background:var(--grad-agent-soft);border-color:transparent;color:var(--c-primary)}
.chip--person{background:var(--c-accent-person-soft);color:var(--c-accent-person);border-color:transparent}
.chip--biz{background:var(--c-accent-biz-soft);color:var(--c-accent-biz);border-color:transparent}
.chip--new{background:var(--c-primary-soft);color:var(--c-primary);border-color:transparent}
.chip--ok{background:color-mix(in srgb,var(--c-success) 14%,transparent);color:var(--c-success);border-color:transparent}
.dot{width:8px;height:8px;border-radius:50%;background:currentColor;display:inline-block}

/* ── カード ── */
.card{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-lg);padding:var(--sp-6);transition:transform var(--mo-base) var(--ease),box-shadow var(--mo-base),border-color var(--mo-base)}
.card--link:hover{transform:translateY(-3px);box-shadow:var(--sh-2);border-color:transparent}
.card--feature{background:var(--grad-agent-soft);border-color:transparent}
.card__eyebrow{font-family:var(--font-mono);font-size:var(--fs-12);letter-spacing:.1em;text-transform:uppercase;color:var(--c-secondary)}
.card__title{font-size:var(--fs-20);font-weight:700;margin:.3em 0}
.card__body{color:var(--c-text-sub);font-size:var(--fs-14)}
.card__foot{margin-top:var(--sp-4);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2)}

/* SaaSカード */
.saas{display:flex;flex-direction:column;gap:var(--sp-2)}
.saas__icon{width:44px;height:44px;border-radius:var(--r-md);background:var(--grad-agent-soft);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--c-primary);margin-bottom:var(--sp-2)}
.saas__metrics{display:flex;gap:var(--sp-4);margin-top:var(--sp-3);font-size:var(--fs-12);color:var(--c-text-mute)}
.saas__actions{margin-top:auto;padding-top:var(--sp-4);align-items:stretch}
/* 公開DEMO口座（ID/PW を平文掲示してDEMOへ誘導） */
.acct{margin-top:var(--sp-3);border:1px dashed var(--c-line);border-radius:var(--r-md);padding:var(--sp-3);background:var(--c-surface-2)}
.acct__h{font-size:var(--fs-12);font-weight:700;color:var(--c-text-sub);margin-bottom:var(--sp-2);display:flex;align-items:center;gap:.4em}
.acct__h::before{content:"";width:.6em;height:.6em;border-radius:50%;background:var(--c-success)}
.acct__row{display:flex;align-items:center;gap:.5em;font-size:var(--fs-13);padding:.2em 0}
.acct__role{flex:0 0 6.5em;color:var(--c-text-mute);font-size:var(--fs-12)}
.acct code{font-family:var(--font-mono);background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-sm);padding:.12em .5em;font-size:var(--fs-13);user-select:all}
.acct__sep{color:var(--c-text-mute)}
.acct__note{margin-top:var(--sp-3);font-size:var(--fs-12)}
/* カード下部をそろえる（等高カード） */
.saas__foot{margin-top:auto;padding-top:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2)}

/* プラン */
.plan{display:flex;flex-direction:column}
.plan--featured{border-color:var(--c-primary);box-shadow:var(--sh-2);position:relative}
.plan__price{font-size:var(--fs-40);font-weight:800;font-feature-settings:"tnum" 1}
.plan__price small{font-size:var(--fs-14);font-weight:500;color:var(--c-text-mute)}
.plan__list{list-style:none;padding:0;margin:var(--sp-4) 0;display:flex;flex-direction:column;gap:.6em;font-size:var(--fs-14)}
.plan__list li{display:flex;gap:.5em}
.plan__list li::before{content:"";flex:0 0 auto;width:1em;height:1em;margin-top:.35em;background:var(--c-success);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M20 6L9 17l-5-5' fill='none' stroke='black' stroke-width='3'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M20 6L9 17l-5-5' fill='none' stroke='black' stroke-width='3'/></svg>") center/contain no-repeat}

/* KPI / データ */
.kpi{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-md);padding:var(--sp-4)}
.kpi__n{font-size:var(--fs-32);font-weight:800;font-feature-settings:"tnum" 1;line-height:1}
.kpi__l{font-size:var(--fs-12);color:var(--c-text-sub);margin-top:var(--sp-1)}
.table{width:100%;border-collapse:collapse;font-size:var(--fs-14)}
.table th,.table td{text-align:left;padding:.7em .6em;border-bottom:1px solid var(--c-line)}
.table th{color:var(--c-text-sub);font-weight:600}
.statuschip{font-family:var(--font-mono);font-size:var(--fs-12);padding:.2em .6em;border-radius:var(--r-sm);background:var(--c-surface-2);display:inline-flex;gap:.4em;align-items:center}
.statuschip--run{color:var(--c-success)} .statuschip--stop{color:var(--c-text-mute)} .statuschip--warn{color:var(--c-warn)}

/* ── ジャーニーレール ── */
.journey{position:fixed;left:0;top:0;bottom:0;width:72px;z-index:50;background:var(--c-surface);border-right:1px solid var(--c-line);display:flex;flex-direction:column;align-items:center;padding-top:84px;gap:var(--sp-2)}
.journey__step{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--c-text-mute);text-decoration:none;width:100%;padding:8px 0}
.journey__dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--c-line);background:var(--c-surface);z-index:2;transition:transform var(--mo-base) var(--ease)}
.journey__step:hover .journey__dot{transform:scale(1.25);border-color:var(--c-primary)}
.journey__step[aria-current="true"] .journey__dot{background:var(--grad-energy);background-size:200% 200%;border-color:transparent;box-shadow:0 0 0 4px var(--c-primary-soft),var(--glow-strong);animation:fx-pulse 3s ease-in-out infinite,fx-flow 5s linear infinite}
.journey__step[aria-current="true"] .journey__lbl{color:var(--c-primary);font-weight:800}
.journey__step::before{content:"";position:absolute;top:-50%;left:50%;transform:translateX(-50%);width:2px;height:100%;background:var(--c-line)}
.journey__step[aria-current="true"]::before{background:var(--grad-energy);background-size:100% 200%;animation:fx-flow 4s linear infinite}
@media (prefers-reduced-motion:reduce){.journey__step[aria-current="true"] .journey__dot,.journey__step[aria-current="true"]::before{animation:none}}
.journey__step:first-child::before{display:none}
.journey__lbl{font-size:9px;font-weight:700;text-align:center;line-height:1.1}
@media(max-width:900px){.journey{display:none}}
/* モバイル横ステッパー */
.journey-mob{display:none}
@media(max-width:900px){.journey-mob{display:flex;gap:var(--sp-2);overflow-x:auto;padding:var(--sp-3) var(--sp-4);background:var(--c-surface);border-bottom:1px solid var(--c-line);position:sticky;top:57px;z-index:40}
  .journey-mob a{flex:0 0 auto;font-size:var(--fs-12);font-weight:700;color:var(--c-text-mute);padding:.3em .7em;border-radius:var(--r-pill);background:var(--c-surface-2)}
  .journey-mob a[aria-current="true"]{background:var(--grad-agent);color:#fff}}

/* ── 常駐エージェントバー ── */
.agentbar{position:fixed;right:var(--sp-6);bottom:var(--sp-6);z-index:70;width:min(420px,calc(100vw - 32px))}
.agentbar__pill{display:flex;align-items:center;gap:var(--sp-2);background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-pill);box-shadow:var(--sh-3);padding:.5em .6em .5em 1em}
.agentbar__pill::before{content:"";width:22px;height:22px;border-radius:50%;background:var(--grad-agent);flex:0 0 auto}
.agentbar input{flex:1;border:0;background:none;outline:none;font-size:var(--fs-14)}
@media(max-width:900px){.agentbar{left:var(--sp-3);right:var(--sp-3);bottom:var(--sp-3);width:auto}}

/* ── 会話的ヒーロー入力 ── */
.agent-input{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-xl);box-shadow:var(--sh-2);padding:var(--sp-3);display:flex;gap:var(--sp-2);align-items:center}
.agent-input input{flex:1;border:0;background:none;outline:none;font-size:var(--fs-20);padding:.4em .6em}
.agent-input .btn{flex:0 0 auto}
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:-20% -10% auto;height:420px;background:var(--grad-agent-soft);filter:blur(40px);opacity:.7;z-index:-1}

/* 提案チップ列 */
.suggest{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-top:var(--sp-3)}
.suggest button{font-size:var(--fs-12);background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-pill);padding:.4em .9em;cursor:pointer;color:var(--c-text-sub)}
.suggest button:hover{border-color:var(--c-primary);color:var(--c-primary)}

/* 空 / スケルトン / トースト */
.empty{text-align:center;color:var(--c-text-mute);padding:var(--sp-12)}
.skeleton{background:linear-gradient(90deg,var(--c-surface-2) 25%,var(--c-line) 37%,var(--c-surface-2) 63%);background-size:400% 100%;animation:sk 1.4s ease infinite;border-radius:var(--r-sm)}
@keyframes sk{0%{background-position:100% 0}100%{background-position:-100% 0}}
.toast{position:fixed;bottom:var(--sp-6);left:50%;transform:translateX(-50%);background:var(--c-ink-900);color:var(--c-bg);padding:.7em 1.2em;border-radius:var(--r-pill);box-shadow:var(--sh-3);z-index:90;font-size:var(--fs-14)}

/* ── フッター ── */
.site-foot{background:var(--c-surface);border-top:1px solid var(--c-line);padding-block:var(--sp-12) var(--sp-6);margin-top:var(--sp-16)}
.site-foot__grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:var(--sp-8)}
@media(max-width:768px){.site-foot__grid{grid-template-columns:1fr 1fr}}
.site-foot h4{font-size:var(--fs-12);text-transform:uppercase;letter-spacing:.1em;color:var(--c-text-mute);margin-bottom:var(--sp-3)}
.site-foot a{display:block;color:var(--c-text-sub);font-size:var(--fs-14);padding:.2em 0;text-decoration:none}
.site-foot a:hover{color:var(--c-primary)}
.site-foot__copy{border-top:1px solid var(--c-line);margin-top:var(--sp-8);padding-top:var(--sp-4);font-size:var(--fs-12);color:var(--c-text-mute)}

/* ── 動画ヒーロー（ヘッダー動画：漆黒×赤・常に暗コンテキスト） ── */
.hero-v{position:relative;overflow:hidden;min-height:clamp(520px,84vh,780px);display:flex;align-items:flex-end;background:#0a0607}
.hero-v__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-v__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,6,7,.18) 0%,rgba(10,6,7,0) 30%,rgba(10,6,7,.55) 72%,rgba(10,6,7,.92) 100%)}
.hero-v__in{position:relative;z-index:3;padding-block:clamp(28px,5vw,60px);color:#fff;width:100%}
.hero-v__kicker{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-mono);font-size:var(--fs-12);letter-spacing:.2em;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.22);padding:.4em .9em;border-radius:var(--r-pill);backdrop-filter:blur(4px)}
.hero-v__sub{color:#f5ebec;font-family:var(--font-disp);font-weight:800;font-size:clamp(1.3rem,3.4vw,2.4rem);line-height:1.2;letter-spacing:-.01em;margin:var(--sp-4) 0;max-width:20ch;text-shadow:0 2px 30px rgba(0,0,0,.5)}
.hero-v__sub .fx-energy-text{filter:drop-shadow(0 0 18px rgba(255,45,85,.4))}
.hero-v .agent-input{box-shadow:0 18px 50px rgba(0,0,0,.4)}
.hero-v .suggest button{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:#fff;backdrop-filter:blur(4px)}
.hero-v .suggest button:hover{background:rgba(255,255,255,.2);border-color:#fff;color:#fff}
.hero-v .u-mute{color:rgba(255,255,255,.7)!important}

/* ── 動画フッター（白地×日の丸ブルーム・適応スクリム） ── */
.site-foot--video{position:relative;overflow:hidden}
.foot-v__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.9}
.foot-v__scrim{position:absolute;inset:0;z-index:1;background:color-mix(in srgb,var(--c-surface) 82%,transparent)}
.site-foot--video > .container,.site-foot--video > .fx-band{position:relative;z-index:2}

