/* ================================================================
   necfru drive Plan2 — LP  |  css/lp.css  v5
   Scoped entirely to #drive-archive-lp
   ✓ No global resets
   ✓ No html / body / header / footer / nav / a / button overrides
   Desktop-first · breakpoints 1024 / 768 / 480 px

   necfru Brand Colors:
     Primary blue: #004DF4
     Accent gold:  #f5cd46
     Support yellow: #fef652

   Typography targets:
     H1 hero   : clamp(2.5rem, 4.8vw, 3.75rem)  ≈ 56–60 px
     H2 section: clamp(2rem,   3vw,   2.5rem)    ≈ 34–40 px
     H2 proof  : clamp(1.5rem, 2.4vw, 1.875rem)  ≈ 24–30 px
     body base : 1.0625rem = 17 px
     labels    : 13–15 px (readability improved)
     subnav    : 14 px
   ================================================================ */

html{
  font-size:100%;
}

/* ── Scoped custom properties ───────────────────────────────── */
#drive-archive-lp {
  /* necfru brand colors */
  --c-blue:      #004DF4;    /* primary brand blue */
  --c-blue-d:    #0043D6;
  --c-blue-dd:   #0039B8;
  --c-blue-10:   #E5F0FF;
  --c-blue-20:   #CCE1FF;

  --c-gold:      #f5cd46;    /* accent gold */
  --c-gold-d:    #E0B830;
  --c-gold-10:   #FEF9E8;

  --c-yellow:    #fef652;    /* support yellow */
  --c-yellow-10: #FFFEF0;

  --c-ink-900:   #0F172A;
  --c-ink-800:   #1E293B;
  --c-ink-700:   #334155;
  --c-ink-600:   #475569;
  --c-ink-500:   #64748B;
  --c-ink-400:   #94A3B8;
  --c-ink-200:   #E2E8F0;
  --c-ink-150:   #EEF2F7;
  --c-ink-100:   #F1F5F9;
  --c-ink-50:    #F8FAFC;

  --c-red:       #DC2626;
  --c-red-10:    #FEF2F2;
  --c-amber:     #D97706;
  --c-amber-10:  #FFF7ED;
  --c-green:     #16A34A;
  --c-green-10:  #F0FDF4;

  --r-sm:   6px;
  --r-md:  10px;
  --r-lg:  16px;
  --r-xl:  22px;

  --sh-xs: 0 1px 4px rgba(15,23,42,.06);
  --sh-sm: 0 2px 10px rgba(15,23,42,.08), 0 1px 3px rgba(15,23,42,.04);
  --sh-md: 0 5px 20px rgba(15,23,42,.09), 0 2px 7px rgba(15,23,42,.04);
  --sh-lg: 0 10px 36px rgba(15,23,42,.11), 0 4px 12px rgba(15,23,42,.05);
  --sh-xl: 0 20px 64px rgba(15,23,42,.14), 0 8px 24px rgba(15,23,42,.07);

  --max-w:      1120px;
  --subnav-h:   48px;
  --global-header-h: 64px;

  font-family: 'Noto Sans JP', 'Hiragino Sans', 'Yu Gothic UI', -apple-system, sans-serif;
  font-size: 1.0625rem;
  color: var(--c-ink-900);
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
}

#drive-archive-lp *,
#drive-archive-lp *::before,
#drive-archive-lp *::after { box-sizing: inherit; }

#drive-archive-lp img { max-width: 100%; height: auto; display: block; }

/* ── Container ──────────────────────────────────────────────── */
#drive-archive-lp .nd-wrap {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 40px;
}


/* ================================================================
   SUB-NAV  — 14 px, clear click area, horizontally scrollable
   ================================================================ */
#drive-archive-lp .nd-subnav {
  position: sticky;
  top: var(--global-header-h);
  z-index: 200;
  background: #fff;
  border-bottom: 1px solid var(--c-ink-200);
  height: var(--subnav-h);
  transition: box-shadow .2s ease;
}
#drive-archive-lp .nd-subnav.is-shadowed { box-shadow: var(--sh-md); }

#drive-archive-lp .nd-subnav__inner {
  height: 100%;
  display: flex;
  align-items: center;
  gap: 16px;
}
#drive-archive-lp .nd-subnav__brand {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-shrink: 0;
}
#drive-archive-lp .nd-subnav__logo-text {
  font-size: 15px;
  font-weight: 600;
  color: var(--c-ink-800);
  font-family: 'Inter', sans-serif;
  letter-spacing: -.02em;
}
#drive-archive-lp .nd-subnav__logo-text strong {
  font-weight: 800;
  color: var(--c-blue);
}
/* Plan2 pill — small */
#drive-archive-lp .nd-subnav__plan {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .07em;
  color: var(--c-blue);
  background: var(--c-blue-10);
  border: 1px solid var(--c-blue-20);
  border-radius: 4px;
  padding: 2px 8px;
  font-family: 'Inter', sans-serif;
}
/* scrollable list */
#drive-archive-lp .nd-subnav__list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
#drive-archive-lp .nd-subnav__list::-webkit-scrollbar { display: none; }

