/*
 * streamline.css
 * STREAMLINE LP — warm-navy editorial design
 * All classes prefixed with .sl-; variables scoped to .lp-streamline
 * Ported from React prototype to WordPress (THE THOR child theme)
 */

/* ============================================================
   1. DESIGN TOKENS — scoped to container
   ============================================================ */
.lp-streamline {
  --sl-ink:              #1d2a40;
  --sl-ink-2:            #14213a;
  --sl-paper:            #f3efe8;
  --sl-paper-2:          #faf7f1;
  --sl-card:             #ffffff;
  --sl-gold:             #c89456;
  --sl-gold-2:           #a67740;
  --sl-clay:             #8a4a3e;
  --sl-ash:              #6f6657;
  --sl-ash-2:            #423d33;
  --sl-line:             #d8cdb8;
  --sl-line-soft:        #e7dfd0;
  --sl-bridge-opacity:   0.4;

  --sl-font-display: "Shippori Mincho B1", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --sl-font-body:    "Zen Kaku Gothic New", "Hiragino Sans", "Yu Gothic", sans-serif;
  --sl-font-mono:    "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;

  --sl-max:    1280px;
  --sl-gutter: clamp(20px, 4vw, 56px);
}


/* ============================================================
   2. BASE RESET (scoped inside container)
   ============================================================ */
.lp-streamline *,
.lp-streamline *::before,
.lp-streamline *::after {
  box-sizing: border-box;
}

.lp-streamline {
  background:              var(--sl-paper);
  color:                   var(--sl-ink);
  font-family:             var(--sl-font-body);
  font-size:               16px;
  line-height:             1.75;
  -webkit-font-smoothing:  antialiased;
  text-rendering:          optimizeLegibility;
  font-feature-settings:   "palt" 1;
}

.lp-streamline img {
  max-width: 100%;
  display:   block;
}

.lp-streamline button {
  font-family: inherit;
}


/* ============================================================
   3. TYPOGRAPHY HELPERS
   ============================================================ */
.lp-streamline .sl-eyebrow {
  font-family:     var(--sl-font-mono);
  font-size:       11px;
  letter-spacing:  0.22em;
  text-transform:  uppercase;
  color:           var(--sl-gold-2);
  font-weight:     500;
}


/* ============================================================
   4. LAYOUT CONTAINER
   ============================================================ */
.sl-wrap {
  max-width: var(--sl-max);
  margin:    0 auto;
  padding:   0 var(--sl-gutter);
}


/* ============================================================
   5. SECTION HEADER  (grid: number | title | en)
   ============================================================ */
.sl-section-header {
  display:               grid;
  grid-template-columns: auto 1fr auto;
  gap:                   24px;
  align-items:           end;
  padding:               88px 0 36px;
  border-bottom:         1px solid var(--sl-line);
  margin-bottom:         48px;
}

.sl-section-header .sl-num {
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  letter-spacing: 0.2em;
  color:          var(--sl-gold-2);
  padding-bottom: 6px;
}

.sl-section-header h2 {
  font-family:    var(--sl-font-display);
  font-weight:    600;
  font-size:      clamp(28px, 3.4vw, 44px);
  margin:         0;
  letter-spacing: 0.01em;
  line-height:    1.2;
}

.sl-section-header .sl-en {
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  color:          var(--sl-ash);
  letter-spacing: 0.18em;
  padding-bottom: 8px;
}


/* ============================================================
   6. PHOTO SLOT  (striped placeholder box)
   ============================================================ */
.sl-photo-slot {
  position:         relative;
  background:       var(--sl-paper-2);
  background-image: repeating-linear-gradient(
    135deg,
    transparent 0 14px,
    rgba(0, 0, 0, 0.022) 14px 15px
  );
  border:           1px solid var(--sl-line);
  display:          flex;
  align-items:      center;
  justify-content:  center;
  overflow:         hidden;
  color:            var(--sl-ash);
}

.sl-photo-slot .sl-label {
  font-family:      var(--sl-font-mono);
  font-size:        11px;
  letter-spacing:   0.18em;
  color:            var(--sl-ash);
  background:       rgba(243, 239, 232, 0.85);
  border:           1px solid var(--sl-line);
  padding:          6px 12px;
  border-radius:    100px;
  white-space:      nowrap;
}

.sl-photo-slot .sl-corner {
  position:       absolute;
  font-family:    var(--sl-font-mono);
  font-size:      9px;
  letter-spacing: 0.18em;
  color:          var(--sl-ash);
  opacity:        0.6;
}

.sl-photo-slot .sl-corner.tl {
  top:  10px;
  left: 12px;
}

.sl-photo-slot .sl-corner.br {
  bottom: 10px;
  right:  12px;
}


/* ============================================================
   7. BUTTONS
   ============================================================ */
