/* ============================================================
   DEAL BASE — style.css  |  Refined Corporate Design
   ============================================================ */

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font:inherit}

/* ── Design Tokens ── */
:root{
  /* Color */
  --ink:       #06060A;
  --ink-mid:   #30303C;
  --ink-soft:  #6C6C80;
  --ink-xsoft: #7C7C96;
  --rule:      #EBEBF4;
  --bg:        #FFFFFF;
  --bg-warm:   #F8F8FC;
  --deal:      #2B3FDF;
  --deal-dark: #1E2FA8;
  --deal-bg:   rgba(43,63,223,.06);
  --deal-mid:  rgba(43,63,223,.12);

  /* Type */
  --en:  'Inter', system-ui, sans-serif;
  --ja:  'Noto Sans JP', sans-serif;

  /* Space */
  --s1:  8px;
  --s2:  16px;
  --s3:  24px;
  --s4:  40px;
  --s5:  64px;
  --s6:  96px;
  --s7:  132px;

  /* Easing */
  --ease: cubic-bezier(.16,1,.3,1);
  --ease-in: cubic-bezier(.4,0,1,1);

  --max: 1160px;
  --header-h: 62px;
}

/* ── Base ── */
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased}
body{
  font-family:var(--ja);
  background:var(--bg);
  color:var(--ink);
  line-height:1.7;
  overflow-x:hidden;
}

/* ── Layout ── */
.container{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--s4);
}
.section{padding:var(--s7) 0}

/* ── Section eyebrow ── */
.section__eyebrow{
  display:flex;
  align-items:center;
  gap:var(--s2);
  margin-bottom:var(--s4);
}
.eyebrow{
  font-family:var(--en);
  font-size:11px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--deal);
  white-space:nowrap;
}
.eyebrow-rule{
  flex:1;
  height:1px;
  background:var(--rule);
}
.section__title{
  font-size:clamp(26px,3vw,40px);
  font-weight:700;
  line-height:1.2;
  letter-spacing:-.02em;
  color:var(--ink);
  margin-bottom:var(--s4);
}

/* ── Buttons ── */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:11px 22px;
  font-family:var(--ja);
  font-size:13px;
  font-weight:600;
  border-radius:3px;
  transition:all .2s var(--ease);
  letter-spacing:.02em;
}
.btn--primary{
  background:var(--ink);
  color:var(--bg);
}
.btn--primary:hover{
  background:var(--deal);
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(43,63,223,.25);
}
.btn--ghost{
  color:var(--ink-soft);
  border:1px solid var(--rule);
}
.btn--ghost:hover{
  color:var(--ink);
  border-color:var(--ink-mid);
}

/* ============================================================
   PROGRESS BAR
   ============================================================ */
