    :root {
      /* Base Colors - Light Mode */
      --color-bg: #FCFCFB;
      --color-bg-alt: #F9F9F8;
      --color-text: #1A1A19;
      --color-text-secondary: #5E5E5C;
      --color-border: #E8E7E5;
      --color-accent: #5D8BF4;
      --color-accent-hover: #4a77d1;
      --color-micro-accent: #F5C6B1;
      --color-success: #4CAF50;
      --shadow-ambient: 0 4px 12px rgba(0, 0, 0, 0.03);
      --transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
      --radius: 16px;
      --container-width: 1200px;
      --spacing-xs: 0.75rem;
      --spacing-sm: 1.5rem;
      --spacing-md: 3rem;
      --spacing-lg: 4.5rem;
    }

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

    body {
      font-family: 'Sora', -apple-system, BlinkMacSystemFont, sans-serif;
      background-color: var(--color-bg);
      color: var(--color-text);
      line-height: 1.6;
      overflow-x: hidden;
      transition: var(--transition);
    }

    h1, h2, h3 {
      font-family: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
      font-weight: 700;
      line-height: 1.2;
      letter-spacing: -0.5px;
    }

    h1 {
      font-size: clamp(2.25rem, 5vw, 3.5rem);
      max-width: 32ch;
    }

    h2 {
      font-size: clamp(1.75rem, 4vw, 2.5rem);
      margin-bottom: var(--spacing-sm);
    }

    p {
      max-width: 65ch;
      margin-bottom: var(--spacing-xs);
      color: var(--color-text-secondary);
      font-weight: 400;
    }

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

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

    .container {
      width: min(95%, var(--container-width));
      margin-inline: auto;
    }

    .btn {
      display: inline-block;
      background: var(--color-accent);
      color: white;
      padding: 0.875rem 1.75rem;
      border-radius: 50rem;
      font-family: 'Manrope', sans-serif;
      font-weight: 600;
      font-size: 1.05rem;
      border: none;
      cursor: pointer;
      transition: var(--transition);
      box-shadow: var(--shadow-ambient);
    }

    .btn:hover {
      background: var(--color-accent-hover);
      transform: translateY(-2px);
    }

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

    .btn-secondary:hover {
      border-color: var(--color-accent);
      background: rgba(93, 139, 244, 0.05);
    }

    section {
      padding-block: var(--spacing-lg);
    }

    .section-header {
      text-align: center;
      margin-bottom: var(--spacing-md);
      max-width: 45ch;
      margin-inline: auto;
    }

    .section-header-wide {
      max-width: none;
      width: 100%;
    }

    .section-subtitle {
      margin-top: 0.9rem;
      color: var(--color-text-secondary);
      font-size: 1.05rem;
      line-height: 1.7;
      max-width: 70ch;
      margin-inline: auto;
      text-align: center;
    }

    @media (min-width: 900px) {
      .definition-side {
        padding-top: 1.25rem;
      }
    }


    .divider {
      height: 1px;
      background: linear-gradient(to right, transparent, var(--color-border), transparent);
      margin-block: var(--spacing-md);
      border: none;
    }

    /* Header & Navigation */
    header {
      position: sticky;
      top: 0;
      z-index: 100;
      background: var(--color-bg);
      backdrop-filter: blur(12px);
      padding-block: 1rem;
      transition: var(--transition);
      box-shadow: 0 1px 0 rgba(0,0,0,0.02);
    }

    header.scrolled {
      padding-block: 0.75rem;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.03);
    }

    .header-container {
      display: flex;
      align-items: center;
      justify-content: space-between;
    }

    .logo {
      font-family: 'Manrope', sans-serif;
      font-weight: 800;
      font-size: 1.5rem;
      color: var(--color-text);
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .logo svg {
      width: 32px;
      height: 32px;
    }

    .nav-links {
      display: flex;
      gap: var(--spacing-sm);
      margin-left: auto;
    }

    .nav-links a {
      font-weight: 500;
      padding: 0.5rem 0;
      position: relative;
      transition: var(--transition);
    }

    .nav-links a::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      height: 1px;
      background: var(--color-accent);
      transform: scaleX(0);
      transition: transform 0.3s ease;
      transform-origin: right;
    }

    .nav-links a:hover::after {
      transform: scaleX(1);
      transform-origin: left;
    }

    .nav-cta {
      margin-left: var(--spacing-sm);
    }

    .mode-switcher {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      margin-left: var(--spacing-sm);
      cursor: pointer;
      user-select: none;
    }

    .mode-toggle {
      width: 48px;
      height: 24px;
      background: var(--color-border);
      border-radius: 50rem;
      position: relative;
      transition: var(--transition);
    }

    .mode-toggle::before {
      content: '';
      position: absolute;
      width: 18px;
      height: 18px;
      border-radius: 50%;
      background: white;
      top: 3px;
      left: 3px;
      transition: var(--transition);
    }


    /* Language toggle states */
    html[data-lang="en"] .mode-toggle {
      background: var(--color-accent);
    }

    html[data-lang="en"] .mode-toggle::before {
      transform: translateX(24px);
      background: var(--color-bg);
    }

    .mobile-menu-btn {
      display: none;
      background: none;
      border: none;
      font-size: 1.5rem;
      cursor: pointer;
      color: var(--color-text);
    }

    /* Hero Section */
    .hero {
      padding-block: var(--spacing-lg) calc(var(--spacing-lg) * 1.5);
      position: relative;
      overflow: hidden;
    }

    .hero-content {
      display: grid;
      grid-template-columns: 1fr;
      gap: var(--spacing-md);
      align-items: center;
      justify-items: center;
    }

    .hero-text {
      grid-column: 1 / -1;
      text-align: center;
      margin-inline: auto;
    }

    .hero-claim {
      color: var(--color-accent);
      font-weight: 600;
      font-size: 1.125rem;
      margin-bottom: var(--spacing-xs);
      display: block;
    }

    .hero-subtitle {
      font-size: 1.25rem;
      max-width: 40ch;
      margin-top: var(--spacing-xs);
      margin-inline: auto;
    }

    .hero-cta-group {
      display: flex;
      gap: 1rem;
      margin-top: var(--spacing-md);
      justify-content: center;
      flex-wrap: wrap;
    }

    .hero-visual {
      grid-column: 2 / 3;
      position: relative;
      justify-self: end;
    }

    .hero-card {
      background: var(--color-bg-alt);
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      padding: 2rem;
      box-shadow: var(--shadow-ambient);
      position: relative;
      overflow: hidden;
    }

    .hero-card::before {
      content: '';
      position: absolute;
      top: -50%;
      right: -50%;
      width: 200%;
      height: 200%;
      background: radial-gradient(circle, rgba(93, 139, 244, 0.08) 0%, transparent 70%);
      z-index: 0;
    }

    .hero-card-content {
      position: relative;
      z-index: 1;
    }

    .mode-switcher-hero {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding-bottom: 1.25rem;
      border-bottom: 1px solid var(--color-border);
      margin-bottom: 1.5rem;
    }

    .mode-label {
      font-weight: 600;
      font-size: 0.95rem;
    }

    .mode-options {
      display: flex;
      gap: 0.75rem;
      background: var(--color-bg);
      padding: 0.25rem;
      border-radius: 50rem;
      border: 1px solid var(--color-border);
    }

    .mode-option {
      padding: 0.5rem 1rem;
      border-radius: 50rem;
      font-size: 0.9rem;
      cursor: pointer;
      transition: var(--transition);
    }

    .mode-option.active {
      background: var(--color-accent);
      color: white;
    }

    .hero-input-group {
      margin-bottom: 1.5rem;
    }

    .hero-input {
      width: 100%;
      padding: 1rem;
      border: 1px solid var(--color-border);
      border-radius: 12px;
      background: var(--color-bg);
      color: var(--color-text);
      font-family: 'Sora', sans-serif;
      font-size: 1rem;
      transition: var(--transition);
    }

    .hero-input:focus {
      outline: none;
      border-color: var(--color-accent);
      box-shadow: 0 0 0 3px rgba(93, 139, 244, 0.2);
    }

    .hero-input::placeholder {
      color: var(--color-text-secondary);
      opacity: 1;
    }

    .hero-output {
      min-height: 8rem;
      padding: 1.25rem;
      background: var(--color-bg);
      border: 1px dashed var(--color-border);
      border-radius: 12px;
      font-family: 'Sora', monospace;
      font-size: 0.95rem;
      line-height: 1.5;
      color: var(--color-text-secondary);
      transition: var(--transition);
    }

    .hero-output.loading::after {
      content: "Chwila… dopieszczamy szczegóły.";
    }

    .hero-output.ready {
      color: var(--color-text);
    }

    .hero-output.ready::after {
      content: "Twoja oferta gotowa! Skopiuj i wykorzystaj od razu.";
    }



    /* Generator (Hero card) */
    .generator-header {
      margin-bottom: 1.25rem;
    }

    .generator-title {
      font-family: 'Manrope', sans-serif;
      font-weight: 800;
      font-size: 1.25rem;
      letter-spacing: -0.4px;
      margin-bottom: 0.25rem;
    }

    .generator-sub {
      color: var(--color-text-secondary);
      font-size: 0.95rem;
      max-width: 60ch;
    }

    .generator-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 1.25rem;
      align-items: start;
    }

    .generator-block {
      background: var(--color-bg);
      border: 1px solid var(--color-border);
      border-radius: 14px;
      padding: 1rem;
    }

    .generator-label {
      display: block;
      font-weight: 600;
      font-size: 0.95rem;
      margin-bottom: 0.5rem;
      color: var(--color-text);
    }

    .generator-label.mt {
      margin-top: 1rem;
    }

    .generator-textarea {
      width: 100%;
      min-height: 8.5rem;
      resize: vertical;
      padding: 0.9rem;
      border: 1px solid var(--color-border);
      border-radius: 12px;
      background: var(--color-bg-alt);
      color: var(--color-text);
      font-family: 'Sora', sans-serif;
      font-size: 0.95rem;
      transition: var(--transition);
    }

    .generator-textarea:focus,
    .generator-select:focus,
    .generator-file:focus {
      outline: none;
      border-color: var(--color-accent);
      box-shadow: 0 0 0 3px rgba(93, 139, 244, 0.2);
    }

    .generator-divider {
      text-align: center;
      color: var(--color-text-secondary);
      font-size: 0.85rem;
      padding: 0.6rem 0;
    }

    .generator-file {
      width: 100%;
      padding: 0.75rem;
      border: 1px dashed var(--color-border);
      border-radius: 12px;
      background: var(--color-bg-alt);
      color: var(--color-text-secondary);
    }

    .generator-hint {
      margin-top: 0.5rem;
      font-size: 0.82rem;
      color: var(--color-text-secondary);
    }

    .generator-select {
      width: 100%;
      padding: 0.85rem;
      border: 1px solid var(--color-border);
      border-radius: 12px;
      background: var(--color-bg-alt);
      color: var(--color-text);
      font-family: 'Sora', sans-serif;
      font-size: 0.95rem;
      transition: var(--transition);
    }

    .chips {
      display: flex;
      flex-wrap: wrap;
      gap: 0.6rem;
      margin-top: 0.75rem;
    }

    .chip {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      padding: 0.55rem 0.75rem;
      border: 1px solid var(--color-border);
      border-radius: 999px;
      background: var(--color-bg-alt);
      cursor: pointer;
      user-select: none;
      transition: var(--transition);
      font-size: 0.9rem;
      color: var(--color-text);
    }

    .chip input {
      width: 16px;
      height: 16px;
      accent-color: var(--color-accent);
    }

    .chip:hover {
      border-color: var(--color-accent);
      transform: translateY(-1px);
    }

    .chip input:checked + span {
      font-weight: 600;
    }

    .generator-actions {
      display: flex;
      gap: 0.75rem;
      margin-top: 1rem;
    }

    .generator-actions .btn {
      width: auto;
    }

        /* Hero Demo */
    .hero-content {
      grid-template-columns: 1fr;
      justify-items: center;
    }

    @media (min-width: 900px) {
      .hero-content {
        grid-template-columns: 1.05fr 0.95fr;
        align-items: center;
        justify-items: stretch;
      }
      .hero-text {
        max-width: 62ch;
      }
    }

    .hero-microcopy {
      margin-top: 1rem;
      font-size: 0.9rem;
      color: var(--color-text-secondary);
    }

    .hero-demo {
      width: 100%;
      max-width: 520px;
      border: 1px solid var(--color-border);
      background: rgba(255,255,255,0.72);
      backdrop-filter: blur(8px);
      border-radius: 18px;
      padding: 1.1rem;
      box-shadow: var(--shadow-ambient);
    }

    .hero-demo-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 0.75rem;
    }

    .hero-demo-title {
      font-weight: 700;
      letter-spacing: -0.01em;
    }

    .hero-demo-badge {
      font-size: 0.82rem;
      color: var(--color-text-secondary);
      border: 1px solid var(--color-border);
      padding: 0.25rem 0.55rem;
      border-radius: 999px;
      background: var(--color-bg);
    }

    .hero-demo-textarea {
      min-height: 128px;
      resize: vertical;
    }

    .hero-demo-row {
      display: grid;
      grid-template-columns: 1fr;
      gap: 0.9rem;
      margin-top: 0.9rem;
    }

    @media (min-width: 700px) {
      .hero-demo-row {
        grid-template-columns: 1fr 1fr;
      }
    }

    .chips-compact {
      gap: 0.5rem;
      margin-top: 0.35rem;
    }
    .chips-compact .chip {
      padding: 0.55rem 0.65rem;
      font-size: 0.9rem;
    }

    .hero-demo-btn {
      width: 100%;
      margin-top: 0.95rem;
      justify-content: center;
    }

    .hero-demo-hint {
      margin-top: 0.65rem;
      font-size: 0.82rem;
      color: var(--color-text-secondary);
    }

    /* How it works */
    .how-steps {
      list-style: none;
      padding: 0;
      margin: var(--spacing-md) 0 0 0;
      display: grid;
      gap: 0.9rem;
    }

    .how-step {
      display: grid;
      grid-template-columns: 44px 1fr;
      gap: 0.9rem;
      padding: 0.95rem;
      border: 1px solid var(--color-border);
      border-radius: 16px;
      background: var(--color-bg);
      box-shadow: var(--shadow-ambient);
    }

    .how-step-num {
      width: 44px;
      height: 44px;
      border-radius: 14px;
      display: grid;
      place-items: center;
      font-weight: 700;
      background: var(--color-bg-alt);
      border: 1px solid var(--color-border);
    }

    .how-step-title {
      font-weight: 700;
      margin-bottom: 0.25rem;
    }

    .how-step-text {
      color: var(--color-text-secondary);
      font-size: 0.95rem;
      line-height: 1.5;
    }

    .industry-wrap {
      margin-top: var(--spacing-md);
      padding-top: var(--spacing-sm);
      border-top: 1px solid var(--color-border);
    }

    .industry-title {
      font-weight: 700;
      margin-bottom: 0.7rem;
    }

    .industry-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 0.55rem;
    }

    .tag {
      display: inline-flex;
      align-items: center;
      padding: 0.4rem 0.7rem;
      border: 1px solid var(--color-border);
      border-radius: 999px;
      background: var(--color-bg);
      color: var(--color-text-secondary);
      font-size: 0.9rem;
      white-space: nowrap;
    }

    .industry-note {
      margin-top: 0.8rem;
      color: var(--color-text-secondary);
      font-size: 0.95rem;
      line-height: 1.6;
      max-width: 60ch;
    }

    .trust-panel {
      width: 100%;
      display: flex;
      /* Align panel to the left edge of the right column (closer to steps) */
      justify-content: flex-start;
    }

    .panel-card {
      width: 100%;
      max-width: 520px;
      border: 1px solid var(--color-border);
      border-radius: 18px;
      background: var(--color-bg);
      padding: 1.25rem;
      box-shadow: var(--shadow-ambient);
    }

    .panel-title {
      font-weight: 800;
      letter-spacing: -0.01em;
      margin-bottom: 0.8rem;
    }

    .panel-list {
      margin: 0;
      padding-left: 1.1rem;
      color: var(--color-text-secondary);
      line-height: 1.65;
    }

    .panel-cta {
      margin-top: 1rem;
      display: inline-flex;
    }

    /* Definition */
    .definition {
      padding-block: var(--spacing-md);
    }

    .definition-grid {
      display: grid;
      grid-template-columns: 1fr;
      gap: var(--spacing-md);
      align-items: start;
    }

    @media (min-width: 900px) {
      .definition-grid {
        grid-template-columns: 1.05fr 0.95fr;
      }
    }

    .definition-lead {
      margin-top: 0.9rem;
      color: var(--color-text-secondary);
      font-size: 1.05rem;
      line-height: 1.7;
      max-width: 70ch;
    
      margin-inline: auto;
      text-align: center;
    }

    .definition-qa {
      margin-top: var(--spacing-sm);
      display: grid;
      gap: 0.85rem;
    }

    .definition-qa-item {
      padding: 0.95rem;
      border: 1px solid var(--color-border);
      border-radius: 16px;
      background: var(--color-bg);
      box-shadow: var(--shadow-ambient);
    }

    .definition-q {
      font-weight: 750;
      margin-bottom: 0.35rem;
    }

    .definition-a {
      color: var(--color-text-secondary);
      line-height: 1.65;
    }

    .definition-card {
      border: 1px solid var(--color-border);
      border-radius: 18px;
      padding: 1.25rem;
      background: var(--color-bg-alt);
      box-shadow: var(--shadow-ambient);
    }

    .definition-card-title {
      font-weight: 800;
      letter-spacing: -0.01em;
      margin-bottom: 0.8rem;
    }

    .definition-list {
      margin: 0;
      padding-left: 1.1rem;
      color: var(--color-text-secondary);
      line-height: 1.7;
    }

    .definition-card .btn {
      margin-top: 1rem;
    }