.sl-btn {
  display:         inline-flex;
  align-items:     center;
  gap:             10px;
  padding:         14px 22px;
  font-family:     var(--sl-font-body);
  font-weight:     500;
  font-size:       14.5px;
  letter-spacing:  0.04em;
  border-radius:   2px;
  text-decoration: none;
  cursor:          pointer;
  border:          1px solid transparent;
  transition:      transform 0.18s ease,
                   background 0.18s ease,
                   color 0.18s ease,
                   border-color 0.18s ease;
}

.sl-btn-primary {
  background:   var(--sl-ink);
  color:        var(--sl-paper);
  border-color: var(--sl-ink);
}

.sl-btn-primary:hover {
  background: var(--sl-ink-2);
  transform:  translateY(-1px);
}

.sl-btn-ghost {
  background:   transparent;
  color:        var(--sl-ink);
  border-color: var(--sl-ink);
}

.sl-btn-ghost:hover {
  background: var(--sl-ink);
  color:      var(--sl-paper);
}

.sl-btn-gold {
  background:   var(--sl-gold);
  color:        var(--sl-ink);
  border-color: var(--sl-gold);
}

.sl-btn-gold:hover {
  background:   var(--sl-gold-2);
  border-color: var(--sl-gold-2);
  color:        var(--sl-paper);
}

.sl-btn .sl-arrow {
  display:    inline-block;
  transition: transform 0.2s ease;
}

.sl-btn:hover .sl-arrow {
  transform: translateX(4px);
}


/* ============================================================
   8. NAV  (sticky, blur, condenses on scroll)
   ============================================================ */
.sl-nav {
  position:            sticky;
  top:                 0;
  z-index:             50;
  background:          color-mix(in oklab, var(--sl-paper) 88%, transparent);
  backdrop-filter:     blur(14px) saturate(120%);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  border-bottom:       1px solid transparent;
  transition:          border-color 0.2s ease, padding 0.2s ease;
}

.sl-nav.scrolled {
  border-bottom-color: var(--sl-line);
}

.sl-nav-inner {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         18px var(--sl-gutter);
  max-width:       var(--sl-max);
  margin:          0 auto;
}

.sl-nav.scrolled .sl-nav-inner {
  padding-top:    12px;
  padding-bottom: 12px;
}

.sl-logo {
  display:         flex;
  align-items:     center;
  gap:             10px;
  color:           var(--sl-ink);
  text-decoration: none;
}

.sl-logo .sl-mark {
  font-family:    var(--sl-font-display);
  font-size:      22px;
  font-weight:    600;
  letter-spacing: 0.06em;
}

.sl-logo .sl-sub {
  font-family:    var(--sl-font-mono);
  font-size:      9px;
  letter-spacing: 0.2em;
  color:          var(--sl-ash);
  display:        block;
  line-height:    1.2;
  margin-top:     2px;
}

.sl-nav-links {
  display:     flex;
  align-items: center;
  gap:         26px;
}

.sl-nav-links a {
  font-size:       13.5px;
  color:           var(--sl-ink);
  text-decoration: none;
  font-weight:     500;
  letter-spacing:  0.02em;
  padding:         4px 0;
}

.sl-nav-links a:hover {
  color: var(--sl-gold-2);
}

.sl-nav-cta {
  padding:   10px 18px;
  font-size: 13px;
}

@media (max-width: 900px) {
  .sl-nav-links a:not(.sl-nav-cta) {
    display: none;
  }
}


/* ============================================================
   9. HERO  (split grid layout)
   ============================================================ */
.sl-hero {
  position:   relative;
  padding:    64px 0 96px;
  overflow:   hidden;
  background: var(--sl-paper);
}

.sl-hero-inner {
  position:              relative;
  display:               grid;
  grid-template-columns: 1.05fr 1fr;
  gap:                   64px;
  align-items:           center;
  z-index:               1;
}

.sl-hero-eyebrow {
  display:       flex;
  align-items:   center;
  gap:           12px;
  margin-bottom: 24px;
}

.sl-hero-eyebrow .sl-dot {
  width:         6px;
  height:        6px;
  background:    var(--sl-gold);
  border-radius: 50%;
}

.sl-hero h1 {
  font-family:    var(--sl-font-display);
  font-weight:    600;
  font-size:      clamp(36px, 5.2vw, 68px);
  line-height:    1.2;
  letter-spacing: 0.005em;
  margin:         0 0 28px;
  color:          var(--sl-ink);
}

.sl-hero h1 .sl-accent {
  background: linear-gradient(
    180deg,
    transparent 65%,
    color-mix(in oklab, var(--sl-gold) 50%, transparent) 65%
  );
  padding: 0 2px;
}

.sl-hero .sl-sub {
  font-size:   17px;
  line-height: 2;
  color:       var(--sl-ash-2);
  margin:      0 0 36px;
  max-width:   36em;
  text-wrap:   pretty;
}

.sl-hero-ctas {
  display:   flex;
  gap:       14px;
  flex-wrap: wrap;
}

