/* ============================================================
   RE:START — Corporate site design system
   Navy base · logo cyan→blue gradient accent · Noto Sans JP
   ============================================================ */

:root{
  /* Brand — sampled from logo */
  --navy-900:#0f1a3d;
  --navy-800:#152151;
  --navy-700:#1d2c63;
  --navy-600:#27387a;
  --blue:#1f6fc1;
  --blue-2:#2a86d6;
  --cyan:#37c4f2;

  /* Accent (tweakable) — ティール（青緑）グラデーション */
  --acc-1:#0b3d6b;
  --acc-2:#0f8a9e;
  --acc-3:#26c4b8;
  --grad:linear-gradient(118deg, var(--acc-1) 0%, var(--acc-2) 52%, var(--acc-3) 100%);
  --grad-soft:linear-gradient(118deg, var(--acc-2), var(--acc-3));

  /* Neutrals — cool-tinted */
  --ink:#16203c;
  --ink-2:#37425e;
  --muted:#69748f;
  --line:#e6e9f1;
  --line-2:#eef1f6;
  --bg:#ffffff;
  --bg-soft:#f4f6fa;
  --bg-soft-2:#eef2f8;

  /* Type */
  --f-jp:"Noto Sans JP", sans-serif;
  --f-en:"Schibsted Grotesk", "Noto Sans JP", sans-serif;

  /* Layout */
  --pad:clamp(20px, 5vw, 88px);
  --maxw:1280px;
  --r:14px;
  --header-h:78px;

  --ease:cubic-bezier(.2,.7,.2,1);
  --heading-scale:1;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--f-jp);
  color:var(--ink);
  background:var(--bg);
  line-height:1.75;
  font-size:16px;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;}
::selection{background:color-mix(in oklch, var(--acc-2) 28%, white);}

/* ---------- shell ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);width:100%;}
.section{padding-block:clamp(72px,9vw,140px);}
.section--tight{padding-block:clamp(56px,7vw,104px);}

/* ---------- type helpers ---------- */
.eyebrow{
  font-family:var(--f-en);
  font-weight:600;
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--blue);
  display:inline-flex;align-items:center;gap:.7em;
  margin:0 0 22px;
}
.eyebrow::before{
  content:"";width:30px;height:2px;border-radius:2px;
  background:var(--grad);display:inline-block;
}
.eyebrow--center{justify-content:center;}
.sec-title{
  font-family:var(--f-jp);
  font-weight:700;
  font-size:calc(clamp(28px,3.6vw,46px) * var(--heading-scale));
  line-height:1.32;
  letter-spacing:.01em;
  margin:0 0 26px;
  color:var(--ink);
  text-wrap:balance;
}
.sec-lead{
  font-size:clamp(15px,1.15vw,17px);
  color:var(--ink-2);
  line-height:2;
  max-width:46ch;
  margin:0;
}
.en-h{font-family:var(--f-en);font-weight:700;letter-spacing:-.01em;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--f-jp);font-weight:600;font-size:15px;
  padding:16px 26px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:.4s var(--ease);position:relative;letter-spacing:.02em;
  background:none;
}
.btn .ar{
  display:inline-grid;place-items:center;width:26px;height:26px;border-radius:50%;
  transition:.4s var(--ease);flex:none;
}
.btn .ar svg{width:14px;height:14px;transition:transform .4s var(--ease);}
.btn:hover .ar svg{transform:translateX(3px);}

.btn--primary{background:var(--navy-800);color:#fff;border-color:var(--navy-800);}
.btn--primary .ar{background:rgba(255,255,255,.14);}
.btn--primary:hover{background:var(--navy-900);box-shadow:0 14px 34px -12px rgba(21,33,81,.6);transform:translateY(-2px);}

.btn--ghost{border-color:var(--line);color:var(--ink);background:#fff;}
.btn--ghost .ar{background:var(--bg-soft-2);color:var(--blue);}
.btn--ghost:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px);box-shadow:0 14px 30px -16px rgba(31,111,193,.5);}

.btn--light{border-color:rgba(255,255,255,.28);color:#fff;background:rgba(255,255,255,.04);}
.btn--light .ar{background:rgba(255,255,255,.16);}
.btn--light:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.55);transform:translateY(-2px);}

