/* =========================================================
   mystyle.css : LIGHT TRUST + PLAYFUL FLEX（FULL REPLACE）
   - 明るいベースに“ワクワク感”を足す
   - 枠・線で固めず、背景レイヤーと微アニメでリズムを作る
   - 可読性と信頼感は優先（ふざけすぎない）
   - Mobile nav（hamburger + drawer）対応：競合を解消済み
   ========================================================= */

/* ---------- Theme variables ---------- */
:root{
  --bg: #ffffff;
  --bg2: #f5f9ff;
  --bg3: #eef6ff;

  --text: #0b1220;
  --muted: rgba(11,18,32,.70);
  --muted2: rgba(11,18,32,.55);

  --line: rgba(11,18,32,.10);

  --brand: #1d4ed8;
  --brand2: #0284c7;
  --accent: #7c3aed;  /* 少し遊び（紫） */
  --accent2:#fb7185;  /* 少し遊び（ピンク） */

  --shadow: 0 16px 38px rgba(2,6,23,.10);
  --shadow2: 0 14px 26px rgba(2,6,23,.08);
  --shadow3: 0 18px 50px rgba(2,6,23,.12);

  --r-xl: 26px;
  --r-lg: 20px;
  --r-md: 14px;

  --max: 1120px;
}

/* ---------- Base background (layered) ---------- */
body{
  background:
    radial-gradient(900px 520px at 15% -10%, rgba(29,78,216,.14), transparent 55%),
    radial-gradient(760px 460px at 95% 10%, rgba(2,132,199,.12), transparent 55%),
    radial-gradient(560px 360px at 70% 105%, rgba(124,58,237,.10), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg2));
  color: var(--text);
}

/* Remove block dividers */
.section{ border-top: none !important; }

/* ---------- Layout helpers ---------- */
.container{
  width: min(var(--max), calc(100% - 40px));
  margin: 0 auto;
}
.grid{ gap: 18px; }
@media (min-width: 900px){
  .grid.cols-3{ grid-template-columns: repeat(3, 1fr); }
  .grid.cols-2{ grid-template-columns: repeat(2, 1fr); }
}

/* ---------- Header (light glass) ---------- */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(10px);
  background: rgba(255,255,255,.80) !important;
  border-bottom: 1px solid rgba(11,18,32,.10) !important;
}
.site-header .row{ padding: 14px 0; }

/* make sure header text visible */
.site-header,
.site-header a{
  color: var(--text) !important;
}
.brand-sub{ color: var(--muted) !important; }

.nav a{
  color: rgba(11,18,32,.70) !important;
  border-radius: 14px;
  padding: 8px 10px;
}
.nav a:hover{
  background: rgba(29,78,216,.08) !important;
  color: var(--text) !important;
}

/* Brand mark playful gradient */
.brand-mark{
  background: linear-gradient(135deg, rgba(29,78,216,.95), rgba(2,132,199,.90)) !important;
  box-shadow: 0 14px 30px rgba(29,78,216,.18);
  border-radius: 12px !important;
}

/* ---------- Badge ---------- */
.badge{
  border: 1px solid rgba(29,78,216,.18) !important;
  background: rgba(29,78,216,.06) !important;
  color: rgba(11,18,32,.70) !important;
}

/* ---------- Buttons (more fun) ---------- */
.btn{
  border: 1px solid rgba(11,18,32,.14) !important;
  background: rgba(255,255,255,.90) !important;
  box-shadow: var(--shadow2) !important;
  color: var(--text) !important;
  border-radius: 999px;
  transition: transform .14s ease, box-shadow .14s ease, filter .14s ease, background .14s ease;
}
.btn:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow3) !important;
}
.btn.primary{
  background: linear-gradient(135deg, rgba(29,78,216,.98), rgba(2,132,199,.92)) !important;
  border-color: rgba(29,78,216,.35) !important;
  color: #fff !important;
}
.btn.primary:hover{ filter: brightness(1.05); }