.sl-hero-right {
  position:              relative;
  display:               grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows:    220px 140px;
  gap:                   14px;
}

.sl-hero-right .sl-ps-1 {
  grid-column: 1 / 3;
  grid-row:    1;
}

.sl-hero-right .sl-ps-2 {
  grid-column: 1 / 2;
  grid-row:    2;
}

.sl-hero-right .sl-ps-3 {
  grid-column: 2 / 3;
  grid-row:    2;
}

.sl-hero-tags {
  position: absolute;
  left:     -12px;
  bottom:   -32px;
  display:  flex;
  flex-wrap: wrap;
  gap:      8px;
}

.sl-tag-chip {
  font-family:    var(--sl-font-mono);
  font-size:      10.5px;
  letter-spacing: 0.16em;
  padding:        7px 12px;
  background:     var(--sl-card);
  border:         1px solid var(--sl-line);
  border-radius:  100px;
  color:          var(--sl-ink);
  display:        inline-flex;
  align-items:    center;
  gap:            6px;
}

.sl-tag-chip::before {
  content:       "";
  width:         5px;
  height:        5px;
  border-radius: 50%;
  background:    var(--sl-gold);
}

/* Hero bridge backdrop */
.sl-hero-bridge {
  position:       absolute;
  inset:          auto -8% -6% -8%;
  height:         70%;
  pointer-events: none;
  opacity:        var(--sl-bridge-opacity);
  z-index:        0;
}

/* Hero meta row */
.sl-hero-meta {
  display:    flex;
  gap:        28px;
  flex-wrap:  wrap;
  margin-top: 56px;
}

.sl-hero-meta-item {
  display:        flex;
  flex-direction: column;
  gap:            4px;
}

.sl-hero-meta-item .sl-k {
  font-family:    var(--sl-font-mono);
  font-size:      10px;
  letter-spacing: 0.2em;
  color:          var(--sl-ash);
}

.sl-hero-meta-item .sl-v {
  font-size:   13px;
  color:       var(--sl-ink);
  font-weight: 500;
}

@media (max-width: 860px) {
  .sl-hero-inner {
    grid-template-columns: 1fr;
    gap:                   40px;
  }

  .sl-hero-right {
    grid-template-rows: 200px 120px;
  }
}


/* ============================================================
   10. BRIDGE CONNECTOR  (between sections)
   ============================================================ */
.sl-bridge-connector {
  position:       relative;
  height:         80px;
  pointer-events: none;
  opacity:        var(--sl-bridge-opacity);
}

.sl-bridge-connector svg {
  width:   100%;
  height:  100%;
  display: block;
}


/* ============================================================
   11. ENTRIES  (3 ways to start)
   ============================================================ */
.sl-entries {
  padding-bottom: 56px;
}

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

.sl-entry-card {
  background:      var(--sl-card);
  border:          1px solid var(--sl-line);
  position:        relative;
  overflow:        hidden;
  display:         flex;
  flex-direction:  column;
  transition:      transform 0.25s ease,
                   box-shadow 0.25s ease,
                   border-color 0.25s ease;
  text-decoration: none;
  color:           inherit;
}

.sl-entry-card:hover {
  transform:    translateY(-4px);
  box-shadow:   0 22px 44px -22px rgba(29, 42, 64, 0.22);
  border-color: var(--sl-gold);
}

.sl-entry-card .sl-num {
  position:       absolute;
  top:            16px;
  left:           18px;
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  letter-spacing: 0.2em;
  color:          var(--sl-gold-2);
  z-index:        2;
}

.sl-entry-card .sl-photo {
  aspect-ratio: 16 / 11;
}

.sl-entry-card .sl-body {
  padding:        26px 26px 28px;
  flex:           1;
  display:        flex;
  flex-direction: column;
}

.sl-entry-card h3 {
  font-family:    var(--sl-font-display);
  font-weight:    600;
  font-size:      22px;
  line-height:    1.45;
  margin:         0 0 12px;
  letter-spacing: 0.01em;
}

.sl-entry-card p {
  font-size:   14.5px;
  color:       var(--sl-ash-2);
  line-height: 1.85;
  margin:      0 0 22px;
  flex:        1;
}

.sl-entry-audience {
  display:       flex;
  flex-wrap:     wrap;
  gap:           6px;
  margin-bottom: 22px;
}

.sl-entry-audience span {
  font-family:    var(--sl-font-mono);
  font-size:      10px;
  letter-spacing: 0.12em;
  padding:        4px 10px;
  border:         1px solid var(--sl-line);
  border-radius:  2px;
  color:          var(--sl-ash-2);
}

.sl-entry-card .sl-more {
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  letter-spacing: 0.2em;
  color:          var(--sl-ink);
  display:        inline-flex;
  align-items:    center;
  gap:            8px;
}