.progress{
  position:fixed;
  top:0;left:0;
  height:2px;
  width:0%;
  background:var(--deal);
  z-index:2000;
  transition:width .1s linear;
}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:900;
  height:var(--header-h);
  transition:background .35s var(--ease), box-shadow .35s var(--ease);
}
.header.scrolled{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:0 1px 0 var(--rule);
}
.header__inner{
  max-width:1280px;
  margin:0 auto;
  padding:0 var(--s4);
  height:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.header__logo-img{
  height:48px;
  width:auto;
  display:block;
}
.header__nav{
  display:flex;
  align-items:center;
  gap:32px;
}
.header__nav a:not(.nav__cta){
  font-size:13px;
  font-weight:500;
  color:var(--ink-soft);
  transition:color .2s;
  position:relative;
}
.header__nav a:not(.nav__cta)::after{
  content:'';
  position:absolute;
  bottom:-3px;left:0;right:0;
  height:1px;
  background:var(--deal);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .25s var(--ease);
}
.header__nav a:not(.nav__cta):hover{color:var(--ink)}
.header__nav a:not(.nav__cta):hover::after{transform:scaleX(1)}
.nav__cta{
  font-size:12px;
  font-weight:600;
  color:var(--bg) !important;
  background:var(--ink);
  padding:8px 18px;
  border-radius:3px;
  transition:background .2s, transform .15s;
}
.nav__cta:hover{background:var(--deal) !important;transform:translateY(-1px)}
.nav__cta::after{display:none !important}

/* Hamburger */
.hamburger{
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:6px;
  padding:8px;
  z-index:1001;
  width:40px;height:40px;
}
.hamburger span{
  display:block;
  width:22px;height:1.5px;
  background:var(--ink);
  border-radius:2px;
  transition:transform .3s var(--ease), opacity .2s;
  transform-origin:center;
}
/* メニューが開いているとき: ヘッダーが透明なのでspanを白に */
.nav-overlay.open ~ .header .hamburger span,
.hamburger.active span{
  background:var(--bg);
}

/* Mobile nav overlay */
.nav-overlay{
  position:fixed;
  inset:0;
  background:var(--ink);
  z-index:800;
  display:flex;
  flex-direction:column;
  padding:calc(var(--header-h) + 8px) var(--s4) var(--s4);
  opacity:0;
  pointer-events:none;
  visibility:hidden;
  transition:opacity .3s var(--ease), visibility .3s;
}
.nav-overlay.open{
  opacity:1;
  pointer-events:auto;
  visibility:visible;
}
.nav-overlay__nav{
  display:flex;
  flex-direction:column;
  justify-content:center;
  flex:1;
  gap:0;
}
.nav-overlay__nav a{
  display:flex;
  align-items:center;
  gap:14px;
  font-size:clamp(20px,5vw,32px);
  font-weight:700;
  color:var(--bg);
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.07);
  letter-spacing:-.01em;
  transition:color .15s, padding-left .2s var(--ease);
}
.nav-overlay__nav a::before{
  content:attr(data-num);
  font-family:var(--en);
  font-size:9px;
  font-weight:700;
  letter-spacing:.2em;
  color:var(--deal);
  min-width:20px;
}
.nav-overlay__nav a:hover{
  color:rgba(255,255,255,.5);
  padding-left:6px;
}
.nav-overlay__meta{
  padding-top:var(--s3);
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.nav-overlay__meta a{
  font-family:var(--en);
  font-size:12px;
  font-weight:500;
  letter-spacing:.06em;
  color:rgba(255,255,255,.52);
  transition:color .2s;
}
.nav-overlay__meta a:hover{color:rgba(255,255,255,.7)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100svh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:calc(var(--header-h) + var(--s5)) var(--s4) var(--s5);
  max-width:1280px;
  margin:0 auto;
  position:relative;
  overflow:hidden;
}
.hero__inner{position:relative;z-index:1}
.hero__eyebrow{
  display:flex;
  align-items:center;
  gap:var(--s2);
  margin-bottom:var(--s4);
}
.hero__ey-line{
  display:block;
  width:32px;height:1px;
  background:var(--ink-xsoft);
}
.hero__eyebrow span:last-child{
  font-family:var(--en);
  font-size:11px;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-xsoft);
}
.hero__title{
  font-size:clamp(48px,6vw,108px);
  font-weight:800;
  line-height:1.06;
  letter-spacing:-.04em;
  color:var(--ink);
  margin-bottom:var(--s5);
}
.hero__title em{
  font-style:normal;
  color:var(--deal);
}
.hero__meta{
  display:flex;
  align-items:flex-end;
  gap:var(--s5);
}
.hero__sub{
  font-family:var(--en);
  font-size:15px;
  color:var(--ink-soft);
  line-height:1.75;
}
.hero__actions{
  display:flex;
  align-items:center;
  gap:var(--s2);
  flex-shrink:0;
}
.hero__scroll-area{
  position:absolute;
  bottom:var(--s4);
  left:var(--s4);
  z-index:1;
}
.hero__scroll{
  display:flex;
  align-items:center;
  gap:8px;
  font-family:var(--en);
  font-size:10px;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-xsoft);
  transition:color .2s;
}
.hero__scroll:hover{color:var(--ink)}
.hero__bg-text{
  position:absolute;
  right:-20px;
  bottom:-80px;
  font-family:var(--en);
  font-size:clamp(160px,22vw,320px);
  font-weight:900;
  letter-spacing:-.06em;
  color:transparent;
  -webkit-text-stroke:1px var(--rule);
  pointer-events:none;
  user-select:none;
  line-height:1;
  z-index:0;
}

