/*
 * myCelf Top Page Styles
 * ─────────────────────────────────────────
 * 外観 → カスタマイズ → 追加CSS に貼り付けるか
 * Lightning Child の style.css 末尾に追記してください。
 * ─────────────────────────────────────────
 */

/* ═══════════════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════════════ */
:root {
  /* Brand */
  --navy:    #00426C;
  --navy-d:  #001f35;
  --navy-m:  #002d4a;
  --blue:    #009FE8;
  --blue-l:  #4DC3F5;
  --red:     #E50012;
  --yellow:  #FFF000;

  /* Surfaces — warm paper palette */
  --bg:      #0C1118;   /* deep dark base */
  --bg2:     #111820;
  --bg3:     #161E28;
  --ink:     #F0EDE6;   /* warm off-white */
  --ink-2:   #B8B0A4;
  --ink-3:   #6E6860;
  --gold:    #C8A96E;   /* warm accent */
  --gold-l:  #E8C98E;

  /* Borders */
  --b1: rgba(240,237,230,.06);
  --b2: rgba(240,237,230,.12);
  --b3: rgba(0,159,232,.3);

  /* Type */
  --fb: 'Bebas Neue', sans-serif;        /* big display */
  --fc: 'Cormorant Garamond', serif;     /* editorial accent */
  --fm: 'DM Mono', monospace;            /* data / labels */
  --fj: 'Noto Sans JP', sans-serif;      /* body JP */

  --ease: cubic-bezier(.16,1,.3,1);
}