.sl-entry-card:hover .sl-more {
  color: var(--sl-gold-2);
}

.sl-entry-card .sl-more .sl-ar {
  transition: transform 0.2s ease;
}

.sl-entry-card:hover .sl-more .sl-ar {
  transform: translateX(4px);
}

@media (max-width: 880px) {
  .sl-entries-grid {
    grid-template-columns: 1fr;
  }
}


/* ============================================================
   12. SERVICES  (4 columns)
   ============================================================ */
.sl-services-grid {
  display:               grid;
  grid-template-columns: repeat(4, 1fr);
  gap:                   0;
  border-top:            1px solid var(--sl-line);
  border-left:           1px solid var(--sl-line);
}

.sl-service-card {
  background:     var(--sl-card);
  border-right:   1px solid var(--sl-line);
  border-bottom:  1px solid var(--sl-line);
  padding:        32px 28px 36px;
  display:        flex;
  flex-direction: column;
  position:       relative;
  transition:     background 0.2s ease;
}

.sl-service-card:hover {
  background: var(--sl-paper-2);
}

.sl-service-card .sl-num {
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  letter-spacing: 0.2em;
  color:          var(--sl-gold-2);
  margin-bottom:  18px;
}

.sl-service-card .sl-icon-box {
  height:          110px;
  display:         flex;
  align-items:     center;
  justify-content: center;
  margin-bottom:   24px;
  color:           var(--sl-ink);
}

.sl-service-card h3 {
  font-family:    var(--sl-font-display);
  font-weight:    600;
  font-size:      19px;
  line-height:    1.45;
  margin:         0 0 16px;
  min-height:     3em;
}

.sl-service-card ul {
  list-style: none;
  padding:    0;
  margin:     0 0 22px;
  font-size:  13.5px;
  color:      var(--sl-ash-2);
  line-height: 1.7;
  flex:       1;
}

.sl-service-card ul li {
  position:      relative;
  padding-left:  18px;
  margin-bottom: 6px;
}

.sl-service-card ul li::before {
  content:    "";
  position:   absolute;
  left:       0;
  top:        11px;
  width:      8px;
  height:     1px;
  background: var(--sl-gold-2);
}

.sl-service-card .sl-read-more {
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  letter-spacing: 0.2em;
  color:          var(--sl-ink);
  text-decoration: none;
  display:        inline-flex;
  align-items:    center;
  gap:            6px;
}

@media (max-width: 1100px) {
  .sl-services-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .sl-services-grid {
    grid-template-columns: 1fr;
  }
}


/* ============================================================
   13. COMMUNITY SECTION  (dark background)
   ============================================================ */
.sl-community {
  background:  var(--sl-ink);
  color:       var(--sl-paper);
  padding:     96px 0;
  position:    relative;
  overflow:    hidden;
  margin-top:  64px;
}

.sl-community .sl-wrap {
  position: relative;
  z-index:  1;
}

.sl-community .sl-eyebrow {
  color: color-mix(in oklab, var(--sl-gold) 80%, white);
}

.sl-community h2 {
  font-family:    var(--sl-font-display);
  font-weight:    600;
  font-size:      clamp(30px, 4vw, 52px);
  line-height:    1.25;
  margin:         16px 0 22px;
  color:          var(--sl-paper);
}

.sl-community .sl-sub {
  font-size:   16px;
  color:       color-mix(in oklab, var(--sl-paper) 78%, transparent);
  max-width:   38em;
  line-height: 2;
}

.sl-community-grid {
  margin-top:            56px;
  display:               grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap:                   56px;
  align-items:           start;
}

.sl-community-tabs {
  display:        flex;
  flex-direction: column;
  gap:            8px;
  border-left:    1px solid color-mix(in oklab, var(--sl-paper) 18%, transparent);
}

.sl-community-tab {
  background:      transparent;
  border:          none;
  color:           color-mix(in oklab, var(--sl-paper) 65%, transparent);
  text-align:      left;
  padding:         18px 22px;
  cursor:          pointer;
  font-family:     var(--sl-font-body);
  display:         flex;
  flex-direction:  column;
  gap:             4px;
  border-left:     2px solid transparent;
  margin-left:     -1px;
  transition:      color 0.18s ease,
                   border-color 0.18s ease,
                   background 0.18s ease;
}

.sl-community-tab:hover {
  color:      var(--sl-paper);
  background: color-mix(in oklab, var(--sl-paper) 4%, transparent);
}

.sl-community-tab.active {
  color:            var(--sl-paper);
  border-left-color: var(--sl-gold);
  background:       color-mix(in oklab, var(--sl-paper) 5%, transparent);
}

.sl-community-tab .sl-num {
  font-family:    var(--sl-font-mono);
  font-size:      10px;
  letter-spacing: 0.22em;
  color:          var(--sl-gold);
}

.sl-community-tab .sl-ttl {
  font-family: var(--sl-font-display);
  font-size:   18px;
  font-weight: 600;
}