/* 14px links — clear and readable */
#drive-archive-lp .nd-subnav__link {
  display: block;
  height: var(--subnav-h);
  line-height: var(--subnav-h);
  padding: 0 16px;
  font-size: 15px;
  font-weight: 500;
  color: var(--c-ink-500);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: color .14s, border-color .14s;
}
#drive-archive-lp .nd-subnav__link:hover,
#drive-archive-lp .nd-subnav__link.is-active {
  color: var(--c-blue);
  border-bottom-color: var(--c-blue);
}


/* ================================================================
   BUTTONS
   ================================================================ */
#drive-archive-lp .nd-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-family: inherit;
  font-weight: 700;
  border-radius: var(--r-md);
  border: 2px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  letter-spacing: -.01em;
  transition: background .14s, color .14s, border-color .14s, box-shadow .14s, transform .1s;
  line-height: 1;
}
#drive-archive-lp .nd-btn:hover  { transform: translateY(-1px); }
#drive-archive-lp .nd-btn:active { transform: none; }

#drive-archive-lp .nd-btn--xs  { font-size: 11px; padding: 6px 14px; border-radius: 6px; }
#drive-archive-lp .nd-btn--lg  { font-size: 1rem; padding: 14px 30px; }
#drive-archive-lp .nd-btn--xl  { font-size: 1.0625rem; padding: 16px 34px; border-radius: var(--r-lg); }
#drive-archive-lp .nd-btn--block { width: 100%; }

#drive-archive-lp .nd-btn--primary {
  background: var(--c-blue); color: #fff; border-color: var(--c-blue);
  box-shadow: 0 2px 8px rgba(0,77,244,.28);
}
#drive-archive-lp .nd-btn--primary:hover {
  background: var(--c-blue-d); border-color: var(--c-blue-d);
  box-shadow: 0 4px 18px rgba(0,77,244,.40);
}
#drive-archive-lp .nd-btn--outline {
  background: transparent; color: var(--c-blue); border-color: var(--c-blue);
}
#drive-archive-lp .nd-btn--outline:hover { background: var(--c-blue-10); }
#drive-archive-lp .nd-btn--white {
  background: #fff; color: var(--c-blue); border-color: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,.14);
}
#drive-archive-lp .nd-btn--white:hover {
  background: var(--c-blue-10); box-shadow: 0 4px 16px rgba(0,0,0,.18);
}
#drive-archive-lp .nd-btn--ghost {
  background: transparent; color: rgba(255,255,255,.88); border-color: rgba(255,255,255,.44);
}
#drive-archive-lp .nd-btn--ghost:hover {
  background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.78);
}
#drive-archive-lp .nd-btn--on-blue { box-shadow: 0 2px 8px rgba(0,0,0,.18); }


/* ================================================================
   SECTION SHELL  — tighter default padding (72px)
   ================================================================ */
#drive-archive-lp .nd-section { padding: 72px 0; }
#drive-archive-lp .nd-bg-gray { background: var(--c-ink-50); }

/* Heading block — tighter bottom margin */
#drive-archive-lp .nd-sec-hd        { margin-bottom: 40px; }
#drive-archive-lp .nd-sec-hd--center { text-align: center; }
#drive-archive-lp .nd-sec-hd--center .nd-h2,
#drive-archive-lp .nd-sec-hd--center .nd-sec-sub {
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}

/* ── Small supporting labels — 13-15px readable ── */
#drive-archive-lp .nd-label {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-blue);
  margin: 0 0 10px;
}
#drive-archive-lp .nd-eyebrow {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: var(--c-blue);
  margin-bottom: 16px;
}

/* ── H1 (hero only) ── */
#drive-archive-lp .nd-h1 {
  font-size: clamp(2.25rem, 4.8vw, 3.75rem);
  font-weight: 800;
  line-height: 1.13;
  letter-spacing: -.04em;
  color: var(--c-ink-900);
  margin: 0;
}

/* ── H2 main section titles: 34–40 px desktop ── */
#drive-archive-lp .nd-h2 {
  font-size: clamp(1.625rem, 2.8vw, 2.375rem);
  font-weight: 800;
  line-height: 1.22;
  letter-spacing: -.03em;
  color: var(--c-ink-900);
  margin: 0 0 8px;
}

/* Short punchy title (used as the actual H2 visual anchor) */
#drive-archive-lp .nd-h2-short {
  font-size: clamp(2rem, 3.2vw, 2.5rem); /* 32–40px */
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -.035em;
  color: var(--c-ink-900);
  margin: 0 0 10px;
}

/* Descriptive subtitle below short title */
#drive-archive-lp .nd-h2-desc {
  font-size: clamp(1rem, 1.4vw, 1.125rem);
  font-weight: 500;
  color: var(--c-ink-500);
  line-height: 1.65;
  margin: 0;
}

/* ── H2 proof variant (section leads for §6-8) ── */
#drive-archive-lp .nd-h2-proof {
  font-size: clamp(1.5rem, 2.4vw, 1.875rem);
  font-weight: 700;
  line-height: 1.26;
  letter-spacing: -.025em;
  color: var(--c-ink-900);
  margin: 0 0 16px;
}

#drive-archive-lp .nd-sec-sub {
  font-size: 1rem;
  color: var(--c-ink-500);
  margin-top: 8px;
  line-height: 1.7;
}

