:root{
  /* 明るい薄青系（信頼感＋親しみやすさ） */
  --bg:#f3f7ff;
  --bg2:#e8f1ff;
  --card:#ffffff;
  --card2:#f6f9ff;
  --muted:#425470;
  --text:#0b1b33;
  --line:rgba(11,27,51,.12);
  --accent:#1b74ff;
  --accent2:#00b6d6;
  --shadow: 0 18px 50px rgba(15,35,75,.14);
  --r:18px;
  --r2:26px;
  --container: 1120px;
  --focus: 0 0 0 3px rgba(27,116,255,.25);
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Hiragino Sans", "Noto Sans JP", "Yu Gothic", "Meiryo", sans-serif;
}


/* =========================================================
  Tokens compatibility (benefits header / breadcrumb)
========================================================= */
:root{
  --brand: var(--accent);
  --brand-2: var(--text);
  --border: var(--line);
  --muted-2: var(--muted);
  --radius: var(--r);
  --shadow-sm: var(--shadow);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  /* 全体にラジアル背景をかけると、セクションの透明背景と重なり
     スクロール位置で色が変わって“中途半端”に見えるため、ボディはフラットに固定 */
  background: linear-gradient(180deg, var(--bg2), var(--bg));
  color:var(--text);
  line-height:1.7;
}
a{color:inherit}
img{max-width:100%;height:auto;display:block}
.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:14px;top:14px;width:auto;height:auto;background:#fff;color:#000;padding:10px 12px;border-radius:10px;z-index:9999}
.container{width:min(var(--container), calc(100% - 32px));margin:0 auto}
.narrow{width:min(820px, calc(100% - 32px))}
.center{text-align:center}
.mt-8{margin-top:8px}
.mt-12{margin-top:12px}
.mt-16{margin-top:16px}
.mt-24{margin-top:24px}
.w-100{width:100%}
.nobr{white-space:nowrap}
.muted{color:var(--muted)}
.lead{font-size:1.05rem;color:rgba(11,27,51,.9)}
.kicker{display:inline-flex;gap:10px;align-items:center;font-size:.85rem;color:rgba(11,27,51,.86);letter-spacing:.08em;text-transform:uppercase}
.kicker:before{content:"";width:26px;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent2));opacity:.9}
.grad{background: linear-gradient(90deg, var(--accent), var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent}
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.76);backdrop-filter: blur(10px);border-bottom:1px solid var(--line)}
.header__inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px}
.brand{display:flex;flex-direction:column;gap:4px;align-items:flex-start}
.brand__home{display:flex;gap:12px;align-items:center;text-decoration:none}
.brand__office{margin-left:50px;font-size:.82rem;color:var(--muted);text-decoration:none;border-bottom:1px solid transparent;padding-bottom:2px}
.brand__office:hover{border-bottom-color:rgba(255,255,255,.22)}
.brand__mark{width:38px;height:38px;border-radius:14px;overflow:hidden;box-shadow: 0 10px 25px rgba(0,0,0,.28)}
.brand__logo{width:38px;height:38px}
.brand__text{display:flex;flex-direction:column;line-height:1.2}
.brand__name{font-weight:800;font-size:1rem;letter-spacing:.01em}
.burger{display:none;border:1px solid var(--line);background:rgba(11,27,51,.04);border-radius:14px;padding:10px;width:46px;height:42px}
.burger span{display:block;height:2px;background:rgba(11,27,51,.9);margin:6px 0;border-radius:999px}
.header__nav{display:flex;align-items:center;gap:16px;justify-content:flex-end;flex:1;min-width:0}
.nav{display:flex;gap:6px;align-items:center;flex-wrap:nowrap;white-space:nowrap}
.nav__item{white-space:nowrap}
.nav__item{text-decoration:none;padding:10px 12px;border-radius:12px;color:rgba(11,27,51,.88);border:1px solid transparent}
.nav__item:hover{background:rgba(11,27,51,.06);border-color:var(--line)}
.nav__item.is-active{background:rgba(124,92,255,.12);border-color:rgba(124,92,255,.28)}
.nav__cta{background:linear-gradient(135deg, rgba(124,92,255,.95), rgba(0,212,255,.75));border-color:transparent;color:#08101a;font-weight:800}
.header__contact{display:flex;gap:10px;align-items:center}
.mini{font-size:.85rem;color:rgba(11,27,51,.86);text-decoration:none;padding:8px 10px;border-radius:12px;border:1px solid var(--line);background:rgba(11,27,51,.04)}
.mini:hover{background:rgba(11,27,51,.06)}
.mini:focus{outline:none;box-shadow:var(--focus)}
.breadcrumbs{border-bottom:1px solid var(--line);background:rgba(255,255,255,.55)}
.breadcrumbs ol{list-style:none;margin:0;padding:10px 0;display:flex;flex-wrap:wrap;gap:10px}
.breadcrumbs li{font-size:.86rem;color:rgba(11,27,51,.8)}
.breadcrumbs li:not(:last-child):after{content:"/";margin-left:10px;opacity:.5}
.breadcrumbs a{text-decoration:none;color:rgba(11,27,51,.85)}
.hero{
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--line);
  /* ヒーローだけに“霧状のラジアル”を集中させ、サイトのトーンは維持しつつ
     エリアごとの背景を整える */
  background:
    radial-gradient(900px 520px at 70% 10%, rgba(27,116,255,.18), transparent 55%),
    radial-gradient(780px 520px at 20% 20%, rgba(0,182,214,.14), transparent 60%),
    linear-gradient(180deg, var(--bg2), var(--bg));
}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:26px;padding:56px 0}
.hero__title{font-size:2.2rem;line-height:1.2;margin:10px 0 14px}
.hero__lead{color:rgba(11,27,51,.9);max-width:54ch}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin:20px 0 12px}
.hero__points{margin:14px 0 0;padding-left:18px;color:rgba(11,27,51,.82)}
.hero__visual{position:relative}
.glass{border:1px solid var(--line);background:rgba(255,255,255,.04);border-radius:var(--r2);box-shadow:var(--shadow);overflow:hidden}
.cutin{position:absolute;right:-6px;bottom:-10px;width:min(320px, 92%);border:1px solid var(--line);background:rgba(255,255,255,.72);border-radius:18px;padding:14px;box-shadow: 0 20px 60px rgba(0,0,0,.5)}
.cutin__tag{display:inline-flex;padding:6px 10px;border-radius:999px;background:rgba(124,92,255,.16);border:1px solid rgba(124,92,255,.28);font-size:.78rem;color:rgba(11,27,51,.9)}
.cutin__text{margin-top:10px;font-weight:700;color:rgba(11,27,51,.92)}
.hero__bg{position:absolute;inset:-40px -40px auto auto;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle at 30% 30%, rgba(0,212,255,.22), transparent 62%),radial-gradient(circle at 65% 65%, rgba(124,92,255,.22), transparent 58%);opacity:.9}
.section{padding:56px 0;background:var(--bg)}
.section--alt{background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.section__head h2{margin:0;font-size:1.5rem}
.cards{display:grid;grid-template-columns:repeat(3, 1fr);gap:16px}
.cards--thin{grid-template-columns:repeat(auto-fit, minmax(260px, 1fr))}
.cards--stack{grid-template-columns:1fr}
.card{text-decoration:none;border:1px solid var(--line);border-radius:var(--r2);background:rgba(255,255,255,.62);overflow:hidden;box-shadow: 0 14px 44px rgba(0,0,0,.32);display:flex;flex-direction:column;min-height:100%}
.card:hover{transform:translateY(-2px);transition:.18s ease;border-color:rgba(124,92,255,.28)}
.card__media{aspect-ratio: 16/9;background:rgba(0,0,0,.2)}
.card__body{padding:16px}
.card__title{font-size:1.05rem;font-weight:800;margin-bottom:6px}
.card__text{color:rgba(11,27,51,.85);min-height:44px}
.card__arrow{margin-top:auto;padding:12px 16px;border-top:1px solid var(--line);color:rgba(11,27,51,.85)}
.card--mini{flex-direction:row;align-items:center;gap:12px;padding:14px}
.card--mini .card__media{display:none}
.card--mini .card__body{padding:0}
.card--mini .card__arrow{border:0;padding:0;margin-left:auto;opacity:.85}
.card__icon{width:46px;height:46px;border-radius:16px;background:rgba(11,27,51,.06);border:1px solid var(--line);display:grid;place-items:center}
.card__icon img{width:22px;height:22px;opacity:.92}
.pillrow{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.pill{font-size:.78rem;padding:6px 10px;border-radius:999px;background:rgba(11,27,51,.06);border:1px solid var(--line);color:rgba(11,27,51,.86)}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:14px;border:1px solid var(--line);background:rgba(11,27,51,.04);text-decoration:none;font-weight:800}
.btn:hover{background:rgba(11,27,51,.06)}
.btn:focus{outline:none;box-shadow:var(--focus)}
.btn--primary{background:linear-gradient(135deg, rgba(124,92,255,.95), rgba(0,212,255,.75));border-color:transparent;color:#08101a}
.btn--ghost{background:transparent}
.split{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:stretch}
.split>.box{height:100%}
.box{border:1px solid var(--line);border-radius:var(--r2);background:rgba(255,255,255,.58);padding:18px}
.box h3{margin:0 0 10px}
.list{padding-left:18px;color:rgba(11,27,51,.88)}
.list li{margin:6px 0}
.note{margin-top:14px;padding:12px 14px;border-radius:16px;border:1px solid rgba(0,212,255,.18);background:rgba(0,212,255,.07);color:rgba(11,27,51,.86)}
.faq{border:1px solid var(--line);border-radius:var(--r2);overflow:hidden;background:rgba(255,255,255,.55)}
.faq__item + .faq__item{border-top:1px solid var(--line)}
.faq__q{width:100%;text-align:left;background:transparent;border:0;color:inherit;display:flex;align-items:center;gap:12px;padding:16px;font-weight:900;cursor:pointer}
.faq__q:focus{outline:none;box-shadow:var(--focus)}
.faq__qmark,.faq__amark{width:28px;height:28px;border-radius:10px;display:grid;place-items:center;background:rgba(124,92,255,.16);border:1px solid rgba(124,92,255,.28);font-weight:900}
.faq__chev{margin-left:auto;opacity:.8}
.faq__a{padding:0 16px 16px}
.faq__abox{display:flex;gap:12px;align-items:flex-start;color:rgba(11,27,51,.86)}
.faq__a[hidden]{display:none}
.cta-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;border:1px solid var(--line);background:radial-gradient(600px 200px at 15% 0%, rgba(124,92,255,.18), transparent 60%),radial-gradient(500px 180px at 85% 20%, rgba(0,212,255,.14), transparent 60%),rgba(255,255,255,.60);border-radius:var(--r2);padding:22px;box-shadow:var(--shadow)}
.cta-banner__copy h2{margin:0 0 6px;font-size:1.3rem}
.cta-banner__actions{display:flex;gap:12px;flex-wrap:wrap}
.footer{
  border-top:1px solid rgba(255,255,255,.14);
  background:#000;
  color:#fff;
  padding:46px 0 20px;
  font-size:.92rem
}
.footer__grid{display:grid;grid-template-columns:1.05fr 1.25fr .7fr;gap:18px}
.footer__title{font-weight:900}
.footer__sub{color:rgba(255,255,255,.72);font-size:.9rem}
.footer__links{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.footer__col a{display:block;text-decoration:none;color:rgba(255,255,255,.88);padding:6px 0;font-size:.92rem}
.footer__col a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.footer__head{font-weight:900;margin-bottom:8px}
.info{display:grid;grid-template-columns:64px 1fr;gap:10px;margin:8px 0}
.info__k{color:rgba(255,255,255,.68);font-size:.9rem}
.footer .muted{color:rgba(255,255,255,.72)}
.footer__bottom{margin-top:22px;padding-top:16px;border-top:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.70)}
.sticky-cta{position:fixed;left:50%;transform:translateX(-50%);bottom:16px;width:min(520px, calc(100% - 20px));display:grid;grid-template-columns:repeat(3,1fr);border:1px solid rgba(255,255,255,.16);background:rgba(0,0,0,.88);backdrop-filter: blur(10px);border-radius:20px;overflow:hidden;box-shadow: 0 22px 70px rgba(0,0,0,.48);z-index:80}
.sticky-cta__item{display:flex;gap:8px;align-items:center;justify-content:center;text-decoration:none;padding:12px 10px;color:rgba(255,255,255,.92)}
.sticky-cta__item + .sticky-cta__item{border-left:1px solid rgba(255,255,255,.14)}
.pagehead{padding:34px 0 10px}
.pagehead h1{margin:0;font-size:1.9rem}
.pagehead p{margin:10px 0 0;color:rgba(11,27,51,.86)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form{display:grid;gap:12px}
.pre{margin:12px 0 0;padding:14px 16px;border-radius:16px;border:1px solid var(--line);background:rgba(11,27,51,.06);color:rgba(242,246,255,.92);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:.9rem;line-height:1.6;white-space:pre-wrap}
.field label{display:block;font-weight:800;margin:0 0 6px}
.field input,.field select,.field textarea{width:100%;padding:12px;border-radius:14px;border:1px solid var(--line);background:rgba(11,27,51,.04);color:var(--text)}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;box-shadow:var(--focus)}
.help{font-size:.9rem;color:var(--muted)}
.required{display:inline-flex;margin-left:8px;font-size:.78rem;padding:3px 8px;border-radius:999px;background:rgba(124,92,255,.16);border:1px solid rgba(124,92,255,.28)}
@media (max-width: 980px){
  .hero__grid{grid-template-columns:1fr;gap:18px;padding:44px 0}
  .split{grid-template-columns:1fr}
  .cards{grid-template-columns:repeat(2,1fr)}
  .cards--thin{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .footer__links{grid-template-columns:1fr 1fr}
  .header__nav{position:fixed;inset:70px 0 auto 0;display:none;background:rgba(255,255,255,.92);border-bottom:1px solid var(--line);padding:14px}
  .header__nav.is-open{display:block}
  .nav{flex-direction:column;align-items:stretch}
  .nav__item{padding:14px}
  .header__contact{justify-content:flex-start;padding:10px 2px}
  .burger{display:inline-block}
}
@media (max-width: 560px){
  .cards{grid-template-columns:1fr}
  .hero__title{font-size:1.85rem}
}

/* =========================================================
  Header / breadcrumb (from benefits.hanawa-office.jp)
========================================================= */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}

.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}

