/* ── HERO ── */
/* ── HERO (固定表示) ── */
.hero{position:relative;width:100%;height:calc(100vh - 80px);overflow:hidden;background:var(--dark);}
.hero-video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
}
.hero-slide-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.7) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.15) 100%);}
.hero-slide-content{
  position:absolute;top:50%;left:0;right:0;width:100%;
  transform:translateY(-50%);
  max-width:1200px;margin:0 auto;
  padding:0 4rem;z-index:2;
}
.hero-slide-label{
  font-family:var(--ff);font-size:.62rem;font-weight:600;
  letter-spacing:.3em;color:rgba(255,255,255,.5);
  margin-bottom:1.2rem;
}
.hero-slide-title{
  font-family:var(--ffj);font-weight:700;
  font-size:clamp(2rem,4vw,3.8rem);line-height:1.35;
  color:#fff;margin-bottom:1.5rem;
}
.hero-slide-sub{
  font-family:var(--ffj);font-size:.85rem;font-weight:300;
  color:rgba(255,255,255,.6);line-height:1.9;max-width:500px;margin-bottom:2rem;
}
.hero-scroll{
  position:absolute;bottom:3rem;left:50%;transform:translateX(-50%);z-index:10;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
}
.hero-scroll span{font-size:.55rem;letter-spacing:.2em;color:rgba(255,255,255,.4);writing-mode:vertical-rl;}
.hero-scroll-line{width:1px;height:40px;background:rgba(255,255,255,.2);position:relative;overflow:hidden;}
.hero-scroll-line::after{
  content:'';position:absolute;top:-100%;left:0;width:1px;height:100%;background:#fff;
  animation:scrollLine 2s ease infinite;
}
@keyframes scrollLine{0%{top:-100%}50%{top:100%}100%{top:100%}}

/* ── パートナーマーキーバー（ヒーロー下・独立セクション） ── */
.partner-marquee{
  width:100%;overflow:hidden;
  background:#fff;
  border-bottom:1px solid rgba(0,0,0,.06);
  height:80px;display:flex;align-items:center;
}
.partner-marquee-track{
  display:flex;width:max-content;
  animation:partnerMarquee 20s linear infinite;
}
.partner-marquee-set{
  display:flex;align-items:center;gap:3rem;
  padding-right:3rem;
}
@keyframes partnerMarquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.partner-logo{
  height:40px;width:auto;
  object-fit:contain;
  flex-shrink:0;
  transition:opacity .3s;
}
.partner-logo{pointer-events:none;}

/* ── MISSION SECTION (Zelvia風 別パターン) ── */
.mission-zelvia{
  position:relative;overflow:hidden;
  background:#343738;
  padding:6rem 4rem;
}
/* SVG三角パターン背景 */
.mission-zelvia-bg{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='52' height='90'%3E%3Cpolygon points='26,0 52,45 0,45' fill='none' stroke='rgba(255,255,255,.04)' stroke-width='.5'/%3E%3Cpolygon points='26,90 0,45 52,45' fill='none' stroke='rgba(255,255,255,.04)' stroke-width='.5'/%3E%3C/svg%3E");
  background-size:52px 90px;
}
.mission-zelvia-grid{display:none;}
/* パラレログラム装飾（左上） */
.mission-zelvia-visual{
  position:absolute;
  top:-40px;left:-60px;
  width:320px;height:160px;
  background:linear-gradient(160deg,var(--blue) 0%,rgba(0,188,212,.3) 100%);
  clip-path:polygon(80px 0,100% 0,calc(100% - 80px) 100%,0 100%);
  opacity:.12;
}
/* パラレログラム装飾（右下） */
.mission-zelvia::after{
  content:'';position:absolute;
  bottom:-30px;right:-40px;
  width:280px;height:140px;
  background:linear-gradient(160deg,rgba(0,188,212,.3) 0%,var(--blue) 100%);
  clip-path:polygon(70px 0,100% 0,calc(100% - 70px) 100%,0 100%);
  opacity:.08;
}
/* 中央コンテナ */
.mission-zelvia-inner{
  position:relative;z-index:2;
  width:100%;
  max-width:860px;margin:0 auto;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
}
.mission-zelvia-inner::before{display:none;}