/* Asset images */
#drive-archive-lp .nd-asset-img {
  width: 100%;
  border-radius: var(--r-lg);
  cursor: zoom-in;
  transition: opacity .14s;
}
#drive-archive-lp .nd-asset-img:hover { opacity: .92; }
#drive-archive-lp .nd-asset-frame {
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--sh-xl);
  border: 1px solid var(--c-ink-150);
}
#drive-archive-lp .nd-asset-frame .nd-asset-img { border-radius: 0; }

/* Anchor jump offset */
#drive-archive-lp section[id] {
  scroll-margin-top: calc(var(--global-header-h) + var(--subnav-h) + 18px);
}

/* Text wrap balance */
#drive-archive-lp .nd-h1,
#drive-archive-lp .nd-h2-short,
#drive-archive-lp .nd-trust-item__text {
  text-wrap: balance;
}

#drive-archive-lp .nd-trust-item {
  min-width: 0;
}


/* ================================================================
   SCROLL REVEAL
   ================================================================ */
#drive-archive-lp .nd-reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .52s ease, transform .52s ease;
}
#drive-archive-lp .nd-reveal.nd-reveal--delay1 { transition-delay: .10s; }
#drive-archive-lp .nd-reveal.nd-reveal--delay2 { transition-delay: .20s; }
#drive-archive-lp .nd-reveal.is-visible { opacity: 1; transform: none; }


/* ================================================================
   §1  HERO  — large and strong  (pad-top 60px, trust flush)
   ================================================================ */
#drive-archive-lp .nd-hero {
  background: #fff;
  background-image:
    radial-gradient(ellipse 65% 55% at 78% 32%, rgba(229,240,255,.48) 0%, transparent 68%),
    radial-gradient(ellipse 38% 38% at 18% 72%, rgba(254,249,232,.35) 0%, transparent 70%);
  padding: 60px 0 0;
}

#drive-archive-lp .nd-hero__headline { margin-bottom: 36px; }

#drive-archive-lp .nd-hero .nd-h1 {
  font-size: clamp(2.5rem, 4.8vw, 3.75rem);
  line-height: 1.12;
  letter-spacing: -.045em;
}
#drive-archive-lp .nd-h1__line1 { color: var(--c-ink-900); }
#drive-archive-lp .nd-h1__line2 {
  color: var(--c-blue);   /* brand blue */
  font-weight: 900;
  position: relative;
}

#drive-archive-lp .nd-hero__row2 {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 48px;
  align-items: center;
  padding-bottom: 56px;
}
#drive-archive-lp .nd-hero__sub {
  font-size: 1.0625rem;
  color: var(--c-ink-600);
  line-height: 1.78;
  margin: 0 0 28px;
}
#drive-archive-lp .nd-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; }

#drive-archive-lp .nd-hero__img-frame {
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--sh-xl);
  border: 1px solid var(--c-ink-150);
}
#drive-archive-lp .nd-hero__img {
  width: 100%; display: block; cursor: zoom-in; transition: opacity .14s;
}
#drive-archive-lp .nd-hero__img:hover { opacity: .93; }


/* ================================================================
   HERO PROOF STRIP — wider, one-row, three equal columns
   ================================================================ */
#drive-archive-lp .nd-hero__trust {
  border-top: 1px solid var(--c-ink-150);
  background: var(--c-ink-50);
  padding: 24px 0;
}
#drive-archive-lp .nd-hero__trust-inner {
  max-width: 1280px;     /* wider than main wrap (1120px) */
  margin: 0 auto;
  padding: 0 40px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
  align-items: start;
}
#drive-archive-lp .nd-trust-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 0;
}
#drive-archive-lp .nd-trust-item__icon {
  flex-shrink: 0;
  width: 36px; height: 36px;
  background: var(--c-blue-10);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--c-blue-20);
}
#drive-archive-lp .nd-trust-item__text {
  font-size: 1rem;          /* 16px — visually large and scannable */
  font-weight: 500;
  color: var(--c-ink-700);
  line-height: 1.5;
  flex: 1;
}
#drive-archive-lp .nd-trust-item__text strong {
  font-weight: 800;
  color: var(--c-blue);     /* brand blue emphasis */
}
/* No separators — equal columns with gap */

/* Hero product logo — parent LP / Plan1 とサイズ感を統一 */
#drive-archive-lp .nd-hero__product-logo {
  margin-bottom: 24px;
  display: flex;
  justify-content: flex-start;
}

#drive-archive-lp .nd-hero__logo-img {
  width: 300px;
  height: auto;
  max-width: 100%;
  display: block;
}

/* Tablet */
@media (max-width: 768px) {
  #drive-archive-lp .nd-hero__product-logo {
    margin-bottom: 20px;
  }

  #drive-archive-lp .nd-hero__logo-img {
    width: 200px;
  }
}

/* Mobile */
@media (max-width: 480px) {
  #drive-archive-lp .nd-hero__product-logo {
    margin-bottom: 18px;
  }

  #drive-archive-lp .nd-hero__logo-img {
    width: 180px;
  }
}

/* ================================================================
   §2  PAIN  — slightly denser (64px)
   ================================================================ */
#drive-archive-lp #nd-pain { padding: 64px 0; }
#drive-archive-lp #nd-pain .nd-sec-hd { margin-bottom: 32px; }

