.elementor-16108 .elementor-element.elementor-element-635b5ae{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-16108 .elementor-element.elementor-element-635b5ae:not(.elementor-motion-effects-element-type-background), .elementor-16108 .elementor-element.elementor-element-635b5ae > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}.elementor-16108 .elementor-element.elementor-element-a3e3925{width:100%;max-width:100%;}.elementor-16108 .elementor-element.elementor-element-a3e3925 > .elementor-widget-container{background-color:#EDEDED;}:root{--page-title-display:none;}/* Start custom CSS for html, class: .elementor-element-a3e3925 */*,
    *::before,
    *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }

    :root {
      --green: #5dc361;
      --green-dark: #3fa843;
      --green-dim: rgba(93, 195, 97, 0.10);
      --green-border: rgba(93, 195, 97, 0.28);
      --navy: #1d293f;
      --navy-70: rgba(29, 41, 63, 0.7);
      --navy-50: rgba(29, 41, 63, 0.5);
      --navy-35: rgba(29, 41, 63, 0.35);
      --navy-15: rgba(29, 41, 63, 0.15);
      --navy-08: rgba(29, 41, 63, 0.08);
      --amber: #d97706;
      --amber-dim: rgba(217, 119, 6, 0.10);
      --amber-border: rgba(217, 119, 6, 0.25);
      --red: #dc2626;
      --red-dim: rgba(220, 38, 38, 0.07);
      --white: #fff;
      --off: #f7f8fc;
      --surface: #eef0f6;
      --sans: 'DM Sans', system-ui, sans-serif;
      --serif: 'DM Serif Display', Georgia, serif;
      --display-font: 'Bebas Neue', sans-serif;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      font-family: var(--sans);
      background: var(--white);
      color: var(--navy);
      -webkit-font-smoothing: antialiased;
      overflow-x: hidden;
    }

    /* ─── NAV ─── */
    .nav {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 900;
      background: rgba(29, 41, 63, 0.97);
      backdrop-filter: blur(12px);
      border-bottom: 0.5px solid rgba(255, 255, 255, 0.07);
      padding: 0 32px;
      height: 60px;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }

    .nav-brand {
      font-family: var(--display-font);
      font-size: 22px;
      color: #fff;
      letter-spacing: 0.08em;
    }

    .nav-brand span {
      color: var(--green);
    }

    .nav-links {
      display: flex;
      gap: 28px;
      align-items: center;
    }

    .nav-links a {
      font-size: 12px;
      font-weight: 400;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.45);
      text-decoration: none;
      transition: color 0.2s;
    }

    .nav-links a:hover {
      color: rgba(255, 255, 255, 0.85);
    }

    .nav-cta {
      background: var(--green-dark);
      color: #fff !important;
      padding: 9px 18px;
      border-radius: 5px;
      font-weight: 500 !important;
    }

    .nav-cta:hover {
      background: #338a37 !important;
    }

    /* ─── HERO ─── */
    .hero {
      min-height: 100vh;
      background: var(--navy);
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 120px 32px 80px;
      position: relative;
      overflow: hidden;
    }

    .hero::before {
      content: '';
      position: absolute;
      top: -80px;
      right: -120px;
      width: 600px;
      height: 600px;
      background: radial-gradient(circle, rgba(93, 195, 97, 0.08) 0%, transparent 65%);
      pointer-events: none;
    }

    .hero::after {
      content: '';
      position: absolute;
      bottom: -60px;
      left: -80px;
      width: 400px;
      height: 400px;
      background: radial-gradient(circle, rgba(93, 195, 97, 0.05) 0%, transparent 65%);
      pointer-events: none;
    }

    .hero-inner {
      max-width: 980px;
      margin: 0 auto;
      width: 100%;
      position: relative;
      z-index: 2;
    }

    .hero-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-size: 10px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--green);
      font-weight: 500;
      margin-bottom: 24px;
    }

    .hero-eyebrow::before {
      content: '';
      display: block;
      width: 28px;
      height: 1px;
      background: var(--green);
    }

    .hero-headline {
      font-family: var(--display-font);
      font-size: clamp(62px, 9vw, 112px);
      line-height: 0.92;
      color: #fff;
      letter-spacing: 0.02em;
      margin-bottom: 20px;
    }

    .hero-headline .accent {
      color: var(--green);
    }

    .hero-sub {
      font-size: clamp(15px, 2vw, 19px);
      font-weight: 300;
      color: rgba(255, 255, 255, 0.5);
      line-height: 1.65;
      max-width: 520px;
      margin-bottom: 48px;
    }

    .hero-sub strong {
      color: rgba(255, 255, 255, 0.8);
      font-weight: 500;
    }

    .hero-actions {
      display: flex;
      gap: 14px;
      flex-wrap: wrap;
      align-items: center;
    }

    .btn-primary {
      display: inline-block;
      background: var(--green-dark);
      color: #fff !important;
      font-family: var(--sans);
      font-size: 13px;
      font-weight: 500;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      padding: 16px 32px;
      border-radius: 6px;
      text-decoration: none;
      transition: background 0.15s, transform 0.15s;
      border: none;
      cursor: pointer;
    }

    .btn-primary:hover {
      background: #338a37;
      transform: translateY(-1px);
    }

    .btn-ghost {
      display: inline-block;
      background: transparent;
      color: rgba(255, 255, 255, 0.45) !important;
      font-family: var(--sans);
      font-size: 13px;
      font-weight: 400;
      letter-spacing: 0.06em;
      padding: 16px 0;
      text-decoration: none;
      transition: color 0.2s;
      border: none;
      cursor: pointer;
    }

    .btn-ghost:hover {
      color: rgba(255, 255, 255, 0.8);
    }

    /* ─── SHARED SECTION ─── */
    .section-eyebrow {
      font-size: 10px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--green-dark);
      font-weight: 500;
      margin-bottom: 20px;
    }

    .section-headline {
      font-family: var(--serif);
      font-size: clamp(26px, 4vw, 40px);
      color: var(--navy);
      line-height: 1.25;
      margin-bottom: 14px;
    }

    .section-headline em {
      color: var(--green-dark);
      font-style: italic;
    }

    .section-sub {
      font-size: 15px;
      font-weight: 300;
      color: var(--navy-50);
      line-height: 1.7;
      max-width: 560px;
      margin-bottom: 52px;
    }
    
    .fade-up {
      opacity: 0;
      transform: translateY(24px);
      transition: opacity 0.6s ease, transform 0.6s ease;
    }

    .fade-up.visible {
      opacity: 1;
      transform: translateY(0);
    }
    
     /* ─── PROBLEM ─── */
    .problem {
      background: var(--off);
      padding: 100px 32px;
      border-top: 0.5px solid var(--navy-15);
    }

    .problem-inner {
      max-width: 980px;
      margin: 0 auto;
    }

    .landscape-table {
      width: 100%;
      border-collapse: collapse;
    }

    .landscape-table th {
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: 0.16em;
      color: var(--navy-35);
      font-weight: 500;
      padding: 0 16px 14px;
      text-align: left;
    }

    .landscape-table th:not(:first-child) {
      text-align: center;
    }

    .landscape-table td {
      padding: 14px 16px;
      border-top: 0.5px solid var(--navy-15);
      font-size: 13px;
      color: var(--navy-70);
      font-weight: 300;
    }

    .landscape-table td:not(:first-child) {
      text-align: center;
      font-size: 12px;
      font-weight: 500;
    }

    .landscape-table tr:last-child td {
      background: var(--navy);
      color: #fff;
    }

    .landscape-table tr:last-child td:first-child {
      border-radius: 6px 0 0 6px;
      font-family: var(--display-font);
      font-size: 16px;
      letter-spacing: 0.06em;
      color: var(--green);
      font-weight: 400;
    }

    .landscape-table tr:last-child td:last-child {
      border-radius: 0 6px 6px 0;
    }

    .t-yes {
      color: var(--green-dark);
    }

    .t-none {
      color: #dc2626;
    }

    .t-partial {
      color: var(--amber);
    }

    .t-full {
      color: var(--green);
    }
    
     /* ─── PRODUCT ─── */
    .product {
      background: var(--white);
      padding: 100px 32px;
    }

    .product-inner {
      max-width: 980px;
      margin: 0 auto;
    }

    .product-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
      margin-top: 16px;
    }

    .product-card {
      background: var(--off);
      border: 0.5px solid var(--navy-15);
      border-radius: 10px;
      padding: 28px;
      transition: border-color 0.2s, box-shadow 0.2s;
    }

    .product-card:hover {
      border-color: var(--green-border);
      box-shadow: 0 4px 24px rgba(63, 168, 67, 0.07);
    }

    .product-card.featured {
      grid-column: 1 / -1;
      background: var(--navy);
      border-color: rgba(255, 255, 255, 0.06);
      display: flex;
      gap: 32px;
      align-items: flex-start;
    }

    .product-num {
      font-family: var(--display-font);
      font-size: 40px;
      color: var(--navy-15);
      line-height: 1;
      margin-bottom: 12px;
    }

    .product-card.featured .product-num {
      color: rgba(255, 255, 255, 0.1);
    }

    .product-title {
      font-size: 15px;
      font-weight: 500;
      color: var(--navy);
      margin-bottom: 8px;
    }

    .product-card.featured .product-title {
      color: var(--green);
      font-size: 16px;
    }

    .product-body {
      font-size: 13px;
      font-weight: 300;
      color: var(--navy-50);
      line-height: 1.65;
    }

    .product-card.featured .product-body {
      color: rgba(255, 255, 255, 0.4);
      font-size: 14px;
    }

    .product-card.featured .product-text {
      flex: 1;
    }

    .product-badge {
      background: var(--green-dim);
      border: 0.5px solid var(--green-border);
      border-radius: 6px;
      padding: 10px 16px;
      white-space: nowrap;
      align-self: center;
      font-size: 11px;
      font-weight: 500;
      color: var(--green);
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }
    
    
    
    /* ─── WHY NOW ─── */
    .why-now {
      background: var(--navy);
      padding: 100px 32px;
    }

    .why-now-inner {
      max-width: 980px;
      margin: 0 auto;
    }

    .why-grid {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      gap: 1px;
      background: rgba(255, 255, 255, 0.07);
      border-radius: 10px;
      overflow: hidden;
    }

    .why-card {
      background: rgba(29, 41, 63, 0.96);
      padding: 36px 28px;
    }

    .why-icon {
      font-size: 22px;
      margin-bottom: 18px;
    }

    .why-title {
      font-family: var(--serif);
      font-size: 18px;
      color: #fff;
      margin-bottom: 12px;
      line-height: 1.3;
    }

    .why-title em {
      color: var(--green);
    }

    .why-body {
      font-size: 13px;
      font-weight: 300;
      color: rgba(255, 255, 255, 0.38);
      line-height: 1.7;
    }
    
    
    
    
    /* ─── SAMPLE SECTION ─── */
    .sample-section {
      background: var(--surface);
      padding: 100px 32px;
    }

    .sample-inner {
      max-width: 780px;
      margin: 0 auto;
    }

    .sample-intro {
      text-align: center;
      margin-bottom: 48px;
    }

    .sample-intro .section-headline {
      margin-bottom: 12px;
    }

    .sample-intro .section-sub {
      margin: 0 auto 32px;
      text-align: center;
    }

    /* Upload card */
    .upload-card {
      background: var(--white);
      border: 0.5px solid var(--navy-15);
      border-radius: 14px;
      padding: 52px 48px;
      text-align: center;
      box-shadow: 0 4px 32px rgba(29, 41, 63, 0.07);
    }

    .upload-card-eyebrow {
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: 0.18em;
      color: var(--green-dark);
      font-weight: 500;
      margin-bottom: 16px;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
    }

    .upload-card-eyebrow::before,
    .upload-card-eyebrow::after {
      content: '';
      display: block;
      width: 20px;
      height: 1px;
      background: var(--green-dark);
    }

    .upload-card h3 {
      font-family: var(--serif);
      font-size: 26px;
      color: var(--navy);
      margin-bottom: 10px;
      line-height: 1.3;
    }

    .upload-card p {
      font-size: 14px;
      font-weight: 300;
      color: var(--navy-50);
      line-height: 1.65;
      max-width: 440px;
      margin: 0 auto 36px;
    }

    .dropzone {
      border: 1.5px dashed rgba(29, 41, 63, 0.2);
      border-radius: 10px;
      padding: 40px 24px;
      cursor: pointer;
      transition: border-color 0.2s, background 0.2s;
      background: var(--off);
      margin-bottom: 16px;
    }

    .dropzone:hover,
    .dropzone.dragover {
      border-color: var(--green);
      background: rgba(93, 195, 97, 0.05);
    }

    .dropzone-icon {
      font-size: 28px;
      color: var(--green-dark);
      margin-bottom: 12px;
      opacity: 0.7;
    }

    .dropzone-label {
      font-size: 14px;
      color: var(--navy-50);
      font-weight: 300;
    }

    .dropzone-label strong {
      color: var(--navy);
      font-weight: 500;
    }

    .dropzone-hint {
      font-size: 11px;
      color: var(--navy-35);
      margin-top: 8px;
    }

    #csv-file-input {
      display: none;
    }

    .upload-divider {
      font-size: 10px;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      color: var(--navy-35);
      margin: 20px 0;
      display: flex;
      align-items: center;
      gap: 14px;
    }

    .upload-divider::before,
    .upload-divider::after {
      content: '';
      flex: 1;
      height: 0.5px;
      background: var(--navy-15);
    }

    .paste-area {
      width: 100%;
      background: var(--off);
      border: 0.5px solid var(--navy-15);
      border-radius: 8px;
      padding: 14px;
      font-family: 'Courier New', monospace;
      font-size: 12px;
      color: var(--navy-70);
      resize: vertical;
      min-height: 72px;
      outline: none;
      transition: border-color 0.2s;
      display: block;
    }

    .paste-area:focus {
      border-color: rgba(93, 195, 97, 0.4);
    }

    .paste-hint {
      font-size: 11px;
      color: var(--navy-35);
      font-style: italic;
      margin-top: 6px;
      margin-bottom: 20px;
      text-align: left;
    }

    .upload-btn {
      width: 100%;
      background: var(--navy);
      border: none;
      border-radius: 6px;
      padding: 15px;
      font-family: var(--sans);
      font-size: 13px;
      font-weight: 500;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: #fff;
      cursor: pointer;
      transition: background 0.15s;
    }

    .upload-btn:hover {
      background: #14202f;
    }

    .upload-error {
      font-size: 12px;
      color: #dc2626;
      margin-top: 10px;
      display: none;
    }


    /* What's inside */
    .sample-preview {
      margin-top: 40px;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
    }

    .preview-item {
      background: var(--white);
      border: 0.5px solid var(--navy-15);
      border-radius: 8px;
      padding: 16px 18px;
      display: flex;
      gap: 12px;
      align-items: flex-start;
    }

    .preview-num {
      font-family: var(--display-font);
      font-size: 22px;
      color: var(--navy-15);
      flex-shrink: 0;
      line-height: 1;
    }

    .preview-title {
      font-size: 12px;
      font-weight: 500;
      color: var(--navy);
      margin-bottom: 3px;
    }

    .preview-body {
      font-size: 11px;
      color: var(--navy-50);
      font-weight: 300;
      line-height: 1.5;
    }
    
    
    /* ─── REPORT PAGE (hidden until CSV loaded) ─── */
    #report-page {
      display: none;
      background: var(--surface);
      min-height: 100vh;
      padding: 48px 24px;
    }

    .report-wrap {
      max-width: 780px;
      margin: 0 auto;
      background: var(--white);
      border-radius: 16px;
      overflow: hidden;
      border: 0.5px solid var(--navy-15);
      box-shadow: 0 4px 32px rgba(29, 41, 63, 0.08);
    }

    /* Report hero */
    .rpt-hero {
      background: var(--navy);
      padding: 48px 48px 40px;
      position: relative;
      overflow: hidden;
    }

    .rpt-hero::before {
      content: '';
      position: absolute;
      top: -40px;
      right: -40px;
      width: 280px;
      height: 280px;
      background: radial-gradient(circle, rgba(93, 195, 97, 0.1) 0%, transparent 70%);
      pointer-events: none;
    }

    .rpt-eyebrow {
      font-size: 10px;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--green);
      font-weight: 500;
      margin-bottom: 14px;
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .rpt-eyebrow::before {
      content: '';
      display: block;
      width: 22px;
      height: 1px;
      background: var(--green);
    }

    .rpt-headline {
      font-family: var(--display-font);
      font-size: 58px;
      line-height: 0.95;
      color: #fff;
      letter-spacing: 0.02em;
      margin-bottom: 8px;
    }

    .rpt-headline span {
      color: var(--green);
    }

    .rpt-subhead {
      font-size: 12px;
      font-weight: 300;
      color: rgba(255, 255, 255, 0.4);
      letter-spacing: 0.1em;
      text-transform: uppercase;
      margin-bottom: 32px;
    }

    .rpt-meta-row {
      display: flex;
      gap: 32px;
      flex-wrap: wrap;
    }

    .rpt-meta-label {
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      color: rgba(255, 255, 255, 0.3);
      margin-bottom: 4px;
    }

    .rpt-meta-value {
      font-size: 14px;
      color: rgba(255, 255, 255, 0.85);
      font-weight: 500;
    }

    .rpt-date {
      position: absolute;
      top: 48px;
      right: 48px;
      font-size: 11px;
      color: rgba(255, 255, 255, 0.25);
      letter-spacing: 0.06em;
    }

    /* Challenge */
    .rpt-challenge {
      background: var(--off);
      padding: 20px 48px;
      border-bottom: 0.5px solid var(--navy-15);
      display: flex;
      align-items: center;
      gap: 16px;
    }

    .rpt-challenge-label {
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      color: var(--navy-35);
      white-space: nowrap;
      font-weight: 500;
    }

    .rpt-challenge-value {
      font-size: 13px;
      color: var(--navy);
      font-weight: 500;
    }

    .rpt-challenge-value::before {
      content: '\201C';
      color: var(--green);
    }

    .rpt-challenge-value::after {
      content: '\201D';
      color: var(--green);
    }
    
    
    /* Score rings */
    .rpt-scores {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      border-bottom: 0.5px solid var(--navy-15);
    }

    .rpt-score {
      padding: 28px 24px;
      border-right: 0.5px solid var(--navy-15);
      text-align: center;
    }

    .rpt-score:last-child {
      border-right: none;
    }

    .rpt-score-label {
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      color: var(--navy-35);
      margin-bottom: 12px;
      font-weight: 500;
    }

    .score-ring {
      width: 80px;
      height: 80px;
      margin: 0 auto 12px;
      position: relative;
    }

    .score-ring svg {
      transform: rotate(-90deg);
    }

    .score-ring-num {
      position: absolute;
      inset: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: var(--display-font);
      font-size: 26px;
      color: var(--navy);
    }

    .score-ring-num.green {
      color: var(--green-dark);
    }

    .score-ring-num.amber {
      color: var(--amber);
    }

    .rpt-score-desc {
      font-size: 11px;
      color: var(--navy-50);
      font-weight: 300;
      line-height: 1.5;
    }

    /* Benchmark table */
    .rpt-bench {
      padding: 32px 48px;
      background: var(--white);
      border-bottom: 0.5px solid var(--navy-15);
    }

    .rpt-section-title {
      font-size: 10px;
      text-transform: uppercase;
      letter-spacing: 0.16em;
      color: var(--navy-35);
      margin-bottom: 20px;
      font-weight: 500;
    }

    .bench-row {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 12px 0;
      border-bottom: 0.5px solid var(--navy-15);
    }

    .bench-row:last-child {
      border-bottom: none;
      padding-bottom: 0;
    }

    .bench-metric {
      flex: 1;
      font-size: 13px;
      color: var(--navy-70);
      font-weight: 300;
    }

    .bench-industry {
      width: 110px;
      text-align: right;
      font-size: 12px;
      color: var(--navy-50);
    }

    .bench-bar-wrap {
      width: 140px;
      height: 6px;
      background: var(--navy-08);
      border-radius: 3px;
      overflow: hidden;
    }

    .bench-bar {
      height: 100%;
      border-radius: 3px;
      background: var(--green-dark);
      transition: width 0.6s ease;
    }

    .bench-bar.amber {
      background: var(--amber);
    }

    .bench-bar.red {
      background: var(--red);
    }

    .bench-status {
      width: 70px;
      text-align: right;
      font-size: 11px;
      font-weight: 500;
    }

    .bench-status.good {
      color: var(--green-dark);
    }

    .bench-status.watch {
      color: var(--amber);
    }

    .bench-status.risk {
      color: var(--red);
    }

    /* Signals */
    .rpt-signals {
      padding: 32px 48px;
      background: var(--off);
      border-bottom: 0.5px solid var(--navy-15);
    }

    .signal-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
    }

    .signal-card {
      background: var(--white);
      border: 0.5px solid var(--navy-15);
      border-radius: 8px;
      padding: 16px 18px;
    }

    .signal-card.positive {
      border-left: 3px solid var(--green-dark);
    }

    .signal-card.caution {
      border-left: 3px solid var(--amber);
    }

    .signal-title {
      font-size: 12px;
      font-weight: 500;
      color: var(--navy);
      margin-bottom: 5px;
      line-height: 1.3;
    }

    .signal-body {
      font-size: 11px;
      color: var(--navy-50);
      line-height: 1.6;
      font-weight: 300;
    }

    /* Forecast */
    .rpt-forecast {
      padding: 32px 48px;
      background: var(--white);
      border-bottom: 0.5px solid var(--navy-15);
    }

    .forecast-grid {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      gap: 12px;
      margin-top: 4px;
    }

    .forecast-card {
      border-radius: 8px;
      padding: 16px 18px;
    }

    .forecast-card.conservative {
      background: var(--red-dim);
      border: 0.5px solid rgba(220, 38, 38, 0.15);
    }

    .forecast-card.base {
      background: var(--amber-dim);
      border: 0.5px solid var(--amber-border);
    }

    .forecast-card.optimistic {
      background: var(--green-dim);
      border: 0.5px solid var(--green-border);
    }

    .forecast-label {
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      font-weight: 500;
      margin-bottom: 10px;
    }

    .forecast-card.conservative .forecast-label {
      color: var(--red);
    }

    .forecast-card.base .forecast-label {
      color: var(--amber);
    }

    .forecast-card.optimistic .forecast-label {
      color: var(--green-dark);
    }

    .forecast-headline {
      font-family: var(--display-font);
      font-size: 28px;
      line-height: 1;
      margin-bottom: 6px;
      color: var(--navy);
    }

    .forecast-desc {
      font-size: 11px;
      color: var(--navy-50);
      line-height: 1.6;
      font-weight: 300;
    }

    /* Report CTA */
    .rpt-cta {
      padding: 36px 48px;
      background: var(--off);
      border-bottom: 0.5px solid var(--navy-15);
      text-align: center;
    }

    .rpt-cta-headline {
      font-family: var(--serif);
      font-size: 22px;
      color: var(--navy);
      margin-bottom: 10px;
      line-height: 1.4;
    }

    .rpt-cta-sub {
      font-size: 14px;
      color: var(--navy-50);
      font-weight: 300;
      margin-bottom: 24px;
      line-height: 1.6;
      max-width: 440px;
      margin-left: auto;
      margin-right: auto;
    }

    /* Report footer */
    .rpt-footer {
      background: var(--navy);
      padding: 20px 48px;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }

    .rpt-brand {
      font-family: var(--display-font);
      font-size: 18px;
      color: rgba(255, 255, 255, 0.85);
      letter-spacing: 0.1em;
    }

    .rpt-brand span {
      color: var(--green);
    }

    .rpt-brand-sub {
      font-size: 10px;
      color: rgba(255, 255, 255, 0.25);
      margin-top: 3px;
    }

    .rpt-conf {
      font-size: 10px;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      color: rgba(255, 255, 255, 0.25);
      text-align: right;
    }

    /* FAB bar */
    #fab-bar {
      display: none;
      position: fixed;
      bottom: 28px;
      right: 28px;
      flex-direction: column;
      gap: 10px;
      align-items: flex-end;
      z-index: 500;
    }

    .fab-pdf {
      background: var(--green-dark);
      border: none;
      border-radius: 50px;
      padding: 11px 22px;
      font-family: var(--sans);
      font-size: 12px;
      font-weight: 500;
      color: #fff;
      cursor: pointer;
      letter-spacing: 0.06em;
      white-space: nowrap;
      transition: background 0.15s;
    }

    .fab-pdf:hover {
      background: #338a37;
    }

    .fab-back {
      background: var(--navy);
      border: 1.5px solid var(--green);
      border-radius: 50px;
      padding: 10px 20px;
      font-family: var(--sans);
      font-size: 12px;
      font-weight: 500;
      color: var(--green);
      cursor: pointer;
      letter-spacing: 0.06em;
      white-space: nowrap;
      transition: background 0.15s;
    }

    .fab-back:hover {
      background: rgba(29, 41, 63, 0.8);
    }

    /* ─── FINAL CTA ─── */
    .final-cta {
      background: var(--navy);
      padding: 100px 32px;
      text-align: center;
    }

    .final-cta-inner {
      max-width: 600px;
      margin: 0 auto;
    }

    .final-headline {
      font-family: var(--display-font);
      font-size: clamp(48px, 7vw, 80px);
      color: #fff;
      line-height: 0.95;
      margin-bottom: 20px;
      letter-spacing: 0.02em;
    }

    .final-headline span {
      color: var(--green);
    }

    .final-sub {
      font-size: 16px;
      font-weight: 300;
      color: rgba(255, 255, 255, 0.4);
      line-height: 1.7;
      margin-bottom: 40px;
    }

    .final-note {
      margin-top: 20px;
      font-size: 11px;
      color: rgba(255, 255, 255, 0.2);
      font-weight: 300;
    }

    /* ─── SITE FOOTER ─── */
    .site-footer {
      background: #141e2e;
      padding: 40px 32px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap;
      gap: 16px;
      border-top: 0.5px solid rgba(255, 255, 255, 0.06);
    }

    .footer-brand {
      font-family: var(--display-font);
      font-size: 20px;
      color: rgba(255, 255, 255, 0.6);
      letter-spacing: 0.08em;
    }

    .footer-brand span {
      color: var(--green);
    }

    .footer-sub {
      font-size: 10px;
      color: rgba(255, 255, 255, 0.2);
      margin-top: 3px;
    }

    .footer-links {
      display: flex;
      gap: 24px;
    }

    .footer-links a {
      font-size: 11px;
      color: rgba(255, 255, 255, 0.2);
      text-decoration: none;
      transition: color 0.2s;
    }

    .footer-links a:hover {
      color: rgba(255, 255, 255, 0.5);
    }

    .footer-disc {
      font-size: 10px;
      color: rgba(255, 255, 255, 0.15);
      max-width: 360px;
      line-height: 1.6;
    }
    
    /* ─── RESPONSIVE ─── */
    @media (max-width: 768px) {
      nav {
        padding: 0 20px;
      }

      .nav-links {
        display: none;
      }

      .hero,
      .problem,
      .product,
      .why-now,
      .sample-section,
      .final-cta {
        padding-left: 20px;
        padding-right: 20px;
      }

      .hero {
        padding-top: 100px;
        padding-bottom: 60px;
      }

      .problem,
      .product,
      .why-now,
      .sample-section,
      .final-cta {
        padding-top: 64px;
        padding-bottom: 64px;
      }

      .product-grid {
        grid-template-columns: 1fr;
      }

      .product-card.featured {
        flex-direction: column;
      }

      .why-grid {
        grid-template-columns: 1fr;
      }

      .hero-proof {
        gap: 24px;
      }

      .signal-grid,
      .forecast-grid,
      .sample-preview {
        grid-template-columns: 1fr;
      }

      .rpt-scores {
        grid-template-columns: 1fr;
      }

      .rpt-score {
        border-right: none;
        border-bottom: 0.5px solid var(--navy-15);
      }

      .rpt-score:last-child {
        border-bottom: none;
      }

      .rpt-hero,
      .rpt-bench,
      .rpt-signals,
      .rpt-forecast,
      .rpt-cta,
      .rpt-footer,
      .rpt-challenge {
        padding-left: 20px;
        padding-right: 20px;
      }

      .rpt-headline {
        font-size: 42px;
      }

      .rpt-date {
        display: none;
      }

      .bench-industry,
      .bench-bar-wrap {
        display: none;
      }

      .upload-card {
        padding: 36px 24px;
      }

      .site-footer {
        flex-direction: column;
        align-items: flex-start;
      }

      .rpt-footer {
        flex-direction: column;
        gap: 10px;
      }
    }
    
    
    @media print {
      /*body>*:not(#report-page) {*/
      /*  display: none !important;*/
      /*}*/
    header {
        display: none !important;
    }
    
    .footer-section {
        display: none !important;
    }
      #report-page {
        display: block !important;
        padding: 0;
      }

      .report-wrap {
        border-radius: 0;
        box-shadow: none;
        border: none;
        max-width: 100%;
      }

      #fab-bar {
        display: none !important;
      }
    }/* End custom CSS */