@charset "UTF-8";

/* ============================================================
   ROOT VARIABLES
============================================================ */
:root {
  --bg-r: 255; --bg-g: 255; --bg-b: 255;
  --text-r: 17; --text-g: 17; --text-b: 17;
  --muted-r: 88; --muted-g: 88; --muted-b: 88;
  --soft-r: 118; --soft-g: 118; --soft-b: 118;
  --panel-strong-r: 255; --panel-strong-g: 255; --panel-strong-b: 255; --panel-strong-a: .82;
  --border-r: 0; --border-g: 0; --border-b: 0;
  --shadow-r: 0; --shadow-g: 0; --shadow-b: 0;
  --line-r: 0; --line-g: 0; --line-b: 0;
  --container: 1180px;
  --header-h: 76px;
  --ease: cubic-bezier(.22, 1, .36, 1);
  --ease-soft: cubic-bezier(.19, 1, .22, 1);
  --orb-x: 18%; --orb-y: 78%;
  --font-base: "Noto Sans JP", sans-serif;
  --font-ui: "Inter", sans-serif;
  --navy: #0d1f3c;
  --navy-mid: #1a3050;
  --white: #ffffff;
  --accent: #4a7cff;
  --accent-lt: #7eb5ff;
  --sky: #e8f4fc;
  --sky-dark: #c8e2f5;
  --green: #3db87a;

  /* ── 共通トークン ── */
  --card-bg:     rgba(var(--panel-strong-r), var(--panel-strong-g), var(--panel-strong-b), var(--panel-strong-a));
  --card-border: 1px solid rgba(var(--border-r), var(--border-g), var(--border-b), .08);
  --card-shadow: 0 16px 40px rgba(var(--shadow-r), var(--shadow-g), var(--shadow-b), .06),
                 0 1px 0 rgba(255, 255, 255, .5) inset;
  --card-blur:   blur(16px);
  --tag-bg:      rgba(var(--border-r), var(--border-g), var(--border-b), .04);
  --tag-border:  1px solid rgba(var(--border-r), var(--border-g), var(--border-b), .08);
}
@media (max-width: 767px) {
  :root { --header-h: 68px; }
}