.sl-community-panel {
  background:     color-mix(in oklab, var(--sl-paper) 6%, var(--sl-ink));
  border:         1px solid color-mix(in oklab, var(--sl-paper) 14%, transparent);
  padding:        36px 36px 32px;
  min-height:     360px;
  display:        flex;
  flex-direction: column;
  gap:            24px;
}

/* Panels hidden by default, show when active */
.sl-tab-panel {
  display:        none;
  flex-direction: column;
  gap:            24px;
}

.sl-tab-panel.active {
  display: flex;
}

.sl-community-panel h3 {
  font-family: var(--sl-font-display);
  font-weight: 600;
  font-size:   26px;
  margin:      0;
  color:       var(--sl-paper);
}

.sl-community-panel p.sl-panel-body {
  margin:      0;
  color:       color-mix(in oklab, var(--sl-paper) 75%, transparent);
  line-height: 1.95;
  font-size:   14.5px;
}

.sl-ledger {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   18px;
}

.sl-ledger-cell {
  border-top:  1px solid color-mix(in oklab, var(--sl-paper) 18%, transparent);
  padding-top: 14px;
}

.sl-ledger-cell .sl-k {
  font-family:    var(--sl-font-mono);
  font-size:      10px;
  letter-spacing: 0.18em;
  color:          color-mix(in oklab, var(--sl-paper) 60%, transparent);
  margin-bottom:  6px;
}

.sl-ledger-cell .sl-v {
  font-family: var(--sl-font-display);
  font-size:   28px;
  color:       var(--sl-paper);
  display:     flex;
  align-items: baseline;
  gap:         4px;
}

.sl-ledger-cell .sl-unit {
  font-family: var(--sl-font-body);
  font-size:   13px;
  color:       color-mix(in oklab, var(--sl-paper) 70%, transparent);
}

.sl-event-list {
  display: grid;
  gap:     10px;
}

.sl-event-list-label {
  font-family:    var(--sl-font-mono);
  font-size:      10px;
  letter-spacing: 0.2em;
  color:          color-mix(in oklab, var(--sl-paper) 55%, transparent);
  margin-bottom:  4px;
}

.sl-event-row {
  display:               grid;
  grid-template-columns: 90px 1fr auto;
  gap:                   18px;
  padding:               12px 0;
  border-bottom:         1px dotted color-mix(in oklab, var(--sl-paper) 16%, transparent);
  align-items:           center;
}

.sl-event-row:last-child {
  border-bottom: none;
}

.sl-event-row .sl-date {
  font-family:    var(--sl-font-mono);
  font-size:      12px;
  color:          var(--sl-gold);
  letter-spacing: 0.06em;
}

.sl-event-row .sl-name {
  font-size: 14px;
  color:     var(--sl-paper);
}

.sl-event-row .sl-meta {
  font-family:    var(--sl-font-mono);
  font-size:      10px;
  letter-spacing: 0.18em;
  color:          color-mix(in oklab, var(--sl-paper) 55%, transparent);
}

.sl-panel-btns {
  display:    flex;
  gap:        12px;
  margin-top: auto;
  padding-top: 8px;
}

.sl-panel-btns .sl-btn-ghost {
  color:        var(--sl-paper);
  border-color: color-mix(in oklab, var(--sl-paper) 45%, transparent);
}

.sl-panel-btns .sl-btn-ghost:hover {
  background: color-mix(in oklab, var(--sl-paper) 10%, transparent);
  color:      var(--sl-paper);
}

@media (max-width: 900px) {
  .sl-community-grid {
    grid-template-columns: 1fr;
  }

  .sl-community-tabs {
    flex-direction: row;
    flex-wrap:      wrap;
    border-left:    none;
    border-top:     1px solid color-mix(in oklab, var(--sl-paper) 18%, transparent);
    padding-top:    8px;
  }

  .sl-community-tab {
    border-left:  none;
    border-top:   2px solid transparent;
    padding:      14px 16px;
    min-width:    140px;
  }

  .sl-community-tab.active {
    border-left-color: transparent;
    border-top-color:  var(--sl-gold);
  }
}


/* ============================================================
   14. REASONS  (4 columns)
   ============================================================ */
.sl-reasons-grid {
  display:               grid;
  grid-template-columns: repeat(4, 1fr);
  gap:                   0;
  border-top:            1px solid var(--sl-line);
}

.sl-reason-card {
  border-right:  1px solid var(--sl-line);
  padding:       36px 28px;
  display:       flex;
  flex-direction: column;
  gap:           18px;
}

.sl-reason-card:last-child {
  border-right: none;
}

.sl-reason-card .sl-num {
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  letter-spacing: 0.2em;
  color:          var(--sl-gold-2);
}

.sl-reason-card .sl-figure {
  height:      90px;
  display:     flex;
  align-items: center;
  color:       var(--sl-ink);
}