/* ═══════════════════════════════════════════
   RESET
═══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--fj);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.7}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}

/* ═══════════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════════ */
@keyframes fadeUp   {from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes fadeIn   {from{opacity:0}to{opacity:1}}
@keyframes ticker   {to{transform:translateX(-50%)}}
@keyframes float    {0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes blink    {0%,100%{opacity:1}50%{opacity:0}}
@keyframes scanline {0%{transform:translateY(-100%)}100%{transform:translateY(100vh)}}
@keyframes lineW    {from{width:0}to{width:100%}}
@keyframes rotateS  {to{transform:rotate(360deg)}}
@keyframes countUp  {from{opacity:0;transform:translateY(20px) scale(.9)}to{opacity:1;transform:none}}

.rv{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.on{opacity:1;transform:none}
.rv-s{opacity:0;transform:scale(.96);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv-s.on{opacity:1;transform:none}
.rv-x{opacity:0;transform:translateX(-20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv-x.on{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.40s}.d6{transition-delay:.48s}

/* ═══════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════ */
.w   {max-width:1160px;margin:0 auto;padding:0 2.5rem}
.w-n {max-width:1400px;margin:0 auto;padding:0 2.5rem}

/* ═══════════════════════════════════════════
   HEADER
═══════════════════════════════════════════ */
.hdr{
  position:fixed;top:0;left:0;right:0;z-index:300;
  height:60px;
  display:flex;align-items:center;
  transition:all .4s var(--ease);
}
.hdr.solid{
  background:rgba(12,17,24,.92);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--b1);
}
.hdr-in{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:1200px;margin:0 auto;padding:0 2.5rem;
}
.hdr-logo svg{height:28px;width:auto}

.hdr-nav{display:flex;gap:2px}
.hdr-nav a{
  padding:.4rem .875rem;
  font-family:var(--fm);font-size:.72rem;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-3);border-radius:3px;
  transition:color .2s,background .2s;
}
.hdr-nav a:hover{color:var(--ink);background:var(--b1)}

.hdr-r{display:flex;gap:.75rem;align-items:center;margin-left:1.5rem}
.btn-sm{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.48rem 1.1rem;font-family:var(--fm);font-size:.7rem;
  font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  border-radius:3px;border:1px solid;cursor:pointer;
  transition:all .25s var(--ease);
}
.btn-sm-ghost{border-color:var(--b2);color:var(--ink-2)}
.btn-sm-ghost:hover{border-color:var(--ink-2);color:var(--ink);background:var(--b1)}
.btn-sm-red{background:var(--red);border-color:var(--red);color:#fff}
.btn-sm-red:hover{background:#c5000f;transform:translateY(-1px);box-shadow:0 6px 20px rgba(229,0,18,.3)}

.ham{display:none;flex-direction:column;gap:5px;padding:.4rem;cursor:pointer;background:none;border:none}
.ham span{display:block;width:20px;height:1.5px;background:var(--ink-2);border-radius:2px;transition:.3s}
.ham.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile overlay */
.mob{
  display:none;
  position:fixed;
  inset:0;
  top:72px;
  z-index:299;

  background:rgba(17,24,32,0.98);

  padding:2rem 1.5rem;

  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1.25rem;

  overflow-y:auto;

  border-top:1px solid var(--b1);
}

.mob.open{
  display:flex;
}

.mob a{
  display:block;
  width:100%;
  max-width:320px;

  padding:.9rem 1rem;

  font-family:var(--fj);
  font-size:1.05rem;
  font-weight:700;
  line-height:1.6;

  text-align:center;

  color:var(--ink);

  border-bottom:none;
  background:transparent;

  transition:all .2s ease;
}

.mob a{
  transition:all .2s ease;
}

.mob a:hover{
  color:var(--blue-l);
  transform:translateY(-1px);
}


.mob .mob-cta{
  margin-top:1rem;

  padding:1rem 1.25rem;

  background:var(--red);
  color:#fff;

  text-align:center;
  border-radius:8px;

  font-family:var(--fj);
  font-size:0.95rem;
  font-weight:700;
  line-height:1.6;

  max-width:320px;
  width:100%;

  box-shadow:0 8px 24px rgba(229,0,18,.22);
}

.mob .mob-cta:hover{
  background:#c5000f;
  color:#fff;
}

/* ═══════════════════════════════════════════
   HERO
═══════════════════════════════════════════ */
.hero{
  position:relative;min-height:100vh;
  display:grid;place-items:center;
  overflow:hidden;
  background:var(--bg);
}

/* 背景レイヤー */
.h-noise{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");
  opacity:.5;
}
.h-grad{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 80% 60% at 15% 50%,rgba(0,66,108,.35) 0%,transparent 55%),
    radial-gradient(ellipse 50% 70% at 90% 20%,rgba(0,159,232,.1) 0%,transparent 50%),
    radial-gradient(ellipse 40% 40% at 70% 90%,rgba(229,0,18,.06) 0%,transparent 50%);
}
.h-grid{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(var(--b1) 1px,transparent 1px),
    linear-gradient(90deg,var(--b1) 1px,transparent 1px);
  background-size:64px 64px;
}
/* 右側大型装飾テキスト */
.h-deco{
  position:absolute;right:-0.04em;bottom:-0.1em;z-index:0;
  font-family:var(--fb);font-size:clamp(12rem,22vw,28rem);
  color:rgba(255,255,255,.018);letter-spacing:-.02em;line-height:1;
  pointer-events:none;user-select:none;white-space:nowrap;
}
/* スキャンライン効果 */
.h-scan{
  position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden;
}
.h-scan::after{
  content:'';position:absolute;left:0;right:0;height:200px;
  background:linear-gradient(to bottom,transparent,rgba(0,159,232,.018),transparent);
  animation:scanline 8s linear infinite;
}

/* コンテンツ */
.h-inner{
  position:relative;z-index:1;
  width:100%;max-width:1160px;padding:0 2.5rem;
  display:grid;grid-template-columns:1fr 380px;gap:4rem;align-items:center;
}

/* 左: ヘッドライン */
.h-eyebrow{
  display:flex;align-items:center;gap:.875rem;
  font-family:var(--fm);font-size:.65rem;letter-spacing:.25em;
  text-transform:uppercase;color:var(--ink-3);
  margin-bottom:1.5rem;
  animation:fadeIn .6s var(--ease) both;
}
.h-eyebrow-dot{
  width:6px;height:6px;border-radius:50%;background:var(--blue);
  flex-shrink:0;animation:blink 2.5s infinite;
}
.h-eyebrow-line{width:28px;height:1px;background:var(--ink-3)}

.h-title{
  font-family:var(--fb);
  font-size:clamp(5rem,10vw,11rem);
  line-height:.92;letter-spacing:.01em;
  color:var(--ink);
  animation:fadeUp .8s .1s var(--ease) both;
}
.h-title .t-blue{color:var(--blue);display:block}
.h-title .t-thin{
  font-family:var(--fc);font-style:italic;
  font-size:.28em;font-weight:400;
  color:var(--ink-3);letter-spacing:.08em;
  display:block;margin-top:.5em;
}

/* 赤い区切りライン */
.h-rule{
  width:48px;height:2px;background:var(--red);
  margin:2rem 0;
  animation:fadeIn .5s .3s var(--ease) both;
}

.h-desc{
  font-size:1rem;line-height:2.1;
  color:var(--ink-2);max-width:480px;
  animation:fadeUp .8s .25s var(--ease) both;
}
.h-desc strong{color:var(--ink);font-weight:700}

.h-cta{
  display:flex;gap:.875rem;flex-wrap:wrap;margin-top:2.25rem;
  animation:fadeUp .8s .35s var(--ease) both;
}
.btn-hero-main{
  display:inline-flex;align-items:center;gap:.625rem;
  padding:1rem 2.25rem;font-family:var(--fm);font-size:.8rem;
  font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  background:var(--red);color:#fff;border:1px solid var(--red);
  border-radius:3px;cursor:pointer;
  transition:all .3s var(--ease);
}
.btn-hero-main:hover{background:#c5000f;transform:translateY(-2px);box-shadow:0 10px 32px rgba(229,0,18,.35)}
.btn-hero-main svg{width:15px;height:15px;flex-shrink:0}
.btn-hero-sub{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:1rem 2rem;font-family:var(--fm);font-size:.8rem;
  font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  background:transparent;color:var(--ink-2);border:1px solid var(--b2);
  border-radius:3px;cursor:pointer;
  transition:all .3s var(--ease);
}
.btn-hero-sub:hover{border-color:var(--ink-2);color:var(--ink)}

/* 右: データパネル */
.h-panel{
  background:rgba(255,255,255,.03);
  border:1px solid var(--b2);
  border-radius:8px;padding:2rem 1.75rem;
  animation:fadeIn .9s .2s var(--ease) both;
  position:relative;overflow:hidden;
}
.h-panel::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--blue),transparent);
}
.h-panel-label{
  font-family:var(--fm);font-size:.6rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:1.25rem;
}
.h-stat{padding:1.25rem 0;border-bottom:1px solid var(--b1);display:flex;align-items:flex-start;gap:1rem}
.h-stat:last-of-type{border-bottom:none}
.h-stat-num{
  font-family:var(--fb);font-size:2.6rem;line-height:1;
  color:var(--ink);letter-spacing:.01em;flex-shrink:0;min-width:80px;
}
.h-stat-num em{font-family:var(--fm);font-size:.36em;font-style:normal;color:var(--blue);font-weight:500}
.h-stat-body{}
.h-stat-lbl{font-family:var(--fm);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.25rem}
.h-stat-txt{font-size:.82rem;color:var(--ink-2);line-height:1.75}

/* tags */
.h-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--b1)}
.h-tag{
  font-family:var(--fm);font-size:.62rem;letter-spacing:.06em;
  padding:.25rem .7rem;border-radius:2px;
  background:rgba(255,255,255,.04);border:1px solid var(--b1);
  color:var(--ink-3);transition:all .2s;
}
.h-tag.hi{background:rgba(0,159,232,.1);border-color:rgba(0,159,232,.25);color:var(--blue-l)}
.h-tag:hover{border-color:var(--b2);color:var(--ink-2)}

/* scroll hint */
.h-scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  z-index:2;animation:fadeIn 1s 1.2s var(--ease) both;
}
.h-scroll-label{font-family:var(--fm);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3)}
.h-scroll-bar{width:1px;height:36px;background:linear-gradient(to bottom,transparent,var(--blue))}

