/* ============================================
   Sections CSS — all other page sections
   ============================================ */


/* ====================================================
   REST OF PAGE SECTIONS (unchanged)
   ==================================================== */
.pricing-btn {
  font-family: 'Inter', sans-serif; font-size: 16px; font-weight: 500;
  border-radius: 16px; padding: 14px 16px;
  transition: all 0.2s ease-in; display: inline-block;
  text-align: center; border: none; min-width: 180px; cursor: pointer;
}
.pricing-btn.green { background: var(--ui-green); color: white; }
.pricing-btn.green:hover { background: #14926E; transform: translateY(-1px); }
.pricing-btn.white { background: #fff; color: rgb(17,17,17); border: 1px solid rgb(223,225,231); }
.pricing-btn.white:hover { background: #F9F9F9; transform: translateY(-1px); }

.demo-embed { margin-bottom: 32px; }
.demo-placeholder { border-radius: 16px; overflow: hidden; border: 1px solid rgb(223,225,231); }
.demo-window { background: white; }
.demo-toolbar { display: flex; gap: 6px; padding: 12px 16px; background: #FAFAFA; border-bottom: 1px solid #ECEFF3; }
.dot { width: 12px; height: 12px; border-radius: 50%; }
.dot.red { background: #ff5f57; }
.dot.yellow { background: #ffbd2e; }
.dot.green { background: #28c840; }
.demo-content { min-height: 300px; display: flex; align-items: center; justify-content: center; }
.demo-actions { display: flex; gap: 16px; justify-content: center; }

.templates-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.template-card { background: white; border: 1px solid rgb(223,225,231); border-radius: 16px; overflow: hidden; transition: transform 0.2s, box-shadow 0.2s; cursor: pointer; }
.template-card:hover { transform: translateY(-2px); box-shadow: rgba(0,0,0,0.1) 0px 8px 24px -4px; }
.template-thumb { width: 100%; height: 180px; background: linear-gradient(135deg, #f3ebff, #e8e4f0); }
.template-card span { display: block; padding: 16px; color: rgb(28,28,28); font-weight: 500; }

.steps-grid { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; gap: 16px; align-items: start; }
.steps-grid .step-card { display: flex; flex-direction: column; gap: 8px; padding: 24px; background: white; border: 1px solid rgb(223,225,231); border-radius: 16px; }
.step-icon { width: 48px; height: 48px; background: var(--soft-lavender); border-radius: 12px; margin-bottom: 8px; }
.steps-grid .step-connector { display: flex; align-items: center; justify-content: center; padding-top: 40px; opacity: 0.3; }
.secret-weapon-badge { display: inline-flex; background: #E0DEF5; color: #372E7D; border-radius: 90px; padding: 6px 10px; margin-top: 8px; width: fit-content; }
.secret-weapon-badge .text-size-14px { color: #372E7D; }

.section_agentic-ai { background: rgb(2, 6, 23); }
.section_agentic-ai h2 { color: white; }
.build-task-panel { background: rgba(255,255,255,0.05); border: 0.5px solid rgba(255,255,255,0.1); border-radius: 16px; padding: 24px; margin-bottom: 48px; max-width: 500px; margin-left: auto; margin-right: auto; }
.task-steps { display: flex; flex-direction: column; gap: 12px; }
.task-step { display: flex; align-items: center; gap: 12px; padding: 8px 0; }
.step-indicator { width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.step-indicator.empty { border: 1px solid rgba(255,255,255,0.2); border-radius: 50%; }
.spin-icon-text { animation: spin 2s linear infinite; display: inline-block; }
.task-step.completed .text-size-14px { opacity: 0.6; }
.progress-bar { position: absolute; bottom: -4px; left: 32px; right: 0; height: 2px; background: rgba(255,255,255,0.1); border-radius: 2px; overflow: hidden; }
.progress-fill { width: 65%; height: 100%; background: var(--ui-green); border-radius: 2px; }
.task-step.active { position: relative; }

.why-choose-container { background: #1A1B25; border-radius: 16px; padding: 48px; display: flex; flex-direction: column; gap: 24px; }
.agent-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.agent-card { background: rgba(255,255,255,0.1); border: 0.5px solid rgba(255,255,255,0.1); border-radius: 14px; transition: background 0.3s; }
.agent-card:hover { background: rgba(255,255,255,0.15); }
.agent-card-inner { padding: 24px; display: flex; flex-direction: column; gap: 8px; }

.advisor-video { margin-bottom: 48px; }
.video-placeholder { width: 100%; max-width: 979px; margin: 0 auto; aspect-ratio: 16/9; background: #F9F9F9; border: 1px solid rgb(223,225,231); border-radius: 16px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; }
.video-play-btn { cursor: pointer; transition: transform 0.2s; }
.video-play-btn:hover { transform: scale(1.1); }
.features-watch-bottom { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.watch-card { display: flex; flex-direction: column; gap: 8px; padding: 24px; }
.watch-icon { font-size: 32px; margin-bottom: 8px; }

.metrics-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 48px; }
.metric-card { background: white; border: 1px solid rgb(223,225,231); border-radius: 16px; padding: 32px; display: flex; flex-direction: column; gap: 8px; }
.metric-number { font-size: 48px; font-weight: 600; color: rgb(17,17,17); line-height: 1; margin-bottom: 8px; }
.feature-pills { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.feature-pill { display: inline-flex; align-items: center; gap: 8px; background: rgba(22, 160, 122, 0.1); border-radius: 90px; padding: 8px 16px; }
.pill-check { color: var(--ui-green); font-weight: 600; }
.feature-pill .text-size-14px { color: rgb(28,28,28); }

.use-cases-content { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.use-case-card { background: white; border: 1px solid rgb(223,225,231); border-radius: 16px; overflow: hidden; transition: transform 0.2s; cursor: pointer; }
.use-case-card:hover { transform: translateY(-2px); box-shadow: rgba(0,0,0,0.1) 0px 8px 24px -4px; }
.use-case-thumb { width: 100%; height: 200px; }
.use-case-info { padding: 24px; display: flex; flex-direction: column; gap: 8px; }

.section_pricing { background: linear-gradient(180deg, rgb(243,235,255), rgb(255,255,255)); }
.pricing-cards { display: flex; gap: 24px; justify-content: center; align-items: flex-start; }
.pricing-card { background: white; border: 1px solid rgb(223,225,231); border-radius: 16px; padding: 32px; flex: 1; max-width: 360px; display: flex; flex-direction: column; gap: 24px; position: relative; }
.pricing-card.featured { border-color: var(--purple-ui-1); box-shadow: 0 0 0 1px var(--purple-ui-1), rgba(119,30,230,0.15) 0px 8px 24px -4px; }
.popular-badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--purple-ui-1); color: white; padding: 4px 16px; border-radius: 90px; }
.popular-badge .text-size-12px { color: white; }
.pricing-card-header { display: flex; flex-direction: column; gap: 8px; }
.price { display: flex; align-items: baseline; gap: 4px; }
.price-amount { font-size: 36px; font-weight: 700; line-height: 46.8px; color: rgb(28,28,28); }
.pricing-features { display: flex; flex-direction: column; gap: 12px; flex: 1; }
.pricing-feature { display: flex; align-items: center; gap: 10px; }
.pf-check { color: var(--ui-green); font-weight: 600; font-size: 16px; }
.pricing-feature .text-size-14px { color: rgb(28,28,28); }
.pricing-card .pricing-btn { width: 100%; margin-top: auto; }

.comparison-table-wrapper { overflow-x: auto; border-radius: 16px; border: 1px solid #E5E7EB; }
.comparison-table { width: 100%; border-collapse: collapse; background: white; }
.comparison-table th, .comparison-table td { padding: 14px 16px; border: 1px solid #E5E7EB; text-align: center; white-space: nowrap; }
.comparison-table th { background: #FAFAFA; font-size: 15px; font-weight: 600; color: #111827; }
.comparison-table td:first-child, .comparison-table th:first-child { text-align: left; font-weight: 500; color: rgb(28,28,28); }
.highlight-col { background: rgba(243,235,255,0.3); }
.check { font-size: 16px; font-weight: 600; }
.check.green { color: var(--ui-green); }
.check.red { color: #DC2626; }

.faq-content { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.faq-wrapper-3-2 { background: white; border: 1px solid #ECEFF3; border-radius: 12px; padding: 24px; cursor: pointer; transition: background 0.2s; }
.faq-wrapper-3-2:hover { background: #FAFAFA; }
.faq-question { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.faq-indicator { font-size: 24px; color: rgb(28,28,28); transition: transform 0.3s; flex-shrink: 0; line-height: 1; }
.faq-answer { display: none; padding-top: 16px; }
.faq-wrapper-3-2.open .faq-answer { display: block; }
.faq-wrapper-3-2.open .faq-indicator { transform: rotate(45deg); }

.section_cta { border-radius: 28px 28px 0 0; margin-bottom: 0; }
.cta-inner { background: linear-gradient(135deg, var(--purple-ui-1), var(--baked-purple)); border-radius: 20px; margin: 40px; padding: 80px 40px; }
.cta-content { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.cta-content h2 { color: white; max-width: 600px; }

.footer-instance { background: white; padding: 64px 0 32px; margin: 0 16px 16px; border-radius: 0 0 28px 28px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
.footer-logo-text { font-size: 20px; }
.footer-col { display: flex; flex-direction: column; gap: 12px; }
.footer-col h4 { color: rgb(28,28,28); margin-bottom: 4px; }
.footer-link { color: rgb(102,109,128); transition: color 0.2s; }
.footer-link:hover { color: rgb(28,28,28); }
.social-links { display: flex; flex-direction: column; gap: 12px; }
.footer-bottom { border-top: 1px solid #ECEFF3; padding-top: 24px; text-align: center; }

/* Animations */
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.scroll-reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.6s ease-out, transform 0.6s ease-out; }
.scroll-reveal.visible { opacity: 1; transform: translateY(0); }


/* ════════════════════════════════════════════
   Booking Demo Section
   ════════════════════════════════════════════ */
/* ════════════════════════════════════════════
   TASK 4: Booking demo — refactored CSS classes
   ════════════════════════════════════════════ */
.booking-demo-section {
  padding: 80px 0;
  overflow: hidden;
}
.booking-demo-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
}
.booking-demo-layout {
  display: flex;
  gap: 28px;
  align-items: flex-start;
}
.booking-demo-controls {
  width: 300px;
  flex-shrink: 0;
}
.booking-demo-preview {
  flex: 1;
}
.booking-controls-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 20px;
  padding: 28px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.04);
}
.booking-controls-heading {
  font-size: 13px;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.booking-form-group {
  margin-bottom: 16px;
}
.booking-form-label {
  font-size: 10px;
  font-weight: 600;
  color: #6b7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  display: block;
  margin-bottom: 5px;
}
.booking-form-input {
  width: 100%;
  height: 44px;
  border: 1px solid #e8e5df;
  border-radius: 10px;
  padding: 0 14px;
  font-size: 16px;
  color: #1a1a1a;
  outline: none;
  transition: all 0.2s;
}
.booking-form-input:focus {
  border-color: #1e9a80;
  box-shadow: 0 0 0 3px rgba(30,154,128,0.08);
}
.booking-upload-zone {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 48px;
  border: 2px dashed #e8e5df;
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.2s;
  background: #fafafa;
  font-size: 12px;
  color: #6b7280;
}
.booking-upload-zone:hover {
  border-color: #1e9a80;
  background: rgba(30,154,128,0.02);
}
.booking-upload-logo {
  height: 64px;
}
.booking-color-row {
  display: flex;
  gap: 8px;
}
.demo-color {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 2.5px solid transparent;
  cursor: pointer;
  transition: all 0.15s;
}
.demo-color.active {
  border-color: inherit;
}
.booking-url-group {
  display: flex;
  align-items: center;
  border: 1px solid #e8e5df;
  border-radius: 10px;
  overflow: hidden;
}
.booking-url-input {
  flex: 1;
  height: 40px;
  border: none;
  padding: 0 12px;
  font-size: 16px;
  color: #1a1a1a;
  outline: none;
}
.booking-url-suffix {
  font-size: 11px;
  color: #6b7280;
  padding: 0 12px;
  white-space: nowrap;
  border-left: 1px solid #e8e5df;
  background: #fafafa;
}
.booking-cta-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, #1e9a80, #10b981);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s;
  box-shadow: 0 4px 12px rgba(30,154,128,0.2);
}
.booking-cta-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(30,154,128,0.3);
}
.booking-cta-sub {
  text-align: center;
  font-size: 11px;
  color: #6b7280;
  margin-top: 8px;
}

@media (max-width: 991px) {
  .booking-demo-layout {
    flex-direction: column;
  }
  .booking-demo-controls {
    width: 100%;
  }
}

/* ═══════════════════════════════════════════
   nfstay System — sections, cards, grids, buttons
   ═══════════════════════════════════════════ */

/* ── SECTIONS ── */
.s { padding: var(--section-py) 0; }
.s.sm { padding: 48px 0; }
.s.bg-white { background: var(--card); }
.s.bg-cream { background: var(--bg); }
.s.bg-dark { background: #0f0f0f; color: #fff; }
.s.bg-dark-alt { background: #1a1a1a; color: #fff; }
.s.bg-green { background: var(--green); color: #fff; }
.s.bg-gradient { background: linear-gradient(135deg, var(--green), #0e1726); color: #fff; }
.wrap { max-width: 1100px; margin: 0 auto; padding: 0 24px; }
.wrap.narrow { max-width: 640px; }
.wrap.wide { max-width: 1280px; }
.sh { text-align: center; margin-bottom: 48px; }
.sh.left { text-align: left; }
.sh h2 { font-size: 34px; font-weight: 700; line-height: 1.15; letter-spacing: 0.01em; color: var(--text); }
.s.bg-dark .sh h2, .s.bg-dark-alt .sh h2, .s.bg-green .sh h2, .s.bg-gradient .sh h2 { color: #fff; }
.sh p { font-size: 16px; color: var(--text-2); margin-top: 12px; max-width: 540px; margin-left: auto; margin-right: auto; line-height: 1.6; }
.sh.left p { margin-left: 0; }
.s.bg-dark .sh p, .s.bg-dark-alt .sh p { color: rgba(255,255,255,0.6); }
.badge { display: inline-flex; align-items: center; gap: 6px; background: var(--green-light); color: var(--green); font-size: 11px; font-weight: 600; padding: 5px 14px; border-radius: 100px; margin-bottom: 16px; text-transform: uppercase; letter-spacing: 0.5px; }
.green { color: var(--green); }

/* ── GLASSMORPHIC CARD ── */
.glass { background: var(--glass-bg); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid var(--glass-border); border-radius: var(--radius); box-shadow: var(--glass-shadow); }

/* ── CARDS ── */
.card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 28px; transition: box-shadow 200ms ease-out, transform 200ms ease-out; }
.card:hover { box-shadow: var(--shadow-2); transform: translateY(-4px); }
.s.bg-dark .card { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); }
.s.bg-dark .card:hover { background: rgba(255,255,255,0.06); }
.card-icon { width: 40px; height: 40px; border-radius: var(--radius-sm); background: var(--green-light); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.card-icon svg { width: 20px; height: 20px; stroke: var(--green); fill: none; stroke-width: 1.8; }
.card h3 { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 6px; letter-spacing: 0.01em; }
.s.bg-dark .card h3 { color: #fff; }
.card p { font-size: 14px; color: var(--text-2); line-height: 1.6; }
.s.bg-dark .card p { color: rgba(255,255,255,0.5); }

/* ── GRIDS ── */
.g2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
.g3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.g4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.g6 { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }

/* ── BUTTONS ── */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 32px; border-radius: var(--radius-sm); font-size: 15px; font-weight: 600; text-decoration: none; border: none; cursor: pointer; transition: all 150ms ease-out; letter-spacing: 0.01em; }
.btn:active { transform: scale(0.97); transition: transform 120ms ease; }
.btn-green { background: var(--green); color: #fff; }
.btn-green:hover { background: #178f72; }
.btn-white { background: #fff; color: var(--text); }
.btn-white:hover { background: var(--bg); }
.btn-outline { background: transparent; color: var(--green); border: 1.5px solid var(--green); }
.btn-outline:hover { background: var(--green-light); }
.btn-ghost { background: transparent; color: var(--text-2); font-weight: 500; padding: 14px 16px; }
.btn-ghost:hover { color: var(--text); }
.btn-full { display: flex; width: 100%; }
.btn-sm { padding: 10px 20px; font-size: 13px; }

/* ── TRUST STRIPE (Block 1) ── */
.trust-stripe { display: flex; justify-content: center; align-items: center; gap: 0; flex-wrap: wrap; }
.trust-stripe .ts-item { padding: 0 28px; text-align: center; border-right: 1px solid var(--border); }
.trust-stripe .ts-item:last-child { border-right: none; }
.trust-stripe .ts-val { font-size: 28px; font-weight: 800; color: var(--text); letter-spacing: -0.02em; }
.trust-stripe .ts-lbl { font-size: 12px; color: var(--text-2); margin-top: 2px; }
.s.bg-dark .trust-stripe .ts-val { color: #fff; }
.s.bg-dark .trust-stripe .ts-lbl { color: rgba(255,255,255,0.5); }

/* ── DEAL CARDS (Block 2) ── */
.deal-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; transition: box-shadow 200ms ease-out, transform 200ms ease-out; }
.deal-card:hover { box-shadow: var(--shadow-2); transform: translateY(-4px); }
.deal-img { height: 160px; background-size: cover; background-position: center; position: relative; }
.deal-badge { position: absolute; top: 10px; left: 10px; background: var(--card); font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: var(--radius-xs); box-shadow: var(--shadow-1); color: var(--text); }
.deal-body { padding: 16px; }
.deal-body h4 { font-size: 15px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.deal-meta { font-size: 12px; color: var(--text-2); margin-bottom: 10px; }
.deal-row { display: flex; justify-content: space-between; font-size: 13px; padding: 5px 0; border-top: 1px solid var(--border-light); }
.deal-row .label { color: var(--text-2); }
.deal-row .val { font-weight: 600; color: var(--text); }
.deal-row .val.profit { color: var(--green); }
.deal-btns { display: flex; gap: 6px; margin-top: 12px; }
.deal-btns .btn { flex: 1; font-size: 12px; padding: 8px 12px; }

/* ── PIPELINE (Block 3) ── */
.pipeline { display: flex; gap: 12px; overflow-x: auto; padding-bottom: 8px; }
.pipe-col { flex: 1; min-width: 180px; background: var(--bg); border-radius: var(--radius-sm); padding: 12px; }
.pipe-head { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-2); margin-bottom: 10px; display: flex; align-items: center; gap: 6px; }
.pipe-dot { width: 8px; height: 8px; border-radius: 50%; }
.pipe-dot.blue { background: #3b82f6; }
.pipe-dot.amber { background: #f59e0b; }
.pipe-dot.purple { background: #8b5cf6; }
.pipe-dot.green { background: var(--green); }
.pipe-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-xs); padding: 10px 12px; margin-bottom: 6px; font-size: 13px; }
.pipe-card strong { display: block; color: var(--text); }
.pipe-card span { font-size: 11px; color: var(--text-2); }
.benefits { list-style: none; padding: 0; margin: 32px auto 0; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; max-width: 600px; }
.benefits li { font-size: 14px; color: var(--text-2); display: flex; align-items: center; gap: 10px; }
.benefits li::before { content: ''; width: 20px; height: 20px; border-radius: 50%; background: var(--green-light); flex-shrink: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231e9a80' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; }

/* ── INBOX MOCK (Block 4) ── */
.inbox-mock { display: flex; border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; min-height: 320px; background: var(--card); }
.inbox-list { width: 240px; border-right: 1px solid var(--border-light); background: #fafafa; flex-shrink: 0; }
.inbox-list-head { padding: 14px 16px; font-size: 14px; font-weight: 700; color: var(--text); border-bottom: 1px solid var(--border-light); }
.inbox-thread { padding: 12px 16px; border-bottom: 1px solid var(--border-light); cursor: pointer; transition: background 150ms; }
.inbox-thread:hover { background: #f0f0ec; }
.inbox-thread.active { background: #ecfdf5; }
.inbox-thread-name { font-size: 13px; font-weight: 600; color: var(--text); }
.inbox-thread-preview { font-size: 12px; color: var(--text-2); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.inbox-chat { flex: 1; display: flex; flex-direction: column; }
.inbox-chat-head { padding: 14px 16px; font-size: 14px; font-weight: 600; border-bottom: 1px solid var(--border-light); display: flex; align-items: center; gap: 8px; }
.inbox-chat-head .deal-tag { font-size: 10px; font-weight: 600; background: var(--green-light); color: var(--green); padding: 2px 8px; border-radius: 100px; }
.inbox-msgs { flex: 1; padding: 16px; display: flex; flex-direction: column; gap: 10px; background: #fafafa; }
.msg { max-width: 75%; padding: 10px 14px; border-radius: 14px; font-size: 13px; line-height: 1.5; }
.msg.them { background: var(--card); border: 1px solid var(--border); border-bottom-left-radius: 4px; align-self: flex-start; }
.msg.me { background: var(--green); color: #fff; border-bottom-right-radius: 4px; align-self: flex-end; }
.inbox-features { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 32px; }
.inbox-feat { font-size: 14px; color: var(--text-2); display: flex; align-items: flex-start; gap: 10px; }
.inbox-feat::before { content: ''; width: 20px; height: 20px; border-radius: 50%; background: var(--green-light); flex-shrink: 0; margin-top: 2px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231e9a80' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; }

/* ── JOURNEY (Block 5) ── */
.journey { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.journey-step { display: flex; gap: 14px; }
.journey-num { width: 36px; height: 36px; border-radius: 50%; background: var(--green); color: #fff; font-size: 14px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.journey-body h4 { font-size: 14px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.journey-body p { font-size: 13px; color: var(--text-2); line-height: 1.5; }
.journey-mock { background: #fafafa; border: 1px solid var(--border); border-radius: var(--radius-xs); padding: 8px 10px; margin-top: 8px; font-size: 11px; color: var(--text-2); }

/* ── COURSE CARDS (Block 6) ── */
.course { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; transition: box-shadow 200ms ease-out, transform 200ms ease-out; }
.course:hover { box-shadow: var(--shadow-2); transform: translateY(-4px); }
.course h3 { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 6px; }
.course-meta { font-size: 12px; color: var(--text-2); margin-bottom: 10px; }
.course-level { display: inline-block; font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 100px; }
.course-level.beginner { background: #ecfdf5; color: var(--green); }
.course-level.intermediate { background: #fef3c7; color: #92400e; }

/* ── TESTIMONIALS (Block 7) ── */
.testimonial { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; }
.testimonial:hover { box-shadow: var(--shadow-1); }
.tq { font-size: 15px; color: var(--text); line-height: 1.6; margin-bottom: 16px; }
.tq::before { content: '\201C'; font-size: 24px; color: var(--bg-warm); margin-right: 2px; line-height: 0; }
.t-author { display: flex; align-items: center; gap: 10px; padding-top: 14px; border-top: 1px solid var(--border-light); }
.t-avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--green-light); display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; color: var(--green); flex-shrink: 0; }
.t-name { font-size: 14px; font-weight: 600; color: var(--text); }
.t-role { font-size: 12px; color: var(--text-2); }
.trust-badges { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 32px; }
.trust-badge { display: inline-flex; align-items: center; gap: 6px; background: var(--card); border: 1px solid var(--border); border-radius: 100px; padding: 8px 16px; font-size: 13px; font-weight: 500; color: var(--text-2); }

/* ── PRICING (Block 8) ── */
.price-card { max-width: 480px; margin: 0 auto; background: var(--card); border: 2px solid var(--green); border-radius: 20px; padding: 40px 32px; text-align: center; box-shadow: 0 0 0 1px var(--green), 0 12px 40px rgba(30,154,128,0.08); }
.price-title { font-size: 20px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.price-amt { font-size: 52px; font-weight: 800; color: var(--text); line-height: 1; letter-spacing: -0.03em; }
.price-amt span { font-size: 18px; font-weight: 400; color: var(--text-2); }
.price-trial { font-size: 15px; font-weight: 600; color: var(--green); margin: 8px 0; }
.price-cancel { font-size: 13px; color: var(--text-2); margin-bottom: 24px; }
.price-list { list-style: none; padding: 0; margin: 0 0 28px; text-align: left; }
.price-list li { font-size: 14px; color: var(--text-2); padding: 8px 0; display: flex; align-items: center; gap: 10px; border-bottom: 1px solid var(--border-light); }
.price-list li::before { content: ''; width: 20px; height: 20px; border-radius: 50%; background: var(--green-light); flex-shrink: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231e9a80' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; }
.price-micro { font-size: 12px; color: var(--text-2); margin-top: 10px; }

/* ── CTA BAND (Block 9) ── */
.cta-band { text-align: center; padding: 64px 24px; }
.cta-band h2 { font-size: 30px; font-weight: 700; margin-bottom: 8px; }
.cta-band p { font-size: 16px; margin-bottom: 24px; }
.s.bg-green .cta-band h2, .s.bg-gradient .cta-band h2, .s.bg-dark .cta-band h2 { color: #fff; }
.s.bg-green .cta-band p, .s.bg-gradient .cta-band p, .s.bg-dark .cta-band p { color: rgba(255,255,255,0.7); }
.cta-btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ── VARIANT-SPECIFIC ── */

/* 01: Tab rail */
.tab-layout { display: flex; gap: 0; min-height: 480px; border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; background: var(--card); }
.tab-rail { width: 200px; background: #fafafa; border-right: 1px solid var(--border); padding: 16px 0; flex-shrink: 0; }
.tab-btn { display: flex; align-items: center; gap: 10px; padding: 14px 20px; font-size: 14px; font-weight: 500; color: var(--text-2); cursor: pointer; transition: all 200ms; border-left: 3px solid transparent; }
.tab-btn:hover { color: var(--text); background: rgba(0,0,0,0.02); }
.tab-btn.active { color: var(--green); background: var(--green-light); border-left-color: var(--green); font-weight: 600; }
.tab-screen { flex: 1; padding: 32px; position: relative; }
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* 04: Dark variant overrides */
.dark-card { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: var(--radius); }
.dark-card:hover { background: rgba(255,255,255,0.06); box-shadow: var(--shadow-2); }

/* 05: Playground */
.playground { background: var(--card); border: 1px solid var(--border); border-radius: 20px; padding: 32px; max-width: 640px; margin: 0 auto; box-shadow: var(--shadow-1); }
.play-row { display: flex; gap: 24px; margin-bottom: 16px; }
.play-ctrl { flex: 1; }
.play-label { font-size: 12px; font-weight: 600; color: var(--text-2); margin-bottom: 6px; display: block; }
.play-select, .play-input { width: 100%; height: 40px; border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 0 12px; font-size: 14px; color: var(--text); background: var(--card); }
.play-select:focus, .play-input:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 3px var(--green-light); }
.play-slider { width: 100%; height: 6px; border-radius: 3px; -webkit-appearance: none; appearance: none; background: var(--bg-warm); cursor: pointer; }
.play-slider::-webkit-slider-thumb { -webkit-appearance: none; width: 18px; height: 18px; border-radius: 50%; background: var(--green); border: 2px solid #fff; box-shadow: var(--shadow-1); cursor: pointer; }
.play-output { background: #ecfdf5; border: 1px solid #a7f3d0; border-radius: var(--radius); padding: 24px; text-align: center; margin-top: 16px; }
.play-profit { font-size: 40px; font-weight: 800; color: var(--green); letter-spacing: -0.02em; }
.play-profit-lbl { font-size: 14px; color: var(--text-2); margin-top: 4px; }

/* 08: Persona pills */
.persona-bar { display: flex; gap: 8px; justify-content: center; margin-bottom: 40px; }
.persona-pill { padding: 12px 28px; border-radius: 10px; border: 1.5px solid var(--border); font-size: 14px; font-weight: 500; color: var(--text-2); cursor: pointer; transition: all 200ms; background: var(--card); }
.persona-pill:hover { border-color: var(--green); color: var(--green); }
.persona-pill.active { border-color: var(--green); background: var(--green-light); color: var(--green); font-weight: 600; }
.persona-content { display: none; }
.persona-content.active { display: block; }
/* Cascade animation for persona cards */
.persona-content .card {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 350ms var(--ease), transform 350ms var(--ease);
}
.persona-content.active .card.cascade-in {
  opacity: 1;
  transform: translateY(0);
}

/* 09: KPI tiles */
.kpi-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.kpi { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; }
.kpi-label { font-size: 12px; color: var(--text-2); font-weight: 500; }
.kpi-val { font-size: 32px; font-weight: 800; color: var(--text); margin-top: 4px; letter-spacing: -0.02em; }
.kpi-val.green { color: var(--green); }
.kpi-delta { font-size: 11px; color: var(--green); font-weight: 600; margin-top: 4px; }

/* 10: Timeline */
.timeline { position: relative; max-width: 640px; margin: 0 auto; }
.timeline::before { content: ''; position: absolute; left: 20px; top: 0; bottom: 0; width: 2px; background: linear-gradient(180deg, var(--green), var(--bg-warm)); }
.tl-step {
  display: flex; gap: 24px; padding: 28px 0; position: relative;
  /* Scroll animation: slides in from left or right, expands */
  opacity: 0;
  transform: translateX(-40px) scale(0.95);
  max-height: 50px;
  overflow: hidden;
  transition: opacity 600ms cubic-bezier(0.22,1,0.36,1),
              transform 600ms cubic-bezier(0.22,1,0.36,1),
              max-height 800ms cubic-bezier(0.22,1,0.36,1);
}
.tl-step:nth-child(even) {
  transform: translateX(40px) scale(0.95);
}
.tl-step.visible {
  opacity: 1;
  transform: translateX(0) scale(1);
  max-height: 400px;
  overflow: visible;
}
.tl-dot { width: 40px; height: 40px; border-radius: 50%; background: var(--green); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 13px; font-weight: 700; flex-shrink: 0; z-index: 1; border: 3px solid var(--bg); }
.tl-body { max-width: 480px; }
.tl-body h4 { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.tl-body p { font-size: 14px; color: var(--text-2); line-height: 1.5; }
.tl-tag { display: inline-block; font-size: 10px; font-weight: 600; color: var(--green); background: var(--green-light); padding: 2px 8px; border-radius: var(--radius-xs); margin-top: 8px; }
.tl-mock { background: #fafafa; border: 1px solid var(--border); border-radius: var(--radius-xs); padding: 10px 12px; margin-top: 10px; font-size: 12px; color: var(--text-2); }

/* Alternating left-right on desktop */
@media (min-width: 769px) {
  .timeline { max-width: 800px; }
  .timeline::before { left: 50%; transform: translateX(-50%); }
  .tl-step { width: 50%; }
  .tl-step:nth-child(odd) { flex-direction: row-reverse; margin-left: 50%; padding-left: 28px; text-align: left; }
  .tl-step:nth-child(odd) .tl-dot { margin-left: -20px; }
  .tl-step:nth-child(even) { flex-direction: row; margin-right: 50%; padding-right: 28px; text-align: right; justify-content: flex-end; }
  .tl-step:nth-child(even) .tl-dot { margin-right: -20px; order: 1; }
  .tl-step:nth-child(even) .tl-body { order: 0; }
  .tl-step:nth-child(even) .tl-mock { text-align: left; }
}

/* ── HUB ── */
.hub-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; margin-bottom: 48px; }
.hub-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; transition: all 200ms ease-out; cursor: pointer; }
.hub-card:hover { border-color: var(--green); box-shadow: var(--shadow-2); transform: translateY(-4px); }
.hub-num { font-size: 11px; font-weight: 700; color: var(--green); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
.hub-card h3 { font-size: 17px; font-weight: 600; color: var(--text); margin-bottom: 6px; }
.hub-card p { font-size: 13px; color: var(--text-2); line-height: 1.5; margin-bottom: 14px; }
.hub-link { font-size: 13px; font-weight: 600; color: var(--green); text-decoration: none; }
.hub-link:hover { text-decoration: underline; }
.hub-pills { display: flex; gap: 6px; justify-content: center; margin-bottom: 16px; flex-wrap: wrap; }
.hub-pill { padding: 8px 16px; border-radius: 100px; border: 1.5px solid var(--border); font-size: 13px; font-weight: 500; color: var(--text-2); cursor: pointer; transition: all 150ms; background: var(--card); }
.hub-pill:hover { border-color: var(--green); }
.hub-pill.active { background: var(--green); border-color: var(--green); color: #fff; }
.hub-iframe { width: 100%; height: 800px; border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }

/* ── FOOTER ── */
.footer { background: var(--card); padding: 48px 0 24px; border-top: 1px solid var(--border); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 32px; }
.footer-brand { display: flex; align-items: center; gap: 3px; margin-bottom: 8px; font-family: 'Sora', sans-serif; }
.footer-brand .box { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; border: 2px solid var(--text); border-radius: 6px; font-size: 12px; font-weight: 700; }
.footer-brand .text { font-size: 18px; font-weight: 400; letter-spacing: 2px; }
.footer-desc { font-size: 13px; color: var(--text-2); line-height: 1.5; }
.footer-col h4 { font-size: 12px; font-weight: 700; color: var(--text); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 12px; }
.footer-col a { display: block; font-size: 13px; color: var(--text-2); text-decoration: none; padding: 3px 0; transition: color 150ms; }
.footer-col a:hover { color: var(--green); }
.footer-bottom { border-top: 1px solid var(--border-light); padding-top: 16px; font-size: 12px; color: var(--text-2); text-align: center; }


/* ═══════════════════════════════════════════
   nfstay Sections — variant styles
   ═══════════════════════════════════════════ */
/* ============================================
   nfstay Landing Sections — Full Design System
   10 variants + hub. No emojis. UK spelling.
   Brand: #1e9a80 / #f3f3ee / #e8e5df / #0a0a0a
   ============================================ */

/* ---------- SECTION BASES ---------- */
.nfs-section { padding: 80px 0; }
.nfs-section.sm { padding: 48px 0; }
.nfs-section.cream { background: #f3f3ee; }
.nfs-section.white { background: #fff; }
.nfs-section.dark { background: #0e1726; color: #fff; }
.nfs-section.gradient { background: linear-gradient(135deg, #0e1726, #1a2744); color: #fff; }
.nfs-section.green-band { background: linear-gradient(135deg, #1e9a80, #0e1726); color: #fff; }
.nfs-inner { max-width: 1100px; margin: 0 auto; padding: 0 24px; }
.nfs-inner.narrow { max-width: 680px; }
.nfs-inner.wide { max-width: 1280px; }
.nfs-section-head { text-align: center; margin-bottom: 48px; }
.nfs-section-head.left { text-align: left; }
.nfs-section-title { font-size: 32px; font-weight: 700; line-height: 1.15; letter-spacing: -0.5px; color: #0a0a0a; }
.nfs-section-title.lg { font-size: 40px; letter-spacing: -0.8px; }
.nfs-section.dark .nfs-section-title,
.nfs-section.gradient .nfs-section-title,
.nfs-section.green-band .nfs-section-title { color: #fff; }
.nfs-section-sub { font-size: 15px; color: #737373; margin-top: 12px; max-width: 560px; margin-left: auto; margin-right: auto; line-height: 1.6; }
.nfs-section-head.left .nfs-section-sub { margin-left: 0; }
.nfs-section.dark .nfs-section-sub { color: #94a3b8; }
.nfs-section-badge { display: inline-flex; align-items: center; gap: 6px; background: rgba(30,154,128,0.08); color: #1e9a80; font-size: 11px; font-weight: 600; padding: 5px 14px; border-radius: 100px; margin-bottom: 16px; text-transform: uppercase; letter-spacing: 0.5px; }
.nfs-accent { color: #1e9a80; }
.nfs-italic { font-family: 'Playfair Display', serif; font-style: italic; }

/* ---------- FEATURE CARD GRID ---------- */
.nfs-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.nfs-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.nfs-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.nfs-card { background: #fff; border: 1px solid #e8e5df; border-radius: 16px; padding: 28px; transition: box-shadow 0.2s, transform 0.2s; }
.nfs-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.1); transform: translateY(-4px); }
.nfs-section.dark .nfs-card { background: rgba(255,255,255,0.05); border-color: rgba(255,255,255,0.08); }
.nfs-card-icon { width: 40px; height: 40px; border-radius: 10px; background: rgba(30,154,128,0.08); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; color: #1e9a80; }
.nfs-card h3 { font-size: 15px; font-weight: 600; color: #0a0a0a; margin-bottom: 6px; }
.nfs-section.dark .nfs-card h3 { color: #fff; }
.nfs-card p { font-size: 13px; color: #737373; line-height: 1.6; }

/* ---------- STATS ---------- */
.nfs-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; text-align: center; padding: 40px 0; }
.nfs-stat-val { font-size: 32px; font-weight: 800; color: #1e9a80; }
.nfs-stat-lbl { font-size: 13px; color: #737373; margin-top: 4px; }
.nfs-section.dark .nfs-stat-lbl { color: #94a3b8; }
.nfs-stats-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.nfs-stat-card { background: #fff; border: 1px solid #e8e5df; border-radius: 14px; padding: 24px; text-align: center; }
.nfs-stat-card .val { font-size: 28px; font-weight: 800; color: #1e9a80; }
.nfs-stat-card .lbl { font-size: 12px; color: #737373; margin-top: 4px; }

/* ---------- TESTIMONIALS ---------- */
.nfs-testimonial { background: #fff; border: 1px solid #e8e5df; border-radius: 16px; padding: 24px; }
.nfs-testimonial:hover { box-shadow: 0 6px 20px rgba(0,0,0,0.06); }
.nfs-tq { font-size: 13px; color: #525252; line-height: 1.6; margin-bottom: 16px; font-style: italic; }
.nfs-tq::before { content: '\201C'; font-size: 20px; color: #e8e5df; margin-right: 2px; }
.nfs-t-stars { color: #f59e0b; font-size: 12px; letter-spacing: 1px; margin-bottom: 12px; }
.nfs-t-author { display: flex; align-items: center; gap: 10px; padding-top: 12px; border-top: 1px solid #f3f4f6; }
.nfs-t-avatar { width: 32px; height: 32px; border-radius: 50%; background: #e8e5df; overflow: hidden; flex-shrink: 0; }
.nfs-t-avatar img { width: 100%; height: 100%; object-fit: cover; }
.nfs-t-name { font-size: 13px; font-weight: 600; color: #0a0a0a; }
.nfs-t-role { font-size: 11px; color: #9ca3af; }

/* ---------- SINGLE PRICING (global) ---------- */
.nfs-price-single { max-width: 480px; margin: 0 auto; background: #fff; border: 2px solid #1e9a80; border-radius: 20px; padding: 40px 32px; text-align: center; box-shadow: 0 0 0 1px #1e9a80, 0 12px 40px rgba(30,154,128,0.08); }
.nfs-price-trial { font-size: 14px; font-weight: 600; color: #1e9a80; margin-bottom: 8px; }
.nfs-price-amt { font-size: 48px; font-weight: 800; color: #0a0a0a; line-height: 1; }
.nfs-price-amt span { font-size: 18px; font-weight: 400; color: #737373; }
.nfs-price-cancel { font-size: 13px; color: #9ca3af; margin-top: 6px; margin-bottom: 24px; }
.nfs-price-list { list-style: none; padding: 0; margin: 0 0 28px; text-align: left; }
.nfs-price-list li { font-size: 14px; color: #525252; padding: 7px 0; display: flex; align-items: center; gap: 10px; border-bottom: 1px solid #f3f4f6; }
.nfs-price-list li::before { content: ''; width: 18px; height: 18px; border-radius: 50%; background: rgba(30,154,128,0.1); flex-shrink: 0; display: flex; align-items: center; justify-content: center; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231e9a80' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; }
.nfs-cta-btn { display: inline-block; padding: 14px 36px; border-radius: 12px; font-size: 15px; font-weight: 600; text-decoration: none; transition: all 0.2s; cursor: pointer; }
.nfs-cta-btn.green { background: #1e9a80; color: #fff; border: none; }
.nfs-cta-btn.green:hover { background: #178f72; transform: translateY(-1px); }
.nfs-cta-btn.white { background: #fff; color: #0a0a0a; border: none; }
.nfs-cta-btn.white:hover { background: #f3f3ee; }
.nfs-cta-btn.outline { background: transparent; color: #1e9a80; border: 1.5px solid #1e9a80; }
.nfs-cta-btn.outline:hover { background: rgba(30,154,128,0.04); }
.nfs-cta-btn:active { transform: scale(0.97); transition: transform 120ms ease; }
.nfs-cta-btn:focus-visible { outline: 2px solid #1c1c1c; outline-offset: 3px; }
.nfs-cta-btn.full { display: block; width: 100%; text-align: center; }

/* ---------- CTA BAND ---------- */
.nfs-cta-band { text-align: center; padding: 60px 24px; }
.nfs-cta-band h2 { font-size: 28px; font-weight: 700; margin-bottom: 8px; }
.nfs-cta-band p { font-size: 15px; margin-bottom: 24px; }
.nfs-section.green-band .nfs-cta-band h2,
.nfs-section.dark .nfs-cta-band h2 { color: #fff; }
.nfs-section.green-band .nfs-cta-band p,
.nfs-section.dark .nfs-cta-band p { color: rgba(255,255,255,0.7); }

/* ---------- STEPS / HOW IT WORKS ---------- */
.nfs-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.nfs-step { text-align: center; }
.nfs-step-num { width: 36px; height: 36px; border-radius: 50%; background: rgba(30,154,128,0.08); color: #1e9a80; font-size: 14px; font-weight: 700; display: flex; align-items: center; justify-content: center; margin: 0 auto 12px; }
.nfs-step h4 { font-size: 14px; font-weight: 600; color: #0a0a0a; }
.nfs-step p { font-size: 12px; color: #737373; margin-top: 4px; line-height: 1.5; }

/* ---------- 01: TAB RAIL ---------- */
.nfs-tab-layout { display: flex; gap: 0; min-height: 480px; border: 1px solid #e8e5df; border-radius: 20px; overflow: hidden; background: #fff; }
.nfs-tab-rail { width: 200px; background: #fafafa; border-right: 1px solid #e8e5df; padding: 16px 0; flex-shrink: 0; display: flex; flex-direction: column; gap: 2px; }
.nfs-tab-item { display: flex; align-items: center; gap: 10px; padding: 14px 20px; font-size: 14px; font-weight: 500; color: #737373; cursor: pointer; transition: all 0.2s; border-left: 3px solid transparent; }
.nfs-tab-item:hover { color: #0a0a0a; background: rgba(0,0,0,0.02); }
.nfs-tab-item.active { color: #1e9a80; background: rgba(30,154,128,0.04); border-left-color: #1e9a80; font-weight: 600; }
.nfs-tab-item svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2; }
.nfs-tab-screen { flex: 1; padding: 32px; position: relative; }
.nfs-tab-pane { display: none; }
.nfs-tab-pane.active { display: block; }

/* ---------- 02: STICKY DEVICE ---------- */
.nfs-story-layout { display: flex; gap: 48px; }
.nfs-story-steps { flex: 1; }
.nfs-story-step { padding: 48px 0; border-bottom: 1px solid #f3f4f6; }
.nfs-story-step:last-child { border-bottom: none; }
.nfs-story-num { font-size: 11px; font-weight: 700; color: #1e9a80; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; }
.nfs-story-step h3 { font-size: 22px; font-weight: 700; color: #0a0a0a; margin-bottom: 8px; }
.nfs-story-step p { font-size: 14px; color: #737373; line-height: 1.6; }
.nfs-story-device { width: 400px; flex-shrink: 0; position: sticky; top: 120px; height: fit-content; }
.nfs-device-frame { background: #fafafa; border: 1px solid #e8e5df; border-radius: 16px; padding: 16px; min-height: 360px; }

/* ---------- 03: DEAL GALLERY ---------- */
.nfs-gallery-layout { display: flex; gap: 24px; }
.nfs-gallery-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; flex: 1; }
.nfs-gallery-card { background: #fff; border: 1px solid #e8e5df; border-radius: 12px; padding: 14px; cursor: pointer; transition: all 0.2s; }
.nfs-gallery-card:hover, .nfs-gallery-card.active { border-color: #1e9a80; box-shadow: 0 0 0 1px #1e9a80; }
.nfs-gallery-card h4 { font-size: 14px; font-weight: 600; color: #0a0a0a; }
.nfs-gallery-card .meta { font-size: 12px; color: #737373; margin-top: 2px; }
.nfs-gallery-card .nums { display: flex; justify-content: space-between; margin-top: 8px; font-size: 13px; }
.nfs-gallery-card .profit { color: #1e9a80; font-weight: 700; }
.nfs-gallery-sidebar { width: 320px; flex-shrink: 0; }
.nfs-gallery-panel { background: #fafafa; border: 1px solid #e8e5df; border-radius: 16px; padding: 20px; position: sticky; top: 120px; }

/* ---------- 04: SPLIT COMPARE ---------- */
.nfs-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.nfs-compare-col { border-radius: 16px; padding: 28px; }
.nfs-compare-col.before { background: #fef2f2; border: 1px solid #fecaca; }
.nfs-compare-col.after { background: #ecfdf5; border: 1px solid #a7f3d0; }
.nfs-compare-col h3 { font-size: 16px; font-weight: 700; margin-bottom: 16px; }
.nfs-compare-col.before h3 { color: #dc2626; }
.nfs-compare-col.after h3 { color: #1e9a80; }
.nfs-compare-item { font-size: 13px; padding: 8px 0; border-bottom: 1px solid rgba(0,0,0,0.05); color: #525252; display: flex; align-items: center; gap: 8px; }

/* ---------- 05: PLAYGROUND ---------- */
.nfs-playground { background: #fff; border: 1px solid #e8e5df; border-radius: 20px; padding: 32px; max-width: 640px; margin: 0 auto; box-shadow: 0 8px 32px rgba(0,0,0,0.04); }
.nfs-play-row { display: flex; gap: 24px; margin-bottom: 20px; }
.nfs-play-control { flex: 1; }
.nfs-play-label { font-size: 12px; font-weight: 600; color: #525252; margin-bottom: 6px; display: block; }
.nfs-play-select, .nfs-play-input { width: 100%; height: 40px; border: 1px solid #e8e5df; border-radius: 10px; padding: 0 12px; font-size: 14px; color: #0a0a0a; background: #fff; }
.nfs-play-select:focus, .nfs-play-input:focus { outline: none; border-color: #1e9a80; box-shadow: 0 0 0 3px rgba(30,154,128,0.08); }
.nfs-play-slider { width: 100%; height: 6px; border-radius: 3px; -webkit-appearance: none; appearance: none; background: #e8e5df; cursor: pointer; }
.nfs-play-slider::-webkit-slider-thumb { -webkit-appearance: none; width: 18px; height: 18px; border-radius: 50%; background: #1e9a80; border: 2px solid #fff; box-shadow: 0 1px 4px rgba(0,0,0,0.15); cursor: pointer; }
.nfs-play-output { background: #ecfdf5; border: 1px solid #a7f3d0; border-radius: 16px; padding: 24px; text-align: center; margin-top: 20px; }
.nfs-play-profit { font-size: 36px; font-weight: 800; color: #1e9a80; }
.nfs-play-profit-label { font-size: 13px; color: #525252; margin-top: 4px; }

/* ---------- 06: TRUST BADGES ---------- */
.nfs-trust-row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.nfs-trust-badge { display: inline-flex; align-items: center; gap: 6px; background: #fff; border: 1px solid #e8e5df; border-radius: 100px; padding: 8px 16px; font-size: 13px; font-weight: 500; color: #525252; }
.nfs-trust-badge svg { width: 16px; height: 16px; color: #1e9a80; }

/* ---------- 07: COURSE CARDS ---------- */
.nfs-course { background: #fff; border: 1px solid #e8e5df; border-radius: 16px; padding: 24px; }
.nfs-course h3 { font-size: 16px; font-weight: 600; color: #0a0a0a; margin-bottom: 8px; }
.nfs-course-meta { font-size: 12px; color: #737373; margin-bottom: 12px; }
.nfs-course-bar { height: 6px; background: #f3f4f6; border-radius: 3px; overflow: hidden; }
.nfs-course-fill { height: 100%; background: #1e9a80; border-radius: 3px; }
.nfs-course-pct { font-size: 11px; font-weight: 600; color: #1e9a80; margin-top: 6px; }

/* ---------- 08: PERSONA PILLS ---------- */
.nfs-persona-bar { display: flex; gap: 8px; justify-content: center; margin-bottom: 40px; }
.nfs-persona-pill { padding: 10px 24px; border-radius: 100px; border: 1.5px solid #e8e5df; font-size: 14px; font-weight: 500; color: #737373; cursor: pointer; transition: all 0.2s; background: #fff; }
.nfs-persona-pill:hover { border-color: #1e9a80; color: #1e9a80; }
.nfs-persona-pill.active { border-color: #1e9a80; background: rgba(30,154,128,0.04); color: #1e9a80; font-weight: 600; }
.nfs-persona-content { display: none; }
.nfs-persona-content.active { display: block; }

/* ---------- 09: KPI DASHBOARD ---------- */
.nfs-kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.nfs-kpi { background: #fff; border: 1px solid #e8e5df; border-radius: 14px; padding: 20px; }
.nfs-kpi-label { font-size: 12px; color: #737373; font-weight: 500; }
.nfs-kpi-value { font-size: 28px; font-weight: 800; color: #0a0a0a; margin-top: 4px; }
.nfs-kpi-value.green { color: #1e9a80; }
.nfs-kpi-delta { font-size: 11px; color: #1e9a80; font-weight: 600; margin-top: 4px; }

/* ---------- 10: TIMELINE ---------- */
.nfs-timeline { position: relative; max-width: 640px; margin: 0 auto; }
.nfs-timeline::before { content: ''; position: absolute; left: 20px; top: 0; bottom: 0; width: 2px; background: linear-gradient(180deg, #1e9a80, #e8e5df); }
.nfs-tl-step { display: flex; gap: 24px; padding: 28px 0; position: relative; }
.nfs-tl-dot { width: 40px; height: 40px; border-radius: 50%; background: #1e9a80; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 14px; font-weight: 700; flex-shrink: 0; z-index: 1; border: 3px solid #f3f3ee; }
.nfs-tl-dot.locked { background: #e8e5df; color: #9ca3af; }
.nfs-tl-body h4 { font-size: 16px; font-weight: 600; color: #0a0a0a; margin-bottom: 4px; }
.nfs-tl-body p { font-size: 13px; color: #737373; line-height: 1.5; }
.nfs-tl-tag { display: inline-block; font-size: 10px; font-weight: 600; color: #1e9a80; background: rgba(30,154,128,0.08); padding: 2px 8px; border-radius: 6px; margin-top: 8px; }
.nfs-tl-mock { background: #fafafa; border: 1px solid #e8e5df; border-radius: 10px; padding: 12px; margin-top: 10px; font-size: 12px; color: #525252; }

/* ---------- HUB GRID ---------- */
.nfs-hub-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.nfs-hub-card { background: #fff; border: 1px solid #e8e5df; border-radius: 16px; padding: 24px; display: flex; flex-direction: column; transition: all 0.2s; }
.nfs-hub-card:hover { border-color: #1e9a80; box-shadow: 0 8px 24px rgba(0,0,0,0.06); transform: translateY(-2px); }
.nfs-hub-num { font-size: 11px; font-weight: 700; color: #1e9a80; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
.nfs-hub-card h3 { font-size: 17px; font-weight: 600; color: #0a0a0a; margin-bottom: 6px; }
.nfs-hub-card p { font-size: 13px; color: #737373; line-height: 1.5; flex: 1; margin-bottom: 14px; }
.nfs-hub-link { font-size: 13px; font-weight: 600; color: #1e9a80; text-decoration: none; display: inline-flex; align-items: center; gap: 4px; }
.nfs-hub-link:hover { text-decoration: underline; }

/* ---------- MOCK UI ELEMENTS ---------- */
.nfs-mock-inbox { border: 1px solid #e8e5df; border-radius: 12px; overflow: hidden; background: #fff; }
.nfs-mock-inbox-header { padding: 10px 14px; border-bottom: 1px solid #f3f4f6; font-size: 13px; font-weight: 600; color: #0a0a0a; }
.nfs-mock-msg { padding: 8px 14px; font-size: 12px; }
.nfs-mock-msg.them { background: #f8f9fa; color: #525252; }
.nfs-mock-msg.me { background: #ecfdf5; color: #0a0a0a; text-align: right; }
.nfs-mock-pipeline { display: flex; gap: 8px; }
.nfs-mock-col { flex: 1; background: #f8f9fa; border-radius: 8px; padding: 8px; min-height: 80px; }
.nfs-mock-col-head { font-size: 10px; font-weight: 700; color: #525252; margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.5px; }
.nfs-mock-deal { background: #fff; border: 1px solid #e8e5df; border-radius: 6px; padding: 6px 8px; font-size: 11px; margin-bottom: 4px; }

/* ---------- FOOTER ---------- */
.nfs-footer { background: #fff; padding: 48px 0 24px; border-top: 1px solid #e8e5df; }
.nfs-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 32px; }
.nfs-footer-brand { display: flex; align-items: center; gap: 3px; margin-bottom: 8px; }
.nfs-footer-brand .box { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; border: 2px solid #0a0a0a; border-radius: 6px; font-family: 'Sora', sans-serif; font-size: 12px; font-weight: 700; }
.nfs-footer-brand .text { font-family: 'Sora', sans-serif; font-size: 18px; font-weight: 400; letter-spacing: 2px; }
.nfs-footer-desc { font-size: 13px; color: #737373; line-height: 1.5; }
.nfs-footer-col h4 { font-size: 12px; font-weight: 700; color: #0a0a0a; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 12px; }
.nfs-footer-col a { display: block; font-size: 13px; color: #737373; text-decoration: none; padding: 3px 0; transition: color 0.15s; }
.nfs-footer-col a:hover { color: #1e9a80; }
.nfs-footer-bottom { border-top: 1px solid #f3f4f6; padding-top: 16px; font-size: 12px; color: #9ca3af; text-align: center; }


/* ═══════════════════════════════════════════
   Premium Journey Timeline + Academy Grid
   ═══════════════════════════════════════════ */
/* ═══════════════════════════════════════════
   SECTION A — JOURNEY TIMELINE
   ═══════════════════════════════════════════ */
.prem-journey {
  position: relative;
  padding: 96px 0;
  background: #f3f3ee;
  overflow: hidden;
}
.prem-journey .wrap { position: relative; z-index: 1; }

.prem-journey-grid {
  position: relative;
  max-width: 840px;
  margin: 0 auto;
  padding-top: 20px;
}

.prem-step {
  display: flex;
  gap: 32px;
  padding: 24px 0;
  position: relative;
  z-index: 1;
}

/* Alternating left-right on desktop */
@media (min-width: 769px) {
  .prem-step { width: 50%; }
  .prem-step:nth-child(odd) {
    margin-left: 50%;
    padding-left: 40px;
  }
  .prem-step:nth-child(even) {
    flex-direction: row-reverse;
    text-align: right;
    padding-right: 40px;
  }
  .prem-step:nth-child(even) .prem-step-card { text-align: left; }
}

.prem-step-node {
  width: 44px; height: 44px; border-radius: 50%;
  background: #1e9a80; color: #fff;
  font-size: 14px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; z-index: 2;
  border: 3px solid #f3f3ee;
  position: relative;
}

.prem-step-card {
  background: #fff;
  border: 1px solid rgba(30,154,128,0.12);
  border-radius: 20px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.06);
  padding: 28px 32px;
  flex: 1;
  position: relative;
  overflow: hidden;
}
.prem-step-card h4 {
  font-size: 16px; font-weight: 600; color: #1a1a1a;
  margin-bottom: 6px; letter-spacing: 0.01em;
}
.prem-step-card p {
  font-size: 14px; color: #6b7280; line-height: 1.6; margin-bottom: 10px;
}
.prem-tag {
  display: inline-block;
  background: rgba(30,154,128,0.08);
  border: 1px solid rgba(30,154,128,0.2);
  color: #1e9a80;
  border-radius: 100px;
  font-size: 0.72rem;
  font-weight: 600;
  padding: 3px 12px;
}

/* Mobile: single column, line on left */
@media (max-width: 768px) {
  .journey-line { left: 22px; transform: none; }
  .prem-step { padding-left: 56px; }
  .prem-step-node { position: absolute; left: 0; }
  .prem-step-card { padding: 20px 24px; }
  .prem-journey { padding: 64px 0; }
}

/* ═══════════════════════════════════════════
   SECTION B — ACADEMY GRID
   ═══════════════════════════════════════════ */
.prem-academy {
  position: relative;
  padding: 96px 0;
  background: #e8e5df;
  overflow: hidden;
}
.prem-academy .wrap { position: relative; z-index: 1; }

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

.prem-course {
  background: #fff;
  border: 1px solid rgba(30,154,128,0.1);
  border-radius: 20px;
  padding: 32px;
  position: relative;
  overflow: hidden;
  transition: all 200ms ease-out;
  cursor: pointer;
}
.prem-course:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(30,154,128,0.15);
  border-color: rgba(30,154,128,0.35);
}
.prem-course:hover .shimmer-once {
  animation: shimmerOnce 600ms ease forwards;
}

.prem-level {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 600;
  padding: 3px 12px;
  border-radius: 100px;
  margin-bottom: 14px;
}
.prem-level.beginner {
  background: rgba(30,154,128,0.08);
  color: #1e9a80;
}
.prem-level.intermediate {
  background: rgba(99,102,241,0.08);
  color: #6366f1;
}

.prem-course h3 {
  font-size: 1.1rem; font-weight: 600; color: #1a1a1a;
  margin-bottom: 4px; letter-spacing: 0.01em;
}
.prem-course .lesson-count {
  font-size: 0.8rem; color: #6b7280; margin-bottom: 12px;
}
.prem-course .desc {
  font-size: 0.875rem; color: #6b7280; line-height: 1.6; margin-bottom: 16px;
}
.prem-course .start-link {
  font-size: 0.875rem; color: #1e9a80; font-weight: 500;
  text-decoration: none; position: relative; display: inline-block;
}
.prem-course .start-link::after {
  content: ''; position: absolute; bottom: -2px; left: 0;
  width: 0; height: 1.5px; background: #1e9a80;
  transition: width 200ms ease-in-out;
}
.prem-course:hover .start-link::after { width: 100%; }

@keyframes shimmerOnce {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(200%); }
}
.shimmer-once {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,0.5) 50%, transparent 60%);
  transform: translateX(-100%);
}

.prem-academy-cta {
  text-align: center;
  margin-top: 40px;
}
.prem-academy-cta p {
  font-size: 14px; color: #6b7280; margin-bottom: 16px;
}
.prem-academy-btn {
  display: inline-flex; align-items: center; justify-content: center;
  height: 48px; padding: 0 36px;
  background: #1e9a80; color: #fff;
  font-size: 15px; font-weight: 600;
  border-radius: 100px; border: none;
  text-decoration: none; cursor: pointer;
  transition: all 200ms ease-out;
}
.prem-academy-btn:hover {
  transform: scale(1.03);
  box-shadow: 0 8px 24px rgba(30,154,128,0.35);
}
.prem-academy-btn:active {
  transform: scale(0.97);
}
.prem-academy-btn:focus-visible {
  outline: 2px solid #1c1c1c;
  outline-offset: 3px;
}

