/* ===== RESET & BASE ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --grad: linear-gradient(to top, #f43b47 0%, #453a94 100%);
  --grad-h: linear-gradient(to bottom, #f43b47 0%, #453a94 100%);
  --black: #0a0a0a;
  --gray-900: #111;
  --gray-700: #333;
  --gray-500: #666;
  --gray-200: #e8e8e8;
  --gray-100: #f5f5f5;
  --white: #fff;
  --max: 1100px;
  --font-en: 'Noto Sans JP', sans-serif;
  --font-ja: 'Noto Sans JP', sans-serif;
  --font-mono: 'Barlow', sans-serif;
  --font-display: 'Barlow', sans-serif;
}

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-en);
  background: var(--white);
  color: var(--black);
  font-size: 15px;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: .1em;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "palt";
  overflow-x: hidden;
}

/* ===== UTILITY ===== */
.container {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 32px;
}

.grad-text {
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.fade-in {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1), transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.fade-in.visible {
  opacity: 1;
  transform: none;
}
.fade-in.delay-1 { transition-delay: 0.1s; }
.fade-in.delay-2 { transition-delay: 0.2s; }
.fade-in.delay-3 { transition-delay: 0.3s; }
.fade-in.delay-4 { transition-delay: 0.4s; }

/* ===== NAV ===== */

/* ===== HERO ===== */
#hero {
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  border-bottom: 1px solid var(--gray-200);
  position: relative;
  overflow: hidden;
}
#hero .container { margin: 0; padding-bottom: 48px; }
.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(228,228,228,.45) 1px,transparent 1px),linear-gradient(90deg,rgba(228,228,228,.45) 1px,transparent 1px);background-size:calc(100%/12) 80px;pointer-events:none}
.hero-signal{position:absolute;right:80px;top:0;bottom:0;width:1px;background:rgba(200,200,200,.35);overflow:hidden}
.hero-signal::after{content:'';position:absolute;top:-30%;left:0;width:1px;height:30%;background:var(--grad);animation:sigSlide 2.8s ease-in-out 1.8s infinite}
@keyframes sigSlide{0%{top:-30%;opacity:0}20%{opacity:1}80%{opacity:1}100%{top:100%;opacity:0}}
.hero-coord{position:absolute;bottom:40px;right:32px;font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;color:var(--gray-500);writing-mode:vertical-rl;opacity:0;animation:cdFade 1s ease 2s forwards}
@keyframes cdFade{to{opacity:1}}

.hero-eyebrow {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.22em;
  color: var(--gray-500);
  text-transform: uppercase;
  margin-bottom: 32px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.hero-eyebrow::before { content: ''; width: 14px; height: 1px; background: var(--grad); flex-shrink: 0; }

.hero-headline {
  font-family: var(--font-display);
  font-size: clamp(40px, 7.5vw, 96px);
  line-height: 0.88;
  letter-spacing: -0.03em;
  color: var(--black);
  margin-bottom: 16px;
}

.hero-sub {
  font-family: var(--font-ja);
  font-size: clamp(12px, 1.5vw, 14px);
  font-weight: 300;
  color: var(--gray-500);
  letter-spacing: 0.1em;
  margin-bottom: 80px;
}

/* MVV */
.mvv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--gray-200);
  border: 1px solid var(--gray-200);
  margin-bottom: 80px;
}

.mvv-item {
  background: var(--white);
  padding: 40px 32px;
}

.mvv-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.25em;
  color: var(--gray-500);
  margin-bottom: 16px;
}

.mvv-heading {
  font-family: var(--font-ja);
  font-size: clamp(13px, 1.4vw, 16px);
  font-weight: 700;
  line-height: 1.5;
  color: var(--black);
  margin-bottom: 16px;
}

.mvv-body {
  font-family: var(--font-ja);
  font-size: 13px;
  font-weight: 300;
  color: var(--gray-500);
  line-height: 1.9;
}