/* ═══════════════════════════════════════════
   TICKER
═══════════════════════════════════════════ */
.ticker{overflow:hidden;background:var(--navy);padding:9px 0;position:relative}
.ticker::before,.ticker::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:1}
.ticker::before{left:0;background:linear-gradient(to right,var(--navy),transparent)}
.ticker::after{right:0;background:linear-gradient(to left,var(--navy),transparent)}
.ticker-t{display:flex;width:max-content;animation:ticker 22s linear infinite}
.ti{
  display:flex;align-items:center;gap:.5rem;padding:0 1.5rem;
  font-family:var(--fm);font-size:.65rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.3);white-space:nowrap;
}
.ti b{width:3px;height:3px;border-radius:50%;background:var(--blue);flex-shrink:0}

/* ═══════════════════════════════════════════
   SECTION BASE
═══════════════════════════════════════════ */
.sec{padding:100px 0}
.sec-sm{padding:72px 0}

.sec-eye{
  display:flex;align-items:center;gap:.625rem;
  font-family:var(--fm);font-size:.62rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--blue-l);
  margin-bottom:.875rem;
}
.sec-eye::before{content:'';width:18px;height:1px;background:currentColor}
.sec-eye.gold{color:var(--gold-l)}
.sec-eye.dk{color:var(--navy)}

