/* ===== Furniture Story — B2B & Trade page. Scoped under .fs-b2b.
   Uses global :root tokens from furniture_story_chrome.css. ===== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Inter:wght@300;400;500;600&display=swap');

.fs-b2b { --line-strong:#D7CFC2; font-family:var(--sans); font-size:16px; line-height:1.7; color:var(--ink); background:var(--bg); -webkit-font-smoothing:antialiased; }
.fs-b2b *, .fs-b2b *::before, .fs-b2b *::after { margin:0; padding:0; box-sizing:border-box; }
.fs-b2b img { max-width:100%; display:block; }
.fs-b2b a { color:inherit; text-decoration:none; transition:opacity var(--transition); }
.fs-b2b a:hover { opacity:0.75; }
.fs-b2b .b2b-wrap { max-width:1180px; margin:0 auto; padding:0 48px; }

/* eyebrow */
.fs-b2b .chapter-tag, .fs-b2b .chapter-tag-c { font-size:11px; letter-spacing:0.3em; text-transform:uppercase; color:var(--terracotta); font-weight:600; display:inline-flex; align-items:center; gap:14px; margin-bottom:24px; }
.fs-b2b .chapter-tag::before, .fs-b2b .chapter-tag::after, .fs-b2b .chapter-tag-c::before, .fs-b2b .chapter-tag-c::after { content:""; flex:0 0 36px; height:1px; background:var(--line-strong); }
.fs-b2b .chapter-tag::before { display:none; }

/* hero */
.fs-b2b .b2b-hero { padding:88px 0 72px; border-bottom:1px solid var(--line); background:linear-gradient(180deg, var(--bg-alt), var(--bg)); }
.fs-b2b .b2b-hero-grid { display:grid; grid-template-columns:1.04fr 0.96fr; gap:56px; align-items:center; }
.fs-b2b .b2b-hero-text { min-width:0; }
.fs-b2b .b2b-hero h1 { font-family:var(--serif); font-size:clamp(40px, 4.4vw, 72px); line-height:1.05; font-weight:500; letter-spacing:-0.015em; max-width:none; margin-bottom:22px; }
.fs-b2b .b2b-hero h1 em { font-style:italic; color:var(--terracotta); font-weight:400; }
.fs-b2b .b2b-deck { font-family:var(--serif); font-style:italic; font-size:20px; line-height:1.5; color:var(--ink-soft); max-width:54ch; margin-bottom:34px; }
.fs-b2b .b2b-actions { display:flex; gap:14px; flex-wrap:wrap; }
.fs-b2b .b2b-hero-media { border-radius:2px; overflow:hidden; aspect-ratio:4/3; background:var(--bg-warm); box-shadow:0 20px 50px rgba(26,22,18,0.13); }
.fs-b2b .b2b-hero-media img { width:100%; height:100%; object-fit:cover; }

/* buttons */
.fs-b2b .btn { display:inline-flex; align-items:center; gap:10px; padding:16px 28px; font-family:var(--sans); font-size:12px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; border-radius:2px; cursor:pointer; transition:all var(--transition); }
.fs-b2b .btn svg { width:15px; height:15px; }
.fs-b2b .btn-primary { background:var(--ink); color:var(--bg); border:1px solid var(--ink); }
.fs-b2b .btn-primary:hover { background:var(--accent); border-color:var(--accent); color:var(--bg); opacity:1; }
.fs-b2b .btn-outline { background:transparent; color:var(--ink); border:1px solid var(--ink); }
.fs-b2b .btn-outline:hover { background:var(--ink); color:var(--bg); opacity:1; }
.fs-b2b .btn-block { width:100%; justify-content:center; margin-top:8px; }