.btn--grad{background:var(--grad);color:#fff;border:none;}
.btn--grad .ar{background:rgba(255,255,255,.2);}
.btn--grad:hover{filter:brightness(1.06);transform:translateY(-2px);box-shadow:0 16px 38px -12px rgba(38,130,207,.6);}

/* ---------- image placeholders ---------- */
.ph{
  position:relative;overflow:hidden;border-radius:var(--r);
  background:
    repeating-linear-gradient(135deg, var(--bg-soft) 0 14px, var(--bg-soft-2) 14px 28px);
  isolation:isolate;
}
.ph::after{
  content:attr(data-ph);
  position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:1em;
  font-family:"SFMono-Regular",ui-monospace,Menlo,monospace;
  font-size:12px;letter-spacing:.08em;color:var(--muted);
  text-transform:uppercase;opacity:.7;
}
.ph--dark{
  background:repeating-linear-gradient(135deg,#16224e 0 14px,#1b2a5c 14px 28px);
}
.ph--dark::after{color:rgba(255,255,255,.5);}
/* real photo filling a placeholder frame */
.ph > img.media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1;}
.ph:has(> img.media)::after{content:none;}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(255,255,255,.86);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  backdrop-filter:blur(18px) saturate(150%);
  border-bottom:1px solid transparent;
  transition:border-color .3s, box-shadow .3s, background .3s;
}
.site-header[data-scrolled="1"]{
  border-bottom-color:var(--line);
  box-shadow:0 6px 30px -22px rgba(15,26,61,.45);
}
.header-inner{
  height:var(--header-h);display:flex;align-items:center;justify-content:space-between;gap:30px;
  max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);
}
.brand{display:flex;align-items:center;gap:12px;flex:none;}
.brand img{height:42px;width:auto;}
.nav{display:flex;align-items:center;gap:clamp(14px,2vw,34px);margin-left:auto;}
.nav a{
  font-size:14.5px;font-weight:500;color:var(--ink-2);position:relative;padding:6px 2px;
  transition:color .25s;white-space:nowrap;
}
.nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;border-radius:2px;
  background:var(--grad);transition:right .3s var(--ease);
}
.nav a:hover{color:var(--ink);}
.nav a:hover::after{right:0;}
.header-actions{display:flex;align-items:center;gap:18px;flex:none;}
.icon-btn{
  display:inline-flex;align-items:center;gap:7px;background:none;border:none;cursor:pointer;
  color:var(--ink-2);font-size:13.5px;font-weight:500;padding:6px;transition:color .25s;
}
.icon-btn:hover{color:var(--blue);}
.icon-btn svg{width:18px;height:18px;}
.header-cta{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--navy-800);color:#fff;font-size:14px;font-weight:600;
  padding:11px 20px;border-radius:999px;transition:.35s var(--ease);white-space:nowrap;
}
.header-cta:hover{background:var(--grad);transform:translateY(-1px);box-shadow:0 12px 26px -12px rgba(38,130,207,.6);}
.nav-toggle{display:none;}

/* ============================================================
   HERO  (3 variants)
   ============================================================ */
.hero{position:relative;}
.hero-variant{display:none;}
[data-hero="a"] .hero-a{display:block;}
[data-hero="b"] .hero-b{display:block;}
[data-hero="c"] .hero-c{display:block;}

.hero-eyebrow{
  font-family:var(--f-en);font-weight:600;font-size:14px;letter-spacing:.22em;text-transform:uppercase;
  margin:0 0 24px;display:flex;align-items:center;gap:14px;
}
.hero-eyebrow::before{content:"";width:42px;height:2px;background:var(--grad);}
.hero-title{
  font-family:var(--f-jp);font-weight:700;
  font-size:calc(clamp(34px,5vw,66px) * var(--heading-scale));line-height:1.28;letter-spacing:.02em;margin:0 0 28px;
  text-wrap:balance;
}
.hero-sub{font-size:clamp(15px,1.3vw,18px);line-height:2.05;margin:0 0 40px;max-width:34ch;}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;}

/* scroll cue */
.scroll-cue{
  position:absolute;left:50%;transform:translateX(-50%);bottom:30px;z-index:5;
  writing-mode:horizontal-tb;font-family:var(--f-en);font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:12px;color:inherit;opacity:.8;
}
.scroll-cue::after{content:"";width:1px;height:54px;background:currentColor;animation:cue 2.2s var(--ease) infinite;transform-origin:top;}
@keyframes cue{0%{transform:scaleY(0);opacity:.2;}45%{transform:scaleY(1);opacity:1;}70%{transform:scaleY(1);opacity:1;}100%{transform:scaleY(1);opacity:0;}}

/* --- Variant B: dark immersive (default, OKI-like) --- */
.hero-b{position:relative;min-height:min(88vh,820px);display:flex;align-items:center;
  background:radial-gradient(120% 130% at 78% 8%, #20418f 0%, #142154 46%, #0d1737 100%);
  color:#fff;overflow:hidden;}
.hero-b .hero-bg{position:absolute;inset:0;z-index:0;}
.hero-b .hero-photo{
  position:absolute;inset:0 0 0 38%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 32%);
  mask-image:linear-gradient(90deg,transparent,#000 32%);
  opacity:.85;border-radius:0;
}
.hero-b .hero-photo.ph{border-radius:0;background:repeating-linear-gradient(135deg,#1a2c63 0 16px,#21357a 16px 32px);}
.hero-b .hero-photo.ph::after{color:rgba(255,255,255,.45);}
.hero-b .beam{position:absolute;width:2px;height:120%;top:-10%;
  background:linear-gradient(to bottom,transparent,rgba(120,200,255,.45),transparent);
  filter:blur(.3px);animation:beam 6s ease-in-out infinite;}
.hero-b .beam:nth-child(1){left:54%;animation-delay:0s;}
.hero-b .beam:nth-child(2){left:64%;height:90%;animation-delay:1.1s;}
.hero-b .beam:nth-child(3){left:73%;animation-delay:2.3s;}
.hero-b .beam:nth-child(4){left:84%;height:80%;animation-delay:.6s;}
@keyframes beam{0%,100%{opacity:.15;}50%{opacity:.7;}}
.hero-b .hero-grid-glow{position:absolute;inset:0;
  background:radial-gradient(60% 50% at 75% 30%, rgba(55,196,242,.22), transparent 70%);}
.hero-b .wrap{position:relative;z-index:3;width:100%;padding-block:clamp(80px,11vw,150px);}
.hero-b .hero-inner{max-width:760px;}
.hero-b .hero-eyebrow{color:var(--cyan);}
.hero-b .hero-sub{color:rgba(255,255,255,.82);}
.hero-b .scroll-cue{color:rgba(255,255,255,.7);}

/* --- Variant A: split photo --- */
.hero-a{display:none;}
[data-hero="a"] .hero-a{display:grid;grid-template-columns:1.05fr 1fr;min-height:min(86vh,800px);}
.hero-a .hero-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(60px,8vw,110px) var(--pad);background:var(--bg);}
.hero-a .hero-text-inner{max-width:560px;margin-left:auto;width:100%;}
.hero-a .hero-eyebrow{color:var(--blue);}
.hero-a .hero-sub{color:var(--ink-2);}
.hero-a .hero-media{position:relative;background:var(--navy-900);}
.hero-a .hero-media .ph{position:absolute;inset:0;border-radius:0;}
.hero-a .hero-media-badge{
  position:absolute;left:34px;bottom:34px;z-index:2;color:#fff;
  background:rgba(15,26,61,.42);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.18);border-radius:12px;padding:16px 20px;max-width:62%;
}
.hero-a .hero-media-badge .en-h{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);}
.hero-a .hero-media-badge p{margin:6px 0 0;font-size:14px;line-height:1.7;}

/* --- Variant C: light minimal --- */
.hero-c{display:none;}
[data-hero="c"] .hero-c{display:block;position:relative;overflow:hidden;
  background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);}