.sec-h{
  font-family:var(--fb);
  font-size:clamp(2.4rem,5vw,4.5rem);
  line-height:1;letter-spacing:.01em;color:var(--ink);
}
.sec-h.dk{color:var(--navy)}
.sec-h .accent{color:var(--blue-l)}
.sec-h .serif{font-family:var(--fc);font-style:italic;font-weight:400;font-size:.65em;letter-spacing:.02em}

.sec-sub{font-size:.92rem;color:var(--ink-2);line-height:2.05;max-width:520px;margin-top:.875rem}
.sec-sub.dk{color:var(--navy-m);opacity:.7}
.sec-hd{margin-bottom:3.5rem}
.sec-hd.c{text-align:center}.sec-hd.c .sec-sub{margin:auto}
.sec-div{width:32px;height:2px;background:var(--blue);border-radius:2px;margin-top:1.5rem}
.sec-div.c{margin:1.5rem auto 0}
.sec-div.red{background:var(--red)}

/* ═══════════════════════════════════════════
   ABOUT — 大型テキスト + 3列変換ステップ
═══════════════════════════════════════════ */
.about-sec{background:var(--bg2);position:relative;overflow:hidden}
.about-bg-num{
  position:absolute;right:-0.02em;top:50%;transform:translateY(-50%);
  font-family:var(--fb);font-size:clamp(16rem,28vw,36rem);
  color:rgba(255,255,255,.018);line-height:1;
  pointer-events:none;user-select:none;
}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;position:relative;z-index:1}
.about-l{}
.about-big{
  font-family:var(--fc);font-size:clamp(1.6rem,3vw,2.6rem);
  font-weight:600;line-height:1.4;color:var(--ink);
  margin-bottom:1.5rem;letter-spacing:-.01em;
}
.about-big em{font-style:italic;color:var(--blue-l)}
.about-body{font-size:.92rem;color:var(--ink-2);line-height:2.1;margin-bottom:1.25rem}
.about-link{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--fm);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue-l);transition:gap .2s;
}
.about-link:hover{gap:.875rem}
.about-link svg{width:14px;height:14px}

.about-r{}
/* 変換ステップ */
.step-list{display:flex;flex-direction:column;gap:0}
.step-item{
  display:grid;grid-template-columns:52px 1fr;gap:1.25rem;
  padding:1.5rem 0;border-bottom:1px solid var(--b1);
  transition:border-color .3s;cursor:default;
}
.step-item:last-child{border-bottom:none}
.step-item:hover{border-color:var(--b2)}
.step-n{
  font-family:var(--fb);font-size:2.8rem;line-height:1;
  color:rgba(255,255,255,.08);letter-spacing:-.01em;
  transition:color .3s;padding-top:.1em;
}
.step-item:hover .step-n{color:rgba(0,159,232,.4)}
.step-lbl{font-family:var(--fm);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.25rem}
.step-title{font-family:var(--fj);font-size:.95rem;font-weight:700;color:var(--ink);margin-bottom:.375rem}
.step-desc{font-size:.82rem;color:var(--ink-2);line-height:1.85}