/* セクションタイトル（英語 + 装飾ライン + 日本語 2段構成） */
.mz-sec-en{
  font-family:var(--ff);font-size:clamp(.6rem,.8vw,.7rem);font-weight:800;
  letter-spacing:.35em;color:var(--blue);text-transform:uppercase;
  margin-bottom:.8rem;
}
.mz-sec-deco{
  width:40px;height:2px;
  background:linear-gradient(90deg,var(--blue),rgba(0,188,212,.3));
  margin:0 auto .8rem;
}
.mz-sec-ja{
  font-family:var(--ffj);font-size:.78rem;font-weight:500;
  color:rgba(255,255,255,.4);letter-spacing:.15em;
  margin-bottom:3rem;
}

/* 大型タイポグラフィ */
.mz-typo{
  margin-bottom:2rem;
  line-height:1;
  position:relative;
}
.mz-line1-wrap{
  position:relative;
  display:inline-block;
  margin-bottom:.3rem;
}
.mz-line1-wrap::before{display:none;}
.mz-line1{
  display:block;
  position:relative;z-index:1;
  font-family:var(--ff);font-size:clamp(2.5rem,7vw,5rem);
  font-weight:900;letter-spacing:-.02em;
  color:transparent;
  -webkit-text-stroke:1px rgb(255 255 255 / 50%);
  text-transform:uppercase;
}
.mz-line2{
  display:inline-block;
  font-family:var(--ff);font-size:clamp(3rem,9vw,6.5rem);
  font-weight:900;letter-spacing:-.03em;
  color:#fff;
  text-transform:uppercase;
  line-height:.9;
  border-bottom:none;
  padding-bottom:0;
  position:relative;
}
.mz-line2::after{display:none;}
.mz-line3{
  display:block;
  font-family:var(--ff);font-size:clamp(1.2rem,3.5vw,2.4rem);
  font-weight:300;letter-spacing:.25em;
  color:rgba(255,255,255,.25);
  text-transform:uppercase;
  margin-top:.6rem;
  padding-left:0;border-left:none;
}

/* キャッチコピー（pill型バッジ） */
.mz-catchband{
  display:inline-block;
  background:transparent;
  border:1px solid rgba(255,255,255,.15);
  border-radius:100vmax;
  padding:.6rem 2rem;
  margin-bottom:1.5rem;
  margin-top:.5rem;
}
.mz-catchband span{
  font-family:var(--ffj);font-size:clamp(.8rem,2.5vw,1rem);
  font-weight:700;color:rgba(255,255,255,.8);
  letter-spacing:.08em;
}
/* 本文 */
.mz-body{
  font-family:var(--ffj);font-size:.82rem;font-weight:300;
  color:rgba(255,255,255,.4);line-height:2.1;
  max-width:560px;
  text-align:center;
  letter-spacing:.05em;
}

/* ── MESSAGE ── */
.message{
  padding:6rem 4rem;background:var(--bg);text-align:center;
  position:relative;overflow:hidden;
}
.message-catch{
  font-family:var(--ffj);font-weight:700;
  font-size:clamp(1.6rem,3.2vw,3rem);
  line-height:1.7;color:var(--ink-dark);
  opacity:0;transform:translateY(30px);
  transition:opacity 1s ease,transform 1s ease;
}
.message-catch.vis{opacity:1;transform:none;}
.message-sub{
  font-family:var(--ffj);font-size:.88rem;font-weight:300;
  line-height:2.2;color:rgba(26,26,26,.5);
  max-width:700px;margin:2.5rem auto 0;
  opacity:0;transform:translateY(20px);
  transition:opacity .8s ease .3s,transform .8s ease .3s;
}
.message-sub.vis{opacity:1;transform:none;}

/* ── NUMBERS ── */
.numbers{
  background:var(--dark);padding:5rem 4rem;position:relative;overflow:hidden;
}
.numbers::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:40px 40px;pointer-events:none;
}
.numbers-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1;}
.numbers-label{
  font-family:var(--ff);font-size:.7rem;font-weight:600;
  letter-spacing:.3em;color:rgba(255,255,255,.35);
  text-align:center;margin-bottom:3rem;
}
.numbers-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:2rem;
}
.num-card{text-align:center;padding:2rem 1rem;}
.num-val{
  font-family:var(--ff);font-size:clamp(2.6rem,5vw,4rem);font-weight:800;
  color:#fff;line-height:1;margin-bottom:.6rem;
  display:flex;align-items:baseline;justify-content:center;gap:.15rem;
}
.num-unit{font-size:.95rem;font-weight:400;color:rgba(255,255,255,.4);letter-spacing:.05em;}
.num-label{
  font-family:var(--ffj);font-size:.78rem;font-weight:400;
  color:rgba(255,255,255,.4);letter-spacing:.06em;margin-top:.6rem;
}