/* STATS */
.stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  margin-bottom: 64px;
}

.stat-item { }

.stat-num {
  font-family: var(--font-display);
  font-size: clamp(24px, 3.2vw, 44px);
  line-height: 1;
  margin-bottom: 8px;
}

.stat-label {
  font-family: var(--font-ja);
  font-size: 12px;
  font-weight: 300;
  color: var(--gray-500);
  letter-spacing: 0.05em;
}

/* GRAD LINE */
.grad-line {
  width: 48px;
  height: 2px;
  background: var(--grad);
  margin: 16px 0;
}

/* HERO CTA */
.hero-cta-area {
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
}

.btn-primary {
  display: inline-block;
  font-family: var(--font-en);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--white);
  background: var(--grad);
  padding: 18px 48px;
  text-decoration: none;
  border: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: opacity 0.3s;
}
.btn-primary::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--grad-h);
  opacity: 0;
  transition: opacity 0.4s;
}
.btn-primary:hover::after { opacity: 1; }
.btn-primary span { position: relative; z-index: 1; }

.hero-note {
  font-family: var(--font-ja);
  font-size: 12px;
  font-weight: 300;
  color: var(--gray-500);
}

/* ===== NEWS ===== */
#news {
  padding: 120px 0;
  border-bottom: 1px solid var(--gray-200);
}

.section-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.25em;
  color: var(--gray-500);
  text-transform: uppercase;
  margin-bottom: 48px;
  display: flex;
  align-items: center;
  gap: 16px;
}
.section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--gray-200);
}

.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.news-card {
  border: 1px solid var(--gray-200);
  padding: 32px;
  text-decoration: none;
  color: inherit;
  display: block;
  transition: transform 0.3s cubic-bezier(0.16,1,0.3,1), box-shadow 0.3s;
  background: var(--white);
}
.news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.06);
}

.news-date {
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--gray-500);
  margin-bottom: 12px;
}

.news-title {
  font-family: var(--font-ja);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.6;
  color: var(--black);
  margin-bottom: 12px;
}

.news-desc {
  font-family: var(--font-ja);
  font-size: 12px;
  font-weight: 300;
  color: var(--gray-500);
  line-height: 1.8;
}

/* ===== BUSINESS ===== */
#business {
  padding: 120px 0;
  border-bottom: 1px solid var(--gray-200);
}

.business-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--gray-200);
  border: 1px solid var(--gray-200);
  margin-top: 48px;
}

.biz-item {
  background: var(--white);
  padding: 48px 40px;
}

.biz-num {
  font-family: var(--font-display);
  font-size: 28px;
  color: var(--gray-200);
  line-height: 1;
  margin-bottom: 24px;
}

.biz-title {
  font-family: var(--font-ja);
  font-size: 18px;
  font-weight: 700;
  color: var(--black);
  margin-bottom: 16px;
}

.biz-body {
  font-family: var(--font-ja);
  font-size: 13px;
  font-weight: 300;
  color: var(--gray-500);
  line-height: 2;
}

.biz-detail {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--gray-200);
}

.biz-detail-title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: var(--gray-500);
  margin-bottom: 12px;
}

.biz-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.biz-tag {
  font-family: var(--font-en);
  font-size: 11px;
  padding: 4px 12px;
  border: 1px solid var(--gray-200);
  color: var(--gray-700);
  letter-spacing: 0.05em;
}

/* ===== FOOTER ===== */


/* ===== SECTION HEADLINE ===== */
.section-headline {
  font-family: var(--font-display);
  font-size: clamp(20px, 3vw, 34px);
  line-height: 0.95;
  letter-spacing: 0.02em;
  color: var(--black);
  margin-bottom: 16px;
}