.sl-reason-card .sl-figure .sl-big {
  font-family: var(--sl-font-display);
  font-size:   56px;
  font-weight: 600;
  line-height: 1;
  color:       var(--sl-ink);
  display:     flex;
  align-items: baseline;
  gap:         4px;
}

.sl-reason-card .sl-figure .sl-big .sl-u {
  font-family: var(--sl-font-body);
  font-size:   14px;
  color:       var(--sl-ash);
  font-weight: 500;
}

.sl-reason-card h3 {
  font-family: var(--sl-font-display);
  font-weight: 600;
  font-size:   19px;
  margin:      0;
  line-height: 1.5;
}

.sl-reason-card p {
  font-size:   13.5px;
  color:       var(--sl-ash-2);
  line-height: 1.85;
  margin:      0;
}

@media (max-width: 1000px) {
  .sl-reasons-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .sl-reason-card:nth-child(2) {
    border-right: none;
  }
}

@media (max-width: 600px) {
  .sl-reasons-grid {
    grid-template-columns: 1fr;
  }

  .sl-reason-card {
    border-right:  none;
    border-bottom: 1px solid var(--sl-line);
  }
}


/* ============================================================
   15. FOUNDER
   ============================================================ */
.sl-founder {
  padding:   96px 0 64px;
  position:  relative;
  overflow:  hidden;
}

.sl-founder-inner {
  display:               grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap:                   64px;
  align-items:           start;
}

.sl-founder-photo {
  aspect-ratio: 4 / 5;
  position:     relative;
}

.sl-founder-photo .sl-stamp {
  position:        absolute;
  bottom:          -16px;
  right:           -16px;
  width:           110px;
  height:          110px;
  background:      var(--sl-gold);
  display:         flex;
  align-items:     center;
  justify-content: center;
  flex-direction:  column;
  color:           var(--sl-ink);
  font-family:     var(--sl-font-mono);
  text-align:      center;
  border-radius:   50%;
  font-size:       9px;
  letter-spacing:  0.18em;
}

.sl-founder-photo .sl-stamp .sl-big {
  font-family:    var(--sl-font-display);
  font-size:      22px;
  font-weight:    600;
  letter-spacing: 0;
  margin:         4px 0;
}

.sl-founder-body .sl-eyebrow {
  margin-bottom: 16px;
  display:       block;
}

.sl-founder-body h2 {
  font-family:    var(--sl-font-display);
  font-weight:    600;
  font-size:      clamp(28px, 3.4vw, 42px);
  line-height:    1.3;
  margin:         0 0 28px;
}

.sl-founder-body .sl-quote {
  font-family:  var(--sl-font-display);
  font-size:    18px;
  line-height:  2;
  color:        var(--sl-ash-2);
  border-left:  2px solid var(--sl-gold);
  padding:      4px 0 4px 22px;
  margin:       0 0 30px;
}

.sl-founder-body .sl-bio {
  font-size:   14.5px;
  color:       var(--sl-ash-2);
  line-height: 1.95;
  margin:      0 0 28px;
}

.sl-founder-meta {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   24px 32px;
  border-top:            1px solid var(--sl-line);
  padding-top:           24px;
}

.sl-founder-meta .sl-k {
  font-family:    var(--sl-font-mono);
  font-size:      10px;
  letter-spacing: 0.2em;
  color:          var(--sl-ash);
  margin-bottom:  4px;
}

.sl-founder-meta .sl-v {
  font-size:   14px;
  color:       var(--sl-ink);
  line-height: 1.7;
}

.sl-sig {
  display:     flex;
  align-items: baseline;
  gap:         14px;
  margin-top:  24px;
}

.sl-sig .sl-jp {
  font-family:    var(--sl-font-display);
  font-size:      26px;
  font-weight:    600;
  letter-spacing: 0.08em;
}

.sl-sig .sl-en {
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  letter-spacing: 0.2em;
  color:          var(--sl-ash);
}

/* Bridge bg behind founder */
.sl-founder-bridge-bg {
  position:       absolute;
  right:          -6%;
  bottom:         -12%;
  width:          52%;
  max-width:      720px;
  opacity:        0.7;
  pointer-events: none;
}

@media (max-width: 880px) {
  .sl-founder-inner {
    grid-template-columns: 1fr;
  }

  .sl-founder-photo {
    max-width: 380px;
  }
}


/* ============================================================
   16. MVV
   ============================================================ */
.sl-mvv {
  padding: 32px 0 96px;
}

.sl-mvv-grid {
  display:               grid;
  grid-template-columns: 200px 1fr;
  gap:                   56px;
  align-items:           start;
}

.sl-mvv-grid .sl-label {
  font-family: var(--sl-font-display);
  font-size:   28px;
  font-weight: 600;
}