/* ── SERVICES ── */
/* ── SERVICES (Agileware風) ── */
.services{
  padding:6rem 4rem;
  background:#fff;
  position:relative;overflow:hidden;
}
/* ネットワーク背景キャンバス */
.svc-network-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;opacity:.35;
}
.services-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1;}
.sec-label{
  display:flex;align-items:center;gap:.8rem;
  font-family:var(--ff);font-size:.7rem;font-weight:700;
  letter-spacing:.3em;color:var(--blue);margin-bottom:1rem;
  overflow:hidden;
}
.sec-label::before{
  content:'';display:block;width:0;height:1.5px;
  background:var(--blue);flex-shrink:0;
  transition:width .8s cubic-bezier(.16,1,.3,1) .2s;
}
.sec-label.vis::before{width:28px;}
.sec-label[class*="sr"]{
  opacity:0;transform:translateX(-12px);
  transition:opacity .6s cubic-bezier(.16,1,.3,1) .3s,transform .6s cubic-bezier(.16,1,.3,1) .3s;
}
.sec-label[class*="sr"].vis{opacity:1;transform:translateX(0);}
.sec-title{
  font-family:var(--ffj);font-weight:700;
  font-size:clamp(1.7rem,3vw,2.6rem);
  line-height:1.5;color:var(--ink-dark);margin-bottom:1.2rem;
}
.sec-title[class*="sr"]{
  opacity:0;transform:translateY(24px);
  transition:opacity .8s cubic-bezier(.16,1,.3,1) .5s,transform .8s cubic-bezier(.16,1,.3,1) .5s;
}
.sec-title[class*="sr"].vis{opacity:1;transform:translateY(0);}
.sec-desc{
  font-family:var(--ffj);font-size:.88rem;font-weight:300;
  line-height:2.2;color:rgba(26,26,26,.5);max-width:640px;margin-bottom:3rem;
}
.sec-desc[class*="sr"]{
  opacity:0;transform:translateY(16px);
  transition:opacity .8s cubic-bezier(.16,1,.3,1) .7s,transform .8s cubic-bezier(.16,1,.3,1) .7s;
}
.sec-desc[class*="sr"].vis{opacity:1;transform:translateY(0);}
/* ── Agileware風 BUSINESSカード ── */
.biz-list{
  display:flex;flex-direction:column;gap:0;
  margin-top:2rem;
}
.biz-item{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:340px;
  border-top:1px solid var(--border);
  overflow:hidden;
  transition:background .3s;
}
.biz-item:last-child{border-bottom:1px solid var(--border);}
.biz-item:hover{background:rgba(0,188,212,.02);}
/* 奇数: 画像左・テキスト右 / 偶数: テキスト左・画像右 */
.biz-item:nth-child(even) .biz-img{order:2;}
.biz-item:nth-child(even) .biz-text{order:1;}

.biz-img{
  position:relative;overflow:hidden;
  background:var(--bg2);
  min-height:280px;
}
.biz-img-placeholder{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:1rem;
}
.biz-img-placeholder svg{
  width:80px;height:80px;opacity:.15;
}
.biz-img-label{
  font-family:var(--ff);font-size:.55rem;font-weight:700;
  letter-spacing:.25em;color:rgba(0,0,0,.18);text-transform:uppercase;
}
/* 画像ホバー */
.biz-item:hover .biz-img-placeholder svg{
  opacity:.22;transform:scale(1.04);
  transition:opacity .4s,transform .4s;
}

.biz-text{
  padding:3rem 3.5rem;
  display:flex;flex-direction:column;justify-content:center;
  border-left:1px solid var(--border);
}
.biz-item:nth-child(even) .biz-text{
  border-left:none;
  border-right:1px solid var(--border);
}
.biz-num{
  font-family:var(--ff);font-size:.55rem;font-weight:700;
  letter-spacing:.2em;color:var(--blue);margin-bottom:1rem;
  display:flex;align-items:center;gap:.6rem;
}
.biz-num::after{
  content:'';display:block;width:32px;height:1px;background:var(--blue);opacity:.4;
}
.biz-tag{
  display:inline-block;
  font-family:var(--ff);font-size:.55rem;font-weight:700;
  letter-spacing:.15em;color:var(--blue);
  border:1px solid rgba(0,188,212,.25);border-radius:2px;
  padding:.2rem .7rem;margin-bottom:1rem;
  text-transform:uppercase;
}
.biz-name{
  font-family:var(--ffj);font-size:clamp(1.3rem,2vw,1.8rem);font-weight:700;
  color:var(--ink-dark);line-height:1.4;margin-bottom:1rem;
}
.biz-desc{
  font-family:var(--ffj);font-size:.85rem;line-height:2.1;
  color:rgba(26,26,26,.5);margin-bottom:1.8rem;
  max-width:440px;
}
.biz-link{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--ff);font-size:.65rem;font-weight:700;
  letter-spacing:.1em;color:var(--blue);text-decoration:none;
  border-bottom:1px solid rgba(0,188,212,.3);
  padding-bottom:.2rem;
  transition:gap .25s,border-color .25s;
  width:fit-content;
}
.biz-link:hover{gap:.9rem;border-color:var(--blue);}