/* ===== MOBILE ===== */
@media (max-width: 768px) {
  .container { padding: 0 20px; }

  .mvv-grid { grid-template-columns: 1fr; }
  .stats-row { grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .news-grid { grid-template-columns: 1fr; }
  .business-grid { grid-template-columns: 1fr; }

  #hero { padding-top: 100px; }
  .hero-cta-area { flex-direction: column; align-items: flex-start; }
}


}

/* ===== SES REALITY ===== */
#ses{padding:120px 0;border-bottom:1px solid var(--gray-200);background:var(--gray-100)}
.ses-list{margin-top:48px;display:flex;flex-direction:column;gap:1px;background:var(--gray-200);border:1px solid var(--gray-200)}
.ses-row{background:var(--white);padding:40px;display:grid;grid-template-columns:48px 1fr 1fr;gap:40px;align-items:start}
.ses-num{font-family:var(--font-display);font-size:24px;color:var(--gray-200);line-height:1.3}
.ses-stmt{font-family:var(--font-ja);font-size:15px;font-weight:700;color:var(--black);line-height:1.7}
.ses-note-t{font-family:var(--font-ja);font-size:13px;font-weight:300;color:var(--gray-500);line-height:2}

.promise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);margin-top:48px;margin-bottom:40px}
.promise-card{background:var(--white);padding:40px 32px}
.promise-num{font-family:var(--font-display);font-size:28px;color:var(--gray-200);line-height:1;margin-bottom:16px}
.promise-title{font-family:var(--font-ja);font-size:15px;font-weight:700;color:var(--black);margin-bottom:12px}
.promise-body{font-family:var(--font-ja);font-size:13px;font-weight:300;color:var(--gray-500);line-height:2}
.promise-declaration{border:1px solid var(--gray-200);padding:40px 48px;background:var(--white)}
.decl-text{font-family:var(--font-ja);font-size:14px;font-weight:300;color:var(--gray-500);line-height:2;margin-bottom:24px}
.decl-sign{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--black)}
.commitment-sub-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--gray-500);margin-top:80px;margin-bottom:8px}
.commitment-sub-desc{font-family:var(--font-ja);font-size:14px;font-weight:300;color:var(--gray-500);line-height:2;max-width:640px;margin-bottom:0}

@media(max-width:768px){
  .val-grid,.ses-list{grid-template-columns:1fr}
  .ses-row{grid-template-columns:1fr;gap:16px}.ses-num{display:none}
  .promise-grid{grid-template-columns:1fr}
  .promise-declaration{padding:32px 20px}
}