/* generic section */
.fs-b2b .b2b-section { padding:84px 0; }
.fs-b2b .b2b-values-sec { background:var(--white); border-bottom:1px solid var(--line); }
.fs-b2b .b2b-audience-sec { background:var(--bg); }
.fs-b2b .b2b-steps-sec { background:var(--bg-alt); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.fs-b2b .b2b-apply-sec { background:var(--bg); }
.fs-b2b .section-head { text-align:center; max-width:680px; margin:0 auto 52px; }
.fs-b2b .section-head .chapter-tag-c { justify-content:center; }
.fs-b2b .section-head .chapter-tag-c::before { display:inline-block; }
.fs-b2b .section-head h2 { font-family:var(--serif); font-size:clamp(32px, 4vw, 50px); line-height:1.12; font-weight:500; letter-spacing:-0.01em; margin-bottom:14px; }
.fs-b2b .section-head h2 em { font-style:italic; color:var(--terracotta); font-weight:400; }
.fs-b2b .section-head p { font-size:16px; color:var(--ink-soft); }

/* value props */
.fs-b2b .b2b-values { display:grid; grid-template-columns:repeat(4, 1fr); gap:32px; }
.fs-b2b .b2b-value .vi { width:46px; height:46px; border-radius:50%; background:var(--bg-warm); color:var(--accent); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.fs-b2b .b2b-value .vi svg { width:20px; height:20px; }
.fs-b2b .b2b-value h3 { font-family:var(--serif); font-size:23px; font-weight:500; line-height:1.2; margin-bottom:10px; }
.fs-b2b .b2b-value p { font-size:14px; line-height:1.7; color:var(--ink-soft); }

/* audience */
.fs-b2b .b2b-audience { display:grid; grid-template-columns:repeat(4, 1fr); gap:0; border:1px solid var(--line); border-radius:2px; overflow:hidden; }
.fs-b2b .aud { padding:36px 30px; border-right:1px solid var(--line); }
.fs-b2b .aud:last-child { border-right:none; }
.fs-b2b .aud .ai { width:40px; height:40px; color:var(--terracotta); margin-bottom:16px; }
.fs-b2b .aud .ai svg { width:32px; height:32px; }
.fs-b2b .aud h4 { font-family:var(--serif); font-size:22px; font-weight:500; margin-bottom:8px; }
.fs-b2b .aud p { font-size:14px; line-height:1.65; color:var(--ink-soft); }

/* steps */
.fs-b2b .b2b-steps { display:grid; grid-template-columns:repeat(4, 1fr); gap:32px; }
.fs-b2b .step .sn { font-family:var(--serif); font-style:italic; font-size:30px; color:var(--terracotta); margin-bottom:14px; }
.fs-b2b .step h4 { font-family:var(--serif); font-size:22px; font-weight:500; margin-bottom:8px; }
.fs-b2b .step p { font-size:14px; line-height:1.65; color:var(--ink-soft); }

/* apply */
.fs-b2b .b2b-apply { display:grid; grid-template-columns:0.9fr 1.1fr; gap:64px; align-items:start; }
.fs-b2b .b2b-apply-intro .lbl { font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--terracotta); font-weight:600; margin-bottom:12px; }
.fs-b2b .b2b-apply-intro h2 { font-family:var(--serif); font-size:clamp(32px, 3.5vw, 48px); line-height:1.12; font-weight:500; letter-spacing:-0.01em; margin-bottom:18px; }
.fs-b2b .b2b-apply-intro h2 em { font-style:italic; color:var(--terracotta); font-weight:400; }
.fs-b2b .b2b-apply-intro > p { font-size:16px; line-height:1.8; color:var(--ink-soft); margin-bottom:26px; }
.fs-b2b .b2b-checklist { list-style:none; display:flex; flex-direction:column; gap:14px; margin-bottom:28px; }
.fs-b2b .b2b-checklist li { display:flex; align-items:flex-start; gap:12px; font-size:15px; color:var(--ink); }
.fs-b2b .b2b-checklist svg { width:20px; height:20px; color:var(--sage); flex:none; margin-top:1px; }
.fs-b2b .b2b-login-note { font-size:14px; color:var(--ink-soft); padding-top:22px; border-top:1px solid var(--line); }
.fs-b2b .b2b-login-note a { color:var(--terracotta); font-weight:500; }

/* form card */
.fs-b2b .form-card { background:var(--bg-alt); padding:44px; border-radius:2px; border:1px solid var(--line); }
.fs-b2b .form-card .lbl { font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--terracotta); font-weight:600; margin-bottom:10px; }
.fs-b2b .form-card h3 { font-family:var(--serif); font-size:clamp(26px, 3vw, 34px); line-height:1.15; font-weight:500; margin-bottom:22px; }
.fs-b2b .form-card h3 em { font-style:italic; color:var(--terracotta); font-weight:400; }
.fs-b2b .field-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.fs-b2b .field-row.full { grid-template-columns:1fr; }
.fs-b2b .field label { display:block; font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-soft); font-weight:600; margin-bottom:7px; }
.fs-b2b .field label .rq { color:var(--terracotta); }
.fs-b2b .field label .opt { text-transform:none; letter-spacing:0; color:var(--muted); font-weight:400; }
.fs-b2b .field input, .fs-b2b .field textarea { width:100%; padding:13px 15px; font-family:var(--sans); font-size:14px; color:var(--ink); background:var(--white); border:1px solid var(--line-strong); border-radius:2px; transition:border-color var(--transition); }
.fs-b2b .field textarea { resize:vertical; min-height:96px; }
.fs-b2b .field input:focus, .fs-b2b .field textarea:focus { outline:none; border-color:var(--ink); }
.fs-b2b .field .fe { color:#C0392B; font-size:12px; margin-top:5px; }
.fs-b2b .b2b-alert { background:#FBEAEA; border:1px solid #E3B7B4; color:#9B2C28; font-size:13px; padding:11px 14px; border-radius:2px; margin-bottom:18px; }
.fs-b2b .b2b-hp { position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.fs-b2b .form-foot { margin-top:16px; font-size:12px; color:var(--muted); line-height:1.6; }
.fs-b2b .form-foot a { text-decoration:underline; text-underline-offset:2px; }

/* success / flash */
.fs-b2b .b2b-flash { background:#EAF3EA; border-bottom:1px solid #CADfCA; }
.fs-b2b .b2b-flash-inner { display:flex; align-items:center; gap:12px; padding:16px 0; color:#2C6B3F; font-size:15px; }
.fs-b2b .b2b-flash-inner svg { width:20px; height:20px; flex:none; }
.fs-b2b .b2b-thanks { text-align:center; }
.fs-b2b .b2b-thanks-ic { width:64px; height:64px; margin:0 auto 18px; border-radius:50%; background:var(--bg-warm); color:var(--accent); display:flex; align-items:center; justify-content:center; }
.fs-b2b .b2b-thanks-ic svg { width:28px; height:28px; }
.fs-b2b .b2b-thanks h3 { font-family:var(--serif); font-size:30px; font-weight:500; margin-bottom:12px; }
.fs-b2b .b2b-thanks p { color:var(--ink-soft); margin-bottom:24px; }

/* responsive */
@media (max-width:1024px) {
  .fs-b2b .b2b-hero-grid { grid-template-columns:1fr; gap:34px; }
  .fs-b2b .b2b-hero-media { aspect-ratio:16/9; }
  .fs-b2b .b2b-values, .fs-b2b .b2b-steps { grid-template-columns:repeat(2, 1fr); gap:36px 32px; }
  .fs-b2b .b2b-audience { grid-template-columns:repeat(2, 1fr); }
  .fs-b2b .aud:nth-child(2) { border-right:none; }
  .fs-b2b .aud:nth-child(1), .fs-b2b .aud:nth-child(2) { border-bottom:1px solid var(--line); }
  .fs-b2b .b2b-apply { grid-template-columns:1fr; gap:40px; }
}
@media (max-width:640px) {
  .fs-b2b .b2b-wrap { padding:0 22px; }
  .fs-b2b .b2b-hero { padding:56px 0 48px; }
  .fs-b2b .b2b-section { padding:56px 0; }
  .fs-b2b .b2b-values, .fs-b2b .b2b-steps, .fs-b2b .b2b-audience { grid-template-columns:1fr; }
  .fs-b2b .aud { border-right:none; border-bottom:1px solid var(--line); }
  .fs-b2b .aud:last-child { border-bottom:none; }
  .fs-b2b .field-row { grid-template-columns:1fr; }
  .fs-b2b .form-card { padding:28px 22px; }
}