/* ---------- Cards (less “boxy”) ---------- */
.card{
  position: relative;
  border: 1px solid rgba(11,18,32,.10) !important;
  border-radius: var(--r-xl) !important;
  background:
    radial-gradient(900px 240px at 15% 0%, rgba(29,78,216,.06), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(243,247,255,.70)) !important;
  box-shadow: var(--shadow) !important;
}
.card::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: var(--r-xl);
  pointer-events:none;
  background:
    radial-gradient(600px 180px at 30% 0%, rgba(2,132,199,.14), transparent 60%),
    radial-gradient(500px 160px at 90% 10%, rgba(124,58,237,.10), transparent 60%);
  opacity: .35;
  -webkit-mask: linear-gradient(#000, transparent 72%);
          mask: linear-gradient(#000, transparent 72%);
}
.card--lift{
  transition: transform .16s ease, box-shadow .16s ease;
}
.card--lift:hover{
  transform: translateY(-4px) rotate(-.15deg);
  box-shadow: 0 22px 56px rgba(2,6,23,.14);
}

/* Text helpers */
.kicker{ color: rgba(11,18,32,.62) !important; }
.lead{ color: rgba(11,18,32,.72) !important; }

/* ---------- HERO playful video ---------- */
.hero.hero--video{
  position: relative;
  overflow: hidden;
  color: #fff;
  padding: 78px 0 56px;
}
.hero .inner{ gap: 22px; }
@media (min-width: 980px){
  .hero .inner{
    grid-template-columns: 1.2fr .8fr;
    align-items:center;
  }
}

.hero.hero--video .hero-bg{ position:absolute; inset:0; z-index:0; }
.hero.hero--video .hero-video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform: scale(1.02);
  filter: saturate(.95) contrast(1.08);
}
.hero.hero--video .hero-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(900px 420px at 15% 10%, rgba(29,78,216,.36), transparent 55%),
    radial-gradient(700px 360px at 85% 0%, rgba(2,132,199,.26), transparent 60%),
    linear-gradient(180deg, rgba(11,18,32,.72), rgba(11,18,32,.44));
}

/* sparkles layer */
.hero-sparkles{
  position:absolute; inset:0;
  background:
    radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(2px 2px at 40% 60%, rgba(255,255,255,.38), transparent 60%),
    radial-gradient(2px 2px at 70% 35%, rgba(255,255,255,.44), transparent 60%),
    radial-gradient(2px 2px at 82% 58%, rgba(255,255,255,.34), transparent 60%);
  opacity: .35;
  animation: spark 6s ease-in-out infinite alternate;
}
@keyframes spark{
  from{ transform: translateY(0); opacity:.30; }
  to{ transform: translateY(-10px); opacity:.40; }
}

.hero.hero--video .container{ position:relative; z-index:1; }
.hero.hero--video .badge{
  border-color: rgba(255,255,255,.26) !important;
  background: rgba(11,18,32,.28) !important;
  color: rgba(255,255,255,.90) !important;
}
.hero.hero--video p{ color: rgba(255,255,255,.88) !important; }

.panel--glass{
  position: relative;
  border-radius: var(--r-xl) !important;
  border: 1px solid rgba(255,255,255,.26) !important;
  background: rgba(255,255,255,.14) !important;
  backdrop-filter: blur(10px);
  box-shadow: 0 24px 60px rgba(0,0,0,.26);
}
.panel-chip{
  position:absolute;
  right: 14px;
  bottom: 14px;
  width: 40px;
  height: 40px;
  display:grid;
  place-items:center;
  border-radius: 999px;
  background: rgba(255,255,255,.20);
  border: 1px solid rgba(255,255,255,.28);
}

.hero-wave{
  position:absolute;
  left:0; right:0; bottom:-1px;
  height: 120px;
  z-index: 2;
}
.hero-wave svg{ width:100%; height:100%; display:block; }
.hero-wave path{ fill: rgba(255,255,255,.92); }

/* ---------- About media tilt + sticker ---------- */
.about-media{
  position: relative;
  display: grid;
  gap: 18px;
  margin: 18px 0 22px;
}
.about-media--tilt .about-figure{ transform: rotate(-1.2deg); }
.about-figure{
  margin:0;
  border-radius: var(--r-xl);
  overflow:hidden;
  border: 1px solid rgba(11,18,32,.10);
  box-shadow: 0 24px 60px rgba(2,6,23,.14);
  background: rgba(255,255,255,.70);
}
.about-figure img{ width:100%; height:auto; display:block; }