/* ═══════════════════════════════════════════
   PROBLEM GRID
═══════════════════════════════════════════ */
.prob-sec{
  background:var(--bg);
  position:relative;overflow:hidden;
}
.prob-sec::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--b2),transparent);
}
.prob-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--b1);
  border:1px solid var(--b1);border-radius:10px;overflow:hidden;
}
.pg{
  background:var(--bg);padding:2rem 1.75rem;position:relative;overflow:hidden;
  transition:background .3s;cursor:default;
}
.pg:hover{background:var(--bg2)}
.pg-glow{
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--red),transparent);
  opacity:0;transition:opacity .3s;
}
.pg:hover .pg-glow{opacity:1}
.pg-n{font-family:var(--fm);font-size:.56rem;letter-spacing:.2em;color:var(--ink-3);margin-bottom:.875rem}
.pg-icon{font-size:1.625rem;display:block;margin-bottom:.75rem}
.pg-q{font-size:.9rem;font-weight:700;color:var(--ink);line-height:1.6;margin-bottom:.4rem}
.pg-d{font-size:.78rem;color:var(--ink-3);line-height:1.85}

/* ═══════════════════════════════════════════
   VALUE MAP — 横フロー図 (改良版)
═══════════════════════════════════════════ */
.vmap-sec{
  background:var(--bg2);position:relative;overflow:hidden;
}
.vmap-sec::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 80% at 65% 50%,rgba(0,159,232,.06),transparent 60%);
}
.vmap-grid{display:grid;grid-template-columns:420px 1fr;gap:72px;align-items:center;position:relative;z-index:1}

/* 右: フロー図 */
.vm-diagram{
  background:rgba(255,255,255,.025);
  border:1px solid var(--b2);border-radius:10px;
  padding:1.875rem;overflow:hidden;position:relative;
}
.vm-diagram::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--blue),transparent);
}
.vm-label{font-family:var(--fm);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}
.vm-label::after{content:'';flex:1;height:1px;background:var(--b1)}

/* 行 */
.vm-row{display:grid;grid-template-columns:1fr 36px 100px 36px 1fr;align-items:center;gap:0;margin-bottom:10px}
.vm-row:last-child{margin-bottom:0}

/* before */
.vm-b{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:6px;padding:10px 12px;text-align:center;
}
.vm-b-tag{font-family:var(--fm);font-size:.5rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.2);margin-bottom:3px}
.vm-b-text{font-size:.82rem;font-weight:700;color:rgba(255,255,255,.55);line-height:1.3}

/* arrow */
.vm-arr{display:flex;align-items:center;justify-content:center;position:relative;height:40px}
.vm-arr::before{content:'';position:absolute;left:4px;right:16px;top:50%;height:1px;background:linear-gradient(to right,rgba(0,159,232,.2),rgba(0,159,232,.6))}
.vm-arr::after{content:'▶';font-size:.5rem;color:var(--blue);position:absolute;right:2px;top:50%;transform:translateY(-50%)}