#drive-archive-lp .nd-pain-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
#drive-archive-lp .nd-pain-card {
  background: #fff;
  border: 1px solid var(--c-ink-200);
  border-radius: var(--r-lg);
  padding: 26px 22px;
  display: flex;
  gap: 16px;
  align-items: flex-start;
  box-shadow: var(--sh-xs);
  transition: box-shadow .18s;
}
#drive-archive-lp .nd-pain-card:hover { box-shadow: var(--sh-sm); }
#drive-archive-lp .nd-pain-icon {
  flex-shrink: 0;
  width: 46px; height: 46px;
  background: var(--c-blue-10);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
}
#drive-archive-lp .nd-pain-text h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--c-ink-900);
  margin: 0 0 6px;
  line-height: 1.34;
}
#drive-archive-lp .nd-pain-text p {
  font-size: .9375rem;
  color: var(--c-ink-500);
  margin: 0;
  line-height: 1.70;
}


/* ================================================================
   §3  COST  — most compact (52px)
   ================================================================ */
#drive-archive-lp #nd-cost { padding: 52px 0; }
#drive-archive-lp #nd-cost .nd-sec-hd { margin-bottom: 28px; }

#drive-archive-lp .nd-cost-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
#drive-archive-lp .nd-cost-card {
  background: #fff;
  border: 1px solid var(--c-ink-200);
  border-radius: var(--r-lg);
  padding: 22px 20px;
  box-shadow: var(--sh-xs);
  transition: box-shadow .18s;
}
#drive-archive-lp .nd-cost-card:hover { box-shadow: var(--sh-sm); }
#drive-archive-lp .nd-cost-marker {
  display: inline-block;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .10em;
  padding: 3px 10px;
  border-radius: 20px;
  margin-bottom: 10px;
}
#drive-archive-lp .nd-cost-marker--cost { background: var(--c-red-10);   color: var(--c-red);   border: 1px solid #FECACA; }
#drive-archive-lp .nd-cost-marker--risk { background: var(--c-amber-10); color: var(--c-amber); border: 1px solid #FED7AA; }
#drive-archive-lp .nd-cost-marker--opp  { background: var(--c-gold-10);  color: var(--c-gold);  border: 1px solid var(--c-gold); }
#drive-archive-lp .nd-cost-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--c-ink-900);
  margin: 0 0 7px;
  line-height: 1.35;
}
#drive-archive-lp .nd-cost-card p {
  font-size: .9375rem;
  color: var(--c-ink-500);
  margin: 0;
  line-height: 1.68;
}


/* ================================================================
   §4  POSITIONING  — medium density (72px), diagram-led
   ================================================================ */
#drive-archive-lp #nd-position { padding: 72px 0; }
#drive-archive-lp #nd-position .nd-sec-hd { margin-bottom: 36px; }

#drive-archive-lp .nd-position-asset { text-align: center; }
#drive-archive-lp .nd-position-asset .nd-asset-img {
  max-width: 960px;
  margin: 0 auto;
  box-shadow: var(--sh-lg);
  border: 1px solid var(--c-ink-150);
}


/* ================================================================
   §5  VALUES  — standard (72px)
   ================================================================ */
#drive-archive-lp #nd-values { padding: 72px 0; }

#drive-archive-lp .nd-values-row {
  display: flex;
  align-items: stretch;
  border: 1px solid var(--c-ink-200);
  border-radius: var(--r-xl);
  overflow: hidden;
  background: #fff;
  box-shadow: var(--sh-sm);
}
#drive-archive-lp .nd-value {
  flex: 1;
  padding: 42px 34px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
#drive-archive-lp .nd-value-div {
  width: 1px;
  background: var(--c-ink-150);
  flex-shrink: 0;
  align-self: stretch;
}
#drive-archive-lp .nd-value__num {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  color: var(--c-gold);     /* accent gold for numeric badges */
}
#drive-archive-lp .nd-value__icon {
  width: 52px; height: 52px;
  background: var(--c-blue-10);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
}
/* Value titles — clear and readable */
#drive-archive-lp .nd-value__title {
  font-size: 1.3125rem;
  font-weight: 700;
  color: var(--c-ink-900);
  margin: 0;
  line-height: 1.28;
}
#drive-archive-lp .nd-value__body {
  font-size: .9375rem;
  color: var(--c-ink-500);
  margin: 0;
  line-height: 1.74;
}


/* ================================================================
   PROOF SECTIONS §6 / §7 / §8  — dense and technical (60px)
   ================================================================ */
#drive-archive-lp #nd-proof6,
#drive-archive-lp #nd-proof7,
#drive-archive-lp #nd-proof8 { padding: 60px 0; }

#drive-archive-lp .nd-proof-row {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 52px;
  align-items: center;
}
#drive-archive-lp .nd-proof-row--rev .nd-proof-copy  { order: 2; }
#drive-archive-lp .nd-proof-row--rev .nd-proof-visual { order: 1; }

