:root{
  --bg:#fff;--bg2:#f4f6f9;--bg3:#eceff3;--ink:#111723;--ink2:#39414f;--mut:#6a7280;--mut2:#9aa1ac;
  --line:#e4e7ec;--line2:#d8dce3;--accent:#fa6400;--accent-d:#d9540f;--soft:rgba(250,100,0,.10);--softline:rgba(250,100,0,.28);
  --dark:#0d111a;--darkglow:rgba(250,100,0,.2);
  --fd:"Schibsted Grotesk",sans-serif;--fb:"Hanken Grotesk",sans-serif;--fj:"Zen Kaku Gothic New",sans-serif;--max:1120px;--r:16px;--r-lg:22px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--fb),var(--fj);font-size:16px;line-height:1.9;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(22px,5vw,44px)}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--fd),var(--fj);font-weight:800;letter-spacing:-.01em;line-height:1.2}
.ey{font-family:var(--fb);font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--accent-d);font-weight:700;display:inline-flex;align-items:center;gap:.7em}
.ey::before{content:"";width:26px;height:2px;background:var(--accent);border-radius:2px}
.ey.lt{color:var(--accent)}
.btn{font-family:var(--fb);font-weight:700;font-size:.94rem;padding:.95em 1.8em;border-radius:999px;display:inline-flex;align-items:center;gap:.55em;transition:.22s;border:1.5px solid transparent;cursor:pointer}
.btn.solid{background:var(--accent);color:#fff;box-shadow:0 14px 30px -14px var(--accent)}
.btn.solid:hover{background:var(--accent-d);transform:translateY(-2px)}
.btn.line{border-color:var(--line2);color:var(--ink)}
.btn.line:hover{border-color:var(--ink)}
.btn.ondark{background:var(--accent);color:#fff}
.btn.ondark.ghost{background:transparent;border-color:rgba(255,255,255,.3);color:#fff}

/* nav */
.nav{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;height:66px;gap:20px}
.logo{font-family:var(--fd);font-weight:800;font-size:1.32rem;letter-spacing:.04em}
.logo b{color:var(--accent)}
.menu{margin-left:auto;display:flex;gap:20px;font-size:.86rem;color:var(--ink2);font-weight:500}
.menu a:hover{color:var(--accent-d)}
.nav .btn{padding:.55em 1.15em;font-size:.8rem}
@media(max-width:1000px){.menu{display:none}}

/* hero */
.hero{background:linear-gradient(180deg,var(--bg2),var(--bg));border-bottom:1px solid var(--line);padding:clamp(52px,7vw,84px) 0}
.hero h1{font-size:clamp(2rem,5vw,3.3rem);font-weight:800;font-family:var(--fj);line-height:1.24}
.hero h1 span{color:var(--accent)}
.hero .sub{max-width:640px;margin:1.3em 0 1.8em;color:var(--ink2);font-size:1.04rem}
.hero .acts{display:flex;gap:12px;flex-wrap:wrap}
.cred{display:flex;flex-wrap:wrap;gap:12px 26px;margin-top:clamp(32px,5vw,48px);padding-top:24px;border-top:1px solid var(--line)}
.cred .t{display:flex;align-items:center;gap:.5em;font-size:.88rem;color:var(--ink2);font-weight:500}
.cred .t svg{width:18px;height:18px;color:var(--accent)}

.sec{padding:clamp(50px,6.5vw,86px) 0;border-bottom:1px solid var(--line)}
.sec.tint{background:var(--bg2)}
.head{max-width:720px;margin-bottom:clamp(24px,4vw,40px)}
.head h2{font-size:clamp(1.6rem,3.4vw,2.4rem);margin:.4em 0 .35em;font-family:var(--fj)}
.head .lead{color:var(--mut)}

/* intro / fairino meaning */
.intro{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(26px,4vw,52px);align-items:center}
@media(max-width:840px){.intro{grid-template-columns:1fr;gap:26px}}
.intro p{color:var(--ink2);margin-bottom:1em}
.intro p strong{color:var(--ink);box-shadow:inset 0 -.5em 0 var(--soft)}
.meaning{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 26px}
.meaning .t{font-family:var(--fd);font-weight:800;letter-spacing:.1em;font-size:1.1rem;margin-bottom:14px}
.meaning ul{list-style:none}
.meaning li{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--line);font-size:.92rem;color:var(--ink2)}
.meaning li b{font-family:var(--fd);color:var(--accent-d);width:1.2em;font-size:1.1rem}

/* features 3 */
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:820px){.feat{grid-template-columns:1fr}}
.feat .it{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 26px}
.tint .feat .it{background:#fff}
.feat .ic{width:46px;height:46px;border-radius:12px;background:var(--soft);color:var(--accent-d);display:grid;place-items:center;margin-bottom:15px}
.feat .ic svg{width:24px;height:24px}
.feat h3{font-size:1.16rem;margin-bottom:.4em;font-family:var(--fj)}
.feat p{color:var(--mut);font-size:.94rem}

/* task grid */
.task{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}
@media(max-width:820px){.task{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.task{grid-template-columns:1fr}}
.task .t{display:flex;gap:13px;align-items:center;background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:18px}
.task .ic{width:40px;height:40px;border-radius:11px;background:var(--soft);color:var(--accent-d);display:grid;place-items:center;flex:0 0 auto}
.task .ic svg{width:21px;height:21px}
.task b{font-family:var(--fd);font-size:1rem}
.task small{display:block;color:var(--mut);font-size:.8rem;font-family:var(--fb);font-weight:400}
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px}
.chips span{border:1px solid var(--line2);border-radius:999px;padding:.55em 1.1em;font-size:.86rem;color:var(--ink2);background:var(--bg)}

/* lineup */
.spec{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);overflow-x:auto}
.spec table{width:100%;border-collapse:collapse;min-width:680px}
.spec th,.spec td{padding:14px 12px;text-align:center;border-bottom:1px solid var(--line)}
.spec thead th{background:var(--ink);color:#fff;font-family:var(--fd);font-weight:600;font-size:.9rem}
.spec tbody th{text-align:left;background:var(--bg);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--mut);font-weight:700;white-space:nowrap}
.tint .spec tbody th{background:#fff}
.spec tbody td{font-weight:600}
.spec tbody tr:hover td{background:var(--soft)}
.mguide{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
@media(max-width:820px){.mguide{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.mguide{grid-template-columns:1fr}}
.mguide .m{border:1px solid var(--line);border-radius:var(--r);padding:16px 16px;background:var(--bg)}
.mguide .mn{font-family:var(--fd);font-weight:800}.mguide .mn b{color:var(--accent)}
.mguide .mp{font-family:var(--fd);font-size:1.2rem;margin:3px 0 6px}.mguide .mp i{font-style:normal;font-size:.5em;color:var(--mut)}
.mguide .mu{font-size:.82rem;color:var(--mut);line-height:1.7}
.spec-note{font-size:.8rem;color:var(--mut2);margin-top:14px}

/* why */
.why{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:820px){.why{grid-template-columns:1fr}}
.why .it{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 26px}
.why .no{font-family:var(--fd);font-weight:800;color:var(--accent)}
.why h3{font-size:1.18rem;margin:.5em 0 .4em;font-family:var(--fj)}
.why p{color:var(--mut);font-size:.94rem}

/* FAQ */
.qa{max-width:880px}
.qa .cat{font-family:var(--fd);font-weight:700;font-size:1.05rem;margin:26px 0 12px;color:var(--ink)}
.qa details{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);margin-bottom:10px;overflow:hidden}
.tint .qa details{background:#fff}
.qa details[open]{border-color:var(--softline)}
.qa summary{cursor:pointer;list-style:none;padding:18px 50px 18px 20px;font-weight:700;position:relative;font-size:.98rem}
.qa summary::-webkit-details-marker{display:none}
.qa summary::before{content:"Q";font-family:var(--fd);color:var(--accent-d);margin-right:.6em;font-weight:800}
.qa summary::after{content:"";position:absolute;right:22px;top:50%;width:10px;height:10px;border-right:2px solid var(--mut);border-bottom:2px solid var(--mut);transform:translateY(-65%) rotate(45deg);transition:.25s}
.qa details[open] summary::after{transform:translateY(-30%) rotate(-135deg)}
.qa .a{padding:0 20px 20px;color:var(--ink2);font-size:.94rem;line-height:1.9}

/* flow */
.flow{list-style:none;counter-reset:f;max-width:760px}
.flow li{counter-increment:f;position:relative;padding:16px 0 16px 56px;border-bottom:1px solid var(--line);color:var(--ink2)}
.flow li b{color:var(--ink);font-family:var(--fj)}
.flow li::before{content:counter(f,decimal-leading-zero);position:absolute;left:0;top:14px;font-family:var(--fd);font-weight:800;color:var(--accent);font-size:1.25rem}

/* support links */
.sup{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:760px){.sup{grid-template-columns:1fr}}
.sup a{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;transition:.2s}
.sup a:hover{border-color:var(--softline);transform:translateY(-3px)}
.sup b{font-family:var(--fd);font-size:1.04rem;display:block;margin-bottom:.3em}
.sup p{color:var(--mut);font-size:.88rem}

/* cta */
.cta{position:relative;overflow:hidden;background:var(--dark);color:#fff;border-radius:var(--r-lg);padding:clamp(40px,6vw,68px) clamp(26px,5vw,56px)}
.cta::before{content:"";position:absolute;width:560px;height:560px;right:-160px;top:-220px;border-radius:50%;background:radial-gradient(circle,var(--darkglow),transparent 62%);filter:blur(16px)}
.cta .in{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:center}
.cta h2{font-size:clamp(1.5rem,3.2vw,2.2rem);max-width:560px;font-family:var(--fj)}
.cta p{color:#aeb4c0;margin-top:.6em;max-width:520px}

footer{background:var(--ink);color:#aeb4c0;padding:44px 0 26px}
footer .wrap{display:flex;flex-wrap:wrap;gap:18px 28px;align-items:center}
footer .logo{color:#fff}
footer nav{display:flex;flex-wrap:wrap;gap:18px;font-size:.86rem}
footer nav a:hover{color:#fff}
footer .cp{width:100%;margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);font-size:.8rem;color:var(--mut2)}

/* ===== 追加: ページヘッダ（下層ページ） ===== */
.page-head{background:linear-gradient(180deg,var(--bg2),var(--bg));border-bottom:1px solid var(--line);padding:clamp(44px,6vw,74px) 0 clamp(28px,4vw,44px)}
.page-head .crumb{font-size:.8rem;color:var(--mut)}
.page-head .crumb a:hover{color:var(--accent-d)}
.page-head h1{font-size:clamp(1.7rem,3.6vw,2.6rem);margin-top:.4em;font-family:var(--fj)}

/* ===== 追加: 記事/プライバシー ===== */
.article{max-width:820px}
.article h2{font-size:1.4rem;margin:1.8em 0 .5em;padding-left:.55em;border-left:4px solid var(--accent);font-family:var(--fj)}
.article p{color:var(--ink2);margin-bottom:1em}
.article ul.bul{margin:1em 0 1.6em;padding-left:0;list-style:none}
.article ul.bul li{position:relative;padding-left:1.4em;margin-bottom:.5em;color:var(--ink2)}
.article ul.bul li::before{content:"";position:absolute;left:0;top:.7em;width:8px;height:8px;background:var(--accent);border-radius:2px}
.article hr{border:0;border-top:1px solid var(--line);margin:2.2em 0}
.article .note{font-size:.82rem;color:var(--mut2)}
.data-table{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin:1.2em 0;width:100%;border-collapse:collapse}
.data-table th,.data-table td{padding:13px 15px;border-bottom:1px solid var(--line);text-align:left;font-size:.94rem;vertical-align:top}
.data-table th{background:var(--bg2);font-size:.78rem;letter-spacing:.04em;color:var(--mut);width:32%;font-weight:700;white-space:nowrap}

/* ===== 追加: フォーム ===== */
.form-wrap{max-width:720px}
.field{margin-bottom:20px}
.field label{display:block;font-weight:700;font-size:.9rem;margin-bottom:.45em}
.field .req{color:var(--accent-d);font-size:.7rem;margin-left:.5em;font-weight:700}
.field .opt{color:var(--mut2);font-size:.7rem;margin-left:.5em}
.field input,.field select,.field textarea{width:100%;padding:.8em .95em;border:1px solid var(--line2);border-radius:var(--r);background:var(--bg);font-family:var(--fb),var(--fj);font-size:1rem;color:var(--ink);transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--soft)}
.field textarea{min-height:150px;resize:vertical}
.field-note{font-size:.8rem;color:var(--mut2);margin-top:.4em}
.consent{display:flex;gap:.6em;align-items:flex-start;font-size:.92rem;color:var(--ink2)}
.consent a{color:var(--accent-d);text-decoration:underline}
.form-msg{border-radius:var(--r);padding:18px 20px;margin-bottom:18px;font-size:.95rem}
.form-msg.ok{background:var(--soft);border:1px solid var(--softline);color:var(--accent-d)}
.form-msg.err{background:#fdecec;border:1px solid #f3c0c0;color:#c0392b}
.err-note{color:#c0392b;font-size:.82rem;margin-top:.35em}


/* ===== 追加: 画像ロゴ ===== */
.logo{display:inline-flex;align-items:center;line-height:0}
.logo-img{height:23px;width:auto;display:block}
@media(max-width:480px){.logo-img{height:19px}}
footer .logo-img{height:20px;filter:brightness(0) invert(1)}