/* ── ABOUT ── */
.about{
  padding:7rem 4rem;background:var(--bg);position:relative;overflow:hidden;
}
.about-inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:4rem 6rem;align-items:center;
}
.about-catch{
  font-family:var(--ffj);font-weight:700;
  font-size:clamp(1.6rem,2.8vw,2.6rem);
  line-height:1.5;color:var(--ink-dark);margin-bottom:1.8rem;
}
.about-body{
  font-family:var(--ffj);font-size:.88rem;font-weight:300;
  line-height:2.2;color:rgba(26,26,26,.55);margin-bottom:2.5rem;
}
.about-btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.72rem;font-weight:600;letter-spacing:.08em;
  color:var(--ink-dark);text-decoration:none;padding:.6rem 0;
  border-bottom:1px solid var(--ink-dark);
  transition:color .3s,border-color .3s;
}
.about-btn:hover{color:var(--blue);border-color:var(--blue);}
.about-right{
  position:relative;height:380px;overflow:hidden;
  background:var(--dark);
}
.about-visual{
  position:absolute;top:30px;left:0;right:0;
  display:flex;align-items:center;justify-content:center;
}
.about-visual-text{
  font-family:var(--ff);font-size:5rem;font-weight:900;
  letter-spacing:.15em;color:#fff;
}
.about-mission{
  position:absolute;bottom:2rem;left:2rem;right:2rem;
  background:rgba(255,255,255,.06);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.1);border-radius:8px;
  padding:1.5rem 1.8rem;
}
.about-mission-label{
  font-family:var(--ff);font-size:.55rem;font-weight:600;
  letter-spacing:.2em;color:rgba(255,255,255,.4);margin-bottom:.6rem;
}
.about-mission-text{
  font-family:var(--ffj);font-size:1rem;font-weight:500;
  line-height:1.8;color:rgba(255,255,255,.85);
}

/* ── NEWS ── */
.news{padding:6rem 4rem;background:var(--bg);position:relative;}
.news-inner{max-width:1200px;margin:0 auto;}
.news-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2.5rem;}
.news-more{
  font-size:.72rem;font-weight:600;letter-spacing:.08em;
  color:var(--ink-dark);text-decoration:none;
  display:flex;align-items:center;gap:.4rem;
  transition:color .2s;
}
.news-more:hover{color:var(--blue);}
.news-tabs{display:flex;gap:0;margin-bottom:2rem;border-bottom:1px solid var(--border);}
.ntab{
  background:none;border:none;cursor:pointer;
  padding:.6rem 1.4rem;font-family:var(--ff);font-size:.68rem;font-weight:600;
  letter-spacing:.1em;color:var(--ink);opacity:.3;
  position:relative;transition:opacity .2s;
}
.ntab::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;
  background:var(--ink-dark);transform:scaleX(0);transition:transform .2s;
}
.ntab.on{opacity:1;}.ntab.on::after{transform:scaleX(1);}
.news-list{display:flex;flex-direction:column;gap:0;}
.news-item{
  display:grid;grid-template-columns:110px 90px 1fr auto;
  align-items:center;gap:1.5rem;
  padding:1rem 0;border-bottom:1px solid var(--border);
  text-decoration:none;color:inherit;transition:background .2s,padding-left .2s;
}
.news-item:hover{background:rgba(0,0,0,.015);padding-left:.5rem;}
.ni-date{font-family:var(--ff);font-size:.68rem;color:rgba(26,26,26,.4);letter-spacing:.04em;}
.ni-cat{
  font-family:var(--ff);font-size:.55rem;font-weight:700;
  letter-spacing:.08em;padding:.25rem .6rem;
  background:var(--ink-dark);color:#fff;text-align:center;
}
.ni-cat.blue{background:var(--blue);}
.ni-title{font-family:var(--ffj);font-size:.88rem;font-weight:500;color:var(--ink-dark);line-height:1.6;}
.ni-arrow{font-size:.7rem;color:rgba(26,26,26,.25);transition:transform .2s,color .2s;}
.news-item:hover .ni-arrow{transform:translateX(4px);color:var(--blue);}