#drive-archive-lp .nd-proof-lead {
  font-size: 1rem;
  color: var(--c-ink-700);
  margin: 0 0 20px;
  line-height: 1.74;
}
#drive-archive-lp .nd-proof-bullets {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 9px;
}
#drive-archive-lp .nd-proof-bullets li {
  font-size: .9375rem;
  color: var(--c-ink-700);
  padding-left: 18px;
  position: relative;
  line-height: 1.6;
}
#drive-archive-lp .nd-proof-bullets li::before {
  content: '';
  position: absolute;
  left: 0; top: 8px;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--c-blue);
}


/* ================================================================
   §9  HOT / COLD  — standard (72px)
   ================================================================ */
#drive-archive-lp #nd-hotcold { padding: 72px 0; }

#drive-archive-lp .nd-hotcold-asset {
  display: flex; flex-direction: column; align-items: center; gap: 16px;
}
#drive-archive-lp .nd-hotcold-asset .nd-asset-img {
  max-width: 980px; margin: 0 auto;
  box-shadow: var(--sh-lg); border: 1px solid var(--c-ink-150);
}
#drive-archive-lp .nd-hotcold-note {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; color: var(--c-ink-500); margin: 0;
}


/* ================================================================
   §10  PRICING  — decision-oriented (72px, tighter gaps)
   ================================================================ */
#drive-archive-lp #nd-pricing { padding: 72px 0; }
#drive-archive-lp #nd-pricing .nd-sec-hd { margin-bottom: 36px; }

#drive-archive-lp .nd-pricing-layout {
  display: grid;
  grid-template-columns: 370px 1fr;
  gap: 40px;
  align-items: start;
}
#drive-archive-lp .nd-pricing-card {
  background: #fff;
  border: 1.5px solid var(--c-ink-200);
  border-radius: var(--r-xl);
  padding: 32px 28px;
  box-shadow: var(--sh-md);
}
#drive-archive-lp .nd-pricing-card__type {
  font-size: 13px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--c-ink-400); margin: 0 0 8px;
}
#drive-archive-lp .nd-pricing-card__main {
  display: flex; align-items: baseline; gap: 4px; margin-bottom: 4px;
}
#drive-archive-lp .nd-pricing-card__yen {
  font-family: 'Inter', sans-serif;
  font-size: 3.25rem; font-weight: 900; letter-spacing: -.05em;
  color: var(--c-ink-900); line-height: 1;
}
#drive-archive-lp .nd-pricing-card__per {
  font-size: 1rem; color: var(--c-ink-500); font-weight: 500;
}
#drive-archive-lp .nd-pricing-card__div {
  height: 1px; background: var(--c-ink-150); margin: 20px 0;
}
#drive-archive-lp .nd-pricing-card__var-label {
  font-size: 13px; font-weight: 700; letter-spacing: .06em;
  color: var(--c-ink-400); margin: 0 0 12px; text-transform: uppercase;
}
#drive-archive-lp .nd-pricing-tiers { display: flex; flex-direction: column; gap: 10px; }
#drive-archive-lp .nd-pricing-tier {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
#drive-archive-lp .nd-tier-pill {
  font-size: 10px; font-weight: 800; letter-spacing: .12em;
  padding: 3px 9px; border-radius: 20px; flex-shrink: 0;
}
#drive-archive-lp .nd-tier-pill--hot  { background: var(--c-blue-10);  color: var(--c-blue);  border: 1px solid var(--c-blue-20); }
#drive-archive-lp .nd-tier-pill--cold { background: var(--c-ink-100);  color: var(--c-ink-500); border: 1px solid var(--c-ink-200); }
#drive-archive-lp .nd-tier-price {
  font-family: 'Inter', sans-serif;
  font-size: 1.125rem; font-weight: 700; color: var(--c-ink-900);
}
#drive-archive-lp .nd-tier-price small { font-size: .875rem; font-weight: 500; }
#drive-archive-lp .nd-tier-note { font-size: .8125rem; color: var(--c-ink-400); margin-left: auto; }

#drive-archive-lp .nd-pricing-meta { display: flex; flex-direction: column; gap: 7px; margin: 0; }
#drive-archive-lp .nd-pricing-meta__row { display: flex; justify-content: space-between; font-size: .9375rem; }
#drive-archive-lp .nd-pricing-meta dt { color: var(--c-ink-500); }
#drive-archive-lp .nd-pricing-meta dd { font-weight: 700; color: var(--c-ink-900); margin: 0; }
#drive-archive-lp .nd-pricing-card__ctas { display: flex; flex-direction: column; gap: 10px; margin-top: 22px; }

/* Onboarding steps */
#drive-archive-lp .nd-onboarding { padding: 4px 0; }
#drive-archive-lp .nd-onboarding__title {
  font-size: 13px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--c-ink-400); margin: 0 0 24px;
}
#drive-archive-lp .nd-steps { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
#drive-archive-lp .nd-step { display: flex; gap: 20px; position: relative; }
#drive-archive-lp .nd-step:not(:last-child)::after {
  content: ''; position: absolute;
  left: 18px; top: 40px; bottom: 0;
  width: 2px; background: var(--c-blue-20);
}
#drive-archive-lp .nd-step__num {
  flex-shrink: 0; width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--c-blue);    /* brand blue */
  color: #fff;
  font-family: 'Inter', sans-serif; font-size: 15px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  position: relative; z-index: 1;
  box-shadow: 0 2px 8px rgba(0,77,244,.28);
}
#drive-archive-lp .nd-step__body { padding-bottom: 28px; }
/* Step titles — promoted for readability */
#drive-archive-lp .nd-step__title {
  font-size: 1.0625rem;
  font-weight: 700; color: var(--c-ink-900);
  margin: 6px 0 5px; line-height: 1.34;
}
#drive-archive-lp .nd-step__body p {
  font-size: .9375rem; color: var(--c-ink-500); margin: 0; line-height: 1.70;
}