.sl-mvv-grid .sl-label .sl-en {
  font-family:    var(--sl-font-mono);
  font-size:      10px;
  letter-spacing: 0.22em;
  color:          var(--sl-ash);
  display:        block;
  margin-top:     6px;
}

.sl-mvv-rows {
  display:        flex;
  flex-direction: column;
}

.sl-mvv-row {
  display:               grid;
  grid-template-columns: 130px 1fr 1.2fr;
  gap:                   28px;
  padding:               28px 0;
  border-top:            1px solid var(--sl-line);
  align-items:           start;
}

.sl-mvv-row:last-child {
  border-bottom: 1px solid var(--sl-line);
}

.sl-mvv-row .sl-tag {
  font-family: var(--sl-font-display);
  font-weight: 600;
  font-size:   20px;
  color:       var(--sl-ink);
  display:     flex;
  align-items: baseline;
  gap:         10px;
}

.sl-mvv-row .sl-tag .sl-en {
  font-family:    var(--sl-font-mono);
  font-size:      10px;
  letter-spacing: 0.18em;
  color:          var(--sl-gold-2);
}

.sl-mvv-row .sl-ttl {
  font-family: var(--sl-font-display);
  font-size:   18px;
  line-height: 1.6;
  color:       var(--sl-ink);
  margin:      0;
}

.sl-mvv-row .sl-desc {
  font-size:   14px;
  line-height: 1.95;
  color:       var(--sl-ash-2);
  margin:      0;
}

@media (max-width: 880px) {
  .sl-mvv-grid {
    grid-template-columns: 1fr;
    gap:                   16px;
  }

  .sl-mvv-row {
    grid-template-columns: 1fr;
    gap:                   8px;
  }
}


/* ============================================================
   17. FINAL CTA  (dark)
   ============================================================ */
.sl-final-cta {
  background: var(--sl-ink);
  color:      var(--sl-paper);
  padding:    88px 0;
  position:   relative;
  overflow:   hidden;
}

.sl-final-cta .sl-wrap {
  position: relative;
  z-index:  1;
}

.sl-final-cta .sl-grid {
  display:               grid;
  grid-template-columns: 1.2fr auto;
  gap:                   48px;
  align-items:           center;
}

.sl-final-cta h2 {
  font-family:    var(--sl-font-display);
  font-weight:    600;
  font-size:      clamp(28px, 3.4vw, 42px);
  line-height:    1.4;
  margin:         14px 0;
  color:          var(--sl-paper);
}

.sl-final-cta .sl-sub {
  color:       color-mix(in oklab, var(--sl-paper) 75%, transparent);
  font-size:   15px;
  line-height: 1.95;
}

.sl-final-cta .sl-ctas {
  display:        flex;
  flex-direction: column;
  gap:            12px;
  min-width:      280px;
}

.sl-final-cta .sl-ctas .sl-btn-gold {
  justify-content: center;
}

.sl-final-cta .sl-ctas .sl-btn-ghost {
  color:           var(--sl-paper);
  border-color:    color-mix(in oklab, var(--sl-paper) 40%, transparent);
  justify-content: center;
}

.sl-final-cta .sl-ctas .sl-btn-ghost:hover {
  background: color-mix(in oklab, var(--sl-paper) 10%, transparent);
  color:      var(--sl-paper);
}

.sl-cta-bridge-bg {
  position:       absolute;
  inset:          0;
  opacity:        0.18;
  z-index:        0;
  pointer-events: none;
}

.sl-reply-note {
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  letter-spacing: 0.18em;
  color:          color-mix(in oklab, var(--sl-paper) 60%, transparent);
  margin-top:     6px;
  text-align:     center;
}

@media (max-width: 800px) {
  .sl-final-cta .sl-grid {
    grid-template-columns: 1fr;
  }
}


/* ============================================================
   18. FOOTER
   ============================================================ */
.sl-footer {
  background:  var(--sl-paper);
  padding:     48px 0 32px;
  border-top:  1px solid var(--sl-line);
}

.sl-footer .sl-row {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  gap:             24px;
  flex-wrap:       wrap;
}

.sl-footer .sl-links {
  display:        flex;
  gap:            22px;
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  letter-spacing: 0.18em;
}

.sl-footer .sl-links a {
  color:           var(--sl-ash);
  text-decoration: none;
}

.sl-footer .sl-links a:hover {
  color: var(--sl-ink);
}

.sl-footer .sl-copy {
  font-family:    var(--sl-font-mono);
  font-size:      11px;
  letter-spacing: 0.16em;
  color:          var(--sl-ash);
}


/* ============================================================
   19. SCROLL REVEAL & BRIDGE DRAW ANIMATIONS
   ============================================================ */