/* ============================================================
   ABOUT
   ============================================================ */
.about__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--s6) var(--s5);
  align-items:start;
}
.about__title{
  font-size:clamp(26px,3.4vw,46px);
  font-weight:700;
  line-height:1.22;
  letter-spacing:-.025em;
  color:var(--ink);
  margin-bottom:var(--s3);
}
.about__en{
  font-family:var(--en);
  font-size:12px;
  color:var(--ink-xsoft);
  line-height:1.7;
  padding-left:12px;
  border-left:2px solid var(--deal);
}
.about__block{
  padding:var(--s2) 0;
  border-bottom:1px solid var(--rule);
}
.about__block:first-child{border-top:1px solid var(--rule)}
.about__block-label{
  font-family:var(--en);
  font-size:11px;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--deal);
  margin-bottom:8px;
}
.about__block-text{
  font-size:15px;
  font-weight:500;
  color:var(--ink);
  line-height:1.65;
}
.about__body{margin-top:var(--s2)}
.about__body p{
  font-size:15px;
  color:var(--ink-soft);
  line-height:1.75;
  margin-bottom:14px;
}
.about__body strong{color:var(--ink);font-weight:600}

/* ============================================================
   NUMBERS
   ============================================================ */
.numbers{
  background:var(--bg-warm);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:var(--s4) var(--s4);
}
.numbers__inner{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;
  gap:0;
  align-items:center;
}
.numbers__divider{
  width:1px;
  height:48px;
  background:var(--rule);
  margin:0 var(--s3);
}
.numbers__item{text-align:center}
.numbers__figure{
  display:flex;
  align-items:baseline;
  justify-content:center;
  gap:3px;
  font-family:var(--en);
  font-size:clamp(36px,4.8vw,60px);
  font-weight:800;
  color:var(--ink);
  letter-spacing:-.04em;
  line-height:1;
  margin-bottom:7px;
}
.numbers__suffix{
  font-size:clamp(18px,2.2vw,30px);
  font-weight:600;
  color:var(--deal);
}
.numbers__desc{
  font-size:13px;
  color:var(--ink-xsoft);
  line-height:1.5;
}

/* ============================================================
   BUSINESS — Phase 01 / 02
   ============================================================ */
.business{padding-bottom:0}

.phase{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:0;
  border-top:1px solid var(--rule);
  padding:var(--s4) 0;
}
.phase:last-of-type{border-bottom:1px solid var(--rule);margin-bottom:0}