.header__inner{
  display:flex;
  align-items:center;
  justify-content:flex-start;   /* ★ここを space-between から変更 */
  height:72px;
  gap:20px;                    /* ★余白を適正化 */
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  flex: 0 0 auto;              /* ★ブランド領域を固定して崩さない */
}
.brand__logo{
  height:44px;
  width:auto;
}
.brand__name{
  font-weight:950;
  letter-spacing:.03em;
}
.brand__sub{
  display:block;
  margin-top:2px;
  font-size:.82rem;            /* 小さく */
  color:var(--muted-2);
  font-weight:800;
}
.brand__subLink{
  color: var(--muted-2);
  text-decoration: underline;
  text-decoration-color: rgba(100,116,139,.45);
  text-underline-offset: 3px;
}
.brand__subLink:hover{
  color: var(--text);
  text-decoration-color: rgba(15,23,42,.45);
}

.nav{
  display:flex;
  align-items:center;
  gap:14px;
  margin-left:auto;            /* ★右側へ寄せる（押し込み解消） */
  flex: 0 0 auto;
}
.nav__toggle{
  display:none;
  border:1px solid var(--border);
  background:#fff;
  width:44px;
  height:44px;
  border-radius:12px;
}
.nav__toggleBars{
  display:block;
  width:18px;
  height:2px;
  background: var(--text);
  position:relative;
  margin-inline:auto;
}
.nav__toggleBars::before,
.nav__toggleBars::after{
  content:"";
  position:absolute;
  left:0;
  width:18px;
  height:2px;
  background: var(--text);
}
.nav__toggleBars::before{ top:-6px; }
.nav__toggleBars::after{ top:6px; }