.about-sticker{
  position:absolute;
  right: 16px;
  top: -12px;
  display:flex;
  gap: 8px;
  transform: rotate(2deg);
}
.about-sticker .tag{
  font-size: 12px;
  font-weight: 800;
  padding: 8px 10px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(11,18,32,.10);
  box-shadow: var(--shadow2);
}
.about-sticker .tag:nth-child(1){ outline: 2px solid rgba(29,78,216,.18); }
.about-sticker .tag:nth-child(2){ outline: 2px solid rgba(2,132,199,.18); }
.about-sticker .tag:nth-child(3){ outline: 2px solid rgba(124,58,237,.14); }

/* ---------- Services thumbs with slight skew ---------- */
.service-thumb{
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: calc(var(--r-xl) - 6px);
  border: 1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.70);
  box-shadow: var(--shadow2);
  margin-bottom: 12px;
}
.service-thumb--skew{ transform: rotate(.8deg); }
.service-card:nth-child(2) .service-thumb--skew{ transform: rotate(-.6deg); }
.service-card:nth-child(3) .service-thumb--skew{ transform: rotate(.4deg); }

.card-badge{
  position:absolute;
  top: 14px;
  right: 14px;
  width: 44px;
  height: 44px;
  display:grid;
  place-items:center;
  border-radius: 16px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(11,18,32,.10);
  box-shadow: var(--shadow2);
  font-weight: 900;
  color: rgba(11,18,32,.72);
}

/* ---------- Section variation (rhythm) ---------- */
.section--alt{
  background:
    radial-gradient(900px 260px at 15% 0%, rgba(29,78,216,.06), transparent 55%),
    linear-gradient(180deg, rgba(245,249,255,.85), rgba(255,255,255,.75));
}
.section--fun{
  background:
    radial-gradient(900px 320px at 85% 0%, rgba(124,58,237,.06), transparent 60%),
    radial-gradient(900px 320px at 15% 10%, rgba(2,132,199,.06), transparent 60%);
}
.section--cta{ background: transparent; }

/* ---------- CTA band PRO (quality upgrade) ---------- */
.cta-band--pro{
  position: relative;
  display: grid;
  gap: 18px;
  padding: 22px;
  border-radius: var(--r-xl);
  border: 1px solid rgba(11,18,32,.10);
  box-shadow: var(--shadow3);
  overflow: hidden;
  background:
    radial-gradient(900px 360px at 20% 10%, rgba(29,78,216,.14), transparent 55%),
    radial-gradient(900px 360px at 90% 20%, rgba(124,58,237,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(243,247,255,.86));
}
.cta-band--pro::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(2px 2px at 15% 30%, rgba(11,18,32,.12), transparent 60%),
    radial-gradient(2px 2px at 35% 70%, rgba(11,18,32,.10), transparent 60%),
    radial-gradient(2px 2px at 70% 40%, rgba(11,18,32,.10), transparent 60%),
    radial-gradient(2px 2px at 85% 65%, rgba(11,18,32,.10), transparent 60%);
  opacity: .25;
  pointer-events:none;
}
.cta-band--pro > *{ position: relative; z-index: 1; }

@media (min-width: 980px){
  .cta-band--pro{
    grid-template-columns: 1.1fr .9fr;
    align-items: stretch;
    padding: 26px;
  }
}

.cta-left .cta-eyebrow{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-weight: 900;
  letter-spacing: .04em;
  color: rgba(11,18,32,.72);
  margin-bottom: 8px;
}
.cta-left .cta-eyebrow::before{
  content:"";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(29,78,216,.95), rgba(2,132,199,.90));
  box-shadow: 0 10px 20px rgba(29,78,216,.18);
}

.cta-band--pro .title{
  font-size: clamp(18px, 2.1vw, 26px);
  font-weight: 950;
  letter-spacing: .01em;
  line-height: 1.25;
}
.cta-band--pro .desc{
  margin-top: 10px;
  color: rgba(11,18,32,.72);
  line-height: 1.7;
}