/* ================================================================
   §11  CASES  — standard (72px)
   ================================================================ */
#drive-archive-lp #nd-cases { padding: 72px 0; }

#drive-archive-lp .nd-cases-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
}
#drive-archive-lp .nd-case-card {
  background: #fff; border: 1px solid var(--c-ink-200);
  border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--sh-xs); transition: box-shadow .18s, transform .18s;
}
#drive-archive-lp .nd-case-card:hover { box-shadow: var(--sh-md); transform: translateY(-3px); }
#drive-archive-lp .nd-case-header {
  background: var(--c-blue-10); padding: 13px 22px;
  border-bottom: 1px solid var(--c-blue-20);
}
/* Use case industry title — promoted */
#drive-archive-lp .nd-case-industry {
  font-size: 1.0625rem; font-weight: 700; color: var(--c-blue); letter-spacing: .02em;
}
#drive-archive-lp .nd-case-body {
  padding: 18px 22px 22px; display: flex; flex-direction: column; gap: 11px;
}
#drive-archive-lp .nd-case-row { display: flex; gap: 10px; align-items: flex-start; }
#drive-archive-lp .nd-case-badge {
  flex-shrink: 0; font-size: 10px; font-weight: 800; letter-spacing: .04em;
  padding: 3px 8px; border-radius: 4px; margin-top: 2px;
}
#drive-archive-lp .nd-case-badge--q { background: var(--c-red-10);   color: var(--c-red);   border: 1px solid #FECACA; }
#drive-archive-lp .nd-case-badge--h { background: var(--c-gold-10);  color: var(--c-gold);  border: 1px solid var(--c-gold); }
#drive-archive-lp .nd-case-badge--e { background: var(--c-green-10); color: var(--c-green); border: 1px solid #BBF7D0; }
#drive-archive-lp .nd-case-row p {
  font-size: .9375rem; color: var(--c-ink-700); margin: 0; line-height: 1.65;
}


/* ================================================================
   §12  FAQ  — compact (60px)
   ================================================================ */
#drive-archive-lp #nd-faq { padding: 60px 0; }
#drive-archive-lp #nd-faq .nd-sec-hd { margin-bottom: 30px; }

#drive-archive-lp .nd-faq-wrap { max-width: 780px; margin: 0 auto; }
#drive-archive-lp .nd-faq-list {
  margin: 0; padding: 0;
  background: #fff; border: 1px solid var(--c-ink-200);
  border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-sm);
}
#drive-archive-lp .nd-faq-item { border-bottom: 1px solid var(--c-ink-150); }
#drive-archive-lp .nd-faq-item:last-child { border-bottom: none; }
#drive-archive-lp .nd-faq-item dt { margin: 0; }

/* FAQ question — readable weight */
#drive-archive-lp .nd-faq-q {
  width: 100%; background: none; border: none; cursor: pointer;
  font-family: inherit; font-size: 1rem; font-weight: 600;
  color: var(--c-ink-900); text-align: left;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 20px 24px; line-height: 1.5;
  transition: background .12s;
}
#drive-archive-lp .nd-faq-q:hover { background: var(--c-ink-50); }

#drive-archive-lp .nd-faq-icon {
  flex-shrink: 0; width: 24px; height: 24px;
  border: 1.5px solid var(--c-ink-200); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  position: relative; transition: background .14s, border-color .14s;
}
#drive-archive-lp .nd-faq-icon::before,
#drive-archive-lp .nd-faq-icon::after {
  content: ''; position: absolute;
  background: var(--c-ink-500); border-radius: 2px;
  transition: opacity .14s, background .14s;
}
#drive-archive-lp .nd-faq-icon::before { width: 11px; height: 1.5px; }
#drive-archive-lp .nd-faq-icon::after  { width: 1.5px; height: 11px; }

#drive-archive-lp .nd-faq-q[aria-expanded="true"] .nd-faq-icon {
  background: var(--c-blue); border-color: var(--c-blue);
}
#drive-archive-lp .nd-faq-q[aria-expanded="true"] .nd-faq-icon::before,
#drive-archive-lp .nd-faq-q[aria-expanded="true"] .nd-faq-icon::after { background: #fff; }
#drive-archive-lp .nd-faq-q[aria-expanded="true"] .nd-faq-icon::after { opacity: 0; }

#drive-archive-lp .nd-faq-a {
  padding: 0 24px 20px;
  font-size: .9375rem; color: var(--c-ink-700); line-height: 1.80;
  border-top: 1px solid var(--c-ink-100); margin: 0;
}
#drive-archive-lp .nd-faq-a[hidden] { display: none; }


/* ================================================================
   §13  TRUST  — densest (56px, ink-50 panel)
   ================================================================ */