.nav__menu{
  display:flex;
  align-items:center;
  gap:18px;
}
.nav__link{
  color:var(--muted);
  font-weight:850;
  padding:10px 10px;
  border-radius:12px;
  transition: background .15s ease, color .15s ease;
}
.nav__link:hover{
  background: rgba(11,87,208,.08);
  color: var(--text);
}
.nav__link[aria-current="page"]{
  background: rgba(17,24,39,.06);
  color: var(--text);
}

.breadcrumb{
  padding:16px 0 0;
  color: var(--muted-2);
  font-weight:800;
  font-size:.95rem;
}
.breadcrumb a{ color: var(--brand); }


/* =========================================================
  Header buttons (from benefits, scoped)
========================================================= */
.site-header .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55em;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  font-weight:800;
  line-height:1;
  box-shadow:none;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}
.site-header .btn:hover{ transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.site-header .btn:active{ transform: translateY(0); box-shadow:none; }
.site-header .btn:focus-visible{ outline:3px solid rgba(11,87,208,.25); outline-offset:2px; }

.site-header .btn--primary{
  background: var(--brand-2);
  border-color: var(--brand-2);
  color:#fff;
}
.site-header .btn--primary:hover{ box-shadow: var(--shadow); }

.site-header .btn--ghost{ background:#fff; }

.site-header .btn--sm{
  padding:10px 14px;
  font-size:.95rem;
}


/* === Uniformity fixes (header spacing / CTA wrapper) === */
.site-header .brand__text{display:flex;flex-direction:column;line-height:1.25}
.site-header .brand__sub{margin-top:0}
.nav__actions{display:flex;gap:10px;align-items:center}
@media (max-width: 760px){
  .nav__actions{flex-wrap:wrap}
  .nav__actions .btn{flex:1 1 140px;justify-content:center}
}

/* =========================================================
  Overrides: header spacing / actions wrapper
========================================================= */
.site-header .brand__text{display:flex;flex-direction:column;line-height:1.25}
.site-header .brand__sub{margin-top:0}
.nav__actions{display:flex;gap:10px;align-items:center}
@media (max-width: 760px){
  .nav__actions{flex-wrap:wrap}
  .nav__actions .btn{flex:1 1 140px;justify-content:center}
}