.hero-c .ghost-mark{position:absolute;right:-6%;top:50%;transform:translateY(-50%);
  width:min(54vw,720px);opacity:.06;z-index:0;pointer-events:none;}
.hero-c .accent-bar{position:absolute;left:0;top:0;bottom:0;width:8px;background:var(--grad);}
.hero-c .wrap{position:relative;z-index:2;padding-block:clamp(80px,11vw,150px);}
.hero-c .hero-inner{max-width:760px;}
.hero-c .hero-title{font-size:clamp(36px,5.4vw,74px);}
.hero-c .hero-eyebrow{color:var(--blue);}
.hero-c .hero-sub{color:var(--ink-2);}
.hero-c .hero-c-media{margin-top:56px;height:clamp(220px,30vw,360px);}
.hero-c .hero-c-media .ph{height:100%;}

/* ============================================================
   SERVICE  (intro + 2x2 card grid)
   ============================================================ */
.split{display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:clamp(40px,5vw,80px);align-items:start;}
.split--rev{grid-template-columns:1fr minmax(280px,420px);}
.service-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.svc-card{
  position:relative;height:clamp(158px,14vw,182px);border-radius:var(--r);overflow:hidden;
  color:#fff;display:flex;flex-direction:column;justify-content:flex-end;
  text-decoration:none;isolation:isolate;cursor:pointer;
}
.svc-card .ph{position:absolute;inset:0;border-radius:0;z-index:-2;transition:transform .7s var(--ease);}
.svc-card .ph .media{object-position:center;}
.svc-card::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(to top, rgba(11,18,40,.86) 4%, rgba(11,18,40,.28) 52%, rgba(11,18,40,.05) 100%);}
.svc-card:hover .ph{transform:scale(1.06);}
.svc-num{position:absolute;top:18px;left:22px;font-family:var(--f-en);font-weight:700;font-size:14px;letter-spacing:.1em;color:var(--cyan);}
.svc-body{padding:22px 24px;display:flex;align-items:flex-end;justify-content:space-between;gap:14px;}
.svc-body h3{margin:0;font-size:clamp(17px,1.4vw,20px);font-weight:700;line-height:1.5;}
.svc-body p{margin:8px 0 0;font-size:13px;color:rgba(255,255,255,.78);line-height:1.6;font-weight:400;}
.svc-arrow{flex:none;width:34px;height:34px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);
  display:grid;place-items:center;transition:.4s var(--ease);}
.svc-arrow svg{width:15px;height:15px;transition:transform .4s var(--ease);}
.svc-card:hover .svc-arrow{background:#fff;border-color:#fff;color:var(--navy-800);}
.svc-card:hover .svc-arrow svg{transform:translateX(2px);}

/* ============================================================
   STATS BAND
   ============================================================ */
.stats{background:radial-gradient(120% 160% at 12% 0%, #1c2c66 0%, #111d44 60%, #0d1737 100%);color:#fff;}
.stats-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:48px;}
.stats-head .eyebrow{color:var(--cyan);margin:0;}
.stats-head h2{font-family:var(--f-jp);font-weight:700;font-size:clamp(24px,2.6vw,34px);margin:14px 0 0;letter-spacing:.02em;}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;}
.stat{padding:8px clamp(20px,2.4vw,40px);position:relative;}
.stat + .stat::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:1px;background:rgba(255,255,255,.14);}
.stat-ico{width:30px;height:30px;color:var(--cyan);margin-bottom:18px;}
.stat-ico svg{width:100%;height:100%;}
.stat-label{font-size:13.5px;color:rgba(255,255,255,.66);margin:0 0 10px;font-weight:500;letter-spacing:.04em;}
.stat-num{font-family:var(--f-en);font-weight:700;font-size:clamp(34px,3.6vw,52px);line-height:1;letter-spacing:-.01em;
  display:flex;align-items:baseline;gap:6px;}
.stat-num .unit{font-family:var(--f-jp);font-size:18px;font-weight:600;}
.stat-note{font-size:11.5px;color:rgba(255,255,255,.42);margin:10px 0 0;letter-spacing:.02em;}
.stats-foot{display:flex;justify-content:flex-end;margin-top:46px;}

/* ============================================================
   MISSION / VISION / VALUE
   ============================================================ */
.mvv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.mvv-card{
  background:var(--bg);border:1px solid var(--line);border-radius:var(--r);
  padding:clamp(30px,2.6vw,44px);position:relative;overflow:hidden;
  transition:.5s var(--ease);min-height:340px;display:flex;flex-direction:column;
}
.mvv-card::before{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:var(--grad);
  transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease);}