.cta-actions{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.cta-note{
  margin-top: 12px;
  display:flex;
  align-items:center;
  gap: 10px;
  color: rgba(11,18,32,.62);
  font-size: 13px;
}
.cta-note .dot{
  width: 10px; height: 10px;
  border-radius: 999px;
  background: rgba(29,78,216,.18);
  box-shadow: 0 10px 18px rgba(29,78,216,.10);
}

.cta-right{ position: relative; }
.cta-card{
  height: 100%;
  border-radius: var(--r-xl);
  border: 1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.78);
  box-shadow: var(--shadow2);
  padding: 18px;
}
.cta-card h3{
  margin-top: 6px;
  font-size: 18px;
  line-height: 1.3;
}

.cta-points{
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
  display: grid;
  gap: 12px;
}
.cta-points li{
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(11,18,32,.08);
  background: rgba(243,247,255,.72);
}
.cta-points .icon{
  width: 36px; height: 36px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(29,78,216,.10);
  color: rgba(29,78,216,.92);
}
.cta-points .icon svg{ width: 18px; height: 18px; }
.cta-points .t{
  font-weight: 900;
  color: rgba(11,18,32,.86);
}
.cta-points .s{
  margin-top: 2px;
  font-size: 13px;
  color: rgba(11,18,32,.62);
  line-height: 1.55;
}

.cta-mini{
  margin-top: 12px;
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
}
.cta-mini .pill{
  display:inline-flex;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.86);
  color: rgba(11,18,32,.70);
  font-size: 12px;
  font-weight: 800;
}

/* subtle decor behind right card */
.cta-decor{
  position:absolute;
  inset:-30px;
  z-index:0;
  background:
    radial-gradient(80px 80px at 20% 30%, rgba(29,78,216,.14), transparent 60%),
    radial-gradient(90px 90px at 85% 20%, rgba(124,58,237,.12), transparent 60%),
    radial-gradient(70px 70px at 70% 80%, rgba(2,132,199,.12), transparent 60%);
  filter: blur(1px);
  opacity: .55;
  pointer-events:none;
}

/* Mobile: keep it clean */
@media (max-width: 600px){
  .cta-band--pro{ padding: 18px; }
  .cta-card{ padding: 16px; }
}

/* ---------- News fun ---------- */
.news-item{
  border: 1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.88);
  box-shadow: var(--shadow2);
  border-radius: 16px;
}
.news-item--playful{
  position: relative;
  overflow:hidden;
}
.news-item--playful::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(400px 120px at 10% 0%, rgba(29,78,216,.10), transparent 60%),
    radial-gradient(400px 120px at 90% 100%, rgba(2,132,199,.08), transparent 60%);
  opacity:.35;
  transform: translateY(10px);
  transition: transform .18s ease;
}
.news-item--playful:hover::before{ transform: translateY(0); }
.news-item .arrow{
  margin-left: auto;
  font-weight: 900;
  color: rgba(11,18,32,.45);
}
.news-item:hover{
  transform: translateY(-2px);
  transition: transform .16s ease, box-shadow .16s ease;
  box-shadow: 0 22px 56px rgba(2,6,23,.12);
  border-color: rgba(29,78,216,.18);
}
.news-item time{ color: rgba(11,18,32,.55); }
.news-item .title{ color: var(--text); }

/* ---------- Footer ---------- */
.site-footer{
  background: linear-gradient(180deg, rgba(245,249,255,.96), rgba(255,255,255,.96)) !important;
  border-top: 1px solid rgba(11,18,32,.10) !important;
  color: rgba(11,18,32,.70) !important;
}
.site-footer a{ color: rgba(11,18,32,.74) !important; }
.site-footer a:hover{ color: var(--brand) !important; }

/* ---------- Accessibility ---------- */
@media (prefers-reduced-motion: reduce){
  .hero-video{ display:none; }
  .hero-sparkles{ animation: none; }
  .card--lift:hover, .btn:hover{ transform:none; }
}

/* Mobile safety: reduce tilt/overflow for stability */
@media (max-width: 600px){
  .about-media--tilt .about-figure{ transform:none; }
  .about-sticker{ position:static; transform:none; margin-top: 10px; }
  .service-thumb--skew{ transform:none; }
}