/* ── RECRUIT ── */
.recruit{
  padding:6rem 4rem 7rem;background:var(--dark);
  position:relative;overflow:hidden;
}
.recruit::before{
  content:'RECRUIT';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-family:var(--ff);font-size:clamp(6rem,15vw,14rem);
  font-weight:900;letter-spacing:.1em;
  color:rgba(255,255,255,.02);pointer-events:none;white-space:nowrap;
}
.recruit-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1;}
.recruit .sec-label{color:rgba(255,255,255,.6);}
.recruit .sec-label::before{color:rgba(255,255,255,.6);}
.recruit .sec-title{color:#fff;}
.recruit .sec-desc{color:rgba(255,255,255,.45);}
.recruit-cards{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;
  margin-bottom:3.5rem;
}
.rc-card{
  position:relative;min-height:280px;overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.8rem;text-decoration:none;color:#fff;
  transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s;
}
.rc-card::before{
  content:'';position:absolute;inset:0;z-index:0;
  transition:transform .5s cubic-bezier(.16,1,.3,1);
}
.rc-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.3);}
.rc-card:hover::before{transform:scale(1.06);}
.rc-card>*{position:relative;z-index:1;}
.rc-card-num{
  font-family:var(--ff);font-size:.55rem;font-weight:700;
  letter-spacing:.2em;color:rgba(255,255,255,.4);margin-bottom:.4rem;
}
.rc-card-title{
  font-family:var(--ffj);font-size:clamp(1rem,1.8vw,1.3rem);
  font-weight:700;line-height:1.4;margin-bottom:.3rem;
}
.rc-card-sub{
  font-family:var(--ffj);font-size:.68rem;
  color:rgba(255,255,255,.55);line-height:1.6;
}
.rc-card-arrow{
  position:absolute;top:1.2rem;right:1.2rem;
  font-family:var(--ff);font-size:.8rem;color:rgba(255,255,255,.3);
  transition:transform .3s,color .3s;
}
.rc-card:hover .rc-card-arrow{transform:translateX(4px);color:#fff;}
.rc-1::before{background:linear-gradient(135deg,#00BCD4 0%,#0f172a 100%);}
.rc-2::before{background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);}
.rc-3::before{background:linear-gradient(135deg,#7c3aed 0%,#4B8BF5 100%);}
.rc-4::before{background:linear-gradient(135deg,#0ea5e9 0%,#00BCD4 100%);}

.recruit-flow-section{margin-bottom:3.5rem;}
.recruit-flow-label{
  font-family:var(--ff);font-size:.58rem;font-weight:600;
  letter-spacing:.25em;color:rgba(255,255,255,.35);
  margin-bottom:2rem;text-align:center;
}
.recruit-flow{
  display:flex;align-items:flex-start;justify-content:center;gap:0;
}
.rf-step{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;flex:1;max-width:160px;
}
.rf-num{
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff);font-size:.62rem;font-weight:700;
  letter-spacing:.08em;color:#fff;
  background:transparent;border:1px solid rgba(255,255,255,.2);
  margin-bottom:.8rem;transition:background .3s,border-color .3s,transform .3s;
}
.rf-step:hover .rf-num{background:var(--blue);border-color:var(--blue);transform:scale(1.08);}
.rf-title{font-family:var(--ffj);font-size:.75rem;font-weight:600;color:#fff;margin-bottom:.3rem;}
.rf-desc{font-family:var(--ffj);font-size:.6rem;color:rgba(255,255,255,.35);line-height:1.6;}
.rf-connector{width:40px;height:1px;background:rgba(255,255,255,.15);margin-top:26px;flex-shrink:0;}

.recruit-entry{
  text-align:center;padding:3rem 2rem;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
}
.recruit-entry-title{
  font-family:var(--ffj);font-size:clamp(1.2rem,2vw,1.6rem);
  font-weight:700;color:#fff;margin-bottom:.7rem;line-height:1.5;
}
.recruit-entry-sub{
  font-family:var(--ffj);font-size:.75rem;
  color:rgba(255,255,255,.4);line-height:1.9;margin-bottom:1.8rem;
  max-width:500px;margin-left:auto;margin-right:auto;
}
.recruit-entry-btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--ff);font-size:.72rem;font-weight:600;letter-spacing:.1em;
  padding:.8rem 2.2rem;
  background:#fff;color:var(--ink-dark);
  text-decoration:none;transition:background .25s,color .25s,transform .25s;
}
.recruit-entry-btn:hover{background:var(--blue);color:#fff;transform:translateY(-2px);}

/* ── CONTACT ── */
.contact{padding:6rem 4rem;background:var(--bg2);}
.contact-card{
  max-width:960px;margin:0 auto;
  background:var(--dark);
  display:grid;grid-template-columns:1fr 280px;
  overflow:hidden;
}
.contact-body{padding:3rem 3.5rem;z-index:2;position:relative;}
.contact-ey{
  font-family:var(--ff);font-size:.6rem;font-weight:600;letter-spacing:.25em;
  color:rgba(255,255,255,.35);margin-bottom:1rem;
}
.contact-h2{
  font-family:var(--ffj);font-weight:700;
  font-size:clamp(1.2rem,2vw,1.7rem);line-height:1.6;
  color:#fff;margin-bottom:.7rem;
}
.contact-sub{
  font-family:var(--ffj);font-size:.76rem;font-weight:300;
  color:rgba(255,255,255,.4);line-height:2;
  margin-bottom:1.8rem;max-width:420px;
}
.contact-btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--ff);font-size:.7rem;font-weight:600;letter-spacing:.1em;
  color:#fff;text-decoration:none;
  border:1px solid rgba(255,255,255,.25);
  padding:.65rem 1.6rem;
  transition:background .25s,border-color .25s;
}
.contact-btn:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5);}
.contact-deco{position:relative;overflow:hidden;}
.contact-deco-dots{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.06) 1.5px,transparent 1.5px);
  background-size:24px 24px;
}
.contact-deco-ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.06);}
.contact-deco-ring.r1{width:200px;height:200px;top:-60px;right:-70px;}
.contact-deco-ring.r2{width:120px;height:120px;top:70px;right:30px;background:rgba(255,255,255,.03);}

