  *,
  *::before,
  *::after {
      margin: 0;
      padding: 0;
      box-sizing: border-box
  }

  :root {
      --bg: #f5f0eb;
      --bg-deep: #e8e0d6;
      --text: #1a1a1a;
      --text-soft: #4a4540;
      --accent: #1a6b5a;
      --accent-light: #2a9d8f;
      --accent-glow: rgba(26, 107, 90, 0.08);
      --warm: #c4775a;
      --warm-light: #e8a98a;
      --card: #fffdf9;
      --border: rgba(26, 107, 90, 0.12);
      --serif: 'Playfair Display', Georgia, serif;
      --sans: 'Source Sans 3', 'Segoe UI', sans-serif;
      --mono: 'JetBrains Mono', monospace;
      --radius: 12px;
  }

  html {
      scroll-behavior: smooth;
      font-size: 16px
  }

  body {
      font-family: var(--sans);
      background: var(--bg);
      color: var(--text);
      line-height: 1.7;
      overflow-x: hidden
  }

  /* Noise overlay */
  body::before {
      content: '';
      position: fixed;
      inset: 0;
      pointer-events: none;
      z-index: 9999;
      background: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
      opacity: .4;
  }

  /* Scroll progress */
  .scroll-progress {
      position: fixed;
      top: 0;
      left: 0;
      height: 3px;
      background: linear-gradient(90deg, var(--accent), var(--warm));
      z-index: 1000;
      transition: width .1s
  }

  /* Navigation */
  nav {
      position: fixed;
      top: 0;
      width: 100%;
      z-index: 100;
      background: rgba(245, 240, 235, 0.85);
      backdrop-filter: blur(20px);
      border-bottom: 1px solid var(--border);
      transition: transform .3s;
  }

  nav .nav-inner {
      max-width: 1200px;
      margin: 0 auto;
      padding: 14px 32px;
      display: flex;
      align-items: center;
      justify-content: space-between;
  }

  nav .logo {
      font-family: var(--serif);
      font-size: 1.15rem;
      color: var(--accent);
      font-weight: 700;
      letter-spacing: -.02em;
      text-decoration: none
  }

  nav .logo span {
      color: var(--warm);
      font-style: italic
  }

  nav ul {
      list-style: none;
      display: flex;
      gap: 28px
  }

  nav ul li a {
      font-size: .82rem;
      text-decoration: none;
      color: var(--text-soft);
      font-weight: 500;
      letter-spacing: .04em;
      text-transform: uppercase;
      transition: color .2s;
      position: relative
  }

  nav ul li a::after {
      content: '';
      position: absolute;
      bottom: -4px;
      left: 0;
      width: 0;
      height: 1.5px;
      background: var(--accent);
      transition: width .3s
  }

  nav ul li a:hover {
      color: var(--accent)
  }

  nav ul li a:hover::after {
      width: 100%
  }

  .menu-toggle {
      display: none;
      background: none;
      border: none;
      cursor: pointer;
      padding: 8px
  }

  .menu-toggle span {
      display: block;
      width: 22px;
      height: 2px;
      background: var(--text);
      margin: 5px 0;
      transition: .3s
  }

  /* Hero */
  .hero {
      min-height: 100vh;
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      overflow: hidden;
      padding: 120px 32px 80px;
  }

  .hero-bg {
      position: absolute;
      inset: 0;
      background:
          radial-gradient(ellipse 80% 60% at 20% 40%, rgba(26, 107, 90, 0.06), transparent),
          radial-gradient(ellipse 60% 50% at 80% 30%, rgba(196, 119, 90, 0.05), transparent),
          radial-gradient(ellipse 40% 40% at 50% 80%, rgba(42, 157, 143, 0.04), transparent);
  }

  .hero-content {
      position: relative;
      max-width: 900px;
      text-align: center
  }

  .hero-tag {
      display: inline-block;
      font-family: var(--mono);
      font-size: .72rem;
      letter-spacing: .15em;
      text-transform: uppercase;
      color: var(--accent);
      padding: 6px 18px;
      border: 1px solid var(--border);
      border-radius: 40px;
      margin-bottom: 28px;
      animation: fadeUp .8s ease both;
  }

  .hero h1 {
      font-family: var(--serif);
      font-size: clamp(2.4rem, 5.5vw, 4.2rem);
      line-height: 1.15;
      font-weight: 700;
      color: var(--text);
      margin-bottom: 20px;
      letter-spacing: -.03em;
      animation: fadeUp .8s ease .15s both;
  }

  .hero h1 em {
      color: var(--accent);
      font-style: italic
  }

  .hero p {
      font-size: 1.12rem;
      color: var(--text-soft);
      max-width: 640px;
      margin: 0 auto 36px;
      font-weight: 300;
      line-height: 1.8;
      animation: fadeUp .8s ease .3s both;
  }

  .hero-stats {
      display: flex;
      justify-content: center;
      gap: 48px;
      flex-wrap: wrap;
      animation: fadeUp .8s ease .45s both;
  }

  .hero-stat {
      text-align: center
  }

  .hero-stat .num {
      font-family: var(--serif);
      font-size: 2.2rem;
      color: var(--accent);
      font-weight: 700
  }

  .hero-stat .label {
      font-size: .78rem;
      color: var(--text-soft);
      margin-top: 4px;
      letter-spacing: .03em
  }

  .scroll-hint {
      position: absolute;
      bottom: 32px;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
      animation: fadeUp .8s ease .6s both;
  }

  .scroll-hint span {
      font-size: .7rem;
      letter-spacing: .12em;
      text-transform: uppercase;
      color: var(--text-soft)
  }

  .scroll-hint .arrow {
      width: 1px;
      height: 32px;
      background: var(--accent);
      position: relative;
      animation: scrollBounce 2s infinite
  }

  @keyframes scrollBounce {

      0%,
      100% {
          opacity: .3;
          transform: scaleY(.6)
      }

      50% {
          opacity: 1;
          transform: scaleY(1)
      }
  }

  /* Sections */
  section {
      padding: 100px 32px
  }

  .section-inner {
      max-width: 1100px;
      margin: 0 auto
  }

  .section-label {
      font-family: var(--mono);
      font-size: .7rem;
      letter-spacing: .18em;
      text-transform: uppercase;
      color: var(--accent);
      margin-bottom: 12px;
      display: flex;
      align-items: center;
      gap: 12px;
  }

  .section-label::before {
      content: '';
      width: 24px;
      height: 1px;
      background: var(--accent)
  }

  .section-title {
      font-family: var(--serif);
      font-size: clamp(1.8rem, 3.5vw, 2.6rem);
      line-height: 1.2;
      font-weight: 700;
      margin-bottom: 20px;
      letter-spacing: -.02em;
  }

  .section-desc {
      font-size: 1.05rem;
      color: var(--text-soft);
      max-width: 700px;
      line-height: 1.8;
      font-weight: 300;
      margin-bottom: 48px
  }

  /* Cards Grid */
  .cards-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
      gap: 24px;
      margin-top: 36px
  }

  .card {
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 32px;
      transition: transform .3s, box-shadow .3s;
      position: relative;
      overflow: hidden;
  }

  .card:hover {
      transform: translateY(-4px);
      box-shadow: 0 12px 40px rgba(26, 107, 90, 0.08)
  }

  .card-icon {
      width: 48px;
      height: 48px;
      border-radius: 10px;
      background: var(--accent-glow);
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 20px;
      font-size: 1.4rem;
  }

  .card h3 {
      font-family: var(--serif);
      font-size: 1.2rem;
      margin-bottom: 10px;
      font-weight: 700
  }

  .card p {
      font-size: .92rem;
      color: var(--text-soft);
      line-height: 1.7
  }

  /* Info Table */
  .info-table {
      width: 100%;
      border-collapse: collapse;
      margin: 36px 0;
      border-radius: var(--radius);
      overflow: hidden
  }

  .info-table thead {
      background: var(--accent);
      color: #fff
  }

  .info-table th {
      padding: 14px 20px;
      text-align: left;
      font-size: .82rem;
      letter-spacing: .05em;
      font-weight: 600
  }

  .info-table td {
      padding: 14px 20px;
      font-size: .9rem;
      border-bottom: 1px solid var(--border);
      color: var(--text-soft)
  }

  .info-table tbody tr {
      background: var(--card);
      transition: background .2s
  }

  .info-table tbody tr:hover {
      background: var(--accent-glow)
  }

  .info-table tbody tr:last-child td {
      border-bottom: none
  }

  /* Process / Timeline */
  .timeline {
      position: relative;
      padding-left: 40px;
      margin-top: 40px
  }

  .timeline::before {
      content: '';
      position: absolute;
      left: 14px;
      top: 0;
      bottom: 0;
      width: 2px;
      background: linear-gradient(to bottom, var(--accent), var(--warm))
  }

  .timeline-item {
      position: relative;
      margin-bottom: 36px
  }

  .timeline-item::before {
      content: '';
      position: absolute;
      left: -32px;
      top: 6px;
      width: 14px;
      height: 14px;
      border-radius: 50%;
      border: 2px solid var(--accent);
      background: var(--bg);
      z-index: 1;
  }

  .timeline-item h4 {
      font-family: var(--serif);
      font-size: 1.1rem;
      margin-bottom: 6px;
      color: var(--accent)
  }

  .timeline-item p {
      font-size: .92rem;
      color: var(--text-soft);
      line-height: 1.7
  }

  /* PAVAR Steps */
  .pavar-grid {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: 16px;
      margin-top: 36px
  }

  .pavar-step {
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 24px 18px;
      text-align: center;
      position: relative;
      transition: transform .3s, box-shadow .3s;
  }

  .pavar-step:hover {
      transform: translateY(-3px);
      box-shadow: 0 8px 30px rgba(26, 107, 90, 0.08)
  }

  .pavar-letter {
      font-family: var(--serif);
      font-size: 2.4rem;
      font-weight: 700;
      color: var(--accent);
      line-height: 1;
      margin-bottom: 8px;
  }

  .pavar-step h5 {
      font-size: .85rem;
      font-weight: 600;
      margin-bottom: 6px;
      color: var(--text)
  }

  .pavar-step p {
      font-size: .78rem;
      color: var(--text-soft);
      line-height: 1.5
  }

  /* Highlight Box */
  .highlight-box {
      background: linear-gradient(135deg, rgba(26, 107, 90, 0.06), rgba(196, 119, 90, 0.04));
      border-left: 3px solid var(--accent);
      border-radius: 0 var(--radius) var(--radius) 0;
      padding: 28px 32px;
      margin: 36px 0;
  }

  .highlight-box p {
      font-size: .95rem;
      color: var(--text-soft);
      line-height: 1.8
  }

  .highlight-box strong {
      color: var(--accent);
      font-weight: 600
  }

  /* Two Column */
  .two-col {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 48px;
      align-items: start;
      margin-top: 36px
  }

  .two-col p {
      font-size: .95rem;
      color: var(--text-soft);
      line-height: 1.8;
      margin-bottom: 16px
  }

  /* Stats Bar */
  .stats-bar {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 20px;
      margin: 48px 0;
  }

  .stat-item {
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 28px 24px;
      text-align: center;
  }

  .stat-item .stat-num {
      font-family: var(--serif);
      font-size: 2rem;
      font-weight: 700;
      color: var(--accent)
  }

  .stat-item .stat-label {
      font-size: .8rem;
      color: var(--text-soft);
      margin-top: 4px
  }

  /* Digital Models */
  .digital-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 20px;
      margin-top: 36px
  }

  .digital-card {
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 28px;
      transition: transform .3s;
  }

  .digital-card:hover {
      transform: translateY(-3px)
  }

  .digital-card .tag {
      font-family: var(--mono);
      font-size: .68rem;
      letter-spacing: .1em;
      color: var(--warm);
      text-transform: uppercase;
      margin-bottom: 10px;
  }

  .digital-card h4 {
      font-family: var(--serif);
      font-size: 1.1rem;
      margin-bottom: 8px
  }

  .digital-card p {
      font-size: .88rem;
      color: var(--text-soft);
      line-height: 1.7
  }

  /* Footer */
  footer {
      background: var(--text);
      color: rgba(255, 255, 255, 0.6);
      padding: 60px 32px 40px;
      margin-top: 40px;
  }

  footer .footer-inner {
      max-width: 1100px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 2fr 1fr 1fr 1fr;
      gap: 48px
  }

  footer h4 {
      color: #fff;
      font-family: var(--serif);
      font-size: 1.1rem;
      margin-bottom: 16px
  }

  footer p {
      font-size: .88rem;
      line-height: 1.7
  }

  footer ul {
      list-style: none
  }

  footer ul li {
      margin-bottom: 8px
  }

  footer ul li a {
      color: rgba(255, 255, 255, 0.5);
      text-decoration: none;
      font-size: .85rem;
      transition: color .2s
  }

  footer ul li a:hover {
      color: var(--accent-light)
  }

  footer .footer-bottom {
      max-width: 1100px;
      margin: 40px auto 0;
      padding-top: 24px;
      border-top: 1px solid rgba(255, 255, 255, 0.08);
      font-size: .78rem;
      text-align: center;
  }

  /* Animations */
  @keyframes fadeUp {
      from {
          opacity: 0;
          transform: translateY(24px)
      }

      to {
          opacity: 1;
          transform: translateY(0)
      }
  }

  @keyframes loginShake {

      0%,
      100% {
          transform: translateX(0)
      }

      20%,
      60% {
          transform: translateX(-8px)
      }

      40%,
      80% {
          transform: translateX(8px)
      }
  }

  .reveal {
      opacity: 0;
      transform: translateY(24px);
      transition: opacity .7s ease, transform .7s ease
  }

  .reveal.visible {
      opacity: 1;
      transform: translateY(0)
  }

  /* Plan Builder */
  .plan-builder {
      max-width: 860px;
      margin: 0 auto
  }

  .plan-steps-nav {
      display: flex;
      gap: 4px;
      margin-bottom: 40px;
      position: relative
  }

  .plan-steps-nav::after {
      content: '';
      position: absolute;
      bottom: -12px;
      left: 0;
      right: 0;
      height: 2px;
      background: var(--border)
  }

  .plan-step-btn {
      flex: 1;
      padding: 14px 8px;
      background: none;
      border: none;
      cursor: pointer;
      font-family: var(--sans);
      font-size: .78rem;
      font-weight: 600;
      letter-spacing: .04em;
      color: var(--text-soft);
      text-transform: uppercase;
      position: relative;
      transition: color .3s;
      border-radius: 8px 8px 0 0;
  }

  .plan-step-btn.active {
      color: var(--accent);
      background: var(--accent-glow)
  }

  .plan-step-btn.completed {
      color: var(--accent-light)
  }

  .plan-step-btn.completed::before {
      content: '✓ ';
      font-size: .7rem
  }

  .plan-step-btn::after {
      content: '';
      position: absolute;
      bottom: -12px;
      left: 0;
      right: 0;
      height: 2px;
      background: var(--accent);
      transform: scaleX(0);
      transition: transform .3s;
  }

  .plan-step-btn.active::after {
      transform: scaleX(1)
  }

  .plan-step-num {
      display: block;
      font-family: var(--serif);
      font-size: 1.6rem;
      font-weight: 700;
      margin-bottom: 2px;
      color: inherit;
  }

  .plan-panel {
      display: none;
      animation: fadeUp .4s ease
  }

  .plan-panel.active {
      display: block
  }

  .plan-panel h3 {
      font-family: var(--serif);
      font-size: 1.4rem;
      margin-bottom: 6px
  }

  .plan-panel .panel-desc {
      font-size: .92rem;
      color: var(--text-soft);
      margin-bottom: 28px;
      line-height: 1.6
  }

  .field-group {
      margin-bottom: 22px
  }

  .field-label {
      display: block;
      font-size: .8rem;
      font-weight: 600;
      letter-spacing: .04em;
      text-transform: uppercase;
      color: var(--text-soft);
      margin-bottom: 8px;
  }

  .field-input,
  .field-select,
  .field-textarea {
      width: 100%;
      padding: 13px 16px;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      background: var(--card);
      font-family: var(--sans);
      font-size: .95rem;
      color: var(--text);
      transition: border-color .2s, box-shadow .2s;
      outline: none;
  }

  .field-input:focus,
  .field-select:focus,
  .field-textarea:focus {
      border-color: var(--accent);
      box-shadow: 0 0 0 3px var(--accent-glow);
  }

  .field-textarea {
      resize: vertical;
      min-height: 80px
  }

  .field-select {
      cursor: pointer;
      appearance: none;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a4540' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 14px center;
      padding-right: 36px;
  }

  .field-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px
  }

  .chip-group {
      display: flex;
      flex-wrap: wrap;
      gap: 8px
  }

  .chip {
      padding: 9px 18px;
      border: 1px solid var(--border);
      border-radius: 40px;
      background: var(--card);
      font-size: .85rem;
      cursor: pointer;
      transition: all .2s;
      user-select: none;
      color: var(--text-soft);
  }

  .chip:hover {
      border-color: var(--accent-light);
      color: var(--accent)
  }

  .chip.selected {
      background: var(--accent);
      color: #fff;
      border-color: var(--accent)
  }

  .slider-group {
      display: flex;
      align-items: center;
      gap: 16px
  }

  .slider-group input[type=range] {
      flex: 1;
      -webkit-appearance: none;
      height: 6px;
      border-radius: 3px;
      background: linear-gradient(90deg, var(--accent) var(--val, 50%), var(--border) var(--val, 50%));
      outline: none;
  }

  .slider-group input[type=range]::-webkit-slider-thumb {
      -webkit-appearance: none;
      width: 20px;
      height: 20px;
      border-radius: 50%;
      background: var(--accent);
      cursor: pointer;
      border: 3px solid var(--card);
      box-shadow: 0 2px 8px rgba(0, 0, 0, .15);
  }

  .slider-val {
      font-family: var(--mono);
      font-size: .9rem;
      font-weight: 600;
      color: var(--accent);
      min-width: 42px;
      text-align: right;
  }

  .plan-nav-btns {
      display: flex;
      justify-content: space-between;
      margin-top: 36px;
      gap: 12px
  }

  .btn {
      padding: 14px 32px;
      border: none;
      border-radius: var(--radius);
      cursor: pointer;
      font-family: var(--sans);
      font-size: .88rem;
      font-weight: 600;
      letter-spacing: .03em;
      transition: all .25s;
  }

  .btn-primary {
      background: var(--accent);
      color: #fff
  }

  .btn-primary:hover {
      background: #15584a;
      transform: translateY(-2px);
      box-shadow: 0 6px 20px rgba(26, 107, 90, 0.25)
  }

  .btn-secondary {
      background: transparent;
      color: var(--text-soft);
      border: 1px solid var(--border)
  }

  .btn-secondary:hover {
      border-color: var(--accent);
      color: var(--accent)
  }

  .btn-warm {
      background: var(--warm);
      color: #fff
  }

  .btn-warm:hover {
      background: #b06a4f;
      transform: translateY(-2px);
      box-shadow: 0 6px 20px rgba(196, 119, 90, 0.25)
  }

  /* Result Plan */
  .result-plan {
      display: none
  }

  .result-plan.visible {
      display: block;
      animation: fadeUp .5s ease
  }

  .result-header {
      text-align: center;
      padding: 40px 32px;
      background: linear-gradient(135deg, var(--accent), #1a7b6a);
      border-radius: var(--radius) var(--radius) 0 0;
      color: #fff;
  }

  .result-header h2 {
      font-family: var(--serif);
      font-size: 1.8rem;
      margin-bottom: 6px
  }

  .result-header p {
      opacity: .8;
      font-size: .92rem
  }

  .result-body {
      background: var(--card);
      border: 1px solid var(--border);
      border-top: none;
      border-radius: 0 0 var(--radius) var(--radius);
      padding: 36px 32px;
  }

  .result-section {
      margin-bottom: 28px;
      padding-bottom: 24px;
      border-bottom: 1px solid var(--border)
  }

  .result-section:last-child {
      border-bottom: none;
      margin-bottom: 0;
      padding-bottom: 0
  }

  .result-section h4 {
      font-family: var(--serif);
      font-size: 1.1rem;
      margin-bottom: 12px;
      display: flex;
      align-items: center;
      gap: 10px;
  }

  .result-section h4 .r-icon {
      width: 32px;
      height: 32px;
      border-radius: 8px;
      background: var(--accent-glow);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: .95rem;
      flex-shrink: 0;
  }

  .result-item {
      display: flex;
      gap: 12px;
      align-items: baseline;
      margin-bottom: 8px;
      font-size: .92rem;
      color: var(--text-soft);
      line-height: 1.6;
  }

  .result-item::before {
      content: '•';
      color: var(--accent);
      font-weight: bold;
      flex-shrink: 0
  }

  .result-tag {
      display: inline-block;
      padding: 3px 10px;
      border-radius: 20px;
      font-size: .75rem;
      font-weight: 600;
      background: var(--accent-glow);
      color: var(--accent);
      margin-right: 6px;
  }

  .result-warn {
      display: inline-block;
      padding: 3px 10px;
      border-radius: 20px;
      font-size: .75rem;
      font-weight: 600;
      background: rgba(196, 119, 90, 0.1);
      color: var(--warm);
      margin-right: 6px;
  }

  .result-actions {
      display: flex;
      gap: 12px;
      justify-content: center;
      margin-top: 32px
  }

  /* Calculator Section */
  .calc-tabs {
      display: flex;
      gap: 6px;
      flex-wrap: wrap;
      margin-bottom: 32px
  }

  .calc-tab {
      padding: 10px 20px;
      border: 1px solid var(--border);
      border-radius: 40px;
      background: var(--card);
      font-family: var(--sans);
      font-size: .82rem;
      font-weight: 600;
      cursor: pointer;
      transition: all .25s;
      color: var(--text-soft);
      letter-spacing: .02em;
  }

  .calc-tab:hover {
      border-color: var(--accent-light);
      color: var(--accent)
  }

  .calc-tab.active {
      background: var(--accent);
      color: #fff;
      border-color: var(--accent)
  }

  .calc-content {
      display: none;
      animation: fadeUp .4s ease
  }

  .calc-content.active {
      display: block
  }

  .calc-card {
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 32px;
      margin-bottom: 20px;
  }

  .calc-card h4 {
      font-family: var(--serif);
      font-size: 1.2rem;
      margin-bottom: 4px
  }

  .calc-card .calc-subtitle {
      font-size: .85rem;
      color: var(--text-soft);
      margin-bottom: 24px;
      line-height: 1.5
  }

  /* Score display */
  .score-display {
      display: flex;
      align-items: center;
      gap: 24px;
      padding: 24px;
      background: linear-gradient(135deg, var(--accent-glow), rgba(196, 119, 90, 0.04));
      border-radius: var(--radius);
      margin-top: 24px;
  }

  .score-circle {
      width: 90px;
      height: 90px;
      border-radius: 50%;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      position: relative;
  }

  .score-circle svg {
      position: absolute;
      inset: 0;
      transform: rotate(-90deg)
  }

  .score-circle circle {
      fill: none;
      stroke-width: 5
  }

  .score-circle .track {
      stroke: var(--border)
  }

  .score-circle .fill {
      stroke: var(--accent);
      stroke-linecap: round;
      transition: stroke-dashoffset .8s ease, stroke .3s
  }

  .score-num {
      font-family: var(--serif);
      font-size: 1.6rem;
      font-weight: 700;
      color: var(--accent);
      z-index: 1
  }

  .score-max {
      font-size: .7rem;
      color: var(--text-soft);
      z-index: 1;
      margin-top: -2px
  }

  .score-info {
      flex: 1
  }

  .score-info .score-label {
      font-family: var(--serif);
      font-size: 1.05rem;
      font-weight: 700;
      margin-bottom: 4px
  }

  .score-info .score-interp {
      font-size: .88rem;
      color: var(--text-soft);
      line-height: 1.6
  }

  .score-badge {
      display: inline-block;
      padding: 4px 12px;
      border-radius: 20px;
      font-size: .75rem;
      font-weight: 700;
      margin-bottom: 6px;
  }

  .badge-green {
      background: rgba(26, 107, 90, 0.12);
      color: var(--accent)
  }

  .badge-yellow {
      background: rgba(200, 170, 50, 0.12);
      color: #8a7520
  }

  .badge-orange {
      background: rgba(196, 119, 90, 0.12);
      color: var(--warm)
  }

  .badge-red {
      background: rgba(180, 50, 50, 0.12);
      color: #a03030
  }

  /* CAT question rows */
  .cat-q {
      display: grid;
      grid-template-columns: 1fr auto 1fr;
      gap: 12px;
      align-items: center;
      padding: 14px 0;
      border-bottom: 1px solid rgba(26, 107, 90, 0.06);
  }

  .cat-q:last-child {
      border-bottom: none
  }

  .cat-left {
      font-size: .85rem;
      color: var(--accent);
      text-align: right;
      font-weight: 500
  }

  .cat-right {
      font-size: .85rem;
      color: var(--warm);
      text-align: left;
      font-weight: 500
  }

  .cat-dots {
      display: flex;
      gap: 6px;
      justify-content: center
  }

  .cat-dot {
      width: 32px;
      height: 32px;
      border-radius: 50%;
      border: 2px solid var(--border);
      background: var(--card);
      cursor: pointer;
      font-size: .75rem;
      font-weight: 700;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--text-soft);
      transition: all .2s;
  }

  .cat-dot:hover {
      border-color: var(--accent-light);
      transform: scale(1.1)
  }

  .cat-dot.selected {
      background: var(--accent);
      color: #fff;
      border-color: var(--accent)
  }

  /* HADS rows */
  .hads-q {
      margin-bottom: 20px;
      padding-bottom: 16px;
      border-bottom: 1px solid rgba(26, 107, 90, 0.06)
  }

  .hads-q:last-child {
      border-bottom: none
  }

  .hads-q-text {
      font-size: .9rem;
      font-weight: 600;
      margin-bottom: 10px;
      color: var(--text)
  }

  .hads-opts {
      display: flex;
      flex-direction: column;
      gap: 6px
  }

  .hads-opt {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 8px 14px;
      border-radius: 8px;
      cursor: pointer;
      transition: background .2s;
      font-size: .85rem;
      color: var(--text-soft);
  }

  .hads-opt:hover {
      background: var(--accent-glow)
  }

  .hads-opt.selected {
      background: var(--accent);
      color: #fff;
      border-radius: 8px
  }

  .hads-opt .hads-radio {
      width: 16px;
      height: 16px;
      border-radius: 50%;
      border: 2px solid var(--border);
      flex-shrink: 0;
      transition: all .2s;
      display: flex;
      align-items: center;
      justify-content: center;
  }

  .hads-opt.selected .hads-radio {
      border-color: #fff;
      background: rgba(255, 255, 255, 0.3)
  }

  .hads-opt.selected .hads-radio::after {
      content: '';
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: #fff
  }

  /* BODE gauge */
  .bode-gauges {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 16px;
      margin-top: 20px
  }

  .bode-gauge {
      text-align: center
  }

  .bode-gauge .gauge-label {
      font-size: .72rem;
      text-transform: uppercase;
      letter-spacing: .08em;
      color: var(--text-soft);
      margin-bottom: 8px;
      font-weight: 600
  }

  .bode-gauge .gauge-val {
      font-family: var(--serif);
      font-size: 1.8rem;
      font-weight: 700;
      color: var(--accent);
  }

  .bode-gauge .gauge-pts {
      font-size: .78rem;
      color: var(--warm);
      font-weight: 600;
      margin-top: 2px
  }

  /* MNA rows */
  .mna-q {
      margin-bottom: 16px
  }

  .mna-q-label {
      font-size: .88rem;
      font-weight: 600;
      margin-bottom: 8px;
      color: var(--text)
  }

  .mna-opts {
      display: flex;
      flex-wrap: wrap;
      gap: 6px
  }

  .mna-opt {
      padding: 7px 14px;
      border: 1px solid var(--border);
      border-radius: 8px;
      cursor: pointer;
      font-size: .82rem;
      color: var(--text-soft);
      transition: all .2s;
      background: var(--card);
  }

  .mna-opt:hover {
      border-color: var(--accent-light)
  }

  .mna-opt.selected {
      background: var(--accent);
      color: #fff;
      border-color: var(--accent)
  }

  /* Dashboard composite */
  .dash-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
      margin-top: 24px
  }

  .dash-item {
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 20px;
      text-align: center;
      transition: transform .2s;
  }

  .dash-item:hover {
      transform: translateY(-2px)
  }

  .dash-item .dash-icon {
      font-size: 1.5rem;
      margin-bottom: 8px
  }

  .dash-item .dash-label {
      font-size: .75rem;
      text-transform: uppercase;
      letter-spacing: .06em;
      color: var(--text-soft);
      margin-bottom: 6px;
      font-weight: 600
  }

  .dash-item .dash-val {
      font-family: var(--serif);
      font-size: 1.5rem;
      font-weight: 700
  }

  .dash-item .dash-interp {
      font-size: .78rem;
      margin-top: 4px
  }

  .dash-bar {
      height: 6px;
      border-radius: 3px;
      background: var(--border);
      margin-top: 10px;
      overflow: hidden;
  }

  .dash-bar-fill {
      height: 100%;
      border-radius: 3px;
      transition: width .8s ease, background .3s
  }

  @media(max-width:900px) {
      .bode-gauges {
          grid-template-columns: repeat(2, 1fr)
      }

      .dash-grid {
          grid-template-columns: 1fr 1fr
      }

      .cat-q {
          grid-template-columns: 1fr;
          gap: 6px;
          text-align: center
      }

      .cat-left,
      .cat-right {
          text-align: center
      }
  }

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

      .score-display {
          flex-direction: column;
          text-align: center
      }
  }

  /* Severity Recommendation Matrix */
  .sev-header {
      display: flex;
      align-items: center;
      gap: 14px;
      padding: 18px 24px;
      border-radius: var(--radius) var(--radius) 0 0;
      margin: -32px -32px 24px;
  }

  .sev-header .sev-icon {
      font-size: 1.8rem
  }

  .sev-header .sev-title {
      font-family: var(--serif);
      font-size: 1.15rem;
      font-weight: 700;
      color: #fff
  }

  .sev-header .sev-subtitle {
      font-size: .82rem;
      opacity: .85;
      color: #fff
  }

  .sev-mild {
      background: linear-gradient(135deg, #1a6b5a, #2a9d8f)
  }

  .sev-moderate {
      background: linear-gradient(135deg, #8a7520, #c4a830)
  }

  .sev-severe {
      background: linear-gradient(135deg, #c4775a, #e8a98a)
  }

  .sev-critical {
      background: linear-gradient(135deg, #a03030, #d04040)
  }

  .rec-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 14px;
      margin-top: 16px
  }

  .rec-card {
      padding: 16px;
      border-radius: 10px;
      border: 1px solid var(--border);
      background: rgba(255, 255, 255, 0.5);
  }

  .rec-card .rec-type {
      font-size: .68rem;
      text-transform: uppercase;
      letter-spacing: .1em;
      font-weight: 700;
      margin-bottom: 6px;
  }

  .rec-card .rec-type.rec-essential {
      color: var(--accent)
  }

  .rec-card .rec-type.rec-recommended {
      color: var(--warm)
  }

  .rec-card .rec-type.rec-consider {
      color: #8a7520
  }

  .rec-card .rec-type.rec-caution {
      color: #a03030
  }

  .rec-card h5 {
      font-size: .9rem;
      font-weight: 700;
      margin-bottom: 4px
  }

  .rec-card p {
      font-size: .8rem;
      color: var(--text-soft);
      line-height: 1.5
  }

  .rec-param {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 8px 0;
      border-bottom: 1px solid rgba(26, 107, 90, 0.06);
      font-size: .85rem;
  }

  .rec-param:last-child {
      border-bottom: none
  }

  .rec-param .rp-label {
      color: var(--text-soft)
  }

  .rec-param .rp-val {
      font-weight: 700;
      font-family: var(--mono);
      font-size: .82rem
  }

  .sev-level-bar {
      display: flex;
      gap: 3px;
      margin: 16px 0;
      height: 8px;
      border-radius: 4px;
      overflow: hidden;
  }

  .sev-level-bar span {
      flex: 1;
      border-radius: 2px;
      transition: opacity .3s
  }

  .sev-level-bar .seg-1 {
      background: var(--accent)
  }

  .sev-level-bar .seg-2 {
      background: #8a7520
  }

  .sev-level-bar .seg-3 {
      background: var(--warm)
  }

  .sev-level-bar .seg-4 {
      background: #a03030
  }

  .week-timeline {
      display: flex;
      gap: 2px;
      margin-top: 16px;
      flex-wrap: wrap
  }

  .week-block {
      flex: 1;
      min-width: 60px;
      padding: 10px 6px;
      border-radius: 8px;
      text-align: center;
      font-size: .72rem;
      border: 1px solid var(--border);
      background: var(--card);
  }

  .week-block .wk-num {
      font-weight: 700;
      font-size: .82rem;
      color: var(--accent);
      margin-bottom: 2px
  }

  .week-block .wk-desc {
      color: var(--text-soft);
      line-height: 1.3
  }

  /* Session Timeline */
  .session-timeline {
      display: flex;
      flex-direction: column;
      gap: 0;
      margin: 20px 0;
      position: relative
  }

  .session-timeline::before {
      content: '';
      position: absolute;
      left: 23px;
      top: 0;
      bottom: 0;
      width: 2px;
      background: linear-gradient(to bottom, var(--accent), var(--warm), var(--accent))
  }

  .ses-item {
      display: flex;
      gap: 16px;
      align-items: flex-start;
      position: relative;
      padding: 12px 0
  }

  .ses-dot {
      width: 46px;
      height: 46px;
      border-radius: 50%;
      flex-shrink: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.1rem;
      z-index: 1;
      border: 3px solid var(--card);
  }

  .ses-dot.dot-warmup {
      background: rgba(42, 157, 143, 0.15)
  }

  .ses-dot.dot-main {
      background: rgba(26, 107, 90, 0.2)
  }

  .ses-dot.dot-strength {
      background: rgba(196, 119, 90, 0.15)
  }

  .ses-dot.dot-breath {
      background: rgba(42, 157, 143, 0.12)
  }

  .ses-dot.dot-cool {
      background: rgba(138, 117, 32, 0.12)
  }

  .ses-body {
      flex: 1;
      min-width: 0
  }

  .ses-header {
      display: flex;
      align-items: baseline;
      gap: 10px;
      margin-bottom: 3px
  }

  .ses-header h5 {
      font-family: var(--serif);
      font-size: .95rem;
      font-weight: 700
  }

  .ses-time {
      font-family: var(--mono);
      font-size: .75rem;
      font-weight: 600;
      padding: 2px 8px;
      border-radius: 12px;
      background: var(--accent-glow);
      color: var(--accent);
  }

  .ses-detail {
      font-size: .84rem;
      color: var(--text-soft);
      line-height: 1.55
  }

  .ses-total {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 14px 20px;
      margin-top: 16px;
      background: linear-gradient(135deg, var(--accent-glow), rgba(196, 119, 90, 0.04));
      border-radius: var(--radius);
      font-size: .9rem;
      font-weight: 600;
  }

  .ses-total .ses-total-time {
      font-family: var(--mono);
      font-size: 1.2rem;
      color: var(--accent);
      font-weight: 700
  }

  @media(max-width:600px) {
      .ses-item {
          gap: 10px
      }

      .ses-dot {
          width: 36px;
          height: 36px;
          font-size: .9rem
      }

      .session-timeline::before {
          left: 18px
      }
  }

  @media(max-width:700px) {
      .rec-grid {
          grid-template-columns: 1fr
      }

      .week-timeline {
          flex-direction: column
      }
  }

  /* Auto-Prescription System */
  .auto-rx-banner {
      padding: 16px 20px;
      border-radius: var(--radius);
      margin-bottom: 24px;
      display: flex;
      align-items: center;
      gap: 14px;
      border: 1px solid;
  }

  .auto-rx-banner.rx-active {
      background: rgba(26, 107, 90, 0.06);
      border-color: rgba(26, 107, 90, 0.2)
  }

  .auto-rx-banner.rx-empty {
      background: rgba(196, 119, 90, 0.06);
      border-color: rgba(196, 119, 90, 0.2)
  }

  .auto-rx-banner .rx-icon {
      font-size: 1.5rem;
      flex-shrink: 0
  }

  .auto-rx-banner .rx-text {
      font-size: .88rem;
      line-height: 1.5
  }

  .auto-rx-banner .rx-text strong {
      color: var(--accent)
  }

  .rx-section {
      margin-bottom: 24px;
      padding: 20px;
      border-radius: var(--radius);
      background: var(--card);
      border: 1px solid var(--border);
      position: relative;
      overflow: hidden;
  }

  .rx-section::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 4px;
      height: 100%;
  }

  .rx-section.rx-essential::before {
      background: var(--accent)
  }

  .rx-section.rx-recommended::before {
      background: var(--warm)
  }

  .rx-section.rx-optional::before {
      background: #8a7520
  }

  .rx-section-header {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      margin-bottom: 12px;
  }

  .rx-section-title {
      display: flex;
      align-items: center;
      gap: 10px;
  }

  .rx-section-title h4 {
      font-family: var(--serif);
      font-size: 1.05rem;
      font-weight: 700
  }

  .rx-priority {
      font-size: .68rem;
      text-transform: uppercase;
      letter-spacing: .08em;
      font-weight: 700;
      padding: 3px 10px;
      border-radius: 20px;
  }

  .rx-priority.pri-essential {
      background: rgba(26, 107, 90, 0.1);
      color: var(--accent)
  }

  .rx-priority.pri-recommended {
      background: rgba(196, 119, 90, 0.1);
      color: var(--warm)
  }

  .rx-priority.pri-optional {
      background: rgba(138, 117, 32, 0.1);
      color: #8a7520
  }

  .rx-priority.pri-critical {
      background: rgba(160, 48, 48, 0.1);
      color: #a03030
  }

  .rx-reason {
      font-size: .8rem;
      color: var(--text-soft);
      line-height: 1.5;
      padding: 8px 12px;
      background: var(--accent-glow);
      border-radius: 8px;
      margin-bottom: 12px;
  }

  .rx-reason strong {
      color: var(--accent);
      font-weight: 600
  }

  .rx-params {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px;
      margin-top: 12px
  }

  .rx-param-card {
      padding: 10px 14px;
      border-radius: 8px;
      border: 1px solid var(--border);
      background: rgba(255, 255, 255, 0.5);
  }

  .rx-param-label {
      font-size: .72rem;
      text-transform: uppercase;
      letter-spacing: .06em;
      color: var(--text-soft);
      font-weight: 600
  }

  .rx-param-val {
      font-family: var(--mono);
      font-size: .92rem;
      font-weight: 700;
      color: var(--accent);
      margin-top: 2px
  }

  .rx-chip-auto {
      position: relative
  }

  .rx-chip-auto .chip.auto-selected {
      background: var(--accent);
      color: #fff;
      border-color: var(--accent);
  }

  .rx-chip-auto .chip.auto-selected::after {
      content: '✦';
      font-size: .6rem;
      margin-left: 4px;
      opacity: .7;
  }

  .rx-override-note {
      font-size: .72rem;
      color: var(--text-soft);
      margin-top: 8px;
      font-style: italic;
  }

  .rx-summary-bar {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: 8px;
      margin-top: 24px;
      padding: 16px;
      background: var(--accent-glow);
      border-radius: var(--radius);
  }

  .rx-summary-item {
      text-align: center
  }

  .rx-summary-item .rsi-label {
      font-size: .68rem;
      text-transform: uppercase;
      letter-spacing: .06em;
      color: var(--text-soft);
      font-weight: 600
  }

  .rx-summary-item .rsi-val {
      font-family: var(--mono);
      font-size: .95rem;
      font-weight: 700;
      color: var(--accent);
      margin-top: 2px
  }

  @media(max-width:700px) {
      .rx-params {
          grid-template-columns: 1fr
      }

      .rx-summary-bar {
          grid-template-columns: repeat(3, 1fr);
          gap: 12px
      }
  }

  /* Responsive */
  @media(max-width:900px) {
      .pavar-grid {
          grid-template-columns: repeat(3, 1fr)
      }

      .two-col {
          grid-template-columns: 1fr
      }

      .stats-bar {
          grid-template-columns: repeat(2, 1fr)
      }

      .digital-grid {
          grid-template-columns: 1fr
      }

      footer .footer-inner {
          grid-template-columns: 1fr
      }

      nav ul {
          display: none
      }

      nav ul.open {
          display: flex;
          flex-direction: column;
          position: absolute;
          top: 100%;
          left: 0;
          right: 0;
          background: rgba(245, 240, 235, 0.97);
          padding: 20px 32px;
          gap: 16px;
          border-bottom: 1px solid var(--border);
      }

      .menu-toggle {
          display: block
      }

      .plan-steps-nav {
          flex-wrap: wrap
      }

      .plan-step-btn {
          flex: none;
          width: calc(33.33% - 3px)
      }

      .field-row {
          grid-template-columns: 1fr
      }
  }

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

      .hero-stats {
          gap: 28px
      }

      section {
          padding: 64px 20px
      }
  }

  /* Login Overlay */
  .login-overlay {
      position: fixed;
      inset: 0;
      z-index: 10000;
      background: var(--bg);
      display: flex;
      align-items: center;
      justify-content: center;
      transition: opacity .5s, visibility .5s;
  }

  .login-overlay.hidden {
      opacity: 0;
      visibility: hidden;
      pointer-events: none
  }

  .login-box {
      width: 100%;
      max-width: 420px;
      padding: 48px 40px;
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08);
      position: relative;
      overflow: hidden;
      animation: fadeUp .6s ease;
  }

  .login-box::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      height: 4px;
      background: linear-gradient(90deg, var(--accent), var(--warm));
  }

  .login-logo {
      font-family: var(--serif);
      font-size: 1.6rem;
      color: var(--accent);
      font-weight: 700;
      text-align: center;
      margin-bottom: 6px;
  }

  .login-logo span {
      color: var(--warm);
      font-style: italic
  }

  .login-subtitle {
      text-align: center;
      font-size: .88rem;
      color: var(--text-soft);
      margin-bottom: 32px;
      line-height: 1.5;
  }

  .login-field {
      margin-bottom: 18px;
      position: relative
  }

  .login-field label {
      display: block;
      font-size: .75rem;
      font-weight: 600;
      letter-spacing: .05em;
      text-transform: uppercase;
      color: var(--text-soft);
      margin-bottom: 6px;
  }

  .login-field input {
      width: 100%;
      padding: 13px 16px 13px 44px;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      background: var(--bg);
      font-family: var(--sans);
      font-size: .95rem;
      color: var(--text);
      outline: none;
      transition: border-color .2s, box-shadow .2s;
  }

  .login-field input:focus {
      border-color: var(--accent);
      box-shadow: 0 0 0 3px var(--accent-glow)
  }

  .login-field .login-icon {
      position: absolute;
      left: 14px;
      bottom: 13px;
      font-size: 1.1rem;
      opacity: .4;
  }

  .login-field input.error {
      border-color: #a03030;
      box-shadow: 0 0 0 3px rgba(160, 48, 48, 0.08)
  }

  .login-error {
      font-size: .82rem;
      color: #a03030;
      text-align: center;
      margin-bottom: 16px;
      min-height: 20px;
      transition: opacity .2s;
  }

  .login-btn {
      width: 100%;
      padding: 14px;
      border: none;
      border-radius: var(--radius);
      background: var(--accent);
      color: #fff;
      font-family: var(--sans);
      font-size: .95rem;
      font-weight: 600;
      cursor: pointer;
      letter-spacing: .03em;
      transition: background .2s, transform .2s, box-shadow .2s;
  }

  .login-btn:hover {
      background: #15584a;
      transform: translateY(-2px);
      box-shadow: 0 6px 20px rgba(26, 107, 90, 0.25)
  }

  .login-btn:active {
      transform: translateY(0)
  }

  .login-remember {
      display: flex;
      align-items: center;
      gap: 8px;
      margin-top: 16px;
      justify-content: center;
      font-size: .82rem;
      color: var(--text-soft);
      cursor: pointer;
  }

  .login-remember input {
      accent-color: var(--accent);
      cursor: pointer
  }

  .login-footer {
      text-align: center;
      margin-top: 24px;
      padding-top: 20px;
      border-top: 1px solid var(--border);
      font-size: .78rem;
      color: var(--text-soft);
  }

  .login-bg-decor {
      position: fixed;
      inset: 0;
      z-index: -1;
      pointer-events: none;
      background:
          radial-gradient(ellipse 80% 60% at 20% 40%, rgba(26, 107, 90, 0.06), transparent),
          radial-gradient(ellipse 60% 50% at 80% 30%, rgba(196, 119, 90, 0.05), transparent);
  }

  /* Logout button in nav */
  .logout-btn {
      background: none;
      border: 1px solid var(--border);
      border-radius: 20px;
      padding: 5px 14px;
      font-size: .75rem;
      font-weight: 600;
      color: var(--text-soft);
      cursor: pointer;
      transition: all .2s;
      font-family: var(--sans);
      letter-spacing: .03em;
  }

  .logout-btn:hover {
      border-color: var(--warm);
      color: var(--warm)
  }

  /* Print — only show the generated plan */
  @media print {
      body {
          background: #fff !important;
          font-size: 11pt
      }

      body::before,
      nav,
      .scroll-progress,
      .scroll-hint,
      footer,
      .login-overlay,
      section:not(#plan),
      #plan .section-label,
      #plan .section-title,
      #plan .section-desc,
      #plan .plan-builder,
      #plan .result-actions,
      .hero {
          display: none !important
      }

      #plan {
          padding: 0 !important;
          background: none !important
      }

      #plan .section-inner {
          padding: 0 !important
      }

      .result-plan {
          display: block !important
      }

      .result-plan,
      .result-plan * {
          break-inside: avoid-page
      }

      .result-header {
          background: var(--accent) !important;
          -webkit-print-color-adjust: exact;
          print-color-adjust: exact
      }

      .result-body {
          border: 1px solid #ccc
      }

      .result-section {
          page-break-inside: avoid
      }

      .sev-header {
          -webkit-print-color-adjust: exact;
          print-color-adjust: exact
      }

      .sev-level-bar span,
      .dash-bar-fill,
      .score-badge,
      .result-tag,
      .result-warn,
      .rx-priority,
      .rec-card .rec-type,
      .week-block .wk-num {
          -webkit-print-color-adjust: exact;
          print-color-adjust: exact
      }

      .rec-grid {
          grid-template-columns: 1fr 1fr !important
      }

      .week-timeline {
          flex-wrap: wrap !important
      }
  }