/* =========================================================
   COMPANY block styles
   ========================================================= */
.section--company{
  background:
    radial-gradient(900px 320px at 10% 0%, rgba(29,78,216,.07), transparent 60%),
    radial-gradient(900px 320px at 90% 10%, rgba(124,58,237,.06), transparent 60%),
    linear-gradient(180deg, rgba(245,249,255,.85), rgba(255,255,255,.78));
}

.company-dl{
  margin: 14px 0 0;
  display: grid;
  gap: 10px;
}
.company-dl .row{
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(11,18,32,.08);
}
.company-dl dt{
  font-weight: 800;
  color: rgba(11,18,32,.70);
}
.company-dl dd{
  margin: 0;
  color: var(--text);
}
.company-actions{
  margin-top: 14px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.company-list{
  margin: 12px 0 0;
  padding-left: 18px;
  color: rgba(11,18,32,.74);
}

.company-media{
  margin-top: 14px;
  display: grid;
  gap: 14px;
}
@media (min-width: 980px){
  .company-media{
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }
}

.company-map .map-box{
  margin-top: 8px;
  border-radius: 18px;
  border: 1px dashed rgba(29,78,216,.25);
  background: rgba(29,78,216,.05);
  padding: 16px;
  color: rgba(11,18,32,.68);
  min-height: 150px;
  display: grid;
  place-items: center;
  text-align: center;
}

.company-photo img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 18px;
  border: 1px solid rgba(11,18,32,.10);
  box-shadow: var(--shadow2);
}

/* Mobile: DL rows stack */
@media (max-width: 600px){
  .company-dl .row{ grid-template-columns: 1fr; }
}

/* =========================================================
   Mobile header compact（競合解消版）
   - スマホではヘッダーを「1段・省スペース」にたたむ
   - ※対象を desktop ナビ/CTA に限定し、ハンバーガーと競合しない
   ========================================================= */
@media (max-width: 900px){

  .site-header .row{
    padding: 10px 0 !important;
    gap: 10px !important;
  }

  .brand{
    min-width: 0 !important;
    gap: 8px !important;
  }
  .brand-mark{
    width: 28px !important;
    height: 28px !important;
    border-radius: 10px !important;
  }
  .brand-name{
    font-size: 14px !important;
    line-height: 1.1 !important;
  }

  /* サブタイトルはスマホでは非表示 */
  .brand-sub{ display: none !important; }

  /* ★重要：隠すのは desktop ナビだけ */
  .nav--desktop{ display: none !important; }

  /* ★重要：CTAも desktop 側だけ */
  .header-cta--desktop{ display: none !important; }

  /* ハンバーガーは表示 */
  .nav-toggle{ display: inline-flex !important; }
}

/* =========================================================
   Mobile navigation (hamburger + drawer) - STABLE VERSION
   ========================================================= */

/* prevent background scroll when menu open */
html.nav-open, html.nav-open body{
  overflow: hidden;
}