/* ===== DAY IN LIFE ===== */
#day-in-life{padding:120px 0;border-bottom:1px solid var(--gray-200);background:var(--gray-100)}
.day-cols{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);margin-top:64px}
.day-col{background:var(--white);padding:48px 40px}
.day-col-head{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gray-500);margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--gray-200)}
.day-col-head span{display:block;font-family:var(--font-ja);font-size:13px;font-weight:700;color:var(--black);margin-top:8px;letter-spacing:.02em}
.day-timeline{display:flex;flex-direction:column;gap:0}
.day-slot{display:grid;grid-template-columns:64px 1fr;gap:0;position:relative}
.day-slot::before{content:'';position:absolute;left:28px;top:32px;bottom:0;width:1px;background:var(--gray-200)}
.day-slot:last-child::before{display:none}
.day-time{padding:20px 0;font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;color:var(--gray-500);line-height:1.4;padding-top:22px}
.day-content{padding:16px 0 16px 24px;border-left:none;position:relative}
.day-dot{position:absolute;left:-4px;top:24px;width:8px;height:8px;border-radius:50%;background:var(--gray-200);border:1.5px solid var(--white)}
.day-slot.active .day-dot{background:var(--grad)}
.day-slot.highlight .day-dot{background:var(--grad)}
.day-title{font-family:var(--font-ja);font-size:13px;font-weight:700;color:var(--black);margin-bottom:4px;line-height:1.4}
.day-desc{font-family:var(--font-ja);font-size:12px;font-weight:300;color:var(--gray-500);line-height:1.8}
.day-badge{display:inline-block;font-family:var(--font-mono);font-size:8px;letter-spacing:.1em;padding:2px 8px;border:1px solid;margin-bottom:6px}
.day-badge-red{border-color:rgba(244,59,71,.4);color:#f43b47}
.day-badge-gray{border-color:var(--gray-200);color:var(--gray-500)}
@media(max-width:768px){.day-cols{grid-template-columns:1fr}}

/* ===== PAGE TABS ===== */
#page-tabs{position:sticky;top:61px;z-index:90;background:var(--white);border-bottom:1px solid var(--gray-200)}
.page-tab-bar{display:flex;max-width:var(--max);margin:0 auto;padding:0 32px}
.page-tab{font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;padding:16px 24px;text-decoration:none;color:var(--gray-500);border-bottom:2px solid transparent;transition:color .2s,border-color .2s;margin-bottom:-1px}
.page-tab:hover{color:var(--black)}
.page-tab.active{color:var(--black);border-bottom-color:#f43b47}

/* ===== MOBILE NAV ===== */

/* ===== RECRUIT FAQ ===== */
#proof{padding:100px 0;border-bottom:1px solid var(--gray-200)}
.proof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);margin-top:56px}
.proof-item{background:var(--white);padding:40px 32px}
.proof-num{font-family:var(--font-display);font-size:clamp(28px,3.5vw,48px);font-weight:300;line-height:1.1;letter-spacing:-.02em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.proof-label{font-family:var(--font-ja);font-size:12px;font-weight:500;color:var(--black);margin-top:14px;line-height:1.7}
.proof-desc{font-size:11px;color:var(--gray-500);font-weight:300;margin-top:8px;line-height:1.9}
.proof-footnote{margin-top:32px;font-family:var(--font-mono);font-size:10px;color:var(--gray-500);letter-spacing:.12em}
@media(max-width:768px){.proof-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){
  .proof-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .promise-grid{grid-template-columns:1fr}
  .sel-steps{grid-template-columns:1fr}
  .day-cols{grid-template-columns:1fr}
  .rec-faq-q{padding:20px 16px}
  .rec-faq-a-inner{padding:0 16px 20px}
  .cta-body{padding:0 20px}
  .promise-declaration{padding:24px 16px}
}
#rec-faq{padding:120px 0;border-bottom:1px solid var(--gray-200);background:var(--gray-100)}
.rec-faq-intro{font-family:var(--font-ja);font-size:14px;font-weight:300;color:var(--gray-500);line-height:2.1;max-width:600px;margin-top:20px;margin-bottom:64px}
.rec-faq-list{border:1px solid var(--gray-200);background:var(--white)}
.rec-faq-item{border-bottom:1px solid var(--gray-200)}
.rec-faq-item:last-child{border-bottom:none}
.rec-faq-q{width:100%;background:none;border:none;cursor:pointer;padding:28px 40px;display:flex;align-items:center;justify-content:space-between;gap:24px;text-align:left}
.rec-faq-q-text{font-family:var(--font-ja);font-size:15px;font-weight:700;color:var(--black);line-height:1.6}
.rec-faq-icon{width:28px;height:28px;border:1px solid var(--gray-200);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .2s;position:relative}
.rec-faq-icon::before,.rec-faq-icon::after{content:'';position:absolute;background:var(--gray-500);transition:transform .3s,opacity .3s}
.rec-faq-icon::before{width:12px;height:1px}
.rec-faq-icon::after{width:1px;height:12px}
.rec-faq-item.open .rec-faq-icon::after{transform:rotate(90deg);opacity:0}
.rec-faq-item.open .rec-faq-icon{background:var(--black);border-color:var(--black)}
.rec-faq-item.open .rec-faq-icon::before,.rec-faq-item.open .rec-faq-icon::after{background:var(--white)}
.rec-faq-a{overflow:hidden;max-height:0;transition:max-height .4s cubic-bezier(.16,1,.3,1)}
.rec-faq-a-inner{padding:0 40px 32px;border-top:1px solid var(--gray-200)}
.rec-faq-a-inner p{font-family:var(--font-ja);font-size:13px;font-weight:300;color:var(--gray-500);line-height:2.2;padding-top:24px}
.rec-faq-a-inner strong{color:var(--black);font-weight:700}
@media(max-width:768px){.rec-faq-q{padding:24px 24px}.rec-faq-a-inner{padding:0 24px 24px}}

/* ===== SELECTION FLOW ===== */
#sel-flow{padding:120px 0;border-bottom:1px solid var(--gray-200)}
.sel-flow-intro{font-family:var(--font-ja);font-size:14px;font-weight:300;color:var(--gray-500);line-height:2.1;max-width:600px;margin-top:20px;margin-bottom:72px}
.sel-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);margin-bottom:40px}
.sel-step{background:var(--white);padding:48px 32px;position:relative}
.sel-step:not(:last-child)::after{content:'→';position:absolute;right:-14px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:14px;color:var(--gray-200);z-index:1;background:var(--white);padding:4px 0}
.sel-step-num{font-family:var(--font-display);font-size:36px;font-weight:700;color:var(--gray-200);line-height:1;margin-bottom:20px}
.sel-step-title{font-family:var(--font-ja);font-size:15px;font-weight:700;color:var(--black);margin-bottom:12px;line-height:1.4}
.sel-step-body{font-family:var(--font-ja);font-size:12px;font-weight:300;color:var(--gray-500);line-height:1.9;margin-bottom:16px}
.sel-step-badge{display:inline-block;font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;padding:4px 10px;border:1px solid var(--gray-200);color:var(--gray-500)}
.sel-note{border:1px solid var(--gray-200);padding:28px 40px;background:var(--gray-100);font-family:var(--font-ja);font-size:13px;font-weight:300;color:var(--gray-500);line-height:2}
.sel-note strong{color:var(--black);font-weight:700}
@media(max-width:960px){.sel-steps{grid-template-columns:1fr 1fr}.sel-step::after{display:none}}
@media(max-width:480px){.sel-steps{grid-template-columns:1fr}}

