    :root {
      --color-bg: #ffffff;
      --color-primary: #0b2345;
      --color-primary-soft: #24446f;
      --color-primary-guest: #8591a2; /* 50% mix of --color-primary and white */
      --color-primary-guest-hover: #93a0b1;
      --color-accent-bg: #f3f7ff;
      --color-text: #1a2640;
      --color-text-muted: #6d7484;
      --color-border-soft: #e3e8f0;
      --radius-lg: 24px;
      --radius-pill: 999px;
      --shadow-soft: 0 20px 40px rgba(15, 35, 69, 0.08);
      --container-width: 1180px;
    }

    * {
      box-sizing: border-box;
    }

    body {
      margin: 0;
      font-family: -apple-system, BlinkMacSystemFont, "Inter", system-ui, sans-serif;
      background-color: var(--color-bg);
      color: var(--color-text);
      line-height: 1.4;
    }

    img {
      max-width: 100%;
      display: block;
    }

    a {
      text-decoration: none;
      color: inherit;
    }

    .container {
      max-width: var(--container-width);
      margin: 0 auto;
      padding: 0 24px;
    }

    .hidden {
      display: none !important;
    }

    /* HEADER */

    .site-header {
      position: sticky;
      top: 0;
      z-index: 20;
      background-color: var(--color-bg);
      backdrop-filter: blur(10px);
    }

    .header-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 20px 0;
      gap: 32px;
    }

    .logo {
      display: flex;
      flex-direction: column;
      font-size: 14px;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--color-primary);
      font-weight: 600;
      white-space: nowrap;
      cursor: pointer;
    }

    .logo-sub {
      font-size: 10px;
      letter-spacing: 0.15em;
      font-weight: 400;
      opacity: 0.8;
      margin-top: 4px;
    }

    .main-nav {
      display: flex;
      align-items: center;
      gap: 32px;
      font-size: 14px;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      flex: 1;
      justify-content: center;
    }

    .main-nav a {
      position: relative;
      padding: 4px 0;
      font-weight: 500;
      color: #151b2f;
    }

    .main-nav a::after {
      content: "";
      position: absolute;
      left: 0;
      bottom: -4px;
      width: 0;
      height: 2px;
      background-color: var(--color-primary);
      border-radius: 999px;
      transition: width 0.2s ease;
    }

    .main-nav a:hover::after,
    .main-nav a:focus-visible::after {
      width: 100%;
    }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding: 10px 24px;
      border-radius: var(--radius-pill);
      font-size: 14px;
      font-weight: 500;
      border: none;
      cursor: pointer;
      transition: transform 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease, color 0.15s ease;
      white-space: nowrap;
      font-family: inherit;
      line-height: 1;
    
    }

    .btn-primary {
      background-color: var(--color-primary);
      color: #ffffff;
      box-shadow: 0 18px 30px rgba(11, 35, 69, 0.22);
    }

    .btn-primary:hover {
      transform: translateY(-1px);
      box-shadow: 0 22px 36px rgba(11, 35, 69, 0.28);
      background-color: var(--color-primary-soft);
    }

    
    
    .btn-primary-guest {
      background-color: var(--color-primary-guest);
      color: #ffffff;
      box-shadow: 0 18px 30px rgba(11, 35, 69, 0.18);
    }

    .btn-primary-guest:hover {
      transform: translateY(-1px);
      box-shadow: 0 22px 36px rgba(11, 35, 69, 0.22);
      background-color: var(--color-primary-guest-hover);
    }

    @supports (background-color: color-mix(in srgb, #000 50%, #fff)) {
      .btn-primary-guest {
        background-color: color-mix(in srgb, var(--color-primary) 50%, white);
      }
      .btn-primary-guest:hover {
        background-color: color-mix(in srgb, var(--color-primary-soft) 55%, white);
      }
    }

.btn-primary-light {
      background-color: var(--color-primary-soft);
      color: #ffffff;
      box-shadow: 0 18px 30px rgba(11, 35, 69, 0.18);
    }

    .btn-primary-light:hover {
      transform: translateY(-1px);
      box-shadow: 0 22px 36px rgba(11, 35, 69, 0.22);
      background-color: #325b92;
    }

.btn-outline {
      background-color: transparent;
      border: 1px solid var(--color-border-soft);
      color: var(--color-primary);
      padding-inline: 28px;
    }

    .btn-outline:hover {
      background-color: #f5f7fb;
      box-shadow: 0 8px 16px rgba(15, 35, 69, 0.08);
      transform: translateY(-1px);
    }

    .btn-full {
      width: 100%;
      justify-content: center;
    }

    .btn-ghost {
      background: none;
      border: none;
      padding: 0;
      font: inherit;
      color: var(--color-primary);
      cursor: pointer;
      text-decoration: underline;
      text-underline-offset: 3px;
    }

    /* HEADER – ACTIONS + LANGUAGE SWITCH */

    .header-actions {
      display: flex;
      align-items: center;
      gap: 16px;
      white-space: nowrap;
    }

    .lang-switch {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-size: 12px;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: var(--color-text-muted);
    }

    .lang-switch a {
      padding: 4px 10px;
      border-radius: var(--radius-pill);
      transition: background-color 0.15s ease, color 0.15s ease;
      color: var(--color-text-muted);
    }

    .lang-switch a:hover {
      background-color: #f0f2f8;
      color: var(--color-primary);
    }

    .lang-switch a.is-active {
      background-color: var(--color-primary);
      color: #ffffff;
    }

    .lang-divider {
      opacity: 0.6;
      font-size: 11px;
    }

    /* HERO */

    .hero {
      padding: 60px 0 0;
      position: relative;
      z-index: 0;
    }

    .hero-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 60px;
    }

    .hero-content {
      flex: 1 1 40%;
      max-width: 460px;
    }

    .hero-title {
      font-size: 44px;
      line-height: 1.1;
      letter-spacing: -0.02em;
      margin: 0 0 24px;
      color: var(--color-primary);
    }

    .hero-subtitle {
      font-size: 18px;
      font-weight: 400;
      color: var(--color-text-muted);
      margin: 0 0 32px;
      max-width: 420px;
    }

    .hero-actions {
      display: flex;
      align-items: center;
      gap: 16px;
      margin-bottom: 40px;
    }

    
    .hero-actions--stack {
      flex-direction: column;
      align-items: flex-start;
      gap: 14px;
    }