/* toggle button */
.nav-toggle{
  display:none;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(11,18,32,.12);
  background: rgba(255,255,255,.86);
  box-shadow: var(--shadow2);
  color: var(--text);
  align-items: center;
  justify-content: center;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.nav-toggle-lines{
  position: relative;
  width: 18px;
  height: 2px;
  background: rgba(11,18,32,.78);
  border-radius: 999px;
  display:block;
}
.nav-toggle-lines::before,
.nav-toggle-lines::after{
  content:"";
  position:absolute;
  left:0;
  width: 18px;
  height: 2px;
  background: rgba(11,18,32,.78);
  border-radius: 999px;
}
.nav-toggle-lines::before{ top: -6px; }
.nav-toggle-lines::after{ top: 6px; }

/* desktop / mobile switching */
.nav--desktop,
.header-cta--desktop{ display:flex; }

/* container: keep defined even on desktop */
.mobile-nav{
  position: fixed;
  inset: 0;
  z-index: 1000;              /* 強制最前面 */
  display: none;              /* mobile only */
  visibility: hidden;         /* うっすら表示を防止 */
  pointer-events: none;       /* 閉じてる時は絶対に触れない */
}

/* breakpoint */
@media (max-width: 900px){
  .nav--desktop,
  .header-cta--desktop{ display:none !important; }

  .nav-toggle{ display:inline-flex; }

  .mobile-nav{
    display:block;
  }

  .mobile-nav__overlay{
    position:absolute;
    inset:0;
    background: rgba(11,18,32,.44);
    opacity: 0;
    transition: opacity .18s ease;
  }

  .mobile-nav__panel{
    position:absolute;
    top: 10px;
    right: 10px;
    left: 10px;
    max-width: 520px;
    margin-left: auto;

    border-radius: var(--r-xl);
    border: 1px solid rgba(11,18,32,.10);
    background:
      radial-gradient(900px 360px at 20% 10%, rgba(29,78,216,.14), transparent 55%),
      radial-gradient(900px 360px at 90% 20%, rgba(124,58,237,.10), transparent 60%),
      linear-gradient(180deg, rgba(255,255,255,.96), rgba(243,247,255,.92));
    box-shadow: 0 26px 70px rgba(2,6,23,.20);

    transform: translateY(-8px) scale(.98);
    opacity: 0;
    transition: transform .18s ease, opacity .18s ease;
    pointer-events: auto;
    overflow: hidden;
  }

  /* OPEN state */
  .mobile-nav.is-open{
    visibility: visible;
    pointer-events: auto;
  }
  .mobile-nav.is-open .mobile-nav__overlay{
    opacity: 1;
  }
  .mobile-nav.is-open .mobile-nav__panel{
    transform: translateY(0) scale(1);
    opacity: 1;
  }

  .mobile-nav__head{
    display:flex;
    align-items:center;
    justify-content: space-between;
    padding: 14px 14px 10px;
    border-bottom: 1px solid rgba(11,18,32,.08);
  }
  .mobile-nav__title{
    font-weight: 950;
    letter-spacing: .02em;
  }
  .mobile-nav__close{
    width: 40px; height: 40px;
    border-radius: 14px;
    border: 1px solid rgba(11,18,32,.12);
    background: rgba(255,255,255,.86);
    cursor:pointer;
    font-size: 20px;
    line-height: 1;
  }

  .mobile-nav__links{
    display:grid;
    padding: 12px 14px;
    gap: 8px;
  }
  .mobile-nav__links a{
    display:flex;
    align-items:center;
    justify-content: space-between;
    padding: 12px 12px;
    border-radius: 16px;
    border: 1px solid rgba(11,18,32,.08);
    background: rgba(255,255,255,.80);
    color: rgba(11,18,32,.78);
    font-weight: 850;
  }
  .mobile-nav__links a::after{
    content:"→";
    color: rgba(11,18,32,.38);
    font-weight: 900;
  }

  .mobile-nav__cta{
    display:flex;
    gap: 10px;
    flex-wrap: wrap;
    padding: 6px 14px 12px;
  }
  .mobile-nav__note{
    padding: 0 14px 14px;
    color: rgba(11,18,32,.60);
    font-size: 13px;
    line-height: 1.6;
  }
}


/* =========================================================
   SERVICES extras (このほかも相談OK)
   ========================================================= */
.service-extras{
  margin: 14px 0 18px;
  padding: 14px 14px;
  border-radius: var(--r-xl);
  border: 1px solid rgba(11,18,32,.08);
  background:
    radial-gradient(900px 240px at 15% 0%, rgba(29,78,216,.08), transparent 55%),
    radial-gradient(900px 240px at 90% 10%, rgba(124,58,237,.06), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(243,247,255,.86));
  box-shadow: var(--shadow2);
}
.service-extras__title{
  font-weight: 950;
  letter-spacing: .01em;
  color: rgba(11,18,32,.86);
}
.service-extras__chips{
  margin-top: 10px;
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
}
.chip{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.88);
  color: rgba(11,18,32,.74);
  font-size: 12px;
  font-weight: 800;
  box-shadow: 0 10px 20px rgba(2,6,23,.06);
}
.chip::before{
  content:"";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(29,78,216,.95), rgba(2,132,199,.90));
  box-shadow: 0 10px 18px rgba(29,78,216,.14);
}
.service-extras__note{
  margin-top: 10px;
  color: rgba(11,18,32,.64);
  font-size: 13px;
  line-height: 1.6;
}