/* ===== TRAJECTORY CHART ===== */
#trajectory{padding:160px 0;border-top:1px solid var(--gray-200);position:relative}
.traj-header{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;margin-bottom:80px}
.traj-title{font-family:var(--font-ja);font-size:clamp(28px,4vw,56px);font-weight:700;line-height:1.15;letter-spacing:.02em}
.traj-phase-bar{display:flex;padding:10px 48px 0;font-family:var(--font-mono);font-size:8px;letter-spacing:.12em;color:var(--gray-400)}
.tpb-train{width:20%;text-align:center;border-top:1px solid rgba(0,0,0,.1);padding-top:6px}
.tpb-dispatch{flex:1;padding-top:6px;padding-left:8px;border-top:1px solid rgba(0,0,0,.04)}
.traj-desc{font-size:12px;color:var(--gray-500);line-height:2.1;padding-bottom:4px}
#traj-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-display);font-size:clamp(52px,11vw,175px);letter-spacing:-.02em;color:transparent;-webkit-text-stroke:1px rgba(238,238,238,1);pointer-events:none;z-index:0;white-space:nowrap;transition:opacity .4s ease,-webkit-text-stroke-color .4s ease;opacity:0;user-select:none}
#traj-watermark.show{opacity:1}
.lanes{display:flex;gap:24px;margin-bottom:40px;position:relative;z-index:1}
.lane-btn{font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;padding:8px 16px;border:1px solid var(--gray-200);background:none;cursor:pointer;color:var(--gray-500);transition:all .25s}
.lane-btn.active{border-color:var(--black);color:var(--black)}
.chart-wrap{position:relative;border:1px solid var(--gray-200);padding:48px 48px 56px;overflow:hidden;background:var(--white);z-index:1}
.chart-bg-lines{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:48px 48px 56px;pointer-events:none}
.chart-bg-line{width:100%;height:1px;background:var(--gray-200);display:flex;align-items:center}
.chart-bg-val{font-family:var(--font-mono);font-size:9px;color:var(--gray-400);letter-spacing:.05em;white-space:nowrap}
#main-svg{width:100%;height:380px;display:block}
.chart-months{display:flex;justify-content:space-between;padding:0 48px;margin-top:16px}
.chart-month{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;color:var(--gray-400);text-align:center}
#traj-tooltip{position:absolute;background:var(--black);color:var(--white);padding:12px 16px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;pointer-events:none;opacity:0;transition:opacity .2s;z-index:10;white-space:nowrap}
.traj-legend{display:flex;gap:40px;margin-top:32px;position:relative;z-index:1}
.legend-item{display:flex;align-items:center;gap:12px;cursor:pointer;transition:opacity .3s}
.legend-item.dimmed{opacity:.2}
.legend-dot{width:24px;height:1px;position:relative}
.legend-dot::after{content:'';position:absolute;top:-2px;right:0;width:5px;height:5px;border-radius:50%;background:currentColor}
.legend-name{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-500)}
.legend-peak{font-family:var(--font-mono);font-size:12px;letter-spacing:-.01em;margin-left:4px}
@media(max-width:960px){.traj-header{grid-template-columns:1fr;gap:32px}}