/* ============================================================
   RESET / BASE
============================================================ */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; background: #fff; overflow-x: hidden; }
body {
  font-family: var(--font-base);
  position: relative;
  overflow-x: hidden;
  background: transparent;
  color: rgb(var(--text-r), var(--text-g), var(--text-b));
  line-height: 1.75;
  letter-spacing: .01em;
  text-align: left;
  -webkit-text-size-adjust: none;
}
body.menu-open { overflow: hidden; }
img { display: block; height: auto; width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button { background: none; border: none; cursor: pointer; }
ul, ol { list-style: none; }
main { width: 100%; padding-top: var(--header-h); overflow: hidden; }
section.section { position: relative; padding: 7% 0; scroll-margin-top: 96px; }
@media (max-width: 767px) {
  section.section { padding: 92px 0; scroll-margin-top: 84px; }
}
@media (max-width: 767px) {
  body {
    -webkit-text-size-adjust: 100%;
  }
}
/* ============================================================
   CONTAINER
============================================================ */
.container { padding: 0 5%; max-width: 1280px; margin: 0 auto; }
.hero .container,
section .container { width: min(100% - 10%, var(--container)); margin-inline: auto; }

/* ============================================================
   UTILITY
============================================================ */
.forPc { display: block; }
.forMobile { display: none; }
@media (max-width: 767px) {
  .forPc { display: none; }
  .forMobile { display: block; }
}

/* ── ライン装飾 ── */
.leftLine { line-height: 100%; display: flex; align-items: center; }
.leftLine::after { border-top: 1px solid; content: ""; flex-grow: 1; margin-left: 2%; }

.wLine { display: flex; align-items: center; }
.wLine::before,
.wLine::after { content: ""; height: 1px; flex-grow: 1; background-color: #222; }
.wLine::before { margin-right: 1rem; }
.wLine::after  { margin-left: 1rem; }

/* ── グラデーションテキスト ── */
.color-grad {
  background: linear-gradient(90deg, #5b8cff, #8e6cff, #6fd3b5, #5b8cff);
  background-size: 300% 300%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: cgGradient 8s ease infinite;
}
@keyframes cgGradient {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* ── フェードアップ ── */
.fade-up {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s ease, transform .8s var(--ease);
}
.fade-up.is-inview { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: .06s; }
.delay-2 { transition-delay: .12s; }
.delay-3 { transition-delay: .18s; }

/* ── キャラ画像サイズ ── */
.face10 { width: 10%; margin-right: 15px; }
.face20 { width: 38%; margin-right: 10px; }
.hand10 { width: 10%; margin-right: 15px; }
.body15 { width: 18%; margin-right: 15px; }
@media (max-width: 767px) {
  .face10 { width: 22%; margin-right: 5%; }
  .face20 { width: 30%; margin-right: 0; }
  .hand10 { width: 18%; margin-right: 5%; }
  .body15 { width: 25%; margin-right: 5%; }
}

/* ============================================================
   SECTION HEADING
============================================================ */
.section-heading { max-width: 900px; margin: 0 auto 56px; text-align: center; }
.section-label {
  display: inline-block;
  margin-bottom: 12px;
  font-size: 100%;
  font-weight: 800;
  letter-spacing: .18em;
}
.section-heading h2 {
  margin-bottom: 18px;
  font-size: clamp(20px, 5.2vw, 40px);
  line-height: 1.2;
  letter-spacing: -.04em;
  font-weight: 900;
}
.section-heading h2 span { color: #bbb907; }
.section-heading p {
  font-size: clamp(100%, 1.5vw, 112%);
  line-height: 1.95;
  text-align: left;
  font-weight: 600;
}
.section-heading > p:not(.section-label) {
  max-width: 760px;
  margin: 18px auto 0;
  line-height: 1.95;
}
.section-heading .face01-grid { display: flex; justify-content: center; align-items: center; }
.section-heading .face01-grid p { text-align: left; }

.section-label02 {
  position: absolute;
  top: -40px;
  left: -7%;
  font-size: clamp(17px, 10vw, 110px);
  font-weight: 800;
  opacity: 0.2;
  writing-mode: vertical-rl;
  white-space: nowrap;
}

@media (max-width: 767px) {
  .section-heading { margin-bottom: 38px; text-align: left; }
  .section-heading h2 {
    display: block;
    align-items: center;
    font-size: clamp(20px, 6.6vw, 40px);
    line-height: 1.4;
  }
  .section-heading h2::after { content: ""; flex-grow: 1; margin-left: 2%; border-top: 1px solid; }
  .section-heading p { width: 100%; }
  .section-label02 { font-size: clamp(17px, 19vw, 120px); left: -15%; }
}

/* ============================================================
   GLASS CARD（共通ベース）
   旧: .service-card / .work-card / .flow-card / .about-card / .area-card
   → すべて .glass-card に統一。個別名は alias として残す。
============================================================ */
.glass-card {
  background: var(--card-bg);
  border: var(--card-border);
  box-shadow: var(--card-shadow);
  backdrop-filter: var(--card-blur);
  -webkit-backdrop-filter: var(--card-blur);
}

/* 後方互換エイリアス（HTML変更なしで動く） */
.service-card,
.work-card,
.flow-card,
.about-card,
.area-card { background: var(--card-bg); border: var(--card-border); box-shadow: var(--card-shadow); backdrop-filter: var(--card-blur); -webkit-backdrop-filter: var(--card-blur); }

/* ── カードホバー共通 ── */
.card-hover {
  transition: transform .35s var(--ease), box-shadow .35s ease;
}
.card-hover:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 50px rgba(var(--shadow-r), var(--shadow-g), var(--shadow-b), .09);
}

/* ============================================================
   BADGE / TAG（共通）
   section内の小さなラベル pill をまとめる
============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .10em;
  background: var(--tag-bg);
  border: var(--tag-border);
  color: rgba(var(--muted-r), var(--muted-g), var(--muted-b), .8);
}
.badge--accent {
  background: rgba(74, 124, 255, .07);
  border-color: rgba(74, 124, 255, .12);
  color: var(--accent);
}
.badge--dark {
  background: rgba(13, 31, 60, .06);
  border-color: rgba(13, 31, 60, .12);
  color: var(--navy);
}

/* ============================================================
   SECTION LABEL（上部 uppercase ラベル行）
   共通: font-ui / uppercase / letter-spacing
============================================================ */
.label-upper {
  font-family: var(--font-ui, "Inter", sans-serif);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(var(--muted-r), var(--muted-g), var(--muted-b), .48);
}
.label-upper--accent { color: rgba(74, 124, 255, .65); }

/* ============================================================
   ARROW CIRCLE（丸囲み矢印）
   .wc-arrow / .area-btn-arrow など共通パターン
============================================================ */
.arrow-circle {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(var(--border-r), var(--border-g), var(--border-b), .14);
  transition: background .25s ease, border-color .25s ease, transform .3s var(--ease);
  flex-shrink: 0;
}
.arrow-circle svg {
  width: 14px;
  height: 14px;
  stroke: rgba(var(--text-r), var(--text-g), var(--text-b), .6);
  transition: stroke .25s ease;
}
/* 親ホバーで塗りつぶし */
*:hover > .arrow-circle,
.arrow-circle:hover {
  background: rgb(var(--text-r), var(--text-g), var(--text-b));
  border-color: transparent;
}
*:hover > .arrow-circle svg,
.arrow-circle:hover svg { stroke: #fff; }

/* ============================================================
   BUTTONS
============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 178px;
  min-height: 56px;
  padding: 0 22px;
  border: 1px solid transparent;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .04em;
  transition: transform .3s ease, box-shadow .3s ease, background .3s ease, opacity .3s ease;
}
.btn:hover { transform: translateY(-2px); }

.btn-primary {
  background: rgba(var(--text-r), var(--text-g), var(--text-b), .98);
  color: #fff;
  box-shadow: 0 14px 34px rgba(var(--shadow-r), var(--shadow-g), var(--shadow-b), .14);
}
.btn-primary:hover {
  opacity: .92;
  box-shadow: 0 20px 42px rgba(var(--shadow-r), var(--shadow-g), var(--shadow-b), .18);
}

.btn-secondary {
  background: rgba(255, 255, 255, .68);
  color: rgb(var(--text-r), var(--text-g), var(--text-b));
  border-color: rgba(0, 0, 0, .08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.btn-secondary:hover {
  background: rgba(255, 255, 255, .84);
  box-shadow: 0 14px 30px rgba(var(--shadow-r), var(--shadow-g), var(--shadow-b), .08);
}

@media (max-width: 767px) {
  .btn { min-width: 100%; min-height: 52px; }
}

/* ============================================================
   REDUCED MOTION
============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .fade-up { opacity: 1; transform: none; }
}

/* =============================================
   7BEE Pill Button
   黒地版: .btn-ps--dark  + .sw-sh--dark
   白地版: .btn-ps--light + .sw-sh--light
============================================= */

/* ── SVG が img{width:100%} で崩れないよう上書き ── */
.btn-ps svg {
  display: inline;
  width: auto;
  height: auto;
}

/* ── ラッパー（オフセット影） ── */
.sw {
  position: relative;
  display: inline-block;
  cursor: pointer;
	margin: 0 18px 18px 0
}
.sw .btn-ps {
  transition: transform 0.22s cubic-bezier(.34, 1.2, .64, 1);
}
.sw:hover .btn-ps { transform: translate(-2px, -2px); }
.sw:active .btn-ps { transform: translate(0, 0); }

/* ── 影レイヤー ── */
.sw-sh {
  position: absolute;
  inset: 0;
  border-radius: 100px;
  transform: translate(5px, 5px);
  transition: transform 0.22s cubic-bezier(.34, 1.2, .64, 1);
}
.sw:hover .sw-sh { transform: translate(2px, 2px); }
.sw:active .sw-sh { transform: translate(0, 0); }
.sw-sh--dark  { background: #555; }
.sw-sh--light { background: #bbb; }
.sw-sh--olive { background: rgba(80, 78, 0, .6); }

/* ── オリーブ版 ── */
.btn-ps--olive {
  background: rgba(170, 166, 0, 1);
  border: 1px solid rgba(255, 255, 255, 0.6);
}
.btn-ps--olive .ps-dot                 { background: #fff; }
.sw:hover .btn-ps--olive .ps-dot       { background: #111; }
.btn-ps--olive .ps-main                { color: #fff; }
.btn-ps--olive .ps-sub                 { color: rgba(255, 255, 255, 1.0); }
.sw:hover .btn-ps--olive .ps-main      { color: #111; }
.sw:hover .btn-ps--olive .ps-sub       { color: rgba(0, 0, 0, 0.6); }
.btn-ps--olive .ps-aw                  { background: #fff; }

/* ── ボタン本体 ── */
.btn-ps {
  position: relative;
  display: inline-flex;
  align-items: center;
  border-radius: 100px;
  cursor: pointer;
  overflow: hidden;
  text-decoration: none;
  padding: 0;
  font: inherit;
}

/* 黄色スライド層 */
.btn-ps::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 100px;
  background: #F0E000;
  transform: translateX(-100%);
  transition: transform 0.38s cubic-bezier(.77, 0, .175, 1);
  z-index: 0;
}
.sw:hover .btn-ps::before { transform: translateX(0); }

/* ── 黒地版 ── */
.btn-ps--dark {
  background: #111;
  border: 1px solid #fff;
}
.btn-ps--dark .ps-dot                  { background: #fff; }
.sw:hover .btn-ps--dark .ps-dot        { background: #111; }
.btn-ps--dark .ps-main                 { color: #fff; }
.btn-ps--dark .ps-sub                  { color: rgba(255, 255, 255, 0.5); }
.sw:hover .btn-ps--dark .ps-main       { color: #111; }
.sw:hover .btn-ps--dark .ps-sub        { color: rgba(0, 0, 0, 0.5); }
.btn-ps--dark .ps-aw                   { background: #fff; }

/* ── 白地版 ── */
.btn-ps--light {
  background: #fff;
  border: 1px solid #111;
}
.btn-ps--light .ps-dot                 { background: #111; }
.sw:hover .btn-ps--light .ps-dot       { background: #111; }
.btn-ps--light .ps-main                { color: #111; }
.btn-ps--light .ps-sub                 { color: rgba(0, 0, 0, 0.45); }
.sw:hover .btn-ps--light .ps-main      { color: #111; }
.sw:hover .btn-ps--light .ps-sub       { color: rgba(0, 0, 0, 0.55); }
.btn-ps--light .ps-aw                  { background: #111; }

/* ── 内部パーツ（共通） ── */
.ps-dot {
  position: relative;
  z-index: 1;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-left: 24px;
  transition: background 0.2s 0.1s, transform 0.3s cubic-bezier(.34, 1.56, .64, 1);
}
.sw:hover .ps-dot { transform: scale(1.5); }

.ps-texts {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 14px 16px;
  text-align: left;
}
.ps-main {
  font-size: clamp(15px, 1.9vw, 18px);
  font-weight: 600;
  white-space: normal;
  word-break: keep-all;
  transition: color 0.2s 0.08s;
}
.ps-sub {
  font-size: 11px;
  font-weight: 400;
  white-space: normal;
  word-break: keep-all;
  transition: color 0.2s 0.08s;
	margin-top: -6px;
}

.ps-aw {
  position: relative;
  z-index: 1;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-left: auto;   /* ←これが本質 */
  margin-right: 8px;   /* ←右余白だけ残す */
  transition: transform 0.25s cubic-bezier(.34, 1.56, .64, 1);
}
.sw:hover .ps-aw { transform: translateX(4px); }


/* ============================================================
   E — Pill form (sw-e)
============================================================ */
.sw-e svg { display: inline; width: auto; height: auto; }

.sw-e {
  position: relative;
  display: block;
  cursor: pointer;
}
.sw-e .sh {
  position: absolute;
  inset: 0;
  background: #111;
  border-radius: 100px;
  transform: translate(6px, 6px);
  transition: transform 0.22s cubic-bezier(.34, 1.2, .64, 1);
}
.sw-e .bd {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 32px;
  background: #fff;
  border: 1.5px solid #111;
  border-radius: 100px;
  font-size: 15px;
  font-weight: 500;
  color: #111;
  white-space: normal;
  word-break: keep-all;
  text-decoration: none;
  box-sizing: border-box;
  transition: transform 0.22s cubic-bezier(.34, 1.2, .64, 1);
}
.sw-e .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #111;
  flex-shrink: 0;
  transition: transform 0.3s cubic-bezier(.34, 1.56, .64, 1);
}
.sw-e .ico {
  display: block;
  width: 15px;
  height: 15px;
  flex-shrink: 0;
  transition: transform 0.22s cubic-bezier(.34, 1.56, .64, 1);
}
.sw-e:hover .sh  { transform: translate(3px, 3px); }
.sw-e:hover .bd  { transform: translate(-2px, -2px); }
.sw-e:hover .dot { transform: scale(1.6); }
.sw-e:hover .ico { transform: translateX(5px); }
.sw-e:active .sh { transform: translate(1px, 1px); }
.sw-e:active .bd { transform: translate(0, 0); }

.sw-e .bd--dark {
  background: #111;
  border: 1px solid #fff;
  color: #fff;
}
.sw-e .sh--dark  { background: #555; }
.sw-e .dot--dark { background: #fff; }
.sw-e .ico--dark path { stroke: #fff; }

@media (max-width: 767px) {
  .sw {
    display: block;
    width: 100%;
    margin-right: 0;
  }

  .sw .btn-ps {
    width: 100%;
  }
}