@media (max-width: 900px) {
      .generator-grid {
        grid-template-columns: 1fr;
      }
      .generator-actions {
        flex-direction: column;
      }
    }
    /* Benefits Section */
    .benefits {
      background: var(--color-bg-alt);
    }

    .benefits-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: var(--spacing-md);
    }

    .benefit-card {
      background: var(--color-bg);
      border-radius: var(--radius);
      padding: 2rem;
      box-shadow: var(--shadow-ambient);
      transition: var(--transition);
      border: 1px solid var(--color-border);
    }

    .benefit-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 6px 16px rgba(0, 0, 0, 0.05);
    }

    .benefit-icon {
      width: 56px;
      height: 56px;
      background: rgba(93, 139, 244, 0.1);
      border-radius: 16px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 1.25rem;
    }

    .benefit-icon svg {
      width: 28px;
      height: 28px;
      color: var(--color-accent);
    }

    .benefit-title {
      font-size: 1.5rem;
      margin-bottom: 0.75rem;
    }

    /* Trust Section */
    .trust {
      position: relative;
    }

    .trust-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: var(--spacing-md);
      align-items: start;
    }

    .trust-content {
      grid-column: 1 / 2;
    }

    .trust-stats {
      display: flex;
      gap: 2rem;
      margin-top: var(--spacing-md);
    }

    .stat-item {
      text-align: center;
    }

    .stat-number {
      font-family: 'Manrope', sans-serif;
      font-size: 2.5rem;
      font-weight: 800;
      color: var(--color-accent);
      line-height: 1;
    }

    .stat-label {
      font-size: 0.95rem;
      color: var(--color-text-secondary);
    }

    .trust-logos {
      display: flex;
      flex-wrap: wrap;
      gap: 1.5rem;
      margin-top: 2rem;
      justify-content: center;
      grid-column: 2 / 3;
    }

    .logo-item {
      height: 2.5rem;
      opacity: 0.7;
      transition: var(--transition);
    }

    .logo-item:hover {
      opacity: 1;
    }

    /* FAQ Section */
    .faq-container {
      max-width: 50rem;
      margin-inline: auto;
    }

    .faq-item {
      border-bottom: 1px solid var(--color-border);
      padding-block: 1.5rem;
    }

    .faq-question {
      display: flex;
      justify-content: space-between;
      cursor: pointer;
      font-weight: 600;
      font-size: 1.125rem;
      padding-right: 1.5rem;
    }

    .faq-question::after {
      content: '+';
      font-size: 1.5rem;
      transition: var(--transition);
    }

    .faq-item.active .faq-question::after {
      content: '−';
    }

    .faq-answer {
      max-height: 0;
      overflow: hidden;
      transition: max-height 0.3s ease, padding 0.3s ease;
      padding-inline: 0.75rem;
    }

    .faq-item.active .faq-answer {
      max-height: 500px;
      padding-block: 1rem;
    }

    /* Contact Section */
    .contact-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: var(--spacing-md);
    }

    .contact-info {
      grid-column: 1 / 2;
    }

    .contact-form {
      grid-column: 2 / 3;
    }

    .form-group {
      margin-bottom: 1.5rem;
    }

    .form-label {
      display: block;
      margin-bottom: 0.5rem;
      font-weight: 500;
    }

    .form-input,
    .form-textarea {
      width: 100%;
      padding: 0.875rem;
      border: 1px solid var(--color-border);
      border-radius: 12px;
      background: var(--color-bg);
      color: var(--color-text);
      font-family: 'Sora', sans-serif;
      font-size: 1rem;
      transition: var(--transition);
    }

    .form-input:focus,
    .form-textarea:focus {
      outline: none;
      border-color: var(--color-accent);
      box-shadow: 0 0 0 3px rgba(93, 139, 244, 0.2);
    }

    .form-textarea {
      min-height: 150px;
      resize: vertical;
    }

    .form-textarea::placeholder,
    .form-input::placeholder {
      color: var(--color-text-secondary);
    }

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

    .form-success {
      color: var(--color-success);
      font-weight: 500;
      margin-top: 1rem;
      display: none;
    }


    /* Full-width Generator (replaces contact form) */
    .generator-full {
      width: 100%;
      background: var(--color-bg-alt);
      border-top: 1px solid var(--color-border);
    }

    .generator-full-inner {
      width: 100%;
      padding: var(--spacing-lg) clamp(16px, 4vw, 48px);
    }

    .generator-full-header {
      max-width: 55ch;
      margin: 0 auto var(--spacing-md);
      text-align: center;
    }

    .generator-full-card {
      width: 100%;
      border: 1px solid var(--color-border);
      background: var(--color-bg);
      border-radius: var(--radius);
      box-shadow: var(--shadow-ambient);
      padding: 28px;
    }

    @media (max-width: 700px) {
      .generator-full-card { padding: 18px; }
    }

    /* Footer */
    footer {
      background: var(--color-bg-alt);
      padding-block: var(--spacing-md);
      text-align: center;
      font-size: 0.95rem;
      color: var(--color-text-secondary);
      border-top: 1px solid var(--color-border);
    }

    .footer-content {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 1rem;
    }

    .back-to-top {
      position: fixed;
      bottom: 2rem;
      right: 2rem;
      width: 56px;
      height: 56px;
      border-radius: 50%;
      background: var(--color-bg);
      border: 1px solid var(--color-border);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      opacity: 0;
      transform: translateY(20px);
      transition: var(--transition);
      box-shadow: var(--shadow-ambient);
      z-index: 90;
    }

    .back-to-top.show {
      opacity: 1;
      transform: translateY(0);
    }

    .back-to-top:hover {
      background: var(--color-accent);
      color: white;
    }

    /* Responsive */
    @media (max-width: 900px) {
      .hero-content,
      .benefits-grid,
      .trust-grid,
      .contact-grid {
        grid-template-columns: 1fr;
      }

      .hero-visual,
      .trust-logos {
        grid-column: 1 / -1;
      }

      .trust-logos {
        order: -1;
        margin-bottom: var(--spacing-md);
      }

      .contact-info {
        text-align: center;
      }
    }

    @media (max-width: 768px) {
      :root {
        --spacing-lg: 3.5rem;
      }

      .nav-links,
      .nav-cta,
      .mode-switcher {
        display: none;
      }

      .mobile-menu-btn {
        display: block;
      }

      .hero-cta-group {
        flex-direction: column;
      }

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

      .trust-stats {
        flex-direction: column;
        gap: 1.5rem;
      }

      .faq-container {
        padding-inline: 1rem;
      }
    }

    @media (prefers-reduced-motion) {
      * {
        animation: none !important;
        transition: none !important;
      }
    }