#drive-archive-lp #nd-trust { padding: 56px 0; background: var(--c-ink-50); }
#drive-archive-lp #nd-trust .nd-sec-hd { margin-bottom: 32px; }

#drive-archive-lp .nd-trust-asset { text-align: center; }
#drive-archive-lp .nd-trust-asset .nd-asset-img {
  max-width: 960px; margin: 0 auto;
  box-shadow: var(--sh-lg); border: 1px solid var(--c-ink-150);
}


/* ================================================================
   §14  FINAL CTA  — open (100px)
   ================================================================ */
#drive-archive-lp .nd-cta-section {
  background: linear-gradient(140deg, #00308A 0%, #0043D6 40%, #004DF4 70%, #0039B8 100%);
  padding: 100px 0;
}
#drive-archive-lp .nd-cta-inner { text-align: center; }
#drive-archive-lp .nd-cta-eyebrow {
  font-size: 13px; font-weight: 700; letter-spacing: .16em;
  text-transform: uppercase; color: rgba(255,255,255,.62); margin: 0 0 14px;
}
#drive-archive-lp .nd-cta-h2 {
  font-size: clamp(1.875rem, 3.2vw, 2.625rem);
  font-weight: 800; line-height: 1.2; letter-spacing: -.03em;
  color: #fff; margin: 0 0 16px;
}
#drive-archive-lp .nd-cta-sub {
  font-size: 1.0625rem; color: rgba(255,255,255,.72); margin: 0 0 44px;
}
#drive-archive-lp .nd-cta-actions {
  display: flex; justify-content: center; gap: 12px; flex-wrap: wrap;
}


/* ================================================================
   LIGHTBOX
   ================================================================ */
#drive-archive-lp .nd-lightbox {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
}
#drive-archive-lp .nd-lightbox[hidden] { display: none; }
#drive-archive-lp .nd-lb-bd {
  position: absolute; inset: 0;
  background: rgba(3,7,18,.90);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  cursor: pointer;
}
#drive-archive-lp .nd-lb-panel {
  position: relative; z-index: 1;
  max-width: min(92vw, 1200px); max-height: 92vh;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
#drive-archive-lp .nd-lb-close {
  position: absolute; top: -48px; right: 0;
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(255,255,255,.14); border: 1.5px solid rgba(255,255,255,.28);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .14s;
}
#drive-archive-lp .nd-lb-close:hover { background: rgba(255,255,255,.28); }
#drive-archive-lp .nd-lb-img {
  max-width: 100%; max-height: 82vh;
  border-radius: var(--r-lg); box-shadow: 0 28px 90px rgba(0,0,0,.65); object-fit: contain;
}
#drive-archive-lp .nd-lb-cap {
  font-size: 12px; color: rgba(255,255,255,.58); text-align: center; margin: 0;
}


/* ================================================================
   RESPONSIVE  —  1024 px
   ================================================================ */
@media (max-width: 1024px) {
  #drive-archive-lp .nd-wrap { padding: 0 32px; }

  /* Hide subnav CTA on tablet/mobile */
  #drive-archive-lp .nd-subnav .nd-btn {
    display: none;
  }

  #drive-archive-lp .nd-subnav__inner {
    gap: 10px;
  }

  #drive-archive-lp .nd-subnav__list {
    min-width: 0;
  }

  #drive-archive-lp .nd-hero__row2 {
    grid-template-columns: 1fr 1.35fr;
    gap: 36px;
  }

  /* Trust strip — try to keep one row, reduce gap */
  #drive-archive-lp .nd-hero__trust-inner {
    max-width: 1120px;
    padding: 0 32px;
    gap: 24px;
  }

  #drive-archive-lp .nd-pricing-layout {
    grid-template-columns: 330px 1fr;
    gap: 32px;
  }
  #drive-archive-lp .nd-proof-row { gap: 40px; }
  #drive-archive-lp .nd-value { padding: 36px 28px; }

  /* H2 — tablet range */
  #drive-archive-lp .nd-h2 { font-size: clamp(1.625rem, 3vw, 2rem); }
  #drive-archive-lp .nd-h2-short { font-size: clamp(1.875rem, 3.2vw, 2.25rem); }
}


/* ================================================================
   RESPONSIVE  —  768 px  (real mobile layout)
   ================================================================ */