/* ── PEOPLE ── */
.people {
  padding:6rem 4rem;
  background:var(--bg);
}
.people-inner { max-width:1200px;margin:0 auto; }
.people-carousel {
  display:flex;
  gap:1.2rem;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding-bottom:1rem;
}
.people-carousel::-webkit-scrollbar { display:none; }
.people-dots{
  display:flex;justify-content:center;gap:.6rem;
  margin-top:1.5rem;
}
.people-dot{
  width:10px;height:10px;border-radius:50%;
  background:rgba(0,0,0,.12);border:none;cursor:pointer;
  transition:background .3s,transform .3s;padding:0;
}
.people-dot.active{background:var(--blue);transform:scale(1.25);}
.people-card {
  flex:0 0 280px;
  scroll-snap-align:start;
  cursor:pointer;
}
.people-card-img {
  position:relative;
  width:100%;
  height:380px;
  background-size:cover;
  background-position:center;
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  border-radius:16px;
  transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s;
}
.people-card:hover .people-card-img {
  transform:scale(1.04);
  box-shadow:0 12px 36px rgba(0,0,0,.18);
}
.people-card-overlay {
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.1) 50%,transparent 100%);
}
.people-card-info {
  position:relative;z-index:1;
  padding:1.5rem;
  display:flex;flex-direction:column;gap:.3rem;
}
.people-card-role {
  font-family:var(--ff);font-size:.6rem;font-weight:700;
  letter-spacing:.15em;color:var(--blue);
  text-transform:uppercase;
}
.people-card-name {
  font-family:var(--ffj);font-size:1.1rem;font-weight:700;
  color:#fff;
}
.people-card-quote {
  font-family:var(--ffj);font-size:.75rem;font-weight:300;
  color:rgba(255,255,255,.7);line-height:1.6;
  margin-top:.3rem;
}

/* ── RECRUIT INFO CARDS ── */
.ri-card {
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;
  background:#fff;
  padding:1.5rem;
  min-height:130px;
  text-decoration:none;color:var(--ink-dark);
  border:1px solid var(--border);
  transition:box-shadow .3s,transform .3s;
}
.ri-card:hover {
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  transform:translateY(-3px);
}
.ri-tag {
  font-family:var(--ff);font-size:.6rem;font-weight:700;
  letter-spacing:.15em;color:var(--blue);
}
.ri-title {
  font-family:var(--ffj);font-size:1rem;font-weight:700;
  color:var(--ink-dark);
}
.ri-arrow {
  position:absolute;bottom:1rem;right:1rem;
  font-size:.8rem;color:rgba(0,0,0,.25);
  transition:transform .3s,color .3s;
}
.ri-card:hover .ri-arrow { transform:translateX(4px);color:var(--blue); }

