/* =========================================================
   ROAD LLC. — Corporate Site
   Soft botanical / sky-green palette
   ========================================================= */

:root{
  --c-ink:        #1f2a36;
  --c-ink-soft:   #4a5663;
  --c-mute:       #8593a1;
  --c-line:       #e3e9ec;

  --c-bg:         #fbfaf6;
  --c-bg-soft:    #f3f6f1;
  --c-bg-card:    #ffffff;

  --c-blue:       #6fa6c4;
  --c-blue-deep:  #3f7d9f;
  --c-blue-soft:  #d9e7ee;

  --c-green:      #8cb88f;
  --c-green-deep: #5d9163;
  --c-green-soft: #dde9d8;

  --c-cream:      #f7f1e1;

  --grad-sky:     linear-gradient(135deg,#7fb6d4 0%,#9cc89a 100%);
  --grad-soft:    linear-gradient(180deg,#f3f8f4 0%,#eaf2f5 100%);

  --shadow-sm:    0 4px 16px rgba(45,80,100,.06);
  --shadow-md:    0 12px 40px rgba(45,80,100,.08);
  --shadow-lg:    0 24px 60px rgba(45,80,100,.10);

  --r-sm: 10px;
  --r-md: 18px;
  --r-lg: 28px;

  --ff-jp:    "Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  --ff-jp-s:  "Noto Serif JP","Hiragino Mincho ProN","Yu Mincho",serif;
  --ff-en:    "Cormorant Garamond","Times New Roman",serif;

  --maxw: 1180px;
  --pad-x: clamp(20px, 5vw, 64px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--ff-jp);
  color:var(--c-ink);
  background:var(--c-bg);
  font-feature-settings:"palt";
  line-height:1.8;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
}
body.is-nav-open{overflow:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none;transition:opacity .25s,color .25s}
a:hover{opacity:.7}
ul,ol{margin:0;padding:0;list-style:none}
button{font-family:inherit;cursor:pointer;background:none;border:0;color:inherit}

.pc-only{display:inline}
.sp-only{display:none}
@media(max-width:720px){
  .pc-only{display:none}
  .sp-only{display:inline}
}

/* ===== Header ===== */
.header{
  position:fixed;top:0;left:0;right:0;
  z-index:50;
  background:rgba(251,250,246,.78);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;
  transition:background .25s,border-color .25s,box-shadow .25s;
}
.header.is-scrolled{
  background:rgba(255,255,255,.92);
  border-bottom-color:var(--c-line);
  box-shadow:0 2px 24px rgba(45,80,100,.06);
}
.header-inner{
  max-width:var(--maxw);
  margin:0 auto;
  padding:8px var(--pad-x);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.logo{display:flex;align-items:center;gap:10px}
.logo-img{
  display:block;
  height:78px;width:auto;
  transition:transform .25s,filter .25s;
}
.logo:hover .logo-img{transform:scale(1.03)}
@media(max-width:720px){
  .logo-img{height:60px}
}
.nav ul{display:flex;align-items:center;gap:28px}
.nav a{
  font-size:14px;font-weight:500;color:var(--c-ink-soft);
  position:relative;padding:6px 0;
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;
  width:0;height:1px;background:var(--c-blue-deep);
  transition:width .3s;
}
.nav a:hover{opacity:1;color:var(--c-blue-deep)}
.nav a:hover::after{width:100%}
.hamburger{display:none;width:36px;height:36px;position:relative}
.hamburger span{
  position:absolute;left:6px;right:6px;height:1.5px;background:var(--c-ink);
  transition:.3s;
}
.hamburger span:nth-child(1){top:11px}
.hamburger span:nth-child(2){top:17px}
.hamburger span:nth-child(3){top:23px}
.hamburger.is-open span:nth-child(1){top:17px;transform:rotate(45deg)}
.hamburger.is-open span:nth-child(2){opacity:0}
.hamburger.is-open span:nth-child(3){top:17px;transform:rotate(-45deg)}

@media(max-width:900px){
  .hamburger{display:block}
  .nav{
    position:fixed;top:0;right:0;
    width:78%;max-width:340px;height:100vh;
    background:#fff;
    box-shadow:-12px 0 40px rgba(45,80,100,.08);
    transform:translateX(100%);
    transition:transform .35s ease;
    padding:90px 32px 32px;
  }
  .nav.is-open{transform:translateX(0)}
  .nav ul{flex-direction:column;align-items:flex-start;gap:18px}
  .nav a{font-size:16px}
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 30px;
  border-radius:999px;
  font-weight:600;font-size:14px;letter-spacing:.08em;
  transition:transform .25s,box-shadow .25s,background .25s,color .25s;
}
.btn--primary{
  background:var(--grad-sky);
  color:#fff;
  box-shadow:0 10px 26px rgba(99,156,180,.35);
}
.btn--primary:hover{
  opacity:1;transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(99,156,180,.45);
}
.btn--ghost{
  background:#fff;
  color:var(--c-ink);
  border:1px solid var(--c-line);
}
.btn--ghost:hover{opacity:1;border-color:var(--c-blue);color:var(--c-blue-deep)}

/* ===== Hero ===== */
.hero{
  position:relative;
  min-height:100vh;
  padding:140px var(--pad-x) 100px;
  display:flex;align-items:center;
  overflow:hidden;
  background:
    radial-gradient(1200px 700px at 70% 0%, #eaf3ee 0%, transparent 60%),
    radial-gradient(900px 600px at 0% 100%, #e6eff5 0%, transparent 60%),
    #fbfaf6;
}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-blob{
  position:absolute;border-radius:50%;
  filter:blur(60px);opacity:.55;
}
.hero-blob--1{width:520px;height:520px;background:#bfdcce;top:-120px;right:-120px}
.hero-blob--2{width:460px;height:460px;background:#c2dae6;bottom:-140px;left:-100px}
.hero-leaf{position:absolute;width:280px;height:280px;opacity:.7}
.hero-leaf--tl{top:40px;left:-40px;transform:rotate(-12deg)}
.hero-leaf--br{bottom:30px;right:-40px;transform:rotate(160deg)}
@media(max-width:720px){
  .hero-leaf{width:180px;height:180px}
  .hero-blob--1{width:340px;height:340px}
  .hero-blob--2{width:300px;height:300px}
}

.hero-inner{
  position:relative;z-index:2;
  max-width:var(--maxw);width:100%;
  margin:0 auto;
}
.hero-eyebrow{
  font-family:var(--ff-en);
  letter-spacing:.4em;
  color:var(--c-blue-deep);
  font-size:13px;
  margin:0 0 18px;
}
.hero-title{
  font-family:var(--ff-jp-s);
  font-weight:600;
  font-size:clamp(32px,5.6vw,64px);
  line-height:1.4;
  letter-spacing:.04em;
  margin:0 0 28px;
  color:var(--c-ink);
}
.accent-blue{
  color:var(--c-blue-deep);
  font-style:normal;
  position:relative;
}
.accent-blue::after,
.accent-green::after{
  content:"";position:absolute;
  left:0;right:0;bottom:-2px;
  height:8px;
  background:rgba(159,201,160,.35);
  z-index:-1;
  border-radius:4px;
}
.accent-blue::after{background:rgba(127,182,212,.35)}
.accent-green{color:var(--c-green-deep);font-style:normal;position:relative}

.hero-lead{
  font-size:clamp(15px,1.4vw,18px);
  line-height:2;
  color:var(--c-ink-soft);
  margin:0 0 40px;
  max-width:680px;
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:60px}

.hero-meta{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;
  border-top:1px solid var(--c-line);
  padding-top:24px;
  max-width:720px;
}
.hero-meta>div{
  font-size:14px;
  color:var(--c-ink-soft);
  display:flex;align-items:baseline;gap:10px;
}
.hero-meta span{
  font-family:var(--ff-en);
  font-size:11px;
  letter-spacing:.3em;
  color:var(--c-blue-deep);
}
@media(max-width:720px){
  .hero-meta{grid-template-columns:1fr;gap:10px}
}

.hero-scroll{
  position:absolute;
  bottom:24px;left:50%;transform:translateX(-50%);
  font-family:var(--ff-en);
  font-size:11px;letter-spacing:.4em;
  color:var(--c-blue-deep);
  display:flex;flex-direction:column;align-items:center;gap:42px;
  z-index:2;
}
.hero-scroll span{
  width:1px;height:36px;
  background:linear-gradient(180deg,var(--c-blue-deep),transparent);
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine{
  0%,100%{transform:scaleY(.4);transform-origin:top}
  50%    {transform:scaleY(1);  transform-origin:top}
}

/* ===== Section base ===== */
.section{padding:120px var(--pad-x);position:relative}
.section-inner{max-width:var(--maxw);margin:0 auto}
.section-head{text-align:center;margin-bottom:64px}
.kicker{
  font-family:var(--ff-en);
  font-size:12px;letter-spacing:.4em;
  color:var(--c-blue-deep);
  margin:0 0 14px;
}
.section-title{
  font-family:var(--ff-jp-s);
  font-weight:600;
  font-size:clamp(26px,3.4vw,40px);
  letter-spacing:.06em;
  line-height:1.5;
  margin:0;
}
.section-lead{
  margin:22px auto 0;max-width:720px;
  color:var(--c-ink-soft);
  font-size:15px;
  line-height:2;
}
@media(max-width:720px){
  .section{padding:80px var(--pad-x)}
}

/* ===== Vision / Mission ===== */
.section--vision{background:var(--c-bg)}
.vision-card{
  background:#fff;
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-md);
  padding:clamp(36px,5vw,72px);
  text-align:center;
  position:relative;overflow:hidden;
  margin-bottom:80px;
}
.vision-card::before,
.vision-card::after{
  content:"";position:absolute;
  width:240px;height:240px;border-radius:50%;
  filter:blur(50px);opacity:.6;
}
.vision-card::before{background:#cfe3d2;top:-80px;left:-80px}
.vision-card::after{background:#d4e3eb;bottom:-80px;right:-80px}
.vision-card>*{position:relative}
.vision-tag,.mission-tag{
  font-family:var(--ff-en);
  letter-spacing:.4em;font-size:12px;
  color:var(--c-green-deep);
  margin:0 0 18px;
}
.vision-statement{
  font-family:var(--ff-jp-s);
  font-weight:600;
  font-size:clamp(22px,3vw,32px);
  line-height:1.7;
  margin:0 0 24px;
  letter-spacing:.06em;
}
.vision-statement em{
  font-style:normal;
  color:var(--c-blue-deep);
  border-bottom:2px dotted var(--c-blue);
  padding-bottom:2px;
}
.vision-body{
  color:var(--c-ink-soft);
  margin:0 auto;max-width:640px;
  font-size:15px;line-height:2;
}

.mission-block{text-align:center}
.mission-tag{color:var(--c-blue-deep)}
.mission-title{
  font-family:var(--ff-jp-s);
  font-weight:600;
  font-size:clamp(20px,2.6vw,28px);
  letter-spacing:.06em;
  margin:0 0 48px;
}
.mission-pillars{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.mission-pillars>li{
  background:#fff;
  border-radius:var(--r-md);
  padding:38px 28px;
  text-align:center;
  border:1px solid var(--c-line);
  transition:transform .3s,box-shadow .3s;
}
.mission-pillars>li:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pillar-no{
  font-family:var(--ff-en);
  font-size:36px;
  color:var(--c-green);
  margin:0 0 8px;
  line-height:1;
}
.mission-pillars h4{
  font-family:var(--ff-jp-s);
  font-size:18px;font-weight:600;
  margin:0 0 14px;letter-spacing:.08em;
}
.mission-pillars p{margin:0;color:var(--c-ink-soft);font-size:14px;line-height:1.9}
@media(max-width:720px){
  .mission-pillars{grid-template-columns:1fr}
}

/* ===== Service ===== */
.section--service{
  background:
    radial-gradient(900px 500px at 100% 0%, #eef5ee 0%, transparent 60%),
    var(--c-bg-soft);
}
.service-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:24px;
}
/* 5-card grid: 3 top + 2 centered bottom (uses 6-col underlying grid) */
.service-grid--5{
  grid-template-columns:repeat(6,1fr);
}
.service-grid--5 .service-card:nth-child(1){grid-column:1 / span 2}
.service-grid--5 .service-card:nth-child(2){grid-column:3 / span 2}
.service-grid--5 .service-card:nth-child(3){grid-column:5 / span 2}
.service-grid--5 .service-card:nth-child(4){grid-column:2 / span 2}
.service-grid--5 .service-card:nth-child(5){grid-column:4 / span 2}
@media(max-width:960px){
  .service-grid--5{grid-template-columns:repeat(2,1fr)}
  .service-grid--5 .service-card{grid-column:auto !important}
}
.service-card{
  background:#fff;
  border-radius:var(--r-md);
  padding:44px 36px;
  position:relative;
  transition:transform .3s,box-shadow .3s;
  border:1px solid rgba(255,255,255,.6);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.service-card::before{
  content:"";position:absolute;
  top:0;left:0;right:0;height:3px;
  background:var(--grad-sky);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s;
}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.service-card:hover::before{transform:scaleX(1)}
.service-num{
  font-family:var(--ff-en);
  font-size:14px;letter-spacing:.3em;
  color:var(--c-blue-deep);
  margin-bottom:18px;
}
.service-icon{
  width:56px;height:56px;border-radius:14px;
  background:linear-gradient(135deg,#eaf3ee,#e3eef4);
  color:var(--c-blue-deep);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:22px;
}
.service-icon svg{width:30px;height:30px}
.service-card h3{
  font-family:var(--ff-jp-s);
  font-size:20px;font-weight:600;
  letter-spacing:.06em;margin:0 0 8px;
}
.service-tag{
  display:inline-block;
  font-size:12px;letter-spacing:.18em;
  color:var(--c-green-deep);
  background:var(--c-green-soft);
  padding:4px 12px;border-radius:999px;
  margin:0 0 18px;
}
.service-desc{
  margin:0;color:var(--c-ink-soft);
  font-size:14.5px;line-height:1.95;
}
@media(max-width:720px){
  .service-grid{grid-template-columns:1fr}
  .service-grid--5{grid-template-columns:1fr}
  .service-card{padding:32px 26px}
}

/* ===== Features ===== */
.section--features{background:var(--c-bg)}
.features-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:36px 48px;
}
.feature{
  padding:32px 12px 32px 0;
  border-top:1px solid var(--c-line);
  position:relative;
}
.feature-no{
  font-family:var(--ff-en);
  font-size:46px;line-height:1;
  background:var(--grad-sky);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
  margin:0 0 14px;
}
.feature h3{
  font-family:var(--ff-jp-s);
  font-size:20px;font-weight:600;
  letter-spacing:.06em;margin:0 0 14px;
}
.feature p{margin:0;color:var(--c-ink-soft);font-size:15px;line-height:1.95}
@media(max-width:720px){
  .features-grid{grid-template-columns:1fr;gap:8px}
}

/* ===== Process ===== */
.section--process{
  background:linear-gradient(180deg,#f4f8f4 0%,#eaf2f5 100%);
}
.process{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  counter-reset:step;
  position:relative;
}
.process::before{
  content:"";
  position:absolute;
  top:64px;left:8%;right:8%;
  height:1px;
  background:repeating-linear-gradient(90deg,var(--c-blue) 0 6px,transparent 6px 14px);
  opacity:.45;
  z-index:0;
}
.process>li{
  background:#fff;
  border-radius:var(--r-md);
  padding:30px 24px;
  text-align:center;
  position:relative;z-index:1;
  box-shadow:var(--shadow-sm);
}
.process-step{
  display:inline-block;
  font-family:var(--ff-en);
  font-size:11px;letter-spacing:.28em;
  color:#fff;
  background:var(--grad-sky);
  padding:5px 14px;border-radius:999px;
  margin-bottom:18px;
}
.process h3{
  font-family:var(--ff-jp-s);
  font-size:17px;font-weight:600;
  margin:0 0 10px;letter-spacing:.06em;
}
.process p{margin:0;color:var(--c-ink-soft);font-size:13.5px;line-height:1.85}
@media(max-width:900px){
  .process{grid-template-columns:repeat(2,1fr)}
  .process::before{display:none}
}
@media(max-width:520px){
  .process{grid-template-columns:1fr}
}

/* ===== Pricing ===== */
.section--pricing{background:var(--c-bg)}
.pricing-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;align-items:stretch;
}
.plan{
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--r-md);
  padding:40px 32px;
  position:relative;
  transition:transform .3s,box-shadow .3s,border-color .3s;
  display:flex;flex-direction:column;
}
.plan:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--c-blue-soft)}
.plan-tag{
  font-family:var(--ff-en);
  font-size:12px;letter-spacing:.3em;
  color:var(--c-blue-deep);
  margin:0 0 12px;
}
.plan h3{
  font-family:var(--ff-jp-s);
  font-size:22px;font-weight:600;
  letter-spacing:.06em;margin:0 0 22px;
}
.plan-price{
  display:flex;align-items:baseline;gap:6px;
  margin:0 0 24px;padding-bottom:24px;
  border-bottom:1px dashed var(--c-line);
}
.plan-price .num{
  font-family:var(--ff-en);
  font-size:48px;font-weight:600;line-height:1;
  color:var(--c-ink);
}
.plan-price small{font-size:13px;color:var(--c-ink-soft)}
.plan-list li{
  font-size:14px;color:var(--c-ink-soft);
  padding:6px 0 6px 22px;
  position:relative;
  line-height:1.7;
}
.plan-list li::before{
  content:"";position:absolute;left:0;top:14px;
  width:10px;height:10px;border-radius:50%;
  background:var(--c-green-soft);
  border:2px solid var(--c-green);
}
.plan--featured{
  background:linear-gradient(180deg,#ffffff 0%,#f1f8f3 100%);
  border-color:transparent;
  box-shadow:0 18px 40px rgba(99,156,180,.15);
  transform:translateY(-8px);
}
.plan--featured:hover{transform:translateY(-12px)}
.plan-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--grad-sky);
  color:#fff;
  font-size:12px;font-weight:600;letter-spacing:.12em;
  padding:6px 18px;border-radius:999px;
  box-shadow:0 8px 20px rgba(99,156,180,.35);
  margin:0;
}
.pricing-note{
  text-align:center;
  font-size:12.5px;color:var(--c-mute);
  margin:32px 0 0;
}
@media(max-width:900px){
  .pricing-grid{grid-template-columns:1fr;gap:32px}
  .plan--featured{transform:none}
  .plan--featured:hover{transform:translateY(-4px)}
}

/* ===== Seminar ===== */
.section--seminar{
  background:
    radial-gradient(700px 400px at 0% 100%, #e9f2ec 0%, transparent 60%),
    radial-gradient(700px 400px at 100% 0%, #e6eff5 0%, transparent 60%),
    var(--c-bg-soft);
}
.seminar-card{
  display:grid;grid-template-columns:1.4fr 1fr;
  gap:0;
  background:#fff;
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.seminar-card__main{padding:clamp(32px,4vw,56px)}
.seminar-row{
  display:grid;grid-template-columns:120px 1fr;gap:20px;
  padding:20px 0;
  border-bottom:1px solid var(--c-line);
  align-items:start;
}
.seminar-row:last-child{border-bottom:0}
.seminar-label{
  font-family:var(--ff-jp-s);font-weight:600;
  font-size:13px;letter-spacing:.16em;
  color:var(--c-blue-deep);
  margin:6px 0 0;
}
.seminar-value{margin:0;color:var(--c-ink);font-size:15px;line-height:1.9}
.seminar-value .time{
  font-family:var(--ff-jp-s);font-weight:500;
  font-size:18px;margin:0 0 6px;letter-spacing:.04em;
  display:flex;align-items:center;gap:10px;
}
.time-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  background:var(--c-blue-soft);
  color:var(--c-blue-deep);
  font-size:14px;
}
.time-note{font-size:12px;color:var(--c-mute);margin:8px 0 0}
.seminar-value .big{
  font-family:var(--ff-en);
  font-size:36px;color:var(--c-green-deep);
  letter-spacing:.04em;
}

.seminar-card__apply{
  background:linear-gradient(160deg,#eaf3ee 0%,#dde9d8 100%);
  padding:clamp(32px,4vw,48px);
  display:flex;flex-direction:column;
}
.apply-title{
  font-family:var(--ff-jp-s);font-weight:600;
  font-size:18px;letter-spacing:.1em;
  margin:0 0 18px;
  color:var(--c-ink);
  position:relative;padding-bottom:14px;
}
.apply-title::after{
  content:"";position:absolute;left:0;bottom:0;
  width:32px;height:2px;background:var(--c-green-deep);
}
.apply-desc{font-size:13.5px;color:var(--c-ink-soft);line-height:1.85;margin:0 0 16px}
.apply-subject{
  display:inline-block;
  background:#fff;
  padding:6px 12px;border-radius:6px;
  font-size:12.5px;color:var(--c-ink);
  margin:6px 0;letter-spacing:.04em;
}
.apply-list{margin:0 0 22px;padding-left:18px}
.apply-list li{
  font-size:14px;color:var(--c-ink);
  list-style:disc;padding:2px 0;
}
.apply-mail{
  display:block;text-align:center;
  background:#fff;
  border-radius:999px;
  padding:14px 20px;
  font-family:var(--ff-en);
  font-size:18px;letter-spacing:.04em;
  color:var(--c-blue-deep);font-weight:600;
  margin:auto 0 16px;
  border:1px solid #fff;
  transition:.25s;
  word-break:break-all;
}
.apply-mail:hover{opacity:1;background:var(--c-blue-deep);color:#fff;border-color:var(--c-blue-deep)}
.apply-note{font-size:12px;color:var(--c-ink-soft);line-height:1.7;margin:0;text-align:center}

@media(max-width:900px){
  .seminar-card{grid-template-columns:1fr}
  .seminar-row{grid-template-columns:90px 1fr}
}
@media(max-width:520px){
  .seminar-row{grid-template-columns:1fr;gap:6px}
  .seminar-label{margin:0}
}

/* ===== Company ===== */
.section--company{background:var(--c-bg)}
.company-table{
  margin:0 auto;max-width:880px;
  background:#fff;
  border-radius:var(--r-md);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--c-line);
}
.company-table>div{
  display:grid;grid-template-columns:200px 1fr;
  border-bottom:1px solid var(--c-line);
}
.company-table>div:last-child{border-bottom:0}
.company-table dt{
  background:var(--c-bg-soft);
  padding:22px 28px;
  font-family:var(--ff-jp-s);font-weight:600;
  font-size:14px;letter-spacing:.1em;
  color:var(--c-blue-deep);
}
.company-table dd{
  margin:0;
  padding:22px 28px;
  font-size:15px;line-height:1.85;
  color:var(--c-ink);
}
.company-table dd a{color:var(--c-blue-deep);border-bottom:1px solid var(--c-blue-soft)}
@media(max-width:720px){
  .company-table>div{grid-template-columns:1fr}
  .company-table dt{padding:14px 22px}
  .company-table dd{padding:14px 22px}
}

/* ===== Footer ===== */
.footer{
  background:linear-gradient(135deg,#3f7d9f 0%,#5d9163 100%);
  color:#fff;
  padding:80px var(--pad-x) 32px;
}
.footer-inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:28px;
  text-align:center;
}
.footer-brand{display:flex;align-items:center;gap:14px}
.footer-logo-img{
  height:120px;width:auto;display:block;
  filter:brightness(0) invert(1);
  opacity:.95;
}
@media(max-width:720px){
  .footer-logo-img{height:96px}
}
.footer-tag{
  font-family:var(--ff-jp-s);
  font-size:14px;opacity:.85;margin:0;letter-spacing:.06em;
}
.footer-nav{
  display:flex;flex-wrap:wrap;justify-content:center;gap:8px 28px;
  margin:8px 0 0;
}
.footer-nav a{font-size:13px;opacity:.85;letter-spacing:.06em}
.footer-nav a:hover{opacity:1}
.copyright{
  font-family:var(--ff-en);
  font-size:11px;letter-spacing:.3em;
  opacity:.7;margin:24px 0 0;
  border-top:1px solid rgba(255,255,255,.2);
  padding-top:24px;width:100%;
}

/* ===== 404 page ===== */
.err{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 24px;background:radial-gradient(900px 600px at 50% 0%,#eaf3ee 0%,transparent 60%),#fbfaf6}
.err__inner{max-width:520px}
.err__code{
  font-family:var(--ff-en);
  font-size:120px;line-height:1;
  background:var(--grad-sky);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
  margin:0 0 16px;letter-spacing:.04em;
}
.err__title{
  font-family:var(--ff-jp-s);
  font-weight:600;font-size:22px;
  margin:0 0 18px;letter-spacing:.06em;
}
.err__lead{
  color:var(--c-ink-soft);
  font-size:14.5px;line-height:1.9;margin:0 0 32px;
}
.err__btn{
  display:inline-flex;
  padding:14px 30px;border-radius:999px;
  background:var(--grad-sky);
  color:#fff;font-weight:600;font-size:14px;letter-spacing:.08em;
  text-decoration:none;
  box-shadow:0 10px 26px rgba(99,156,180,.35);
  transition:transform .25s,box-shadow .25s;
}
.err__btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(99,156,180,.45)}

/* ===== Reveal animation ===== */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .8s ease,transform .8s ease;
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