.phase__marker{
  padding-right:var(--s3);
  padding-top:4px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.phase__num{
  font-family:var(--en);
  font-size:52px;
  font-weight:900;
  color:var(--rule);
  line-height:1;
  letter-spacing:-.04em;
  display:block;
}
.phase__status{
  display:inline-flex;
  align-items:center;
  width:fit-content;
  font-family:var(--en);
  font-size:12px;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:2px;
  border:1px solid var(--rule);
  background:var(--bg-warm);
  color:var(--ink-soft);
}
.phase__status--live{
  background:var(--deal-bg);
  color:var(--deal);
  border-color:rgba(43,63,223,.18);
}
.phase__status--apex{
  background:rgba(43,63,223,.18);
  color:#6B7FFF;
  border-color:rgba(43,63,223,.3);
}

.phase__content{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:var(--s4) var(--s5);
  padding-left:var(--s4);
  border-left:1px solid var(--rule);
  align-items:start;
}
.phase__en{
  font-family:var(--en);
  font-size:11px;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--deal);
  margin-bottom:14px;
}
.phase__title{
  font-size:clamp(23px,2.8vw,36px);
  font-weight:700;
  line-height:1.18;
  letter-spacing:-.025em;
  color:var(--ink);
  margin-bottom:12px;
}
.phase__url{
  font-family:var(--en);
  font-size:12px;
  font-weight:600;
  letter-spacing:.06em;
  color:var(--deal);
  border-bottom:1px solid rgba(43,63,223,.25);
  padding-bottom:2px;
  transition:all .2s;
  display:inline-block;
}
.phase__url:hover{
  border-color:var(--deal);
  gap:14px;
}
.phase__desc{
  font-size:15px;
  color:var(--ink-soft);
  line-height:1.75;
  margin-bottom:var(--s2);
}
.phase__tags{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.phase__tags li{
  font-size:12px;
  color:var(--ink-soft);
  background:var(--bg-warm);
  border:1px solid var(--rule);
  padding:4px 10px;
  border-radius:2px;
}

/* ── Phase 03 ── */
.phase3{
  background:var(--ink);
  padding:var(--s5) 0 0;
  position:relative;
  overflow:hidden;
}
.phase3::before{
  content:'03';
  position:absolute;
  right:-40px;top:-80px;
  font-family:var(--en);
  font-size:clamp(200px,28vw,380px);
  font-weight:900;
  color:transparent;
  -webkit-text-stroke:1px rgba(255, 255, 255, 0.04);
  line-height:1;
  letter-spacing:-.06em;
  pointer-events:none;
  user-select:none;
}
.phase3 .container{position:relative;z-index:1}
.phase3 .phase__num{color:#f6f6f6}
.phase3 .phase__status{
  border-color:rgba(43,63,223,.35);
}
.phase3__marker{
  display:flex;
  align-items:center;
  gap:var(--s2);
  margin-bottom:var(--s4);
}
.phase3__year{
  font-family:var(--en);
  font-size:12px;
  font-weight:500;
  color:rgba(255,255,255,.42);
  margin-left:auto;
}
.phase3__headline{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--s5) var(--s6);
  padding-bottom:var(--s5);
  border-bottom:1px solid rgba(255,255,255,.07);
  margin-bottom:0;
  align-items:end;
}
.phase3__en{
  font-family:var(--en);
  font-size:11px;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#6B7FFF;
  margin-bottom:var(--s3);
  grid-column:1;
}
.phase3__title{
  font-size:clamp(38px,5.2vw,68px);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-.04em;
  color:var(--bg);
  grid-column:1;
}
.phase3__lead{
  font-size:15px;
  color:rgba(255,255,255,.58);
  line-height:1.85;
  align-self:end;
  grid-column:2;
  grid-row:1/3;
}
.phase3__items{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border-top:1px solid rgba(255,255,255,.07);
}
.phase3__item{
  padding:var(--s4) var(--s3);
  border-right:1px solid rgba(255,255,255,.07);
  transition:background .25s;
}
.phase3__item:last-child{border-right:none}
.phase3__item:hover{background:rgba(255,255,255,.02)}
.phase3__item--apex{
  background:rgba(43,63,223,.12);
}
.phase3__item--apex:hover{background:rgba(43,63,223,.18)}
.phase3__item-en{
  font-family:var(--en);
  font-size:11px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.42);
  margin-bottom:18px;
}
.phase3__item--apex .phase3__item-en{color:#6B7FFF}
.phase3__item-title{
  font-size:clamp(14px,1.6vw,18px);
  font-weight:700;
  line-height:1.3;
  color:var(--bg);
  margin-bottom:10px;
  letter-spacing:-.01em;
}
.phase3__item-desc{
  font-size:14px;
  color:rgba(255,255,255,.72);
  line-height:1.8;
}
.phase3__item--apex .phase3__item-desc{color:rgba(255,255,255,.65)}

/* ============================================================
   VALUES
   ============================================================ */
.values__list{
  border-top:1px solid var(--rule);
}
.values__item{
  display:grid;
  grid-template-columns:60px 1fr;
  gap:var(--s2);
  padding:var(--s3) 0;
  border-bottom:1px solid var(--rule);
  align-items:start;
  transition:background .2s;
}
.values__item:hover{
  background:var(--bg-warm);
  margin:0 calc(-1 * var(--s4));
  padding-left:var(--s4);
  padding-right:var(--s4);
}
.values__num{
  font-family:var(--en);
  font-size:16px;
  font-weight:700;
  letter-spacing:.2em;
  color:var(--deal);
  padding-top:3px;
}
.values__name{
  font-size:18px;
  font-weight:700;
  color:var(--ink);
  margin-bottom:8px;
  letter-spacing:-.01em;
}
.values__desc{
  font-size:15px;
  color:var(--ink-soft);
  line-height:1.75;
  max-width:580px;
}

/* ============================================================
   COMPANY
   ============================================================ */
.company__wrap{max-width:720px}
.company__table{
  width:100%;
  border-collapse:collapse;
}
.company__table tr{border-bottom:1px solid var(--rule)}
.company__table tr:first-child{border-top:1px solid var(--rule)}
.company__table th{
  width:160px;
  padding:16px 0;
  font-size:13px;
  font-weight:600;
  color:var(--ink-soft);
  text-align:left;
  vertical-align:top;
  padding-right:var(--s2);
}
.company__table td{
  padding:16px 0;
  font-size:15px;
  color:var(--ink);
}
.table__link{
  color:var(--deal);
  border-bottom:1px solid rgba(43,63,223,.2);
  padding-bottom:1px;
  transition:border-color .2s;
}
.table__link:hover{border-color:var(--deal)}

/* ============================================================
   NEWS
   ============================================================ */
.news__list{
  list-style:none;
  border-top:1px solid var(--rule);
}
.news__item{
  display:flex;
  align-items:baseline;
  gap:var(--s2);
  padding:16px 0;
  border-bottom:1px solid var(--rule);
  transition:all .2s;
}
.news__item:hover{
  background:var(--bg-warm);
  margin:0 calc(-1 * var(--s4));
  padding-left:var(--s4);
  padding-right:var(--s4);
}
.news__date{
  font-family:var(--en);
  font-size:13px;
  color:var(--ink-xsoft);
  white-space:nowrap;
  min-width:60px;
  letter-spacing:.04em;
}
.news__cat{
  font-family:var(--en);
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:3px 9px;
  border-radius:2px;
  background:var(--deal-bg);
  color:var(--deal);
  white-space:nowrap;
}
.news__title{
  font-size:15px;
  color:var(--ink);
  cursor:pointer;
  transition:color .2s;
}
.news__item--clickable:hover .news__title{color:var(--deal)}
.news__item--loading .news__title{color:var(--ink-xsoft)}

/* News detail modal */
.news-modal{
  position:fixed;inset:0;
  z-index:800;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:var(--s4);
}
.news-modal[hidden]{display:none}

.news-modal__overlay{
  position:absolute;inset:0;
  background:rgba(6,6,10,.55);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  animation:nmFade .2s ease;
}
@keyframes nmFade{from{opacity:0}to{opacity:1}}

.news-modal__panel{
  position:relative;
  z-index:1;
  background:var(--bg);
  width:100%;
  max-width:600px;
  max-height:80vh;
  overflow-y:auto;
  border-radius:12px;
  box-shadow:0 24px 64px rgba(6,6,10,.25);
  animation:nmUp .28s var(--ease);
}
@keyframes nmUp{from{transform:translateY(16px);opacity:0}to{transform:none;opacity:1}}

/* 閉じるボタン */
.news-modal__close{
  position:sticky;
  top:0;
  float:right;
  display:flex;
  align-items:center;
  justify-content:center;
  width:36px;height:36px;
  margin:16px 16px 0 0;
  border-radius:50%;
  color:var(--ink-soft);
  background:var(--bg);
  border:1px solid var(--rule);
  transition:color .15s, background .15s, border-color .15s;
  flex-shrink:0;
  z-index:2;
}
.news-modal__close:hover{
  color:var(--ink);
  background:var(--bg-warm);
  border-color:var(--ink-mid);
}

/* パネル内コンテンツ */
.news-modal__content{
  padding:0 var(--s4) var(--s4);
  clear:both;
}
.news-modal__meta{
  display:flex;
  align-items:center;
  gap:var(--s1);
  margin-bottom:var(--s2);
}
.news-modal__title{
  font-size:clamp(18px,2.5vw,22px);
  font-weight:700;
  line-height:1.35;
  letter-spacing:-.01em;
  color:var(--ink);
  margin-bottom:var(--s3);
  padding-bottom:var(--s3);
  border-bottom:1px solid var(--rule);
}
.news-modal__body{
  font-size:14px;
  color:var(--ink-mid);
  line-height:1.9;
  white-space:pre-wrap;
}

@media(max-width:600px){
  .news-modal{padding:0;align-items:flex-end}
  .news-modal__panel{
    border-radius:16px 16px 0 0;
    max-height:85vh;
    max-width:100%;
  }
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact__split{
  display:grid;
  grid-template-columns:320px 1fr;
  gap:var(--s6);
  align-items:start;
}
.contact__title{
  font-size:clamp(26px,3vw,40px);
  font-weight:700;
  letter-spacing:-.02em;
  margin-bottom:var(--s2);
}
.contact__desc{
  font-size:15px;
  color:var(--ink-soft);
  line-height:1.75;
}

/* Form */
.contact__form{display:flex;flex-direction:column;gap:var(--s3)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3)}
.form__field{display:flex;flex-direction:column;gap:8px}
.form__field label{
  font-size:12px;
  font-weight:600;
  color:var(--ink);
  letter-spacing:.02em;
}
.req{color:var(--deal);margin-left:2px}
.form__field input,
.form__field select,
.form__field textarea{
  width:100%;
  padding:12px 16px;
  background:var(--bg-warm);
  border:1px solid var(--rule);
  border-radius:3px;
  font-family:var(--ja);
  font-size:14px;
  color:var(--ink);
  outline:none;
  transition:border-color .2s, box-shadow .2s;
  -webkit-appearance:none;
}
.form__field input::placeholder,
.form__field textarea::placeholder{color:var(--ink-xsoft)}
.form__field input:focus,
.form__field select:focus,
.form__field textarea:focus{
  border-color:var(--deal);
  box-shadow:0 0 0 3px rgba(43,63,223,.1);
  background:var(--bg);
}
.form__select-wrap{position:relative}
.form__select-wrap select{padding-right:40px;cursor:pointer}
.form__select-wrap select option{background:var(--bg);color:var(--ink)}
.form__select-wrap svg{
  position:absolute;
  right:14px;top:50%;
  transform:translateY(-50%);
  pointer-events:none;
  color:var(--ink-soft);
}
.form__field textarea{min-height:140px;resize:vertical;line-height:1.7}
.form__check label{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:13px;
  color:var(--ink-soft);
  cursor:pointer;
  line-height:1.6;
}
.form__check input[type="checkbox"]{
  accent-color:var(--deal);
  width:16px;height:16px;
  margin-top:2px;
  flex-shrink:0;
}
.form__check a{
  color:var(--deal);
  border-bottom:1px solid rgba(43,63,223,.25);
  padding-bottom:1px;
  transition:border-color .2s;
}
.form__check a:hover{border-color:var(--deal)}
.form__submit{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--ink);
  color:var(--bg);
  padding:12px 28px;
  border-radius:3px;
  font-size:13px;
  font-weight:600;
  font-family:var(--ja);
  align-self:flex-start;
  transition:background .2s, transform .15s, gap .2s;
}
.form__submit:hover{
  background:var(--deal);
  transform:translateY(-1px);
  gap:14px;
}
.form__submit:disabled{opacity:.55;cursor:not-allowed;transform:none}
.form__msg{
  font-size:13px;
  min-height:20px;
}
.form__msg.ok{color:#1A7F5A}
.form__msg.err{color:#C03B3B}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--ink);
  padding:var(--s5) 0 var(--s3);
}
.footer__inner{
  max-width:1280px;
  margin:0 auto;
  padding:0 var(--s4);
}
.footer__top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:var(--s5);
  padding-bottom:var(--s4);
  border-bottom:1px solid rgba(255,255,255,.07);
  margin-bottom:var(--s3);
}
.footer__logo{height:22px;width:auto}
.footer__tagline{
  margin-top:10px;
  font-size:13px;
  color:rgba(255,255,255,.48);
  line-height:1.6;
}
.footer__nav{display:flex;gap:var(--s4)}
.footer__col{display:flex;flex-direction:column;gap:12px}
.footer__col-head{
  font-family:var(--en);
  font-size:11px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.42);
  margin-bottom:4px;
}
.footer__col a{
  font-size:13px;
  color:rgba(255,255,255,.6);
  transition:color .2s;
}
.footer__col a:hover{color:var(--bg)}
.footer__bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.footer__bottom small{
  font-size:12px;
  color:rgba(255,255,255,.4);
}
.footer__x{
  display:flex;
  align-items:center;
  color:rgba(255,255,255,.2);
  transition:color .2s;
}
.footer__x:hover{color:var(--bg)}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
[data-reveal]{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .75s var(--ease), transform .75s var(--ease);
}
[data-reveal].in{
  opacity:1;
  transform:none;
}
[data-reveal][data-delay="1"]{transition-delay:.1s}
[data-reveal][data-delay="2"]{transition-delay:.2s}
[data-reveal][data-delay="3"]{transition-delay:.3s}
[data-reveal][data-delay="4"]{transition-delay:.4s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .about__grid{grid-template-columns:1fr;gap:var(--s4)}
  .numbers__inner{grid-template-columns:1fr 1fr;gap:var(--s3)}
  .numbers__divider{display:none}
  .numbers__item{
    padding:var(--s3);
    border-bottom:1px solid var(--rule);
  }
  .phase{grid-template-columns:1fr;gap:var(--s3)}
  .phase__marker{flex-direction:row;align-items:center;gap:var(--s2)}
  .phase__num{font-size:40px}
  .phase__content{
    grid-template-columns:1fr;
    padding-left:0;
    border-left:none;
    border-top:1px solid var(--rule);
    padding-top:var(--s3);
  }
  .phase3__headline{grid-template-columns:1fr;gap:var(--s3)}
  .phase3__lead{grid-column:1;grid-row:auto}
  .phase3__items{grid-template-columns:1fr 1fr}
  .contact__split{grid-template-columns:1fr}
  .footer__top{flex-direction:column;gap:var(--s4)}
}

@media(max-width:768px){
  :root{--s7:80px}
  .container{padding:0 var(--s3)}
  .header__inner{padding:0 var(--s3)}

  .header__nav{display:none}
  .hamburger{display:flex}

  .hero{padding:calc(var(--header-h) + var(--s4)) var(--s3) var(--s6)}
  .hero__meta{flex-direction:column;align-items:flex-start;gap:var(--s3)}
  .hero__bg-text{display:none}
  .hero__scroll-area{display:none}

  .phase3__items{grid-template-columns:1fr}
  .phase3__item{border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}
  .phase3::before{display:none}

  .form__row{grid-template-columns:1fr}
  .footer__nav{gap:var(--s3);flex-wrap:wrap}
  .footer__bottom{flex-direction:column;gap:var(--s2);text-align:center}
  .company__table th{width:100px;font-size:12px}
  .news__item{flex-wrap:wrap;gap:8px}
  .values__item{grid-template-columns:1fr}
  .values__num{font-size:10px}
}