/* ===== PATH DETAILS ===== */
#paths{padding:160px 0;border-top:1px solid var(--gray-200)}
.paths-header{margin-bottom:100px}
.paths-title{font-family:var(--font-display);font-size:clamp(28px,3.5vw,48px);line-height:.92;margin-bottom:32px}
.paths-sub{font-size:12px;color:var(--gray-500);max-width:480px;line-height:2}
.path-card{border:1px solid var(--gray-200);margin-bottom:1px;position:relative;overflow:hidden;transition:border-color .3s}
.path-card:hover{border-color:#999}
.path-card-inner{display:grid;grid-template-columns:280px 1fr 280px;gap:0}
.path-meta{padding:52px 48px;border-right:1px solid var(--gray-200)}
.path-num{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;color:var(--gray-400);margin-bottom:24px}
.path-name{font-family:var(--font-display);font-size:24px;line-height:1;letter-spacing:.05em;margin-bottom:16px}
.path-tagline{font-size:11px;color:var(--gray-500);line-height:1.8}
.path-duration{margin-top:32px;font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--gray-400)}
.path-duration strong{display:block;font-family:var(--font-display);font-size:28px;letter-spacing:.02em;color:var(--black);font-weight:400;margin-top:4px}
.path-circuit{padding:52px 40px;border-right:1px solid var(--gray-200);position:relative}
.circuit-title{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--gray-400);margin-bottom:36px}
.circuit-phases{display:flex;flex-direction:column;gap:0}
.phase-row{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid var(--gray-200)}
.phase-row:last-child{border-bottom:none}
.phase-node{width:10px;height:10px;border:1px solid var(--gray-400);flex-shrink:0;position:relative}
.phase-node.complete{background:var(--black);border-color:var(--black)}
.phase-node.active-node{border-color:transparent}
.phase-node.active-node::before{content:'';position:absolute;inset:-3px;border:1px solid;border-image:linear-gradient(135deg,#f43b47,#453a94) 1}
.phase-node.active-node::after{content:'';position:absolute;inset:1px;background:var(--grad);animation:nodePulse 1.8s ease-in-out infinite}
@keyframes nodePulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}
.phase-vline{position:absolute;left:calc(52px + 16px + 4px);top:0;bottom:0;width:1px;background:var(--gray-200);pointer-events:none}
.phase-label{font-size:12px;font-weight:500;letter-spacing:.02em;flex:1}
.phase-period{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;color:var(--gray-400);white-space:nowrap}
.path-income{padding:52px 40px}
.income-title{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--gray-400);margin-bottom:36px}
.income-stack{display:flex;flex-direction:column;gap:20px}
.income-row{display:flex;align-items:baseline;justify-content:space-between;padding-bottom:20px;border-bottom:1px solid var(--gray-200)}
.income-row:last-child{border-bottom:none;padding-bottom:0}
.income-phase-name{font-size:11px;color:var(--gray-500);letter-spacing:.02em}
.income-val{font-family:var(--font-mono);font-size:16px;letter-spacing:-.02em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.income-peak{margin-top:48px;padding-top:32px;border-top:1px solid var(--gray-200)}
.income-peak-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--gray-400);margin-bottom:12px}
.income-peak-val{font-family:var(--font-display);font-size:32px;line-height:1;letter-spacing:.02em}
.income-peak-sub{font-size:11px;color:var(--gray-500);margin-top:8px}
.path-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--grad);transform:scaleY(0);transform-origin:top;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.path-card:hover::before{transform:scaleY(1)}
@media(max-width:960px){.path-card-inner{grid-template-columns:1fr}.path-circuit,.path-meta{border-right:none;border-bottom:1px solid var(--gray-200)}}

