.reading-view {
      min-height: 100vh;
      background: #edf5f2;
      padding: 8px;
    }

    .reading-shell {
      min-height: calc(100vh - 16px);
      background: white;
      border: 1px solid var(--line);
      border-radius: 8px;
      overflow: hidden;
      box-shadow: 0 8px 22px rgba(31, 41, 55, 0.08);
      display: grid;
      grid-template-rows: auto 1fr;
    }

    .reading-workspace {
      display: grid;
      grid-template-columns: 320px minmax(0, 1fr);
      min-height: 0;
    }

    .reading-panel {
      border-right: 1px solid #dce3ee;
      background: #f7fbf9;
      padding: 14px;
      display: grid;
      gap: 10px;
      align-content: start;
    }

    .reading-panel h2 {
      margin: 0;
      color: #174a3a;
    }

    .reading-panel label {
      display: grid;
      gap: 5px;
      color: #174a3a;
      font-size: 12px;
      font-weight: 900;
    }

    .reading-panel select {
      width: 100%;
      min-height: 36px;
      border: 1px solid #a9c8bd;
      border-radius: 6px;
      padding: 7px 8px;
      background: white;
      color: var(--ink);
      font-weight: 800;
    }

    .reading-panel button {
      border: 1px solid #1f7a5c;
      background: #1f7a5c;
      color: white;
      font-weight: 900;
    }

    .reading-status {
      border: 1px solid #cce8dc;
      border-radius: 8px;
      background: #f0fdf7;
      color: #14532d;
      padding: 9px 10px;
      font-size: 12px;
      font-weight: 900;
      min-height: 38px;
    }

    .reading-output {
      min-width: 0;
      padding: 14px;
      display: grid;
      gap: 12px;
      align-content: start;
      overflow: auto;
    }

    .reading-criteria {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
    }

    .reading-criteria article,
    .reading-card,
    .reading-feedback {
      border: 1px solid #d8e5df;
      border-radius: 8px;
      background: white;
      box-shadow: 0 8px 18px rgba(31, 41, 55, 0.04);
    }

    .reading-criteria article {
      padding: 10px;
      display: grid;
      gap: 4px;
      color: #475467;
      font-size: 12px;
    }

    .reading-criteria strong {
      color: #174a3a;
      font-size: 13px;
    }

    .reading-card {
      padding: 18px;
      display: grid;
      gap: 14px;
      line-height: 1.55;
    }

    .reading-card h2,
    .reading-card h3 {
      margin: 0;
      color: #123d63;
    }

    .reading-card .reading-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
    }

    .reading-card .reading-meta span {
      border-radius: 999px;
      background: #eef6f3;
      color: #174a3a;
      padding: 4px 8px;
      font-size: 12px;
      font-weight: 900;
    }

    .reading-text {
      border-left: 4px solid #1f7a5c;
      padding-left: 14px;
      color: #1f2937;
      font-size: 15px;
    }

    .reading-questions {
      display: grid;
      gap: 8px;
      margin: 0;
      padding-left: 20px;
    }

    .reading-feedback {
      padding: 12px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      color: #475467;
      font-size: 13px;
    }

    .reading-copy-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      justify-content: flex-end;
      border: 1px solid #d8e5df;
      border-radius: 8px;
      background: #fbfefd;
      padding: 10px;
    }

    .reading-copy-actions button {
      border: 1px solid #a9c8bd;
      background: #eef6f3;
      color: #174a3a;
      font-weight: 900;
    }

    .reading-copy-actions .primary {
      border-color: #1f7a5c;
      background: #1f7a5c;
      color: white;
    }

    .reading-feedback strong {
      color: #174a3a;
      display: block;
      margin-bottom: 2px;
    }

    .reading-faces {
      display: flex;
      gap: 8px;
    }

    .reading-faces button {
      width: 44px;
      height: 44px;
      border-radius: 999px;
      border: 1px solid #bfd0e2;
      background: #f8fafc;
      font-size: 22px;
      cursor: pointer;
      transition: transform 0.15s ease, border-color 0.15s ease, background 0.15s ease;
    }

    .reading-faces button:hover,
    .reading-faces button.active {
      transform: translateY(-1px);
      border-color: #1f7a5c;
      background: #dcfce7;
    }