/* ── HERO ENTRY BUTTON ── */
.hero-entry-btn {
  display:inline-block;
  background:var(--accent);color:#fff;
  font-family:var(--ffj);font-size:.85rem;font-weight:700;
  letter-spacing:.08em;
  padding:.9rem 2.4rem;border-radius:40px;
  text-decoration:none;
  transition:background .25s,transform .25s,box-shadow .25s;
}
.hero-entry-btn:hover {
  background:var(--accent-hover);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(232,163,23,.35);
}
.hero-cta-wrap {
  display:flex;gap:1rem;align-items:center;flex-wrap:wrap;
}
.hero-outline-btn {
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--ffj);font-size:.78rem;font-weight:500;
  letter-spacing:.06em;
  color:rgba(255,255,255,.8);
  padding:.7rem 1.8rem;border-radius:40px;
  border:1px solid rgba(255,255,255,.35);
  text-decoration:none;
  transition:background .25s,border-color .25s,color .25s;
}
.hero-outline-btn:hover {
  background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.6);color:#fff;
}

/* ── ENTRY SECTION ── */
.entry-btn-primary {
  display:inline-block;
  background:var(--accent);color:#fff;
  font-family:var(--ffj);font-size:.8rem;font-weight:700;
  letter-spacing:.08em;
  padding:.85rem 2.5rem;border-radius:40px;
  text-decoration:none;
  transition:background .25s,transform .25s;
  margin-bottom:.8rem;
}
.entry-btn-primary:hover { background:var(--accent-hover);transform:translateY(-2px); }
.entry-btn-secondary {
  display:inline-block;
  background:transparent;color:#fff;
  font-family:var(--ffj);font-size:.75rem;font-weight:500;
  letter-spacing:.06em;
  padding:.7rem 2rem;border-radius:40px;
  border:1px solid rgba(255,255,255,.5);
  text-decoration:none;
  transition:background .25s,border-color .25s;
}
.entry-btn-secondary:hover { background:rgba(255,255,255,.15);border-color:#fff; }

/* ══════════════════════════════════════
   RESPONSIVE — 1024px
══════════════════════════════════════ */
@media(max-width:1024px){
  .hero-slide-content{padding:0 3rem;}
  .numbers-grid{gap:1rem;}
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .svc-card:nth-child(2n){border-right:none;}
  .svc-card:nth-child(n+5){border-bottom:none;}
  .about-inner{grid-template-columns:1fr;gap:2.5rem;}
  .about-right{height:280px;}
  .recruit-cards{grid-template-columns:repeat(2,1fr);}
  .contact-card{grid-template-columns:1fr;}
  .contact-deco{display:none;}
}

/* ══════════════════════════════════════
   RESPONSIVE — 640px (スマホ全面最適化)
══════════════════════════════════════ */
@media(max-width:640px){
  /* HERO */
  .hero{height:calc(100svh - 60px);}
  .hero-slide-content{
    padding:0 1.4rem 3rem;
    top:50%;bottom:auto;
    transform:translateY(-50%);
  }
  .hero-slide-label{font-size:.55rem;letter-spacing:.2em;margin-bottom:.8rem;}
  .hero-slide-title{font-size:1.75rem;line-height:1.3;margin-bottom:1rem;}
  .hero-slide-sub{font-size:.75rem;line-height:1.8;margin-bottom:1.5rem;max-width:85%;}
  .hero-scroll{display:none;}
  .partner-marquee{height:60px;}
  .partner-logo{height:30px;}

  /* MISSION (Zelvia風) */
  .mission-zelvia{padding:3.5rem 1.4rem;}
  .mz-sec-ja{margin-bottom:2rem;}
  .mz-typo{margin-bottom:1.2rem;}
  .mz-line1-wrap{display:block;}
  .mz-line1{font-size:clamp(2rem,12vw,3rem);}
  .mz-line2{font-size:clamp(2.4rem,14vw,3.5rem);}
  .mz-line3{font-size:clamp(.9rem,5vw,1.5rem);}
  .mz-catchband{padding:.5rem 1.4rem;margin-bottom:1rem;}
  .mz-catchband span{font-size:clamp(.75rem,3.5vw,.95rem);}
  .mz-body{font-size:.72rem;line-height:1.9;}
  .mission-zelvia-visual{width:200px;height:100px;opacity:.08;}

  /* MESSAGE */
  .message{padding:3rem 1.4rem;}
  .message-catch{font-size:1.4rem;line-height:1.6;}
  .message-sub{font-size:.75rem;margin-top:1.2rem;}

  /* NUMBERS */
  .numbers{padding:3rem 1.4rem;}
  .numbers-label{margin-bottom:2rem;}
  .numbers-grid{grid-template-columns:repeat(2,1fr);gap:.8rem;}
  .num-card{padding:1.2rem .8rem;}
  .num-val{font-size:2.2rem;}
  .num-label{font-size:.7rem;}

  /* PEOPLE */
  .people { padding:3rem 1.4rem; }
  .people-card { flex:0 0 240px; }
  .people-card-img { height:320px; }

  /* BUSINESS (Agileware風スマホ) */
  .services{padding:2.5rem 1.4rem;}
  .sec-title{font-size:1.3rem;}
  .sec-desc{font-size:.73rem;margin-bottom:1.5rem;}
  .svc-network-canvas{display:none;}
  /* スマホ: biz-itemを縦一列に */
  .biz-item{
    grid-template-columns:1fr;
    min-height:auto;
    border-top:1px solid var(--border);
  }
  .biz-item:nth-child(even) .biz-img{order:1;}
  .biz-item:nth-child(even) .biz-text{order:2;}
  .biz-img{min-height:200px;}
  .biz-img-placeholder svg{width:60px;height:60px;}
  .biz-text{
    padding:1.6rem 1.4rem;
    border-left:none;
    border-top:1px solid var(--border);
  }
  .biz-item:nth-child(even) .biz-text{
    border-right:none;
    border-top:1px solid var(--border);
  }
  .biz-name{font-size:1.15rem;}
  .biz-desc{font-size:.73rem;margin-bottom:1rem;}

  /* ABOUT */
  .about{padding:3rem 1.4rem;}
  .about-catch{font-size:1.4rem;margin-bottom:1.2rem;}
  .about-body{font-size:.75rem;line-height:2;margin-bottom:1.5rem;}
  .about-right{display:none;}
  .about-mission{padding:1.1rem 1.3rem;}
  .about-mission-text{font-size:.9rem;}

  /* NEWS */
  .news{padding:3rem 1.4rem;}
  .news-head{margin-bottom:1.5rem;}
  .sec-title{font-size:1.3rem;}
  .news-tabs{margin-bottom:1.2rem;}
  .ntab{padding:.5rem .9rem;font-size:.62rem;}
  .news-item{
    grid-template-columns:1fr;
    gap:.4rem;padding:.9rem 0;
  }
  .ni-date{font-size:.62rem;}
  .ni-cat{display:inline-block;font-size:.5rem;padding:.2rem .5rem;margin-bottom:.2rem;}
  .ni-title{font-size:.78rem;}
  .ni-arrow{display:none;}

  /* RECRUIT */
  .recruit{padding:3rem 1.4rem 4rem;}
  .recruit::before{display:none;}
  .recruit-cards{grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:2.5rem;}
  .rc-card{min-height:160px;padding:1.2rem;}
  .rc-card-title{font-size:.9rem;}
  .rc-card-sub{font-size:.62rem;}
  .recruit-flow{flex-direction:column;gap:0;align-items:stretch;}
  .rf-step{
    flex-direction:row;align-items:center;
    max-width:100%;text-align:left;gap:1rem;
    padding:.8rem 0;
    border-bottom:1px solid rgba(255,255,255,.06);
  }
  .rf-num{width:40px;height:40px;flex-shrink:0;margin-bottom:0;font-size:.58rem;}
  .rf-title{font-size:.78rem;margin-bottom:.15rem;}
  .rf-desc{font-size:.62rem;}
  .rf-step-text{flex:1;}
  .rf-connector{display:none;}
  .recruit-entry{padding:2rem 1.4rem;}
  .recruit-entry-title{font-size:1.2rem;}
  .recruit-entry-sub{font-size:.72rem;margin-bottom:1.5rem;}

  /* CONTACT */
  .contact{padding:3rem 1.4rem;}
  .contact-card{grid-template-columns:1fr;}
  .contact-deco{display:none;}
  .contact-body{padding:2rem 1.6rem;}
  .contact-h2{font-size:1.2rem;}
  .contact-sub{font-size:.72rem;margin-bottom:1.5rem;}
}