/* Mobile: chips wrap nicely */
@media (max-width: 600px){
  .service-extras{ padding: 12px; }
  .chip{ font-size: 12px; padding: 8px 10px; }
}


/* =========================================================
   Form styling (Snow Monkey Forms / generic)
   ========================================================= */
.post-body form{
  margin-top: 12px;
}
.post-body label{
  display:block;
  font-weight: 850;
  color: rgba(11,18,32,.82);
  margin: 12px 0 6px;
}
.post-body input[type="text"],
.post-body input[type="email"],
.post-body input[type="tel"],
.post-body input[type="url"],
.post-body input[type="number"],
.post-body select,
.post-body textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(11,18,32,.14);
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 20px rgba(2,6,23,.05);
  outline: none;
}
.post-body textarea{
  min-height: 140px;
  resize: vertical;
}
.post-body input:focus,
.post-body select:focus,
.post-body textarea:focus{
  border-color: rgba(29,78,216,.35);
  box-shadow: 0 0 0 4px rgba(29,78,216,.12), 0 16px 32px rgba(2,6,23,.08);
}
.post-body input[type="submit"],
.post-body button[type="submit"],
.post-body .smf-button-control__control{
  margin-top: 14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid rgba(29,78,216,.35);
  background: linear-gradient(135deg, rgba(29,78,216,.98), rgba(2,132,199,.92));
  color: #fff;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 18px 40px rgba(2,6,23,.12);
}
.post-body input[type="submit"]:hover,
.post-body button[type="submit"]:hover{
  filter: brightness(1.05);
}
.post-body .smf-error-messages,
.post-body .error,
.post-body .is-error{
  color: #b91c1c;
}


/* =========================================================
   Process cards (with images)
   ========================================================= */
.process-grid{
  margin-top: 14px;
}
.process-card{
  padding: 0;                 /* 画像＋本文なのでカード内余白を再設計 */
  overflow: hidden;
}

.process-media{
  position: relative;
  aspect-ratio: 16/9;
  background: rgba(255,255,255,.70);
  border-bottom: 1px solid rgba(11,18,32,.08);
}
.process-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* 画像が無い場合に備えた“それっぽい”プレースホルダー感 */
.process-media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(700px 260px at 20% 10%, rgba(29,78,216,.14), transparent 60%),
    radial-gradient(600px 260px at 90% 0%, rgba(124,58,237,.10), transparent 60%);
  opacity: .25;
  pointer-events:none;
}

.process-body{
  padding: 16px 18px 18px;
}
.process-body h3{
  margin-top: 6px;
}

/* スマホは読みやすさ優先（2列→1列） */
@media (max-width: 900px){
  .grid.cols-3.process-grid{
    grid-template-columns: 1fr;
  }
}


/* ===== Logo image in header ===== */
.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 0;
}

.brand-logo{
  display:block;
  height: 34px;     /* ヘッダー高さに合わせて調整 */
  width: auto;
  max-width: 220px; /* 横長ロゴが伸びすぎるのを防ぐ */
  object-fit: contain;
}

/* 文字のサイト名を表示しない（ロゴ画像と二重表示になるため） */
.brand-name,
.brand-sub{
  display:none !important;
}