.sl-reveal {
  opacity:    0;
  transform:  translateY(18px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.sl-reveal.in {
  opacity:   1;
  transform: translateY(0);
}

/* Bridge SVG draw-on animation */
.sl-bridge-draw path,
.sl-bridge-draw line {
  stroke-dasharray:  var(--sl-len, 2000);
  stroke-dashoffset: var(--sl-len, 2000);
  transition:        stroke-dashoffset 1.4s ease;
}

.sl-bridge-draw.in path,
.sl-bridge-draw.in line {
  stroke-dashoffset: 0;
}


/* ============================================================
   20. AI SPRINT SECTION (トップページ埋め込みブロック)
   ============================================================ */

.sl-sprint {
  background: var(--sl-ink-2);
  color: var(--sl-paper);
  padding: clamp(64px, 10vw, 112px) 0;
}
.sl-sprint .sl-section-header h2,
.sl-sprint .sl-section-header .sl-num,
.sl-sprint .sl-section-header .sl-en {
  color: var(--sl-paper);
}
.sl-sprint .sl-section-header {
  border-bottom-color: rgba(243,239,232,0.15);
}

.sl-sprint-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  margin: 40px 0 48px;
  padding: 36px 40px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(200,148,86,0.35);
  border-radius: 4px;
}
@media (max-width: 640px) {
  .sl-sprint-hero { flex-direction: column; align-items: flex-start; padding: 28px 24px; }
}

.sl-sprint-price {
  font-family: var(--sl-font-mono);
  font-size: clamp(13px, 2vw, 15px);
  color: var(--sl-gold);
  letter-spacing: 0.1em;
  margin: 0 0 8px;
}
.sl-sprint-hero h3 {
  font-family: var(--sl-font-display);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 600;
  color: var(--sl-paper);
  margin: 0 0 10px;
  line-height: 1.2;
}
.sl-sprint-sub {
  font-size: clamp(14px, 2vw, 16px);
  color: rgba(243,239,232,0.7);
  margin: 0;
}
.sl-sprint-badge {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  border: 1px solid rgba(200,148,86,0.4);
  border-radius: 4px;
  padding: 20px 28px;
  text-align: center;
}
.sl-sprint-badge .sl-num {
  font-family: var(--sl-font-mono);
  font-size: 10px;
  color: var(--sl-gold);
  letter-spacing: 0.15em;
  display: block;
  margin: 0;
}
.sl-sprint-badge .sl-big {
  font-family: var(--sl-font-display);
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--sl-paper);
  line-height: 1;
}
.sl-sprint-badge .sl-u { font-size: 1rem; font-weight: 400; }
.sl-sprint-badge .sl-note {
  font-size: 11px;
  color: rgba(243,239,232,0.5);
  font-family: var(--sl-font-mono);
}

.sl-sprint-steps {
  display: flex;
  align-items: stretch;
  gap: 0;
  margin-bottom: 48px;
}
@media (max-width: 720px) {
  .sl-sprint-steps { flex-direction: column; }
}

.sl-sprint-step {
  display: flex;
  align-items: center;
  flex: 1;
}
.sl-step-card {
  flex: 1;
  padding: 24px 20px;
  border: 1px solid rgba(200,148,86,0.2);
  border-radius: 4px;
}
.sl-step-card .sl-num {
  font-family: var(--sl-font-mono);
  font-size: 10px;
  color: var(--sl-gold);
  letter-spacing: 0.12em;
  margin-bottom: 8px;
  display: block;
}
.sl-step-card h4 {
  font-family: var(--sl-font-display);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--sl-paper);
  margin: 0 0 8px;
}
.sl-step-card p {
  font-size: 13px;
  color: rgba(243,239,232,0.65);
  margin: 0;
  line-height: 1.65;
}
.sl-step-arrow {
  flex-shrink: 0;
  padding: 0 12px;
  color: rgba(200,148,86,0.5);
}
@media (max-width: 720px) {
  .sl-step-arrow { transform: rotate(90deg); padding: 8px 0; }
}

.sl-sprint-conditions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 48px;
}
@media (max-width: 640px) {
  .sl-sprint-conditions { grid-template-columns: 1fr; }
}

.sl-condition-card {
  padding: 24px 20px;
  background: rgba(255,255,255,0.03);
  border-top: 2px solid var(--sl-gold);
}
.sl-cond-label {
  font-family: var(--sl-font-mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  color: var(--sl-gold);
  margin-bottom: 10px;
}
.sl-cond-value {
  font-family: var(--sl-font-display);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--sl-paper);
  margin-bottom: 6px;
}
.sl-cond-note {
  font-size: 12px;
  color: rgba(243,239,232,0.5);
}

.sl-sprint-ctas {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

/* ============================================================
   21. WP THEME INTEGRATION
   ============================================================ */
body.sl-corp-page .site-header,
body.sl-corp-page #header,
body.sl-corp-page .global-nav,
body.sl-corp-page .header-area,
body.page-template-page-streamline .site-header,
body.page-template-page-streamline #header,
body.page-template-page-streamline .global-nav,
body.page-template-page-streamline .header-area {
  display: none !important;
}
