/* KairosFactory Lab — 共有スタイル（白・黒・グレー基調の実験室テーマ） */
:root{
  --bg:#ffffff; --panel:#f6f7f9; --soft:#fafbfc; --line:#e7e9ee; --line2:#f0f2f6;
  --ink:#14161b; --sub:#5f6772; --faint:#9aa2ad;
  --acc:#E2563C; --acc-soft:rgba(226,86,60,.09); --acc-ink:#b9412b;
  --disp:'Space Grotesk',sans-serif; --mono:'Space Mono',monospace; --jp:'Noto Sans JP',sans-serif;
  --maxw:1080px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--jp);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.75;font-weight:400}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.mono{font-family:var(--mono)} .disp{font-family:var(--disp)}
.ey{font-family:var(--mono);font-size:12px;color:var(--acc);letter-spacing:.1em;display:inline-flex;align-items:center;gap:10px;text-transform:uppercase}
.ey::before{content:'';width:24px;height:1px;background:var(--acc)}

/* header */
.lab-hd{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.lab-hd .wrap{display:flex;align-items:center;justify-content:space-between;height:60px}
.lab-logo{display:inline-flex;align-items:center;gap:10px}
.lab-logo svg{width:17px;height:23px;display:block}
.lab-logo .t{font-family:var(--disp);font-weight:600;font-size:15px;letter-spacing:-.01em}
.lab-logo .t b{color:var(--acc);font-weight:700}
.lab-back{font-family:var(--mono);font-size:12px;color:var(--sub);transition:.15s}
.lab-back:hover{color:var(--acc)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--mono);font-size:13px;
  padding:13px 22px;border-radius:3px;transition:.15s;cursor:pointer;border:0;background:none;-webkit-appearance:none;appearance:none;letter-spacing:.02em}