.hero-image {
      flex: 1 1 60%;
      display: flex;
      justify-content: center;
      align-items: flex-start;
      position: relative;
    }

    .hero-photo {
      position: relative;
      z-index: 0;
      max-width: 680px;
      border-radius: 28px;
      transform: translateY(8px);
    }

    /* HERO VIEWS */

    .hero-view {
      display: none;
    }

    .hero-view.is-active {
      display: block;
    }

    .auth-card {
      background-color: #ffffff;
      border-radius: 24px;
      padding: 24px 24px 28px;
      border: 1px solid var(--color-border-soft);
      box-shadow: var(--shadow-soft);
    }

    .auth-title {
      font-size: 24px;
      margin: 0 0 8px;
      color: var(--color-primary);
    }

    .auth-subtitle {
      font-size: 14px;
      color: var(--color-text-muted);
      margin: 0 0 20px;
    }

    .auth-fields {
      display: flex;
      flex-direction: column;
      gap: 14px;
      margin-bottom: 12px;
    }

    .field {
      display: flex;
      flex-direction: column;
      gap: 4px;
    }

    .field-label {
      font-size: 13px;
      color: var(--color-text-muted);
    }

    .field-input,
    .field-select,
    .field-textarea {
      border-radius: 12px;
      border: 1px solid var(--color-border-soft);
      padding: 9px 11px;
      font-size: 14px;
      font-family: inherit;
      outline: none;
      transition: border-color 0.15s ease, box-shadow 0.15s ease;
    }

    .field-input:focus,
    .field-select:focus,
    .field-textarea:focus {
      border-color: var(--color-primary-soft);
      box-shadow: 0 0 0 1px rgba(11, 35, 69, 0.18);
    }

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

    .field-inline {
      display: flex;
      align-items: flex-start;
      gap: 10px;
      font-size: 13px;
      color: var(--color-text-muted);
    }

    .field-inline input[type="checkbox"] {
      margin-top: 2px;
    }

    .auth-footer {
      display: flex;
      flex-direction: column;
      gap: 8px;
      margin-top: 12px;
      font-size: 13px;
      color: var(--color-text-muted);
    }

    .auth-footer strong {
      color: var(--color-primary);
    }

    .auth-options {
      display: flex;
      flex-direction: column;
      gap: 10px;
      margin-top: 12px;
    }

    .auth-hint {
      font-size: 13px;
      color: var(--color-text-muted);
      margin-top: 8px;
    }

    .back-link {
      font-size: 13px;
      margin-top: 10px;
    }

    .auth-message {
      font-size: 13px;
      margin-top: 6px;
      min-height: 16px;
    }

    /* KAFELKI CTA */

    .cta-cards {
      margin-top: 80px;
      padding-bottom: 100px;
      position: relative;
      z-index: 1;
    }

    .cards-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 24px;
      margin-top: 8px;
    }

    .cta-card {
      background-color: #ffffff;
      border-radius: var(--radius-lg);
      padding: 24px 26px;
      border: 1px solid var(--color-border-soft);
      box-shadow: var(--shadow-soft);
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      min-height: 120px;
      transition: transform 0.15s ease, box-shadow 0.15s ease;
    }

    .cta-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 24px 48px rgba(15, 35, 69, 0.12);
    }

    .cta-card-top {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 6px;
    }

    .cta-icon {
      width: 28px;
      height: 28px;
      border-radius: 50%;
      background-color: var(--color-accent-bg);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 16px;
      flex-shrink: 0;
    }

    .cta-title {
      font-size: 16px;
      font-weight: 600;
      color: var(--color-primary);
      margin: 0;
    }

    .cta-subtitle-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin-top: 4px;
    }

    .cta-subtitle {
      font-size: 14px;
      color: var(--color-text-muted);
      margin: 0;
    }
	/* DŁUŻSZY PODTYTUŁ – tylko kafelek "Dla pacjentów" */
	.cta-card--patients .cta-subtitle {
	  font-size: 12px;
	  line-height: 1.25;
	  max-width: 260px;
	}

	
    /* Rozwijane "Dowiedz się więcej" */
    .more-wrap { padding: 0 0 80px; }
    .more-card{
      border: 1px solid var(--color-border-soft);
      border-radius: 18px;
      background: #ffffff;
      padding: 26px 26px 20px;
      box-shadow: 0 10px 30px rgba(11, 35, 69, 0.06);
    }
    .more-head{ max-width: 980px; }
    .more-title{
      margin: 0 0 10px;
      color: var(--color-primary);
      font-size: 26px;
      letter-spacing: -0.02em;
      line-height: 1.18;
    }
    .more-lead{
      margin: 0 0 18px;
      color: var(--color-text-muted);
      font-size: 14px;
      line-height: 1.6;
    }
    .more-grid{
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 16px;
      margin-top: 12px;
    }
    .more-block{
      border: 1px solid var(--color-border-soft);
      border-radius: 16px;
      background: var(--color-accent-bg);
      padding: 16px 16px 14px;
    }
    .more-h{
      margin: 0 0 8px;
      color: var(--color-primary);
      font-size: 15px;
      font-weight: 700;
    }
    .more-p{
      margin: 0 0 10px;
      color: var(--color-text);
      font-size: 13px;
      line-height: 1.55;
    }
    .more-ul{
      margin: 0;
      padding-left: 18px;
      color: var(--color-text);
      font-size: 13px;
      line-height: 1.55;
    }
    .more-ul li{ margin: 6px 0; }
    .more-note{
      margin: 16px 0 0;
      color: var(--color-text-muted);
      font-size: 12px;
      line-height: 1.5;
    }
    @media (max-width: 980px){
      .more-grid{ grid-template-columns: 1fr; }
      .more-title{ font-size: 22px; }
    }