/* =========================
   Cookie banner (RODO/GDPR)
   Small, calm, no dark patterns
   ========================= */

.cookie-banner[hidden],
.cookie-modal[hidden] { display: none !important; }

.cookie-banner {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 9999;
}

.cookie-banner__inner {
  max-width: 1100px;
  margin: 0 auto;
  background: rgba(12, 18, 28, 0.92);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 16px;
  padding: 14px 14px;
  backdrop-filter: blur(10px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.35);
  display: flex;
  gap: 14px;
  align-items: center;
  justify-content: space-between;
}

.cookie-banner__text { flex: 1; min-width: 240px; }
.cookie-banner__title {
  margin: 0 0 6px 0;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.2px;
  color: rgba(255,255,255,0.92);
}

.cookie-banner__desc {
  margin: 0 0 8px 0;
  font-size: 13px;
  line-height: 1.35;
  color: rgba(255,255,255,0.78);
}

.cookie-banner__meta {
  margin: 0;
  font-size: 12px;
  color: rgba(255,255,255,0.62);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.cookie-banner__link {
  color: rgba(255,255,255,0.80);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.cookie-banner__link:hover { color: rgba(255,255,255,0.95); }
.cookie-banner__sep { opacity: 0.5; }

.cookie-banner__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
}

.cookie-btn { padding: 10px 14px; font-size: 13px; }

/* Make reject / accept equally visible */
.cookie-banner .btn.btn-secondary.cookie-btn,
.cookie-banner .btn.btn-primary.cookie-btn {
  min-width: 112px;
}

.cookie-settings-link {
  appearance: none;
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  color: inherit;
  text-decoration: underline;
  cursor: pointer;
  text-underline-offset: 3px;
  font: inherit;
}
.cookie-settings-link:hover { opacity: 0.85; }

/* Modal */
.cookie-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: grid;
  place-items: center;
}