@media (max-width: 768px) {
  #drive-archive-lp .nd-wrap { padding: 0 18px; }

  /* Default section padding */
  #drive-archive-lp .nd-section { padding: 56px 0; }
  #drive-archive-lp #nd-pain    { padding: 52px 0; }
  #drive-archive-lp #nd-cost    { padding: 44px 0; }
  #drive-archive-lp #nd-position { padding: 56px 0; }
  #drive-archive-lp #nd-values  { padding: 56px 0; }
  #drive-archive-lp #nd-proof6,
  #drive-archive-lp #nd-proof7,
  #drive-archive-lp #nd-proof8  { padding: 52px 0; }
  #drive-archive-lp #nd-hotcold { padding: 56px 0; }
  #drive-archive-lp #nd-pricing { padding: 56px 0; }
  #drive-archive-lp #nd-cases   { padding: 56px 0; }
  #drive-archive-lp #nd-faq     { padding: 48px 0; }
  #drive-archive-lp #nd-trust   { padding: 48px 0; }
  #drive-archive-lp .nd-cta-section { padding: 72px 0; }

  #drive-archive-lp .nd-sec-hd { margin-bottom: 28px; }

  /* H2 sizes — tablet/mobile */
  #drive-archive-lp .nd-h2 { font-size: clamp(1.5rem, 5vw, 1.875rem); letter-spacing: -.025em; }
  #drive-archive-lp .nd-h2-short { font-size: clamp(1.75rem, 5.5vw, 2rem); }
  #drive-archive-lp .nd-h2-proof { font-size: clamp(1.375rem, 4.5vw, 1.625rem); }
  #drive-archive-lp .nd-cta-h2 { font-size: clamp(1.625rem, 5.5vw, 2rem); }

  /* SUB-NAV: horizontally scrollable, hide brand */
  #drive-archive-lp .nd-subnav__inner {
    gap: 6px;
  }

  #drive-archive-lp .nd-subnav__list {
    display: flex;
    overflow-x: auto;
    gap: 0;
  }
  #drive-archive-lp .nd-subnav__link { padding: 0 12px; font-size: 13px; }

  #drive-archive-lp .nd-subnav__plan {
    font-size: 10px;
    padding: 1px 6px;
  }

  #drive-archive-lp .nd-subnav__brand { display: none; }

  /* Hero — single column */
  #drive-archive-lp .nd-hero { padding: 44px 0 0; }
  #drive-archive-lp .nd-hero__headline { margin-bottom: 24px; }
  #drive-archive-lp .nd-hero .nd-h1 {
    font-size: clamp(1.875rem, 6.5vw, 2.5rem);
    letter-spacing: -.028em;
    line-height: 1.18;
  }
  #drive-archive-lp .nd-hero__row2 {
    grid-template-columns: 1fr;
    gap: 24px;
    padding-bottom: 40px;
  }
  #drive-archive-lp .nd-hero__copy   { order: 1; }
  #drive-archive-lp .nd-hero__visual { order: 2; }
  #drive-archive-lp .nd-hero__sub { font-size: 1rem; margin-bottom: 22px; }

  /* Trust strip — stack or horizontal scroll */
  #drive-archive-lp .nd-hero__trust { padding: 20px 0; }
  #drive-archive-lp .nd-hero__trust-inner {
    max-width: 100%;
    padding: 0 18px;
    display: flex;
    overflow-x: auto;
    grid-template-columns: none;
    gap: 20px;
    scrollbar-width: none;
  }
  #drive-archive-lp .nd-hero__trust-inner::-webkit-scrollbar { display: none; }
  #drive-archive-lp .nd-trust-item {
    flex-shrink: 0;
    width: 260px;
  }

  /* Pain, Cost — single column */
  #drive-archive-lp .nd-pain-grid  { grid-template-columns: 1fr; gap: 12px; }
  #drive-archive-lp .nd-cost-grid  { grid-template-columns: 1fr; gap: 10px; }

  /* Values */
  #drive-archive-lp .nd-values-row  { flex-direction: column; }
  #drive-archive-lp .nd-value-div   { width: 100%; height: 1px; }
  #drive-archive-lp .nd-value       { padding: 30px 24px; }
  #drive-archive-lp .nd-value__title { font-size: 1.1875rem; }

  /* Proof — stack cleanly */
  #drive-archive-lp .nd-proof-row   { grid-template-columns: 1fr; gap: 24px; }
  #drive-archive-lp .nd-proof-row--rev .nd-proof-copy  { order: 1; }
  #drive-archive-lp .nd-proof-row--rev .nd-proof-visual { order: 2; }

  /* Pricing — single column */
  #drive-archive-lp .nd-pricing-layout { grid-template-columns: 1fr; gap: 24px; }
  #drive-archive-lp .nd-pricing-card { padding: 26px 22px; }

  /* Cases */
  #drive-archive-lp .nd-cases-grid  { grid-template-columns: 1fr; gap: 12px; }

  /* CTA actions */
  #drive-archive-lp .nd-cta-actions { flex-direction: column; align-items: center; }
  #drive-archive-lp .nd-cta-actions .nd-btn { width: 100%; max-width: 320px; }
}


/* ================================================================
   RESPONSIVE  —  480 px
   ================================================================ */
@media (max-width: 480px) {
  #drive-archive-lp .nd-hero .nd-h1 { font-size: 1.75rem; line-height: 1.2; }
  #drive-archive-lp .nd-h2          { font-size: 1.4375rem; }
  #drive-archive-lp .nd-h2-short    { font-size: 1.625rem; }

  #drive-archive-lp .nd-hero__ctas  { flex-direction: column; gap: 10px; }
  #drive-archive-lp .nd-hero__ctas .nd-btn { width: 100%; }

  #drive-archive-lp .nd-pricing-card__yen { font-size: 2.75rem; }

  #drive-archive-lp .nd-trust-item { width: 240px; }
  #drive-archive-lp .nd-trust-item__icon { width: 32px; height: 32px; }
  #drive-archive-lp .nd-trust-item__text { font-size: .9375rem; }

  #drive-archive-lp .nd-faq-q { padding: 16px 18px; font-size: .9375rem; }
  #drive-archive-lp .nd-faq-a { padding: 0 18px 18px; }
}