/* Sekcja informacyjna (landing) */
	.info-section {
	  padding: 70px 0 90px;
	  border-top: 1px solid var(--color-border-soft);
	  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
	}

	.info-hero { max-width: 860px; }

	.info-hero h2 {
	  margin: 0 0 14px;
	  color: var(--color-primary);
	  font-size: 34px;
	  letter-spacing: -0.02em;
	  line-height: 1.12;
	}

	.info-hero p {
	  margin: 0 0 22px;
	  color: var(--color-text-muted);
	  font-size: 16px;
	  line-height: 1.6;
	}

	.info-actions {
	  display: flex;
	  flex-wrap: wrap;
	  gap: 12px;
	  margin: 6px 0 30px;
	}

	.steps {
	  margin-top: 24px;
	  background: #ffffff;
	  border: 1px solid var(--color-border-soft);
	  border-radius: var(--radius-lg);
	  box-shadow: var(--shadow-soft);
	  padding: 22px 24px;
	  max-width: 980px;
	}

	.steps-title {
	  margin: 0 0 14px;
	  color: var(--color-primary);
	  font-size: 18px;
	  letter-spacing: -0.01em;
	}

	.steps-list {
	  margin: 0;
	  padding-left: 18px;
	  color: var(--color-text);
	  font-size: 14px;
	  line-height: 1.55;
	}

	.steps-list li { margin: 10px 0; }
	.steps-list strong { color: var(--color-primary); font-weight: 600; }

	.disclaimer-box {
	  margin-top: 16px;
	  padding: 12px 14px;
	  border-radius: 16px;
	  border: 1px solid #f1d5a8;
	  background: #fff8eb;
	  color: #6a4a12;
	  font-size: 13px;
	  line-height: 1.45;
	}

	@media (max-width: 960px) {
	  .info-section { padding: 56px 0 70px; }
	  .info-hero h2 { font-size: 28px; }
	  .cta-card--patients .cta-subtitle { max-width: 100%; }
	  .steps { padding: 18px 18px; }
	}

    .cta-arrow {
      font-size: 16px;
      flex-shrink: 0;
    }

    /* DASHBOARD (POST-LOGIN) */

    .dashboard {
      padding: 40px 0 80px;
    }

    .dashboard-header {
      display: flex;
      justify-content: space-between;
      align-items: flex-end;
      gap: 16px;
      margin-bottom: 24px;
    }

    .dashboard-title {
      font-size: 28px;
      margin: 0 0 6px;
      color: var(--color-primary);
    }

    .dashboard-subtitle {
      margin: 0;
      font-size: 14px;
      color: var(--color-text-muted);
    }

    .dashboard-user-pill {
      font-size: 12px;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      background-color: var(--color-accent-bg);
      color: var(--color-primary);
      padding: 6px 14px;
      border-radius: var(--radius-pill);
    }

    .tabs {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      border-bottom: 1px solid var(--color-border-soft);
      margin-bottom: 18px;
      padding-bottom: 4px;
    }

    .tab-button {
      border-radius: var(--radius-pill);
      border: 1px solid transparent;
      padding: 7px 18px;
      font-size: 13px;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      background-color: transparent;
      color: var(--color-text-muted);
      cursor: pointer;
      transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
    }

    .tab-button.is-active {
      background-color: var(--color-primary);
      color: #ffffff;
      border-color: var(--color-primary);
    }

    .tab-panel {
      display: none;
    }

    .tab-panel.is-active {
      display: block;
    }

    /* AI TAB LAYOUT */

    .ai-layout {
      display: flex;
      align-items: flex-start;
      gap: 24px;
      margin-top: 4px;
    }

    .ai-left {
      flex: 1 1 40%;
      max-width: 420px;
    }

    .ai-right {
      flex: 1 1 60%;
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 16px;
    }

    

    /* === AI board layout (2 kolumny: 4 odpowiedzi, potem Zapytanie i Historia) === */
    .ai-board {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 16px;
      margin-top: 4px;
      align-items: start;
    }
    .ai-span-2 {
      grid-column: 1 / -1;
    }

    .ai-history-card {
      background-color: #ffffff;
      border-radius: 20px;
      border: 1px solid var(--color-border-soft);
      box-shadow: var(--shadow-soft);
      padding: 18px 18px 20px;
    }
    .ai-history-header {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 10px;
    }
    .ai-history-title {
      margin: 0;
      font-size: 18px;
      color: var(--color-text);
    }
    .ai-history-subtitle {
      color: var(--color-text-muted);
      font-size: 12px;
      line-height: 1.3;
      text-align: right;
      max-width: 60%;
    }
    .ai-history-list {
      border: 1px solid var(--color-border-soft);
      border-radius: 14px;
      padding: 12px;
      background: #f9faff;
      min-height: 110px;
      max-height: 280px;
      overflow: auto;
      white-space: normal;
      font-size: 13px;
      line-height: 1.45;
    }
    .ai-history-item {
      padding: 10px 10px;
      border-radius: 12px;
      background: #fff;
      border: 1px solid rgba(227,232,240,0.9);
    }
    .ai-history-item + .ai-history-item {
      margin-top: 10px;
    }
    .ai-history-meta {
      font-size: 12px;
      color: var(--color-text-muted);
      margin-bottom: 6px;
    }
    .ai-history-user {
      font-weight: 600;
      color: var(--color-text);
      margin-bottom: 6px;
      white-space: pre-wrap;
    }
    .ai-history-answers {
      font-size: 13px;
      color: var(--color-text);
      white-space: pre-wrap;
    }

    /* File input row + czerwony X */
    .ai-file-row {
      display: flex;
      gap: 10px;
      align-items: center;
    }
    .ai-file-row .field-input { flex: 1 1 auto; }
    .file-clear-btn {
      width: 36px;
      height: 36px;
      border-radius: 10px;
      border: 1px solid rgba(220, 38, 38, 0.25);
      background: rgba(220, 38, 38, 0.08);
      color: #b91c1c;
      font-size: 18px;
      font-weight: 700;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      user-select: none;
    }
    .file-clear-btn:hover {
      background: rgba(220, 38, 38, 0.12);
    }

    .ai-note-row{
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
      margin-top: 8px;
      flex-wrap: wrap;
    }
    .ai-note-row .ai-note{
      margin: 0;
      flex: 1 1 auto;
    }
    .ai-note-row .ai-history-jump{
      margin-top: 0;
      flex: 0 0 auto;
      text-align: right;
      margin-left: auto;
    }