.cookie-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
}

.cookie-modal__panel {
  position: relative;
  width: min(620px, calc(100% - 24px));
  background: rgba(12, 18, 28, 0.95);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.45);
  backdrop-filter: blur(12px);
}

.cookie-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.cookie-modal__header h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 800;
  color: rgba(255,255,255,0.92);
}

.cookie-modal__close {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.85);
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
}
.cookie-modal__close:hover { background: rgba(255,255,255,0.10); }

.cookie-modal__lead {
  margin: 0 0 12px 0;
  color: rgba(255,255,255,0.75);
  font-size: 13px;
  line-height: 1.4;
}

.cookie-modal__groups { display: grid; gap: 10px; }
.cookie-group {
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 14px;
  padding: 12px;
  background: rgba(255,255,255,0.03);
}

.cookie-group__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.cookie-group__name {
  margin: 0 0 4px 0;
  font-weight: 700;
  color: rgba(255,255,255,0.90);
  font-size: 14px;
}
.cookie-group__desc {
  margin: 0;
  color: rgba(255,255,255,0.72);
  font-size: 12.5px;
  line-height: 1.35;
}

/* Switch */
.cookie-switch { position: relative; display: inline-flex; align-items: center; }
.cookie-switch input { position: absolute; opacity: 0; pointer-events: none; }
.cookie-switch__ui {
  width: 46px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.06);
  position: relative;
  transition: all 160ms ease;
}
.cookie-switch__ui::after {
  content: '';
  position: absolute;
  width: 22px;
  height: 22px;
  top: 50%;
  left: 3px;
  transform: translateY(-50%);
  border-radius: 999px;
  background: rgba(255,255,255,0.85);
  transition: all 160ms ease;
}

.cookie-switch input:checked + .cookie-switch__ui {
  background: rgba(180, 150, 90, 0.28);
  border-color: rgba(180, 150, 90, 0.55);
}
.cookie-switch input:checked + .cookie-switch__ui::after { left: 21px; }

.cookie-switch input:disabled + .cookie-switch__ui {
  opacity: 0.65;
  cursor: not-allowed;
}

.cookie-modal__footer {
  margin-top: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.cookie-modal__buttons { display: flex; gap: 10px; flex-wrap: wrap; }

@media (max-width: 640px) {
  .cookie-banner__inner { flex-direction: column; align-items: stretch; }
  .cookie-banner__actions { justify-content: flex-start; }
  .cookie-banner .btn { width: 100%; }
  .cookie-modal__footer { flex-direction: column; align-items: stretch; }
  .cookie-modal__buttons .btn { width: 100%; }
}

html.modal-open, body.modal-open { overflow: hidden; }