.mvv-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(15,26,61,.4);border-color:transparent;}
.mvv-card:hover::before{transform:scaleX(1);}
.mvv-kicker{font-family:var(--f-en);font-weight:700;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin:0 0 6px;}
.mvv-no{font-family:var(--f-en);font-weight:700;font-size:clamp(40px,4vw,58px);line-height:1;color:var(--line);margin-bottom:24px;letter-spacing:-.02em;}
.mvv-card h3{font-family:var(--f-jp);font-weight:700;font-size:clamp(20px,1.7vw,25px);line-height:1.55;margin:0 0 16px;letter-spacing:.01em;}
.mvv-card p{font-size:14.5px;color:var(--ink-2);line-height:2;margin:0;}
.mvv-card .mvv-spacer{flex:1;}

/* dark variant — restores the navy rhythm break between white sections */
.mvv-dark{background:radial-gradient(120% 150% at 15% 0%, #1c2c66 0%, #111d44 58%, #0d1737 100%);color:#fff;position:relative;overflow:hidden;}
.mvv-dark .eyebrow{color:var(--cyan);}
.mvv-dark .sec-title{color:#fff;}
.mvv-dark .mvv-card{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.14);}
.mvv-dark .mvv-card:hover{background:rgba(255,255,255,.09);box-shadow:0 30px 60px -30px rgba(0,0,0,.55);border-color:rgba(255,255,255,.24);}
.mvv-dark .mvv-no{color:var(--cyan);opacity:.92;text-shadow:0 0 22px color-mix(in oklch, var(--cyan) 45%, transparent);}
.mvv-dark .mvv-card h3{color:#fff;}
.mvv-dark .mvv-card p{color:rgba(255,255,255,.74);}

/* ============================================================
   COMPANY TEASER
   ============================================================ */
.teaser{background:var(--bg-soft);position:relative;overflow:hidden;}
.teaser .split{align-items:center;}
.teaser-media{position:relative;height:clamp(280px,32vw,420px);}
.teaser-media .ph{position:absolute;inset:0;}
.teaser-media .float-card{
  position:absolute;right:-14px;bottom:-14px;background:#fff;border-radius:var(--r);
  box-shadow:0 30px 60px -30px rgba(15,26,61,.4);padding:24px 28px;max-width:260px;
  border:1px solid var(--line);
}
.teaser-media .float-card .en-h{color:var(--blue);font-size:12px;letter-spacing:.14em;text-transform:uppercase;}
.teaser-media .float-card .big{font-family:var(--f-en);font-weight:700;font-size:30px;line-height:1.1;margin:8px 0 4px;}
.teaser-media .float-card .lbl{font-size:13px;color:var(--muted);margin:0;}

/* ============================================================
   NEWS
   ============================================================ */
.news-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:14px;}
.news-list{border-top:1px solid var(--line);}
.news-item{
  display:grid;grid-template-columns:130px 96px 1fr 40px;align-items:center;gap:24px;
  padding:24px 8px;border-bottom:1px solid var(--line);transition:.35s var(--ease);cursor:pointer;
}
.news-item:hover{background:var(--bg-soft);padding-inline:20px 8px;}
.news-date{font-family:var(--f-en);font-weight:600;font-size:14.5px;color:var(--muted);letter-spacing:.02em;}
.news-cat{justify-self:start;font-size:12px;font-weight:600;letter-spacing:.04em;padding:5px 13px;border-radius:999px;white-space:nowrap;}
.news-cat[data-c="お知らせ"]{background:var(--bg-soft-2);color:var(--navy-700);}
.news-cat[data-c="プレスリリース"]{background:color-mix(in oklch,var(--cyan) 18%,white);color:#0f5e88;}
.news-cat[data-c="メディア"]{background:color-mix(in oklch,var(--acc-1) 14%,white);color:var(--acc-1);}
.news-title{font-size:15.5px;font-weight:500;color:var(--ink);line-height:1.6;}
.news-item:hover .news-title{color:var(--blue);}
.news-arrow{justify-self:end;color:var(--line);transition:.35s var(--ease);}
.news-arrow svg{width:20px;height:20px;}
.news-item:hover .news-arrow{color:var(--blue);transform:translateX(4px);}

/* ============================================================
   CONTACT CTA
   ============================================================ */
.cta-band{position:relative;overflow:hidden;color:#fff;
  background:radial-gradient(110% 140% at 80% 20%, #20418f 0%, #142154 50%, #0c1532 100%);}
.cta-band .cta-photo{position:absolute;inset:0;opacity:.32;z-index:0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 60%);mask-image:linear-gradient(90deg,transparent,#000 60%);}
.cta-band .cta-photo.ph{border-radius:0;background:repeating-linear-gradient(135deg,#16224e 0 16px,#1d2e66 16px 32px);}
.cta-inner{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;
  padding-block:clamp(64px,8vw,112px);}
.cta-inner .eyebrow{color:var(--cyan);}
.cta-inner h2{font-family:var(--f-jp);font-weight:700;font-size:clamp(28px,3.8vw,50px);line-height:1.35;margin:0;letter-spacing:.02em;text-wrap:balance;}
.cta-inner p{color:rgba(255,255,255,.8);margin:18px 0 0;font-size:16px;line-height:1.9;}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact{background:var(--bg-soft);}
.contact .split{grid-template-columns:minmax(280px,400px) 1fr;align-items:start;}
.contact-aside .sec-lead{margin-bottom:36px;}
.contact-info{display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--line);}
.contact-info .row{display:flex;gap:18px;align-items:flex-start;padding:20px 4px;border-bottom:1px solid var(--line);}
.contact-info .ic{flex:none;width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:#fff;border:1px solid var(--line);color:var(--blue);}
.contact-info .ic svg{width:19px;height:19px;}
.contact-info .lbl{font-family:var(--f-en);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);font-weight:700;margin:0 0 4px;}
.contact-info .val{font-size:15.5px;color:var(--ink);margin:0;line-height:1.6;font-weight:500;}
.contact-info .val .tel{font-family:var(--f-en);font-weight:700;font-size:21px;letter-spacing:.01em;}
.contact-info .sub{font-size:12.5px;color:var(--muted);margin:3px 0 0;}

.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:clamp(28px,3.4vw,52px);box-shadow:0 30px 70px -50px rgba(15,26,61,.45);}

/* segmented switch: 個人 / 法人 */
.form-switch{display:flex;gap:6px;background:var(--bg-soft);border:1px solid var(--line);
  border-radius:999px;padding:6px;margin-bottom:30px;}
.form-switch button{flex:1;display:flex;align-items:center;justify-content:center;gap:9px;
  border:none;background:none;cursor:pointer;font-family:var(--f-jp);font-weight:600;font-size:14.5px;
  color:var(--muted);padding:13px 16px;border-radius:999px;transition:.3s var(--ease);letter-spacing:.02em;}
.form-switch button .si{width:18px;height:18px;transition:color .3s var(--ease);}
.form-switch button[aria-selected="true"]{background:#fff;color:var(--ink);
  box-shadow:0 6px 16px -8px rgba(15,26,61,.4);}
.form-switch button[aria-selected="true"] .si{color:var(--blue);}
.cform[hidden]{display:none;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px 24px;}
.field{display:flex;flex-direction:column;gap:9px;}
.field--full{grid-column:1 / -1;}
.field label{font-size:14px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:9px;letter-spacing:.02em;}
.req{font-size:10.5px;font-weight:700;letter-spacing:.04em;color:#fff;background:var(--blue);padding:3px 8px;border-radius:4px;line-height:1;}
.opt{font-size:11px;font-weight:600;color:var(--muted);background:var(--bg-soft-2);padding:3px 8px;border-radius:4px;line-height:1.3;}
.field input[type=text],.field input[type=email],.field input[type=tel],.field select,.field textarea{
  font-family:var(--f-jp);font-size:15px;color:var(--ink);background:var(--bg-soft);
  border:1.5px solid var(--line);border-radius:10px;padding:14px 16px;width:100%;transition:.25s var(--ease);line-height:1.6;}
.field textarea{resize:vertical;min-height:140px;}
.field select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2369748f' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:44px;}
.field input::placeholder,.field textarea::placeholder{color:var(--muted);opacity:.7;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);background:#fff;
  box-shadow:0 0 0 4px color-mix(in oklch,var(--blue) 14%,transparent);}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#d6453f;background:color-mix(in oklch,#d6453f 5%,white);}
.field .err{font-size:12.5px;color:#d6453f;margin:0;display:none;}
.field.invalid .err{display:block;}

.consent{grid-column:1 / -1;display:flex;gap:13px;align-items:flex-start;
  background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:18px 20px;margin-top:2px;}
.consent input{margin-top:3px;width:18px;height:18px;flex:none;accent-color:var(--blue);cursor:pointer;}
.consent label{font-size:13.5px;color:var(--ink-2);line-height:1.7;font-weight:400;}
.consent a{color:var(--blue);text-decoration:underline;text-underline-offset:2px;}
.consent.invalid{border-color:#d6453f;}
.form-actions{grid-column:1 / -1;display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:6px;}
.form-actions .btn{font-size:16px;padding:18px 38px;}
.form-actions .note{font-size:12.5px;color:var(--muted);}
.form-success{display:none;text-align:center;padding:30px 10px;}
.form-success .ok{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;margin:0 auto 22px;
  background:var(--grad);color:#fff;}
.form-success .ok svg{width:30px;height:30px;}
.form-success h3{font-family:var(--f-jp);font-weight:700;font-size:24px;margin:0 0 12px;color:var(--ink);}
.form-success p{font-size:15px;color:var(--ink-2);line-height:1.9;margin:0;max-width:42ch;margin-inline:auto;}
.form-card.sent .form-grid{display:none;}
.form-card.sent .form-success{display:block;}
@media (max-width:860px){
  .contact .split{grid-template-columns:1fr;}
  .form-grid{grid-template-columns:1fr;}
}
.grecaptcha-badge{
  visibility:hidden;
}

.captcha-notice{
  margin-top:12px;
  font-size:11px;
  line-height:1.6;
  color:#8a8f9d;
}

.captcha-notice a{
  color:inherit;
  text-decoration:underline;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:#fff;border-top:1px solid var(--line);padding-block:64px 36px;}
.footer-top{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:40px;}
.footer-brand img{height:46px;width:auto;margin-bottom:20px;}
.footer-brand p{color:var(--muted);font-size:13.5px;line-height:1.9;max-width:30ch;margin:0;}
.footer-col h4{font-family:var(--f-en);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin:0 0 18px;font-weight:700;}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px;}
.footer-col a{font-size:14px;color:var(--ink-2);transition:color .25s;}
.footer-col a:hover{color:var(--blue);}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  margin-top:56px;padding-top:28px;border-top:1px solid var(--line);}
.footer-bottom .legal{display:flex;gap:26px;flex-wrap:wrap;}
.footer-bottom a{font-size:12.5px;color:var(--muted);transition:color .25s;}
.footer-bottom a:hover{color:var(--blue);}
.footer-bottom .copy{font-family:var(--f-en);font-size:12.5px;color:var(--muted);letter-spacing:.02em;}

/* ============================================================
   PAGE HERO (company)
   ============================================================ */
.page-hero{position:relative;overflow:hidden;color:#fff;
  background:radial-gradient(120% 150% at 80% 0%, #20418f 0%, #142154 52%, #0c1532 100%);}
.page-hero .ph{position:absolute;inset:0 0 0 50%;border-radius:0;opacity:.5;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 50%);mask-image:linear-gradient(90deg,transparent,#000 50%);
  background:repeating-linear-gradient(135deg,#1a2c63 0 16px,#21357a 16px 32px);z-index:0;}
.page-hero .ph::after{color:rgba(255,255,255,.4);}
.page-hero .wrap{position:relative;z-index:2;padding-block:clamp(90px,12vw,170px);}
.page-hero .crumbs{font-family:var(--f-en);font-size:12.5px;letter-spacing:.1em;color:rgba(255,255,255,.6);margin:0 0 26px;display:flex;gap:10px;align-items:center;}
.page-hero .crumbs a:hover{color:#fff;}
.page-hero .eyebrow{color:var(--cyan);}
.page-hero h1{font-family:var(--f-jp);font-weight:700;font-size:calc(clamp(34px,5vw,64px) * var(--heading-scale));line-height:1.3;margin:0;letter-spacing:.03em;text-wrap:balance;}
.page-hero .lead{color:rgba(255,255,255,.82);font-size:clamp(15px,1.2vw,18px);line-height:2;margin:26px 0 0;max-width:44ch;}

/* ---------- company info table ---------- */
.info-table{width:100%;border-collapse:collapse;}
.info-table th,.info-table td{text-align:left;vertical-align:top;padding:24px 8px;border-bottom:1px solid var(--line);font-size:15.5px;line-height:1.9;}
.info-table th{width:220px;font-weight:600;color:var(--ink);letter-spacing:.04em;}
.info-table td{color:var(--ink-2);}
.info-table tr:first-child th,.info-table tr:first-child td{border-top:1px solid var(--line);}

/* ---------- 特商法 legal page ---------- */
.legal .info-table th{width:280px;}
.legal .info-table td{color:var(--ink);}
.legal-note{font-size:13px;color:var(--muted);margin:6px 0 0;line-height:1.7;}
.price-plan{display:flex;flex-wrap:wrap;gap:6px 22px;align-items:baseline;padding:10px 0;border-bottom:1px dashed var(--line);}
.price-plan:last-child{border-bottom:none;}
.price-plan .pp-name{font-weight:600;color:var(--ink);min-width:200px;font-size:14.5px;letter-spacing:.01em;}
.price-plan .pp-row{display:flex;gap:18px;flex-wrap:wrap;}
.price-plan .pp-kind{font-size:13px;color:var(--muted);}
.price-plan .pp-amt{font-family:var(--f-en);font-weight:700;font-size:17px;color:var(--blue);letter-spacing:.01em;}
.price-plan .pp-amt small{font-family:var(--f-jp);font-size:12px;color:var(--muted);font-weight:500;margin-left:3px;}
.legal-block th{vertical-align:top;}
.legal-block .lb-title{font-weight:700;color:var(--ink);margin:0 0 8px;font-size:15px;}
.legal-block p{margin:0 0 12px;}
.legal-block p:last-child{margin-bottom:0;}
@media (max-width:860px){
  .legal .info-table th{width:120px;}
  .price-plan .pp-name{min-width:0;}
}

/* ---------- policy (long-form legal doc) ---------- */
.policy-intro{font-size:16px;color:var(--ink-2);line-height:2.05;margin:0 0 12px;max-width:74ch;}
.policy-meta{display:flex;flex-wrap:wrap;gap:8px 28px;margin-top:28px;padding-top:22px;border-top:1px solid var(--line);}
.policy-meta .pm{font-size:14px;color:var(--ink-2);}
.policy-meta .pm b{color:var(--ink);font-weight:600;margin-right:8px;}
.policy-art{display:grid;grid-template-columns:64px 1fr;gap:8px 28px;padding-block:clamp(30px,3.4vw,44px);border-bottom:1px solid var(--line);align-items:start;}
.policy-art:last-of-type{border-bottom:none;}
.policy-art .art-no{font-family:var(--f-en);font-weight:700;font-size:clamp(24px,2.4vw,32px);color:var(--blue);line-height:1.1;letter-spacing:-.01em;}
.policy-art .art-body h2{font-family:var(--f-jp);font-weight:700;font-size:clamp(18px,1.7vw,23px);line-height:1.5;margin:2px 0 16px;letter-spacing:.01em;}
.policy-art .art-body p{font-size:15.5px;color:var(--ink-2);line-height:2;margin:0 0 14px;max-width:72ch;}
.policy-art .art-body p:last-child{margin-bottom:0;}
.policy-art .art-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px;}
.policy-art .art-list li{position:relative;padding-left:22px;font-size:15.5px;color:var(--ink-2);line-height:1.95;max-width:70ch;}
.policy-art .art-list li::before{content:"";position:absolute;left:0;top:13px;width:8px;height:8px;border-radius:50%;background:var(--grad);}
.policy-art .art-list li b{color:var(--ink);font-weight:600;}
@media (max-width:860px){
  .policy-art{grid-template-columns:1fr;gap:8px;}
  .policy-art .art-no{font-size:20px;}
}

/* ---------- MVV detail (company) ---------- */
.mvv-detail{display:grid;grid-template-columns:200px 1fr;gap:clamp(30px,5vw,72px);align-items:start;
  padding-block:clamp(44px,5vw,68px);border-bottom:1px solid var(--line);}
.mvv-detail:last-of-type{border-bottom:none;}
.mvv-detail .tag{font-family:var(--f-en);font-weight:700;font-size:clamp(28px,3vw,40px);letter-spacing:.02em;color:var(--ink);line-height:1;}
.mvv-detail .tag span{display:block;font-family:var(--f-en);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-top:10px;font-weight:600;}
.mvv-detail h2{font-family:var(--f-jp);font-weight:700;font-size:clamp(22px,2.6vw,36px);line-height:1.5;margin:0 0 24px;letter-spacing:.02em;text-wrap:balance;}
.mvv-detail p{font-size:16px;color:var(--ink-2);line-height:2.1;margin:0 0 16px;max-width:60ch;}
.mvv-detail p:last-child{margin-bottom:0;}

/* ---------- 9 values grid ---------- */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;}
.value-cell{background:#fff;padding:clamp(28px,2.6vw,40px);transition:.45s var(--ease);position:relative;}
.value-cell:hover{background:var(--bg-soft);}
.value-cell .vn{font-family:var(--f-en);font-weight:700;font-size:15px;color:var(--blue);letter-spacing:.06em;margin-bottom:18px;display:flex;align-items:center;gap:12px;}
.value-cell .vn::after{content:"";flex:1;height:1px;background:var(--line);}
.value-cell h3{font-family:var(--f-jp);font-weight:700;font-size:clamp(17px,1.4vw,20px);line-height:1.55;margin:0 0 14px;letter-spacing:.01em;}
.value-cell p{font-size:14px;color:var(--ink-2);line-height:1.95;margin:0;}

/* ---------- advisors ---------- */
.advisor-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.advisor{display:flex;gap:24px;align-items:center;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);padding:28px;}
.advisor .face{width:84px;height:84px;border-radius:50%;flex:none;display:grid;place-items:center;
  background:#fff;border:1px solid var(--line);color:var(--blue);box-shadow:0 8px 22px -14px rgba(15,26,61,.4);}
.advisor .face svg{width:38px;height:38px;}
.advisor .face.ph{border-radius:50%;}
.advisor .role{font-family:var(--f-en);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);font-weight:700;margin:0 0 8px;}
.advisor h3{font-family:var(--f-jp);font-weight:700;font-size:20px;margin:0 0 6px;}
.advisor p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.7;}

/* ============================================================
   NEWS ARTICLE (detail.html) — microCMS rich text
   ============================================================ */
.article-wrap{max-width:760px;margin-inline:auto;padding-inline:var(--pad);width:100%;}

/* breadcrumb (light, on white) */
.crumbs-line{display:flex;align-items:center;flex-wrap:wrap;gap:9px;margin:0;
  font-size:13px;color:var(--muted);letter-spacing:.01em;}
.crumbs-line > *{flex:none;}
.crumbs-line a{color:var(--muted);transition:color .2s var(--ease);white-space:nowrap;}
.crumbs-line a:hover{color:var(--blue);}
.crumbs-line .sep{color:var(--line);font-size:14px;}
.crumbs-line .current{color:var(--ink-2);font-weight:500;white-space:nowrap;}
.crumbs-line .current.ellip{flex:0 1 auto;max-width:52ch;overflow:hidden;text-overflow:ellipsis;}
@media (max-width:560px){
  .crumbs-line .current.ellip{max-width:58vw;}
}
.article{padding-block:clamp(48px,6vw,86px);}
.article-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:22px;}
.article-meta .news-cat{justify-self:auto;}
.article-meta .article-date{font-family:var(--f-en);font-weight:600;font-size:14px;color:var(--muted);letter-spacing:.03em;display:inline-flex;align-items:center;gap:8px;}
.article-meta .article-date svg{width:15px;height:15px;opacity:.7;}
.article-title{font-family:var(--f-jp);font-weight:700;
  font-size:clamp(25px,3.4vw,40px);line-height:1.5;letter-spacing:.01em;color:var(--ink);
  margin:0 0 30px;text-wrap:pretty;}
.article-eyecatch{margin:0 0 clamp(34px,4vw,52px);border-radius:var(--r);overflow:hidden;background:var(--bg-soft);}
.article-eyecatch img{width:100%;height:auto;display:block;aspect-ratio:16/9;object-fit:cover;}

/* prose — styles every tag microCMS may output */
.prose{color:var(--ink-2);font-size:clamp(15.5px,1.1vw,17px);line-height:2.05;letter-spacing:.01em;}
.prose > :first-child{margin-top:0;}
.prose > :last-child{margin-bottom:0;}
.prose h2{font-family:var(--f-jp);font-weight:700;color:var(--ink);
  font-size:clamp(21px,2vw,27px);line-height:1.55;letter-spacing:.01em;
  margin:clamp(48px,5vw,68px) 0 22px;padding-bottom:16px;border-bottom:1px solid var(--line);position:relative;}
.prose h2::before{content:"";position:absolute;left:0;bottom:-1px;width:64px;height:3px;border-radius:3px;background:var(--grad);}
.prose h3{font-family:var(--f-jp);font-weight:700;color:var(--ink);
  font-size:clamp(18px,1.5vw,21px);line-height:1.6;letter-spacing:.01em;
  margin:clamp(36px,4vw,48px) 0 16px;padding-left:15px;border-left:4px solid var(--blue);}
.prose p{margin:0 0 1.6em;}
.prose a{color:var(--blue);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;
  text-decoration-color:color-mix(in oklch,var(--blue) 40%,transparent);transition:.2s var(--ease);
  font-weight:500;overflow-wrap:break-word;}
.prose a:hover{text-decoration-color:var(--blue);color:var(--acc-1);}
.prose strong{font-weight:700;color:var(--ink);}
.prose ul,.prose ol{margin:0 0 1.7em;padding-left:1.5em;display:flex;flex-direction:column;gap:10px;}
.prose ul{list-style:disc;}
.prose ol{list-style:decimal;}
.prose ul li,.prose ol li{line-height:1.9;padding-left:4px;}
.prose ul li::marker{color:var(--blue);}
.prose ol li::marker{color:var(--blue);font-weight:600;font-family:var(--f-en);}
.prose li ul,.prose li ol{margin:10px 0 0;}
.prose img{max-width:100%;height:auto;border-radius:var(--r);margin:clamp(26px,3vw,38px) 0;display:block;}
.prose blockquote{margin:clamp(28px,3vw,40px) 0;padding:22px 28px;background:var(--bg-soft);
  border-left:4px solid var(--blue);border-radius:0 10px 10px 0;color:var(--ink-2);font-size:.97em;line-height:1.95;}
.prose blockquote p{margin:0;}
.prose blockquote p + p{margin-top:.9em;}
.prose hr{border:none;border-top:1px solid var(--line);margin:clamp(40px,4vw,56px) 0;}

/* back-to-list */
.article-foot{display:flex;justify-content:center;margin-top:clamp(48px,5vw,72px);
  padding-top:clamp(36px,4vw,52px);border-top:1px solid var(--line);}

@media (max-width:860px){
  .article{padding-block:40px;}
  .article-meta{gap:12px;margin-bottom:18px;}
}

/* ============================================================
   NEWS LIST (news.html)
   ============================================================ */
.news-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:8px;}
.news-filter button{font-family:var(--f-jp);font-size:14px;font-weight:600;color:var(--muted);
  background:var(--bg-soft);border:1px solid var(--line);border-radius:999px;padding:9px 20px;
  cursor:pointer;transition:.25s var(--ease);letter-spacing:.02em;}
.news-filter button:hover{color:var(--blue);border-color:color-mix(in oklch,var(--blue) 40%,var(--line));}
.news-filter button[aria-pressed="true"]{background:var(--navy-800);color:#fff;border-color:var(--navy-800);}
.news-item.is-hidden{display:none;}
.news-empty{padding:56px 8px;text-align:center;color:var(--muted);font-size:15px;display:none;}
.news-empty.show{display:block;}

/* pagination */
.pager{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:clamp(40px,4vw,60px);}
.pager a,.pager span{min-width:42px;height:42px;display:inline-grid;place-items:center;padding:0 12px;
  border:1px solid var(--line);border-radius:10px;font-family:var(--f-en);font-weight:600;font-size:14.5px;
  color:var(--ink-2);transition:.25s var(--ease);}
.pager a:hover{border-color:var(--blue);color:var(--blue);}
.pager .is-current{background:var(--navy-800);color:#fff;border-color:var(--navy-800);}
.pager .is-disabled{opacity:.4;pointer-events:none;}
.pager .pg-arrow{font-size:16px;}
@media (max-width:560px){
  .pager .pg-num.is-far{display:none;}
}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease), transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal[data-d="1"]{transition-delay:.08s;}
.reveal[data-d="2"]{transition-delay:.16s;}
.reveal[data-d="3"]{transition-delay:.24s;}
.reveal[data-d="4"]{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
  .scroll-cue::after{animation:none;}
  .hero-b .beam{animation:none;}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .nav{display:none;}
  .nav-toggle{display:inline-flex;}
  .stat-grid{grid-template-columns:1fr 1fr;gap:8px 0;}
  .stat:nth-child(3)::before,.stat:nth-child(1)::before{display:none;}
  .stat{padding-block:22px;border-top:1px solid rgba(255,255,255,.1);}
  .stat:nth-child(-n+2){border-top:none;}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px;}
}
@media (max-width:860px){
  :root{--header-h:66px;}
  .split,.split--rev{grid-template-columns:1fr;gap:40px;}
  .service-cards{gap:14px;}
  .mvv-grid{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:1fr 1fr;}
  .advisor-grid{grid-template-columns:1fr;}
  [data-hero="a"] .hero-a{grid-template-columns:1fr;}
  .hero-a .hero-media{min-height:340px;}
  .mvv-detail{grid-template-columns:1fr;gap:18px;}
  .info-table th{width:130px;}
  .news-item{grid-template-columns:96px 1fr;grid-template-areas:"date title" "cat title";gap:6px 18px;padding-block:20px;}
  .news-date{grid-area:date;}
  .news-cat{grid-area:cat;}
  .news-title{grid-area:title;align-self:center;}
  .news-arrow{display:none;}
}
@media (max-width:560px){
  .stat-grid{grid-template-columns:1fr;}
  .stat::before{display:none!important;}
  .stat{border-top:1px solid rgba(255,255,255,.1);}
  .stat:first-child{border-top:none;}
  .values-grid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;}
  .cta-inner{flex-direction:column;align-items:flex-start;}
  .hero-cta .btn{flex:1;justify-content:center;}
}