.ai-history-jump{
      display: inline-block;
      margin-top: 8px;
      font-size: 13px;
      font-weight: 600;
      color: var(--color-primary);
      text-decoration: none;
    }
    .ai-history-jump:hover{ text-decoration: underline; }
    .ai-file-field{ margin-top: 12px; }


@media (max-width: 980px) {
      .ai-board { grid-template-columns: 1fr; }
      .ai-span-2 { grid-column: auto; }
      .ai-history-subtitle { max-width: 100%; text-align: left; }
    }
.ai-query-card {
      background-color: #ffffff;
      border-radius: 20px;
      border: 1px solid var(--color-border-soft);
      box-shadow: var(--shadow-soft);
      padding: 18px 18px 20px;
    }

    .ai-query-title {
      font-size: 16px;
      margin: 0 0 8px;
      color: var(--color-primary);
    }

    .ai-query-subtitle {
      font-size: 13px;
      color: var(--color-text-muted);
      margin: 0 0 12px;
    }

    .ai-file-info {
      font-size: 12px;
      color: var(--color-text-muted);
      margin-top: 4px;
    }

    .ai-send-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin-top: 12px;
    }

    .ai-note {
      font-size: 11px;
      color: var(--color-text-muted);
    }

    .ai-message {
      font-size: 13px;
      margin-top: 8px;
      min-height: 16px;
    }

    .ai-model-card {
      background-color: #ffffff;
      border-radius: 16px;
      border: 1px solid var(--color-border-soft);
      padding: 14px 14px 16px;
      box-shadow: 0 10px 24px rgba(15, 35, 69, 0.06);
      display: flex;
      flex-direction: column;
      min-height: 150px;
    }

    .ai-model-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 6px;
    }

    .ai-model-name {
      font-size: 13px;
      font-weight: 600;
      color: var(--color-primary);
      text-transform: uppercase;
      letter-spacing: 0.12em;
    }

    .ai-model-tag {
      font-size: 11px;
      padding: 3px 8px;
      border-radius: 999px;
      background-color: var(--color-accent-bg);
      color: var(--color-text-muted);
    }

    .ai-response {
      font-size: 13px;
      color: var(--color-text-muted);
      margin-top: 4px;
      white-space: pre-wrap;
    }

    /* Historia i pozostałe zakładki – placeholder */

    .history-placeholder,
    .tab-placeholder {
      background-color: #ffffff;
      border-radius: 20px;
      border: 1px solid var(--color-border-soft);
      padding: 18px 18px 24px;
      box-shadow: var(--shadow-soft);
      font-size: 14px;
      color: var(--color-text-muted);
    }

    

    /* Historia – sesje i podgląd */

    .history-board {
      background-color: #ffffff;
      border-radius: 20px;
      border: 1px solid var(--color-border-soft);
      padding: 18px 18px 20px;
      box-shadow: var(--shadow-soft);
    }

    .history-head {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 12px;
      flex-wrap: wrap;
      margin-bottom: 14px;
    }

    .history-title-main {
      font-weight: 700;
      color: var(--color-text);
      font-size: 16px;
    }

    .history-title-sub {
      margin-top: 4px;
      font-size: 13px;
      color: var(--color-text-muted);
      line-height: 1.35;
      max-width: 760px;
    }

    .history-actions {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      align-items: center;
    }

    .history-grid {
      display: grid;
      grid-template-columns: 320px 1fr;
      gap: 14px;
    }

    .history-section-label {
      font-size: 12px;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--color-text-muted);
      margin-bottom: 10px;
      display: flex;
      align-items: center;
      gap: 10px;
      justify-content: space-between;
    }

    .history-active-session {
      font-size: 12px;
      letter-spacing: 0;
      text-transform: none;
      color: var(--color-text-muted);
    }

    .history-sessions-list {
      display: flex;
      flex-direction: column;
      gap: 8px;
      max-height: 520px;
      overflow: auto;
      padding-right: 6px;
    }

    .history-session-item {
      border: 1px solid var(--color-border-soft);
      border-radius: 14px;
      padding: 10px 12px;
      background: #fff;
      cursor: pointer;
      transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
    }

    .history-session-item:hover {
      transform: translateY(-1px);
      box-shadow: var(--shadow-soft);
    }

    .history-session-item.is-active {
      border-color: rgba(11, 35, 69, 0.35);
      box-shadow: var(--shadow-soft);
    }

    .history-session-top {
      display: flex;
      justify-content: space-between;
      gap: 10px;
      align-items: baseline;
    }

    .history-session-title {
      font-weight: 700;
      font-size: 13px;
      color: var(--color-text);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      max-width: 220px;
    }

    .history-session-date {
      font-size: 12px;
      color: var(--color-text-muted);
      white-space: nowrap;
    }

    .history-session-meta {
      margin-top: 6px;
      font-size: 12px;
      color: var(--color-text-muted);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .history-messages-view {
      border: 1px solid var(--color-border-soft);
      border-radius: 18px;
      padding: 12px;
      min-height: 240px;
      max-height: 520px;
      overflow: auto;
      background: #ffffff;
    }

    .history-msg {
      border-bottom: 1px dashed var(--color-border-soft);
      padding: 10px 0;
    }

    .history-msg:last-child {
      border-bottom: none;
    }

    .history-msg-meta {
      font-size: 12px;
      color: var(--color-text-muted);
      display: flex;
      justify-content: space-between;
      gap: 10px;
      margin-bottom: 6px;
    }

    .history-msg-user {
      font-size: 13px;
      color: var(--color-text);
      white-space: pre-wrap;
    }

    .history-msg-answers {
      margin-top: 8px;
      display: grid;
      gap: 6px;
    }

    .history-msg-answer {
      font-size: 12px;
      color: var(--color-text-muted);
      white-space: pre-wrap;
      border-left: 3px solid var(--color-border-soft);
      padding-left: 10px;
    }

    @media (max-width: 980px) {
      .history-grid {
        grid-template-columns: 1fr;
      }
      .history-sessions-list,
      .history-messages-view {
        max-height: 420px;
      }
      .history-session-title {
        max-width: 100%;
      }
    }
/* RESPONSYWNOŚĆ */

    @media (max-width: 960px) {
      .header-inner {
        flex-wrap: wrap;
        row-gap: 16px;
      }

      .main-nav {
        order: 3;
        flex-wrap: wrap;
        gap: 18px;
        font-size: 13px;
      }

      .hero-inner {
        flex-direction: column-reverse;
        align-items: flex-start;
        gap: 40px;
      }

      .hero {
        padding-top: 40px;
      }

      .hero-title {
        font-size: 34px;
      }

      .hero-subtitle {
        font-size: 16px;
      }

      .cards-grid {
        grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
      }

      .auth-card {
        padding: 20px 18px 24px;
      }

      .ai-layout {
        flex-direction: column;
      }

      .ai-left {
        max-width: 100%;
      }
    }

    @media (max-width: 640px) {
      .header-inner {
        justify-content: space-between;
      }

      .main-nav {
        display: none;
      }

      .hero-actions {
        width: 100%;
      }

      .btn-primary {
        width: 100%;
        justify-content: center;
      }

      .cards-grid {
        grid-template-columns: 1fr;
      }

      .cta-cards {
        padding-bottom: 56px;
      }

      .ai-right {
        grid-template-columns: 1fr;
      }
    }

    /* Wyrównanie logo na dużych ekranach */
    @media (min-width: 960px) {
      .logo {
        margin-left: 16px;
      }
    }
    /* --- AI doc processing UI --- */
    .ai-doc-card{
      margin-top: 14px;
      padding: 14px 14px 12px;
      border: 1px solid var(--color-border-soft);
      border-radius: 16px;
      background: #ffffff;
    }
    .ai-doc-header{
      display:flex;
      gap:12px;
      align-items:flex-start;
      justify-content:space-between;
    }
    .ai-doc-title{
      margin:0;
      font-size: 14px;
      font-weight: 700;
      color: var(--color-text);
    }
    .ai-doc-subtitle{
      margin-top: 4px;
      font-size: 12px;
      color: var(--color-text-muted);
      line-height: 1.35;
    }
    .ai-doc-row{
      margin-top: 10px;
      display:flex;
      gap:10px;
      align-items:center;
      flex-wrap: wrap;
    }
    .ai-doc-inline{
      gap:8px;
      user-select:none;
      font-size: 12.5px;
      color: var(--color-text);
    }
    .ai-doc-actions{ display:flex; gap:8px; }
    .btn-sm{ padding: 8px 10px; font-size: 12px; border-radius: 12px; }
    .ai-doc-status{
      margin-top: 10px;
      padding: 10px 12px;
      border-radius: 14px;
      border: 1px solid var(--color-border-soft);
      background: var(--color-accent-bg);
      color: var(--color-text);
      font-size: 12.5px;
      min-height: 18px;
      white-space: pre-line;
    }
    .ai-doc-status.is-error{ background:#fff1f1; border-color:#ffd1d1; color:#8b1a1a; }
    .ai-doc-status.is-ok{ background:#f1fff4; border-color:#c9f5d0; color:#0b5a1b; }
    .ai-doc-toolbar{
      margin-top: 10px;
      display:flex;
      gap:8px;
      flex-wrap:wrap;
      align-items:center;
    }
    .ai-doc-preview{
      margin-top: 10px;
      max-height: 260px;
      overflow:auto;
      padding: 12px;
      border-radius: 14px;
      border: 1px solid var(--color-border-soft);
      background: #0b1220;
      color: #e8eefc;
      font-size: 12px;
      line-height: 1.45;
      white-space: pre-wrap;
      word-break: break-word;
    }

  
    .ai-active-badge{
      display: inline-flex;
      align-items: center;
      gap: 8px;
      margin-top: 8px;
      margin-bottom: 2px;
      font-size: 12px;
      color: var(--color-text-muted);
      background: #f9faff;
      border: 1px solid var(--color-border-soft);
      padding: 6px 10px;
      border-radius: 999px;
      width: fit-content;
    }
    .history-session-top{
      display:flex;
      align-items:center;
      justify-content: space-between;
      gap: 10px;
    }
    .history-session-del{
      border: 0;
      background: transparent;
      color: var(--color-text-muted);
      cursor: pointer;
      padding: 4px 6px;
      border-radius: 10px;
      line-height: 1;
      font-size: 14px;
    }
    .history-session-del:hover{
      background: rgba(11,35,69,0.06);
      color: var(--color-primary);
    }
    /* TEMP: ukryj przycisk "Zobacz, jak to działa" w sekcji Pacjenci */
    #btn-patients-cta-how {
      display: none !important;
    }

    /* Ukrywamy elementy landingowe po zalogowaniu (opcjonalne) */
    .is-auth .public-only { display: none !important; }
  

    /* CONTACT MODAL */
    .modal-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(11, 35, 69, 0.45);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 24px;
      z-index: 1000;
    }

    .modal-card {
      width: 100%;
      max-width: 560px;
      background: #ffffff;
      border-radius: var(--radius-lg);
      border: 1px solid var(--color-border-soft);
      box-shadow: 0 26px 60px rgba(15, 35, 69, 0.18);
      overflow: hidden;
    }

    .modal-header {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 16px;
      padding: 18px 20px 12px;
      border-bottom: 1px solid var(--color-border-soft);
      background: linear-gradient(180deg, #ffffff 0%, #f7f9ff 100%);
    }

    .modal-header h3 {
      margin: 0;
      font-size: 18px;
      color: var(--color-primary);
      letter-spacing: -0.01em;
    }

    .modal-subtitle {
      margin: 6px 0 0;
      font-size: 13px;
      color: var(--color-text-muted);
      line-height: 1.4;
    }

    .modal-close {
      appearance: none;
      border: none;
      background: transparent;
      cursor: pointer;
      font-size: 22px;
      line-height: 1;
      padding: 6px 10px;
      border-radius: 12px;
      color: var(--color-primary);
    }

    .modal-close:hover { background: #f0f4ff; }

    .modal-body {
      padding: 16px 20px 18px;
    }

    .form-grid {
      display: grid;
      grid-template-columns: 1fr;
      gap: 12px;
      margin-top: 6px;
    }

    .form-field label {
      display: block;
      font-size: 12px;
      color: var(--color-text-muted);
      margin-bottom: 6px;
      letter-spacing: 0.02em;
      text-transform: uppercase;
    }

    .form-field input {
      width: 100%;
      padding: 12px 14px;
      border-radius: 16px;
      border: 1px solid var(--color-border-soft);
      font-size: 14px;
      outline: none;
      transition: box-shadow 0.15s ease, border-color 0.15s ease;
    }

    .form-field input:focus {
      border-color: rgba(11, 35, 69, 0.35);
      box-shadow: 0 0 0 4px rgba(11, 35, 69, 0.08);
    }

    .modal-actions {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
      margin-top: 14px;
    }

    .modal-note {
      margin: 12px 0 0;
      font-size: 12px;
      color: var(--color-text-muted);
      line-height: 1.45;
    }

    @media (max-width: 520px) {
      .modal-card { border-radius: 18px; }
      .modal-header { padding: 16px 16px 10px; }
      .modal-body { padding: 14px 16px 16px; }
    }

    /* PDF footer */
    .legal-footer {
      margin-top: 28px;
      padding: 18px 0;
      border-top: 1px solid var(--color-border-soft);
      background: var(--color-accent-bg);
    }
    .legal-footer-inner {
      display: flex;
      justify-content: center;
      align-items: center;
    }
    .legal-links {
      display: flex;
      flex-wrap: wrap;
      gap: 18px;
      justify-content: center;
      font-size: 13px;
      color: var(--color-text-muted);
    }
    .legal-links a {
      color: var(--color-text);
      opacity: 0.86;
    }
    .legal-links a:hover {
      opacity: 1;
      text-decoration: underline;
    }