/* ===== RADAR CHART ===== */
#radar{padding:160px 0;border-top:1px solid var(--gray-200);background:var(--gray-100)}
.radar-header{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;margin-bottom:80px}
.radar-wrap{max-width:660px;margin:0 auto;position:relative}
.radar-legend{display:flex;gap:40px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.rl-item{display:flex;align-items:center;gap:10px}
.rl-swatch{width:28px;height:3px;position:relative}
.rl-swatch::after{content:'';position:absolute;right:0;top:-3px;width:7px;height:7px;border-radius:50%;background:currentColor}
.rl-name{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-500)}
@media(max-width:960px){#radar{padding:100px 0}.radar-header{grid-template-columns:1fr;gap:32px}}

/* ===== RESONANCE ===== */
#resonance{background:var(--black);padding:160px 0;border-bottom:1px solid #111;position:relative;overflow:hidden}
.res-signal{position:absolute;left:50%;top:0;bottom:0;width:1px;background:rgba(255,255,255,.04);pointer-events:none}
.res-eyebrow{font-family:var(--font-mono);font-size:10px;font-weight:400;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.22);margin-bottom:56px;display:flex;align-items:center;gap:14px}
.res-eyebrow::before{content:'';display:block;width:24px;height:1px;background:var(--grad);flex-shrink:0}
.res-headline{font-family:var(--font-display);font-size:clamp(28px,4.5vw,60px);line-height:1.05;letter-spacing:-.02em;color:var(--white);margin-bottom:56px}
.res-headline em{font-style:normal;color:rgba(255,255,255,.28);font-size:.62em;display:block;margin-top:20px;font-family:var(--font-ja);font-weight:300;letter-spacing:.05em;line-height:1.8}
.res-body{font-family:var(--font-ja);font-size:clamp(13px,1.3vw,15px);font-weight:300;color:rgba(255,255,255,.38);line-height:2.8;max-width:560px;margin-bottom:64px}
.res-divider{width:40px;height:1px;background:rgba(255,255,255,.14);margin-bottom:48px}
.res-answer{font-family:var(--font-ja);font-size:clamp(14px,1.4vw,16px);font-weight:400;color:rgba(255,255,255,.7);line-height:2.4;max-width:560px}
.res-answer strong{color:var(--white);font-weight:700}
@media(max-width:768px){#resonance{padding:100px 0}.res-eyebrow{margin-bottom:40px}.res-headline{margin-bottom:40px}.res-body{margin-bottom:48px}}

/* ===== AFTER ONE YEAR ===== */
#after-one-year{padding:160px 0;border-bottom:1px solid var(--gray-200);background:var(--gray-100)}
.aoy-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-top:56px}
.aoy-headline{font-family:var(--font-display);font-size:clamp(24px,3.5vw,48px);line-height:.92;letter-spacing:.02em;color:var(--black);margin-bottom:20px}
.aoy-sub{font-family:var(--font-ja);font-size:13px;font-weight:300;color:var(--gray-500);line-height:2;margin-bottom:40px}
.aoy-markers{display:flex;flex-direction:column;gap:1px;background:var(--gray-200);border:1px solid var(--gray-200)}
.aoy-marker{background:var(--white);padding:20px 28px;display:grid;grid-template-columns:72px 1fr;gap:16px;align-items:center}
.aoy-marker-time{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--gray-500)}
.aoy-marker-text{font-family:var(--font-ja);font-size:14px;font-weight:500;color:var(--black);line-height:1.6}
.aoy-marker.aoy-final{background:var(--grad)}.aoy-marker.aoy-final .aoy-marker-time,.aoy-marker.aoy-final .aoy-marker-text{color:var(--white)}
.aoy-narrative{font-family:var(--font-ja);font-size:14px;font-weight:300;color:var(--gray-500);line-height:3;padding-top:8px}
.aoy-narrative strong{color:var(--black);font-weight:700}
@media(max-width:768px){.aoy-inner{grid-template-columns:1fr;gap:48px}#after-one-year{padding:80px 0}}

/* ===== CLOSING CTA ===== */
#cta{padding:220px 0;text-align:center;position:relative;overflow:hidden}
.cta-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:400px;background:radial-gradient(ellipse,rgba(69,58,148,.05) 0%,transparent 70%);pointer-events:none}
.cta-body{position:relative;z-index:1;max-width:var(--max);margin:0 auto;padding:0 48px}
.cta-kicker{font-family:var(--font-mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--gray-500);margin-bottom:40px}
.cta-title{font-family:var(--font-ja);font-size:clamp(30px,5vw,72px);line-height:1.1;letter-spacing:.02em;margin-bottom:24px}
.cta-sub{font-size:12px;color:var(--gray-500);font-weight:100;letter-spacing:.06em;margin-bottom:72px}
.cta-btn{display:inline-flex;align-items:center;gap:14px;padding:20px 64px;font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;color:#fff;position:relative;overflow:hidden;border:none;cursor:pointer;transition:gap .3s}
.cta-btn:hover{gap:22px}
.cta-btn-bg{position:absolute;inset:0;background:var(--black);transition:opacity .5s}
.cta-btn-g{position:absolute;inset:0;background:var(--grad);opacity:0;transition:opacity .5s cubic-bezier(.16,1,.3,1)}
.cta-btn:hover .cta-btn-g{opacity:1}
.cta-btn:hover .cta-btn-bg{opacity:0}
.cta-btn span{position:relative;z-index:1}
.cta-btn-arr{position:relative;z-index:1;font-size:18px;transition:transform .3s}
.cta-btn:hover .cta-btn-arr{transform:translateX(6px)}
.cta-note{margin-top:40px;font-family:var(--font-mono);font-size:10px;color:var(--gray-500);letter-spacing:.12em}
.cta-sec{display:inline-block;margin-top:24px;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gray-500);text-decoration:none;border-bottom:1px solid var(--gray-200);padding-bottom:2px;transition:color .25s,border-color .25s}
.cta-sec:hover{color:var(--black);border-color:var(--black)}
@media(max-width:768px){#cta{padding:100px 0}.cta-body{padding:0 24px}}
@media(hover:none){.cursor{display:none}}
.cursor{position:fixed;width:5px;height:5px;border-radius:50%;background:var(--grad);pointer-events:none;z-index:9998;mix-blend-mode:multiply;transform:translate(-50%,-50%);transition:transform .08s}