/* engine */
.vm-eng{
  background:linear-gradient(145deg,rgba(0,42,74,.9),rgba(0,22,42,.95));
  border:1.5px solid rgba(0,159,232,.45);border-radius:8px;
  padding:12px 8px;text-align:center;position:relative;overflow:hidden;
  box-shadow:0 0 20px rgba(0,159,232,.12);
}
.vm-eng::before{content:'';position:absolute;top:0;left:0;right:0;height:1.5px;background:linear-gradient(90deg,transparent,rgba(0,159,232,.9),transparent)}
.vm-eng-tag{font-family:var(--fm);font-size:.46rem;letter-spacing:.15em;color:rgba(0,159,232,.5);text-transform:uppercase;margin-bottom:3px}
.vm-eng-text{font-size:.8rem;font-weight:700;color:#fff;line-height:1.25}
.vm-eng-sub{font-family:var(--fm);font-size:.52rem;color:rgba(0,159,232,.6);margin-top:2px;letter-spacing:.1em}

/* after */
.vm-a{
  background:rgba(0,159,232,.1);border:1px solid rgba(0,159,232,.3);
  border-radius:6px;padding:10px 12px;text-align:center;
  transition:all .2s;cursor:default;
}
.vm-a:hover{background:rgba(0,159,232,.18);border-color:rgba(0,159,232,.6)}
.vm-a-tag{font-family:var(--fm);font-size:.5rem;letter-spacing:.15em;text-transform:uppercase;color:var(--blue-l);margin-bottom:3px}
.vm-a-text{font-size:.82rem;font-weight:700;color:#fff;line-height:1.3}

.vm-caption{font-family:var(--fm);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);text-align:center;margin-top:1.25rem}

/* ═══════════════════════════════════════════
   SERVICES
═══════════════════════════════════════════ */
.svc-sec{
  background:#F5F3EE;  /* ライトセクション */
}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.svc-card{
  background:#fff;border:1.5px solid #E8E4DC;border-radius:10px;
  padding:2rem 1.875rem;position:relative;overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;
}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 16px 48px rgba(0,30,50,.09);border-color:#C8B89A}
.svc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--blue-l));
  border-radius:0 0 3px 3px;
}
.svc-icon{width:50px;height:50px;border-radius:10px;background:#EEF6FB;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:1.25rem}
.svc-n{font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:.625rem;font-family:var(--fj)}
.svc-p{font-size:.82rem;color:#5A6A7A;line-height:1.9}
.svc-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:1rem}
.st{font-family:var(--fm);font-size:.62rem;letter-spacing:.04em;padding:.18rem .6rem;border-radius:2px;background:rgba(0,66,108,.06);color:var(--navy)}

/* ═══════════════════════════════════════════
   RESULTS
═══════════════════════════════════════════ */
.res-sec{background:var(--bg3)}
.res-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--b1);border:1px solid var(--b1);border-radius:10px;overflow:hidden;margin-top:3.5rem}
.rc{background:var(--bg3);padding:2.25rem 2rem;text-align:center;transition:background .3s}
.rc:hover{background:var(--bg2)}
.rc-num{
  font-family:var(--fb);font-size:clamp(2.5rem,4vw,3.75rem);
  color:var(--ink);line-height:1;letter-spacing:.01em;margin-bottom:.5rem;
}
.rc-num em{font-family:var(--fm);font-size:.4em;font-style:normal;color:var(--blue-l)}
.rc-lbl{font-family:var(--fm);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.25rem}
.rc-desc{font-size:.78rem;color:var(--ink-3);line-height:1.75}
/* ═══════════════════════════════════════════
   CASES
═══════════════════════════════════════════ */
.cases-sec{background:#F5F3EE}
.cases-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.cc{background:#fff;border:1.5px solid #E8E4DC;border-radius:10px;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s}
.cc:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,30,50,.1)}
.cc-hd{background:var(--navy-d);padding:1.625rem 2rem}
.cc-hd-tag{font-family:var(--fm);font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:.4rem}
.cc-hd h3{font-size:.95rem;font-weight:700;color:#fff;line-height:1.5;font-family:var(--fj)}
.cc-bd{padding:1.625rem 2rem}
.cc-metric{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.875rem}
.cm-b{font-size:1.05rem;color:#9AA5B0;text-decoration:line-through;font-family:var(--fm)}
.cm-arr{color:var(--blue);font-size:1.1rem}
.cm-v{font-family:var(--fb);font-size:2.2rem;color:var(--navy);letter-spacing:.01em}
.cm-u{font-size:.78rem;color:#9AA5B0}
.cc-desc{font-size:.82rem;color:#5A6A7A;line-height:1.9}
.cc-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:.875rem}
.ct{font-family:var(--fm);font-size:.6rem;padding:.18rem .55rem;border-radius:2px;background:rgba(0,66,108,.06);color:var(--navy)}

/* ═══════════════════════════════════════════
   TOOLS
═══════════════════════════════════════════ */
.tools-sec{background:#F5F3EE;padding:52px 0}
.tools-in{display:flex;align-items:center;gap:2.5rem;flex-wrap:wrap;justify-content:center}
.tools-lbl{font-family:var(--fm);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:#9AA5B0;white-space:nowrap}
.tools-row{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}
.tool-chip{
  display:flex;align-items:center;gap:.5rem;padding:.52rem 1.1rem;
  background:#fff;border:1.5px solid #E8E4DC;border-radius:99px;
  font-family:var(--fm);font-size:.72rem;font-weight:500;color:#5A6A7A;
  transition:all .2s;letter-spacing:.04em;
}
.tool-chip:hover{border-color:var(--blue);color:var(--navy);transform:translateY(-2px);box-shadow:0 4px 14px rgba(0,66,108,.1)}
.tool-chip span{font-size:.95rem}

/* ═══════════════════════════════════════════
   PROCESS
═══════════════════════════════════════════ */
.proc-sec{background:var(--bg2)}
.proc-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;position:relative;margin-top:3.5rem;
}
.proc-row::before{
  content:'';position:absolute;top:34px;left:12.5%;right:12.5%;height:1px;
  background:linear-gradient(90deg,rgba(0,159,232,.08),rgba(0,159,232,.4),rgba(0,159,232,.08));
}
.proc-step{text-align:center;padding:0 1rem;position:relative;z-index:1}
.proc-circle{
  width:68px;height:68px;border-radius:50%;margin:0 auto 1.5rem;
  background:rgba(255,255,255,.03);border:1px solid var(--b2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:all .35s var(--ease);position:relative;
}
.proc-step:hover .proc-circle{background:rgba(0,159,232,.1);border-color:rgba(0,159,232,.4);transform:scale(1.08)}
.proc-icon{font-size:1.3rem}
.proc-stepn{font-family:var(--fm);font-size:.48rem;letter-spacing:.1em;color:var(--ink-3);margin-top:3px}
.proc-step h3{font-size:.9rem;font-weight:700;color:var(--ink);margin-bottom:.4rem}
.proc-step p{font-size:.76rem;color:var(--ink-3);line-height:1.8}
.proc-free{
  display:inline-block;font-family:var(--fm);font-size:.54rem;letter-spacing:.1em;
  background:var(--red);color:#fff;padding:.15rem .5rem;border-radius:2px;margin-top:.5rem;
}

/* ═══════════════════════════════════════════
   PHILOSOPHY QUOTE
═══════════════════════════════════════════ */
.phil-sec{
  background:var(--bg);
  position:relative;overflow:hidden;
  padding:100px 0;
}
.phil-deco{
  position:absolute;left:-0.02em;top:50%;transform:translateY(-50%);
  font-family:var(--fb);font-size:clamp(12rem,20vw,25rem);
  color:rgba(255,255,255,.015);line-height:1;
  pointer-events:none;user-select:none;
}
.phil-in{
  position:relative;z-index:1;max-width:800px;margin:0 auto;
  text-align:center;padding:0 2.5rem;
}
.phil-quote{
  font-family:var(--fc);font-style:italic;
  font-size:clamp(1.8rem,4vw,3.2rem);
  color:var(--ink);line-height:1.5;letter-spacing:-.01em;
  margin-bottom:1.5rem;
}
.phil-quote em{font-style:normal;color:var(--blue-l)}
.phil-attr{font-family:var(--fm);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:2.5rem}
.phil-body{font-size:.92rem;color:var(--ink-2);line-height:2.1;max-width:600px;margin:0 auto 2.5rem}

/* ═══════════════════════════════════════════
   CTA
═══════════════════════════════════════════ */
.cta-sec{
  background:var(--navy-d);
  position:relative;overflow:hidden;padding:96px 0;
}
.cta-bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 55% 80% at 0% 100%,rgba(0,159,232,.1),transparent 55%),
    radial-gradient(ellipse 40% 60% at 100% 0%,rgba(229,0,18,.07),transparent 50%);
}
.cta-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(var(--b1) 1px,transparent 1px),linear-gradient(90deg,var(--b1) 1px,transparent 1px);
  background-size:56px 56px;
}
.cta-in{position:relative;z-index:1;text-align:center;max-width:680px;margin:0 auto;padding:0 2.5rem}
.cta-title{
  font-family:var(--fb);font-size:clamp(2.5rem,6vw,5.5rem);
  color:var(--ink);line-height:.95;letter-spacing:.01em;margin-bottom:1.25rem;
}
.cta-title .accent{color:var(--blue-l)}
.cta-serif{
  font-family:var(--fc);font-style:italic;font-size:clamp(1.2rem,2.5vw,1.8rem);
  color:var(--gold-l);display:block;margin-bottom:1.5rem;font-weight:400;
}
.cta-desc{font-size:.92rem;color:rgba(240,237,230,.5);line-height:2.05;margin-bottom:2.5rem}
.cta-btns{display:flex;gap:.875rem;justify-content:center;flex-wrap:wrap}
.btn-cta-main{
  display:inline-flex;align-items:center;gap:.625rem;
  padding:1.1rem 2.5rem;font-family:var(--fm);font-size:.8rem;
  letter-spacing:.12em;text-transform:uppercase;
  background:var(--red);color:#fff;border:1px solid var(--red);
  border-radius:3px;cursor:pointer;transition:all .3s var(--ease);
}
.btn-cta-main:hover{background:#c5000f;transform:translateY(-2px);box-shadow:0 10px 30px rgba(229,0,18,.35)}
.btn-cta-main svg{width:15px;height:15px}
.btn-cta-sub{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:1.1rem 2rem;font-family:var(--fm);font-size:.8rem;
  letter-spacing:.12em;text-transform:uppercase;
  background:transparent;color:var(--ink-2);border:1px solid var(--b2);
  border-radius:3px;cursor:pointer;transition:all .3s var(--ease);
}
.btn-cta-sub:hover{border-color:var(--ink-2);color:var(--ink)}
.cta-note{font-family:var(--fm);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.2);margin-top:1.25rem}

/* ═══════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════ */
.footer{background:var(--bg);border-top:1px solid var(--b1);padding:52px 0 28px}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:3rem;padding-bottom:2.5rem;border-bottom:1px solid var(--b1);margin-bottom:1.75rem}
.fl svg{height:26px;width:auto;margin-bottom:1rem}
.fl-copy{font-size:.78rem;color:var(--ink-3);line-height:1.9}
.fn h4{font-family:var(--fm);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.875rem}
.fn ul{list-style:none}
.fn li{margin-bottom:.375rem}
.fn a{font-size:.8rem;color:var(--ink-3);transition:color .2s}
.fn a:hover{color:var(--ink)}
.ft-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;font-family:var(--fm);font-size:.68rem;color:var(--ink-3)}
.ft-bottom a{color:var(--ink-3);transition:color .2s}
.ft-bottom a:hover{color:var(--ink)}

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media(max-width:1024px){
  .h-inner{grid-template-columns:1fr;gap:3rem}
  .h-panel{max-width:480px}
  .about-grid,.vmap-grid{grid-template-columns:1fr;gap:3rem}
  .hdr-nav,.hdr-r{display:none}
  .ham{display:flex}
  .res-grid{grid-template-columns:1fr 1fr}
  .ft-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .vmap-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .sec{padding:72px 0}
  .hero{min-height:auto;padding:96px 0 64px}
  .prob-grid,.svc-grid,.cases-grid{grid-template-columns:1fr}
  .proc-row{grid-template-columns:1fr 1fr;gap:2rem}
  .proc-row::before{display:none}
  .cta-btns{flex-direction:column;align-items:center}
  .cta-btns a{width:100%;justify-content:center}
}
@media(max-width:480px){
  .w,.w-n{padding:0 1.5rem}
  .h-cta{flex-direction:column}
  .h-cta a{width:100%;justify-content:center;text-align:center}
  .res-grid,.proc-row{grid-template-columns:1fr}
  .ft-grid{grid-template-columns:1fr}
  .tools-in{flex-direction:column;gap:1.25rem;align-items:flex-start}
}


/* Lightning既存スタイルとの競合対策 */
body.mycelf-top {
  margin: 0 !important;
  padding: 0 !important;
}
body.mycelf-top #site-header,
body.mycelf-top .site-header,
body.mycelf-top .vk-mobile-nav-menu-btn,
body.mycelf-top #vk-mobile-nav { display: none !important; }
body.mycelf-top .l-main,
body.mycelf-top main,
body.mycelf-top .entry-content { padding: 0 !important; margin: 0 !important; max-width: none !important; }
body.mycelf-top .l-footer,
body.mycelf-top .site-footer { display: none !important; }