/* スクリーンリーダー用 */
.sr-only{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

@media (max-width: 768px){
  .brand-logo{
    height: 28px;
    max-width: 180px;
  }
}


/* service card as a link */
.service-card--link{
  display: block;
  color: inherit;
  text-decoration: none;
}

.service-card--link:focus-visible{
  outline: 3px solid rgba(29,78,216,.35);
  outline-offset: 4px;
  border-radius: var(--r-xl, 22px);
}

.service-card__cta{
  margin-top: 14px;
}

/* hover時の「押せる感」を少し強化（任意） */
.service-card--link:hover .service-thumb{
  transform: translateY(-1px) rotate(.6deg);
  transition: transform .16s ease;
}



/* =========================================================
   LMIS-like scope (only on IT support template)
   - body に 'lmis' クラスが付いている前提
   ========================================================= */
body.lmis{
  background: #fff !important;
}

/* Hero */
body.lmis .lmis-hero{
  padding: 72px 0 42px;
  background:
    radial-gradient(900px 360px at 20% 10%, rgba(29,78,216,.10), transparent 55%),
    linear-gradient(180deg, #ffffff, #f6f9ff);
  border-bottom: 1px solid rgba(11,18,32,.08);
}
body.lmis .lmis-hero__inner{
  display:grid;
  gap: 22px;
}
@media (min-width: 980px){
  body.lmis .lmis-hero__inner{
    grid-template-columns: 1.05fr .95fr;
    align-items: center;
  }
}

body.lmis .lmis-hero h1{
  font-size: clamp(28px, 3.2vw, 44px);
  line-height: 1.15;
  letter-spacing: .01em;
  margin-top: 10px;
}
body.lmis .lmis-hero .lead{
  font-size: 16px;
  color: rgba(11,18,32,.78) !important;
}

/* Hero media */
body.lmis .lmis-hero__media{
  border-radius: 18px;
  border: 1px solid rgba(11,18,32,.10);
  background: #fff;
  box-shadow: 0 18px 40px rgba(2,6,23,.10);
  overflow:hidden;
}
body.lmis .lmis-hero__media img{
  width:100%;
  height:auto;
  display:block;
}

body.lmis .lmis-hero__note{
  margin-top: 12px;
  border-radius: 18px;
  border: 1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.92);
  box-shadow: 0 12px 26px rgba(2,6,23,.08);
  padding: 14px 14px;
}
body.lmis .lmis-hero__note ul{
  margin: 10px 0 0;
  color: rgba(11,18,32,.74);
}

/* Mail line */
body.lmis .lmis-hero__mail{
  margin-top: 10px;
  color: rgba(11,18,32,.70);
}
body.lmis .lmis-hero__mail a{
  color: var(--brand);
  text-decoration: underline;
}

/* Stats */
body.lmis .lmis-stats{
  margin-top: 16px;
  display:grid;
  gap: 10px;
}
@media (min-width: 900px){
  body.lmis .lmis-stats{
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
  }
}
body.lmis .lmis-stat{
  border-radius: 16px;
  border: 1px solid rgba(11,18,32,.10);
  background: #fff;
  box-shadow: 0 12px 26px rgba(2,6,23,.08);
  padding: 12px 12px;
}
body.lmis .lmis-stat .k{
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .06em;
  color: rgba(11,18,32,.55);
}
body.lmis .lmis-stat .v{
  margin-top: 6px;
  font-size: 18px;
  font-weight: 950;
  color: rgba(11,18,32,.88);
}
body.lmis .lmis-stat .s{
  margin-top: 2px;
  font-size: 13px;
  color: rgba(11,18,32,.62);
}

/* Buttons: LMIS-like (strong primary, clean secondary) */
body.lmis .btn{
  box-shadow: none !important;
  border: 1px solid rgba(11,18,32,.14) !important;
}
body.lmis .btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(2,6,23,.10) !important;
}
body.lmis .btn.primary{
  background: #1d4ed8 !important;
  border-color: rgba(29,78,216,.35) !important;
}

/* Cards: reduce “playful gradients” on this page only */
body.lmis .card{
  background: #fff !important;
  border-radius: 16px !important;
  box-shadow: 0 14px 30px rgba(2,6,23,.08) !important;
}
body.lmis .card::after{
  display:none !important;
}
body.lmis .card--lift:hover{
  transform: translateY(-3px);
  box-shadow: 0 20px 46px rgba(2,6,23,.12) !important;
}

/* Section backgrounds: cleaner blocks like LMIS */
body.lmis .section--alt{
  background: #f7f9fc !important;
}
body.lmis .section--fun{
  background: #ffffff !important;
}

/* Headings spacing */
body.lmis .section h2{
  margin-top: 10px;
  letter-spacing: .01em;
}

/* Mobile: hero spacing */
@media (max-width: 600px){
  body.lmis .lmis-hero{
    padding: 56px 0 34px;
  }
}