.btn-fill{background:var(--acc);color:#fff;font-weight:700}
.btn-fill:hover{filter:brightness(1.06)}
.btn-line{border:1px solid var(--line);color:var(--ink);background:#fff}
.btn-line:hover{border-color:var(--acc);color:var(--acc)}
.btn-ghost{color:var(--sub);border:1px solid var(--line)}
.btn-ghost:hover{color:var(--ink)}

/* free badge */
.free-badge{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;color:var(--acc-ink);
  background:var(--acc-soft);border:1px solid rgba(226,86,60,.22);border-radius:999px;padding:5px 12px;letter-spacing:.04em}

/* hero */
.lab-hero{padding:64px 0 40px;border-bottom:1px solid var(--line)}
.lab-hero h1{font-family:var(--disp);font-weight:700;font-size:clamp(34px,7vw,68px);line-height:1.02;letter-spacing:-.025em;margin:22px 0 0}
.lab-hero .sub{margin-top:20px;font-size:clamp(15px,2.2vw,19px);font-weight:700;color:var(--ink);max-width:30ch}
.lab-hero .lead{margin-top:16px;font-size:14.5px;color:var(--sub);max-width:54ch;line-height:1.95}
.lab-hero .acts{margin-top:30px;display:flex;flex-wrap:wrap;gap:12px}

/* sections */
.sec{padding:54px 0}
.sec-h{font-family:var(--disp);font-weight:700;font-size:clamp(22px,3.4vw,30px);letter-spacing:-.02em;margin:14px 0 6px}
.sec-d{color:var(--sub);font-size:14px;margin-bottom:8px}

/* category chips */
.cats{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.cat{font-family:var(--jp);font-size:13px;font-weight:500;border:1px solid var(--line);background:#fff;color:var(--sub);
  border-radius:999px;padding:8px 16px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:8px}
.cat:hover{border-color:var(--acc);color:var(--ink)}
.cat.on{background:var(--ink);border-color:var(--ink);color:#fff}
.cat .n{font-family:var(--mono);font-size:10px;opacity:.6}

/* tool cards */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;margin-top:26px}
.card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;background:#fff;overflow:hidden;transition:.18s;position:relative}
.card:hover{border-color:#d4d7de;box-shadow:0 12px 34px rgba(20,22,27,.07);transform:translateY(-2px)}
.card.soon{opacity:.66}
.card .top{padding:20px 20px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.card .badge{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--sub);border:1px solid var(--line);border-radius:999px;padding:3px 10px;white-space:nowrap}
.card .badge.cat-b{color:var(--acc-ink);border-color:rgba(226,86,60,.25);background:var(--acc-soft)}
.card .badge.soon-b{color:var(--faint)}
.card h3{font-family:var(--jp);font-weight:700;font-size:18px;line-height:1.5;padding:14px 20px 0;letter-spacing:.01em}
.card .learn{padding:8px 20px 0;font-size:13px;color:var(--sub);line-height:1.7;flex:1}
.card .specs{display:flex;gap:16px;padding:14px 20px;margin-top:10px}
.card .spec{display:flex;flex-direction:column;gap:2px}
.card .spec .k{font-family:var(--mono);font-size:9px;color:var(--faint);letter-spacing:.08em}
.card .spec .v{font-size:12.5px;font-weight:700;color:var(--ink)}
.card .go{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--line2);font-family:var(--mono);font-size:13px;color:var(--acc);font-weight:700;transition:.15s}
.card:hover .go{background:var(--acc-soft)}
.card .go.disabled{color:var(--faint);background:none}

/* tool page: form */
.tool-main{padding:40px 0 20px}
.tool-intro{max-width:60ch}
.tool-intro h1{font-family:var(--disp);font-weight:700;font-size:clamp(28px,5vw,44px);letter-spacing:-.02em;line-height:1.05;margin:18px 0 0}
.tool-intro .desc{margin-top:16px;color:var(--sub);font-size:14.5px;line-height:1.95}
.panel{border:1px solid var(--line);border-radius:16px;background:var(--soft);padding:26px;margin-top:30px}
.field{margin-bottom:18px}
.field:last-child{margin-bottom:0}
.field label{display:block;font-size:13.5px;font-weight:700;margin-bottom:8px}
.field .hint{font-weight:400;color:var(--faint);font-size:12px;font-family:var(--mono);margin-left:6px}
.field input,.field select{width:100%;font-family:var(--jp);font-size:16px;color:var(--ink);background:#fff;border:1.5px solid var(--line);
  border-radius:10px;padding:13px 15px;outline:none;transition:.15s}
.field input:focus,.field select:focus{border-color:var(--acc);box-shadow:0 0 0 3px var(--acc-soft)}
.field .row{display:flex;align-items:center;gap:10px}
.field .row input{flex:1}
.field .unit{font-family:var(--mono);font-size:13px;color:var(--sub);flex-shrink:0}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:520px){.grid2{grid-template-columns:1fr}}
.run-wrap{margin-top:24px}
.run-wrap .btn{width:100%;font-size:15px;padding:16px}

/* yes/no diagnostic */
.q{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:15px 0;border-bottom:1px solid var(--line)}
.q:last-of-type{border-bottom:0}
.q .qt{font-size:14.5px;font-weight:500;line-height:1.6}
.q .yn{display:flex;gap:7px;flex-shrink:0}
.q .yn button{font-family:var(--mono);font-size:12px;font-weight:700;border:1.5px solid var(--line);background:#fff;color:var(--sub);
  border-radius:999px;padding:8px 16px;cursor:pointer;transition:.12s}
.q .yn button.yes.on{background:var(--ink);border-color:var(--ink);color:#fff}
.q .yn button.no.on{background:var(--acc);border-color:var(--acc);color:#fff}

/* results */
.result{margin-top:30px;display:none}
.result.show{display:block;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.res-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
.res-card{border:1px solid var(--line);border-radius:14px;padding:22px 20px;background:#fff;text-align:center}
.res-card.hero-num{background:var(--ink);color:#fff;border-color:var(--ink)}
.res-card.hero-num .num{color:#fff}
.res-card.acc-num{background:var(--acc);border-color:var(--acc)}
.res-card.acc-num .num,.res-card.acc-num .k,.res-card.acc-num .u{color:#fff}
.res-card .k{font-family:var(--mono);font-size:10.5px;color:var(--faint);letter-spacing:.08em;margin-bottom:10px}
.res-card .num{font-family:var(--disp);font-weight:700;font-size:clamp(30px,7vw,46px);line-height:1;letter-spacing:-.02em;color:var(--ink)}
.res-card .u{font-family:var(--mono);font-size:13px;color:var(--sub);margin-left:4px}
.score-wrap{border:1px solid var(--line);border-radius:14px;padding:24px;background:#fff;text-align:center}
.score-num{font-family:var(--disp);font-weight:700;font-size:clamp(44px,11vw,72px);line-height:1;letter-spacing:-.03em}
.score-bar{height:10px;border-radius:999px;background:var(--line);overflow:hidden;margin:18px 0 6px}
.score-bar i{display:block;height:100%;background:var(--acc);border-radius:999px;transition:width .8s ease}
.score-label{font-family:var(--mono);font-size:12px;color:var(--sub)}
.comment{margin-top:18px;border-left:3px solid var(--acc);background:var(--acc-soft);border-radius:0 10px 10px 0;padding:16px 18px;font-size:14px;line-height:1.85;color:#7a3322}
.points{margin-top:18px;display:flex;flex-direction:column;gap:10px}
.point{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:#fff}
.point .ic{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--acc-soft);color:var(--acc-ink);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;font-weight:700;margin-top:1px}
.point .pt{font-size:13.5px;line-height:1.7}
.point .pt b{font-weight:700}
.point .pt span{color:var(--sub);display:block;margin-top:2px;font-size:12.5px}

/* share */
.share{margin-top:22px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.share .lbl{font-family:var(--mono);font-size:11px;color:var(--faint);letter-spacing:.06em}
.share a,.share button{font-family:var(--mono);font-size:12px;font-weight:700;border:1px solid var(--line);background:#fff;color:var(--ink);
  border-radius:999px;padding:9px 15px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:7px}
.share a:hover,.share button:hover{border-color:var(--acc);color:var(--acc)}

/* contact CTA */
.cta-sec{border-top:1px solid var(--line);background:var(--panel);margin-top:50px}
.cta-sec .wrap{padding:54px 22px}
.cta-sec h2{font-family:var(--jp);font-weight:700;font-size:clamp(19px,3vw,26px);line-height:1.6;margin:14px 0 6px;max-width:30ch}
.cta-sec p{color:var(--sub);font-size:14px;line-height:1.9;max-width:50ch}
.cta-sec .btns{margin-top:24px;display:flex;flex-wrap:wrap;gap:12px}

/* footer */
.lab-foot{border-top:1px solid var(--line);padding:30px 0;color:var(--faint);font-family:var(--mono);font-size:11px;letter-spacing:.04em}
.lab-foot .wrap{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center}
.lab-foot a{color:var(--sub)}
.lab-foot a:hover{color:var(--acc)}
