/* ════════════════════════════════════════════════════════════════════════════
 *
 *   SZYBSZA NIŻ KALKULATOR — Platforma arytmetyki mentalnej
 *   Copyright © 2026 ITMEK · Diana Kwit. Wszystkie prawa zastrzeżone.
 *
 *   https://szybszanizkalkulator.pl   ·   biuro@szybszanizkalkulator.pl
 *   NIP 7591698727 · REGON 146948190
 *
 *   Projekt graficzny, układ, kolorystyka i kod stylów (CSS) tej strony
 *   są chronione prawem autorskim. Kopiowanie, modyfikacja oraz
 *   wykorzystanie na innej stronie bez pisemnej zgody właściciela
 *   są zabronione.
 *
 *   Naruszenia praw autorskich będą ścigane na drodze prawnej zgodnie
 *   z polską ustawą o prawie autorskim (Dz.U. 1994 nr 24 poz. 83).
 *
 *   Kontakt licencyjny: biuro@szybszanizkalkulator.pl
 *
 * ════════════════════════════════════════════════════════════════════════════
 */

/* ─────────────────────────────────────────────────────────
     DESIGN TOKENS
     ───────────────────────────────────────────────────────── */
  :root {
    --bg:               #fbf9fa;
    --bg-dim:           #f2efee;
    --surface:          #ffffff;
    --surface-2:        #f5f3f2;
    --ink:              #041627;
    --ink-soft:         #44474c;
    --ink-faint:        #74777d;
    --line:             #d8d4cf;
    --line-soft:        #e9e5e0;

    /* Brass / gold frame system */
    --gold-1:           #d9b985;
    --gold-2:           #b8956a;
    --gold-3:           #8a6a3e;
    --gold-glow:        rgba(184, 149, 106, 0.22);

    /* Retro analog signal */
    --blue:             #2f5fb0;
    --blue-deep:        #1a3f7d;
    --blue-glow:        rgba(47, 95, 176, 0.18);

    --amber:            #f5c382;
    --amber-soft:       #fde0bd;

    --success:          #0f8a5f;
    --success-soft:     #d9f1e6;
    --error:            #b32424;
    --error-soft:       #f8dad6;

    --shadow-soft:      0 1px 2px rgba(4, 22, 39, 0.04), 0 8px 28px rgba(4, 22, 39, 0.05);
    --shadow-card:      0 1px 2px rgba(4, 22, 39, 0.05), 0 12px 36px rgba(4, 22, 39, 0.06);
    --shadow-press:     inset 0 1px 2px rgba(0,0,0,0.08);

    --r-sm: 4px;
    --r-md: 8px;
    --r-lg: 14px;
    --r-xl: 22px;

    --font-display: "Bricolage Grotesque", ui-sans-serif, sans-serif;
    --font-body:    "Manrope", ui-sans-serif, system-ui, sans-serif;
    --font-mono:    "JetBrains Mono", ui-monospace, monospace;
  }

  * { box-sizing: border-box; }
  html, body {
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--ink);
    font-family: var(--font-body);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
  }

  /* Subtle paper-grain background texture */
  body::before {
    content: "";
    position: fixed; inset: 0;
    pointer-events: none;
    z-index: 0;
    background-image:
      radial-gradient(circle at 12% 18%, rgba(184, 149, 106, 0.06), transparent 50%),
      radial-gradient(circle at 88% 82%, rgba(47, 95, 176, 0.05), transparent 55%);
  }

  /* ─────────────────────────────────────────────────────────
     LAYOUT
     ───────────────────────────────────────────────────────── */
  .app {
    position: relative;
    z-index: 1;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
  }

  header.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 22px max(40px, calc((100% - 1180px) / 2 + 40px));
    border-bottom: 1px solid var(--line-soft);
    background: rgba(251, 249, 250, 0.85);
    backdrop-filter: blur(6px);
  }

  .brand {
    display: flex;
    align-items: center;
  }

  .brand-logo {
    height: 50px;
    width: auto;
    display: block;
    /* Make the white background of the PNG blend with the page */
    mix-blend-mode: multiply;
    user-select: none;
    -webkit-user-drag: none;
    cursor: pointer;
    transition: opacity 180ms ease, transform 180ms ease;
  }
  .brand-logo:hover {
    opacity: 0.78;
    transform: translateY(-1px);
  }
  .brand-logo:active {
    transform: translateY(0);
    opacity: 0.6;
  }
  @media (max-width: 600px) {
    .brand-logo { height: 36px; }
  }

  .topbar-right {
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-faint);
  }

  .topbar-nav {
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .topbar-nav .nav-link {
    font-family: var(--font-body);
    font-weight: 600;
    font-size: 14px;
    color: var(--ink-soft);
    text-decoration: none;
    padding: 8px 14px;
    border-radius: 8px;
    transition: color 180ms ease, background 180ms ease;
    white-space: nowrap;
  }
  .topbar-nav .nav-link:hover {
    color: var(--ink);
    background: var(--surface-2);
  }
  .topbar-nav .nav-link:focus-visible {
    outline: 2px solid var(--gold-2);
    outline-offset: 2px;
  }
  .topbar-nav .nav-cta {
    background: #ffddb5;
    color: var(--ink);
    border: 1px solid #e7c08b;
    padding: 8px 18px;
    margin-left: 6px;
    box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset;
  }
  .topbar-nav .nav-cta:hover {
    background: #f5cb9a;
    color: var(--ink);
  }
  /* Hamburger button — hidden on desktop, shown on mobile */
  .topbar-burger {
    display: none;
    background: transparent;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    width: 44px;
    height: 40px;
    padding: 0;
    cursor: pointer;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    transition: background 180ms, border-color 180ms;
  }
  .topbar-burger:hover { background: var(--surface-2); border-color: var(--gold-2); }
  .topbar-burger .burger-line {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--ink);
    border-radius: 2px;
    transition: transform 220ms ease, opacity 180ms ease;
  }
  /* When the menu is open, the icon morphs into an X */
  .topbar-burger.is-open .burger-line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .topbar-burger.is-open .burger-line:nth-child(2) { opacity: 0; }
  .topbar-burger.is-open .burger-line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  /* Mobile menu drawer (off-canvas right) */
  .mobile-menu {
    position: fixed;
    inset: 0;
    z-index: 110;
    display: none;
    pointer-events: none;
  }
  .mobile-menu.show {
    display: block;
    pointer-events: auto;
  }
  .mobile-menu-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(4, 22, 39, 0.4);
    opacity: 0;
    transition: opacity 220ms ease;
  }
  .mobile-menu.show .mobile-menu-backdrop { opacity: 1; }
  .mobile-menu-panel {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(320px, 88vw);
    background: linear-gradient(180deg, #fffdf7 0%, #fbf6ec 100%);
    border-left: 1px solid var(--gold-1);
    box-shadow: -20px 0 50px rgba(4, 22, 39, 0.2);
    padding: 72px 28px 32px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    transform: translateX(100%);
    transition: transform 280ms cubic-bezier(0.25, 0.85, 0.45, 1);
  }
  .mobile-menu.show .mobile-menu-panel { transform: translateX(0); }

  .mobile-menu-close {
    position: absolute;
    top: 18px; right: 18px;
    background: transparent;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    width: 40px; height: 40px;
    font-size: 18px;
    color: var(--ink);
    cursor: pointer;
    transition: background 180ms, border-color 180ms;
  }
  .mobile-menu-close:hover { background: var(--surface-2); border-color: var(--gold-2); }

  .mobile-menu-eyebrow {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold-3);
    margin-bottom: 14px;
    padding-left: 4px;
  }
  .mobile-menu-link {
    display: block;
    font-family: var(--font-body);
    font-weight: 600;
    font-size: 17px;
    color: var(--ink);
    text-decoration: none;
    padding: 14px 12px;
    border-radius: 10px;
    border-bottom: 1px solid var(--line-soft);
    transition: background 160ms, color 160ms, padding-left 200ms;
  }
  .mobile-menu-link:hover,
  .mobile-menu-link:focus-visible {
    background: var(--surface-2);
    color: var(--gold-3);
    padding-left: 18px;
    outline: none;
  }
  .mobile-menu-link:last-of-type { border-bottom: 0; }

  .mobile-menu-cta {
    margin-top: 12px;
    background: #ffddb5;
    border: 1px solid var(--gold-2);
    text-align: center;
    padding: 14px 16px;
    border-radius: 12px;
    border-bottom: 1px solid var(--gold-2) !important;
    box-shadow: 0 4px 12px rgba(184, 149, 106, 0.18);
  }
  .mobile-menu-cta:hover {
    background: #f5cb9a;
    color: var(--ink);
    padding-left: 16px;
  }
  .mobile-menu-cta .arrow { margin-left: 6px; }

  .mobile-menu-footer {
    margin-top: auto;
    padding-top: 18px;
    border-top: 1px solid var(--line-soft);
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .mobile-menu-sub {
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--ink-soft);
    text-decoration: none;
    padding: 4px 4px;
    transition: color 160ms;
  }
  .mobile-menu-sub:hover { color: var(--gold-3); }

  /* Mobile/tablet: collapse the inline nav and show the hamburger */
  @media (max-width: 720px) {
    .topbar-nav { display: none; }
    .topbar-burger { display: flex; }

    /* On mobile, the per-session summary chip is more useful AT THE VERY BOTTOM
       (below the action buttons). This keeps the focus on the grid + actions
       while still allowing users to scroll down for the score. */
    #screen-play-mul.active,
    #screen-play-div.active,
    #screen-play-col.active {
      display: flex;
      flex-direction: column;
    }
    #screen-play-mul .screen-head,
    #screen-play-div .screen-head,
    #screen-play-col .screen-head { order: 1; }
    #screen-play-mul .mul-grid,
    #screen-play-div .mul-grid,
    #screen-play-col .col-grid    { order: 2; }
    #screen-play-mul .actions,
    #screen-play-div .actions,
    #screen-play-col .actions     { order: 3; margin-top: 16px; }
    #screen-play-mul .mul-summary,
    #screen-play-div .mul-summary,
    #screen-play-col .mul-summary {
      order: 4;
      margin-top: 22px;
      margin-bottom: 8px;
      /* Tidy 2x2 grid layout — easier to read than a 4-up flex row that wraps */
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px 16px;
      padding: 16px 18px;
      background: linear-gradient(180deg, #fffdf7 0%, #fbf6ec 100%);
      border: 1px solid var(--gold-1);
      border-radius: var(--r-md);
      box-shadow: 0 6px 20px rgba(184, 149, 106, 0.12);
    }
    #screen-play-mul .mul-summary > div,
    #screen-play-div .mul-summary > div,
    #screen-play-col .mul-summary > div {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: 8px;
      padding: 6px 4px;
      border-bottom: 1px dashed var(--line-soft);
    }
    #screen-play-mul .mul-summary > div:nth-last-child(-n+2),
    #screen-play-div .mul-summary > div:nth-last-child(-n+2),
    #screen-play-col .mul-summary > div:nth-last-child(-n+2) {
      border-bottom: 0;
    }
    #screen-play-mul .mul-summary b,
    #screen-play-div .mul-summary b,
    #screen-play-col .mul-summary b {
      font-size: 20px;
      margin-left: 0;
    }
  }

  /* When the drawer is open, lock the page scroll so users can scroll the menu */
  body.menu-open { overflow: hidden; }

  /* Lightweight modal for "O projekcie" / "Osiągnięcia" placeholders */
  .nav-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(4, 22, 39, 0.45);
    backdrop-filter: blur(2px);
    z-index: 100;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    animation: navFade 200ms ease-out;
  }
  .nav-modal-backdrop.show { display: flex; }
  @keyframes navFade {
    from { opacity: 0; } to { opacity: 1; }
  }
  .nav-modal {
    max-width: 560px;
    width: 100%;
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: var(--r-md);
    box-shadow: 0 24px 60px rgba(4, 22, 39, 0.25);
    overflow: hidden;
    animation: navPop 220ms ease-out;
  }
  @keyframes navPop {
    from { opacity: 0; transform: translateY(8px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
  }
  .nav-modal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 24px;
    border-bottom: 1px solid var(--line-soft);
    background: linear-gradient(180deg, #fffdf7 0%, #fbf8f1 100%);
  }
  .nav-modal-title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 22px;
    letter-spacing: -0.01em;
    color: var(--ink);
    margin: 0;
  }
  .nav-modal-close {
    background: transparent;
    border: 0;
    font-size: 24px;
    line-height: 1;
    color: var(--ink-soft);
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 6px;
    transition: background 150ms;
  }
  .nav-modal-close:hover {
    background: var(--surface-2);
    color: var(--ink);
  }
  .nav-modal-body {
    padding: 24px;
    font-size: 15px;
    line-height: 1.6;
    color: var(--ink-soft);
  }
  .nav-modal-body p {
    margin: 0 0 12px;
  }
  .nav-modal-body p:last-child { margin: 0; }
  .nav-modal-body a {
    color: var(--gold-3);
    border-bottom: 1px dotted var(--gold-2);
    text-decoration: none;
  }

  /* ─────────────────────────────────────────────────────────
     LEGAL / LONG-FORM MODAL  (Regulamin, Polityka)
     Reuses .nav-modal-* but adds size + scroll for long content
     ───────────────────────────────────────────────────────── */
  .nav-modal.large {
    max-width: 820px;
  }
  .nav-modal.large .nav-modal-body {
    max-height: 70vh;
    overflow-y: auto;
    padding: 28px 32px;
  }
  /* Custom scrollbar in a way that won't break Firefox */
  .nav-modal.large .nav-modal-body::-webkit-scrollbar { width: 8px; }
  .nav-modal.large .nav-modal-body::-webkit-scrollbar-track { background: transparent; }
  .nav-modal.large .nav-modal-body::-webkit-scrollbar-thumb {
    background: var(--gold-1);
    border-radius: 4px;
  }
  .nav-modal-body h1 {
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 700;
    color: var(--ink);
    margin: 0 0 18px;
    letter-spacing: -0.01em;
  }
  .nav-modal-body h2 {
    font-family: var(--font-display);
    font-size: 17px;
    font-weight: 700;
    color: var(--ink);
    margin: 24px 0 10px;
    padding-top: 16px;
    border-top: 1px solid var(--line-soft);
    letter-spacing: -0.01em;
  }
  .nav-modal-body h2:first-of-type { border-top: 0; padding-top: 0; }
  .nav-modal-body h3 {
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 700;
    color: var(--ink);
    margin: 16px 0 8px;
    letter-spacing: 0;
  }
  .nav-modal-body ul {
    margin: 0 0 12px;
    padding-left: 22px;
  }
  .nav-modal-body li {
    margin-bottom: 6px;
  }
  /* Metadata block for Regulamin */
  .nav-modal-body .legal-meta {
    background: linear-gradient(180deg, #fffdf7 0%, #faf2e0 100%);
    border: 1px solid var(--gold-1);
    border-radius: var(--r-sm);
    padding: 14px 18px;
    margin: 0 0 20px;
  }
  .nav-modal-body .legal-meta p {
    margin: 4px 0;
    font-size: 13px;
  }
  .nav-modal-body .legal-meta strong {
    color: var(--ink);
  }
  /* Notice / callout block */
  .nav-modal-body .legal-notice {
    background: var(--surface-2);
    border-left: 3px solid var(--gold-2);
    padding: 12px 16px;
    margin: 14px 0;
    border-radius: 0 var(--r-sm) var(--r-sm) 0;
  }
  .nav-modal-body .legal-notice p { margin: 0; font-size: 14px; }

  /* ─────────────────────────────────────────────────────────
     HOME SCREEN  (landing / mission / for-whom / final CTA)
     ───────────────────────────────────────────────────────── */
  #screen-home {
    padding: 0;
    align-self: stretch;
    max-width: none;
    width: 100%;
  }
  #screen-home .home-hero,
  #screen-home .home-section,
  #screen-home .home-cta-section {
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 40px;
    box-sizing: border-box;
  }

  /* Hero */
  .home-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    gap: 60px;
    align-items: center;
    padding-top: 72px !important;
    padding-bottom: 84px !important;
  }
  .home-eyebrow {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold-3);
    margin-bottom: 18px;
  }
  .home-title {
    font-family: var(--font-display);
    font-size: clamp(36px, 4.5vw, 56px);
    font-weight: 700;
    line-height: 1.08;
    letter-spacing: -0.02em;
    color: var(--ink);
    margin: 0 0 24px;
  }
  .home-lead {
    font-family: var(--font-body);
    font-size: 17px;
    line-height: 1.65;
    color: var(--ink-soft);
    margin: 0 0 36px;
    max-width: 580px;
  }
  .home-hero-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
  }

  /* Decorative card next to the hero text */
  .home-hero-card {
    position: relative;
    aspect-ratio: 4 / 5;
    max-width: 380px;
    margin-left: auto;
    background: linear-gradient(160deg, #fffdf7 0%, #faecd1 65%, #f0d9a8 100%);
    border: 1.5px solid var(--gold-2);
    border-radius: var(--r-lg);
    box-shadow:
      0 24px 60px rgba(184, 149, 106, 0.18),
      0 2px 0 #fff inset,
      0 -1px 0 var(--gold-1) inset;
    overflow: hidden;
  }
  /* Photo variant — Diana's portrait fills the card, with a caption strip
     at the bottom over a translucent navy gradient. */
  .home-hero-card.photo-card {
    aspect-ratio: 2 / 3;
    max-width: 360px;
    background: var(--ink);
  }
  .home-hero-photo {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .home-hero-photo-caption {
    position: absolute;
    inset: auto 0 0 0;
    padding: 60px 22px 18px;
    color: #fff;
    background: linear-gradient(180deg, rgba(4,22,39,0) 0%, rgba(4,22,39,0.92) 80%, rgba(4,22,39,0.96) 100%);
    pointer-events: none;
  }
  .home-hero-photo-caption .caption-name {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 22px;
    letter-spacing: -0.01em;
    margin-bottom: 4px;
  }
  .home-hero-photo-caption .caption-meta {
    font-family: var(--font-mono);
    font-size: 10.5px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #ffddb5;
    line-height: 1.4;
  }
  .home-hero-card-inner {
    position: absolute;
    inset: 0;
    display: grid;
    grid-template-areas:
      "digit  op"
      "digit  small"
      "tag    tag";
    grid-template-columns: 1.4fr 1fr;
    grid-template-rows: 1fr auto auto;
    padding: 36px 32px;
    gap: 4px 12px;
    align-items: center;
  }
  .home-hero-digit {
    grid-area: digit;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: clamp(120px, 14vw, 200px);
    line-height: 1;
    color: var(--ink);
    letter-spacing: -0.04em;
    align-self: center;
  }
  .home-hero-digit.small {
    grid-area: small;
    font-size: clamp(48px, 5vw, 72px);
    color: var(--gold-3);
    text-align: left;
    align-self: start;
  }
  .home-hero-op {
    grid-area: op;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: clamp(64px, 7vw, 96px);
    color: var(--gold-3);
    line-height: 1;
    text-align: left;
    align-self: end;
  }
  .home-hero-tag {
    grid-area: tag;
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--gold-3);
    text-align: right;
    line-height: 1.5;
  }

  /* Section structure */
  .home-section {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
    border-top: 1px solid var(--line-soft);
  }
  .home-section-head {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 48px;
  }
  .home-section-title {
    font-family: var(--font-display);
    font-size: clamp(28px, 3.2vw, 40px);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--ink);
    margin: 0;
  }

  /* Mission blockquote */
  .home-quote {
    max-width: 760px;
    margin: 0 auto 56px;
    padding: 28px 36px;
    font-family: var(--font-display);
    font-size: clamp(18px, 1.8vw, 22px);
    line-height: 1.55;
    font-style: italic;
    color: var(--ink);
    border-left: 3px solid var(--gold-2);
    background: linear-gradient(90deg, #fffdf7 0%, transparent 100%);
    border-radius: 0 var(--r-md) var(--r-md) 0;
    position: relative;
  }
  .home-quote cite {
    display: block;
    margin-top: 16px;
    font-style: normal;
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--gold-3);
  }

  /* Feature cards (3-up and 4-up) */
  .home-feature-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
  }
  .home-feature-grid.four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
  }
  .home-feature {
    position: relative;
    background: var(--surface);
    border: 1px solid var(--gold-1);
    border-radius: var(--r-md);
    padding: 32px 24px;
    transition: transform 220ms ease, box-shadow 220ms ease;
  }
  .home-feature:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(184, 149, 106, 0.14);
  }
  .home-feature.compact {
    padding: 24px 20px;
  }
  .home-feature-icon {
    font-size: 32px;
    margin-bottom: 16px;
    color: var(--gold-3);
    line-height: 1;
  }
  .home-feature-icon.small { font-size: 24px; margin-bottom: 12px; }
  .home-feature h3 {
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 700;
    color: var(--ink);
    margin: 0 0 10px;
    letter-spacing: -0.01em;
  }
  .home-feature p {
    font-size: 14px;
    line-height: 1.6;
    color: var(--ink-soft);
    margin: 0;
  }

  /* Numbered steps for "Dlaczego online" */
  .home-step-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 32px;
  }
  .home-step {
    text-align: left;
  }
  .home-step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: linear-gradient(160deg, #ffddb5 0%, #f0c187 100%);
    border: 1.5px solid var(--gold-2);
    color: var(--ink);
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 26px;
    margin-bottom: 18px;
  }
  .home-step h3 {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 700;
    color: var(--ink);
    margin: 0 0 10px;
    letter-spacing: -0.01em;
  }
  .home-step p {
    font-size: 15px;
    line-height: 1.65;
    color: var(--ink-soft);
    margin: 0;
  }

  /* Final CTA block */
  .home-cta-section {
    position: relative;
    margin: 60px auto 80px !important;
    padding: 64px 56px !important;
    text-align: center;
    background: linear-gradient(180deg, #fffdf7 0%, #faecd1 100%);
    border: 1.5px solid var(--gold-2);
    border-radius: var(--r-lg);
    max-width: 920px !important;
  }
  .home-cta-title {
    font-family: var(--font-display);
    font-size: clamp(28px, 3.2vw, 40px);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--ink);
    margin: 0 0 16px;
  }
  .home-cta-lead {
    font-family: var(--font-body);
    font-size: 17px;
    color: var(--ink-soft);
    margin: 0 0 32px;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
  }

  /* ─────────────────────────────────────────────────────────
     ACHIEVEMENTS SCREEN
     ───────────────────────────────────────────────────────── */
  #screen-achievements {
    padding: 0;
    align-self: stretch;
    max-width: none;
    width: 100%;
  }
  #screen-achievements .home-hero,
  #screen-achievements .home-section,
  #screen-achievements .home-cta-section {
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 40px;
    box-sizing: border-box;
  }

  /* ── HERO (rebuilt — feels distinct from home screen) ── */
  .ach-hero {
    position: relative;
    width: 100%;
    max-width: none !important;
    padding: 96px 40px 110px !important;
    margin: 0 auto !important;
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.25fr);
    gap: 64px;
    align-items: center;
    overflow: hidden;
  }
  /* Diagonal navy band sliding across the bottom — instant visual signal
     that this isn't the same hero as on the home screen */
  .ach-hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
      radial-gradient(ellipse 700px 380px at 20% 20%, rgba(255, 221, 181, 0.55) 0%, rgba(255, 221, 181, 0) 60%),
      linear-gradient(180deg, #ffffff 0%, #fbf6ec 60%, #f4e6cb 100%);
  }
  .ach-hero-bg::after {
    content: "";
    position: absolute;
    left: -10%;
    right: -10%;
    bottom: -40px;
    height: 180px;
    /* Warm gold band — stays within the site's amber/gold palette
       instead of the previous navy block that broke the color story. */
    background: linear-gradient(100deg, #e7c08b 0%, #d9b985 50%, #c89a5a 100%);
    transform: skewY(-3deg);
    box-shadow: 0 -20px 50px rgba(184, 149, 106, 0.25);
  }
  .ach-hero > * { position: relative; z-index: 1; }

  /* Photo card — tilted slightly to look "pinned" onto the page */
  .ach-hero-photo-wrap {
    position: relative;
    max-width: 420px;
    justify-self: center;
  }
  .ach-hero-photo-card {
    position: relative;
    aspect-ratio: 2 / 3;
    background: var(--ink);
    border: 1.5px solid var(--gold-2);
    border-radius: var(--r-lg);
    overflow: hidden;
    transform: rotate(-3deg);
    box-shadow:
      0 30px 70px rgba(4, 22, 39, 0.35),
      0 2px 0 #fff inset,
      0 -1px 0 var(--gold-1) inset;
  }
  .ach-hero-photo-card .home-hero-photo {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* Floating medal-style badges */
  .ach-medal {
    position: absolute;
    width: 110px;
    height: 110px;
    border-radius: 50%;
    background: linear-gradient(160deg, #ffe5b9 0%, #e0b06c 60%, #b88245 100%);
    border: 3px solid #fff;
    box-shadow: 0 12px 28px rgba(4, 22, 39, 0.35);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: var(--ink);
    font-family: var(--font-display);
    z-index: 2;
    transform: rotate(8deg);
  }
  .ach-medal-top { top: -16px; right: -28px; }
  .ach-medal-bottom {
    bottom: -20px; left: -32px;
    transform: rotate(-10deg);
    background: linear-gradient(160deg, #f9f9f9 0%, #d0d0d0 55%, #9a9a9a 100%);
  }
  .ach-medal-rank {
    font-weight: 800;
    font-size: 32px;
    line-height: 1;
    margin-bottom: 2px;
  }
  .ach-medal-bottom .ach-medal-rank { color: #b88245; font-size: 30px; }
  .ach-medal-label {
    font-family: var(--font-mono);
    font-weight: 700;
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    line-height: 1.2;
  }

  /* Text side */
  .ach-hero-meta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--gold-3);
    margin-bottom: 22px;
  }
  .ach-hero-chip {
    background: linear-gradient(135deg, #ffddb5 0%, #e7c08b 100%);
    border: 1px solid var(--gold-2);
    color: var(--ink);
    padding: 6px 14px;
    border-radius: 100px;
    letter-spacing: 0.1em;
    font-weight: 700;
  }
  .ach-hero-dot { color: var(--gold-2); }
  .ach-hero-title {
    font-family: var(--font-display);
    font-size: clamp(34px, 4.4vw, 54px);
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.025em;
    color: var(--ink);
    margin: 0 0 24px;
  }
  .ach-hero-lead {
    font-family: var(--font-body);
    font-size: 17px;
    line-height: 1.65;
    color: var(--ink-soft);
    margin: 0 0 30px;
    max-width: 580px;
  }
  .ach-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

  @media (max-width: 920px) {
    .ach-hero {
      grid-template-columns: 1fr;
      padding: 64px 24px 90px !important;
      gap: 56px;
    }
    .ach-hero-photo-wrap { max-width: 320px; }
    .ach-medal { width: 84px; height: 84px; }
    .ach-medal-rank { font-size: 24px; }
    .ach-medal-label { font-size: 9px; }
  }

  /* Quote — slightly tighter spacing inside the highlights section */
  .home-quote.ach-quote {
    margin: 0 auto 48px;
    max-width: 820px;
  }

  /* ── GALLERY ──
     Photo-wall version: thumbnails show the whole photo, not a crop.
     Frames are limited in size but adapt to portrait / landscape proportions. */
  .ach-gallery-section {
    padding-top: 60px !important;
    padding-bottom: 80px !important;
  }

  .ach-videos-section {
    padding-top: 20px !important;
    padding-bottom: 60px !important;
  }
  .ach-videos-section .home-section-title {
    text-align: center;
    margin-bottom: 32px;
  }
  .ach-videos-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    max-width: 1120px;
    margin: 0 auto;
  }
  .ach-video-item {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .ach-video-link {
    display: block;
    text-decoration: none;
  }
  .ach-video-wrap {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%; /* 16:9 */
    border-radius: 12px;
    overflow: hidden;
    background: #000;
    box-shadow: 0 4px 18px rgba(0,0,0,0.13);
    transition: box-shadow 0.2s, transform 0.2s;
  }
  .ach-video-link:hover .ach-video-wrap {
    box-shadow: 0 8px 32px rgba(0,0,0,0.22);
    transform: translateY(-2px);
  }
  .ach-video-wrap img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border: 0;
  }
  .ach-video-play {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 52px;
    color: #fff;
    text-shadow: 0 2px 12px rgba(0,0,0,0.5);
    opacity: 0.88;
    transition: opacity 0.2s, transform 0.2s;
    pointer-events: none;
  }
  .ach-video-link:hover .ach-video-play {
    opacity: 1;
    transform: scale(1.12);
  }
  .ach-video-caption {
    text-align: center;
    font-family: var(--font-ui);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ink-soft);
    margin: 0;
  }
  @media (max-width: 880px) {
    .ach-videos-grid {
      grid-template-columns: 1fr;
      max-width: 520px;
    }
  }

  .ach-gallery {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: center;
    gap: 20px;
    max-width: 1120px;
    margin: 0 auto;
  }

  .ach-gallery-item {
    position: relative;
    margin: 0;
    overflow: visible;
    width: fit-content;
    max-width: 300px;
    padding: 10px;
    border-radius: var(--r-md);
    border: 1px solid rgba(184, 149, 106, 0.45);
    background:
      linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(255,253,247,0.96) 100%);
    box-shadow:
      0 1px 0 rgba(255,255,255,0.9) inset,
      0 10px 26px rgba(184, 149, 106, 0.10);
    cursor: pointer;
    transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
  }

  .ach-gallery-item:hover {
    transform: translateY(-3px);
    border-color: var(--gold-2);
    box-shadow: 0 16px 34px rgba(184, 149, 106, 0.22);
  }

  .ach-gallery-item img {
    position: relative;
    z-index: 1;
    display: block;
    width: auto;
    height: auto;
    max-width: min(100%, 280px);
    max-height: 270px;
    object-fit: contain;
    border-radius: calc(var(--r-md) - 3px);
    background:
      radial-gradient(circle at 30% 28%, rgba(255, 221, 181, 0.35), transparent 34%),
      linear-gradient(135deg, #fffdf7 0%, #f4ead9 100%);
    transition: transform 300ms ease, filter 300ms ease;
  }

  .ach-gallery-item:hover img {
    transform: scale(1.015);
    filter: saturate(1.03) contrast(1.02);
  }

  /* Subtle photo-paper frame. It remains visible around transparent / narrow photos. */
  .ach-gallery-item::before {
    content: "";
    position: absolute;
    inset: 6px;
    border-radius: calc(var(--r-md) - 2px);
    background:
      radial-gradient(circle at 30% 30%, rgba(184, 149, 106, 0.14) 0%, transparent 34%),
      radial-gradient(circle at 70% 60%, rgba(216, 184, 137, 0.18) 0%, transparent 38%);
    z-index: 0;
    pointer-events: none;
  }

  .ach-gallery-item img:not([src]),
  .ach-gallery-item img[src=""] {
    visibility: hidden;
  }

  .ach-gallery-item figcaption {
    position: absolute;
    left: 10px;
    right: 10px;
    bottom: 10px;
    z-index: 2;
    padding: 34px 12px 10px;
    border-radius: 0 0 calc(var(--r-md) - 3px) calc(var(--r-md) - 3px);
    background: linear-gradient(180deg, rgba(4,22,39,0) 0%, rgba(4,22,39,0.64) 62%, rgba(4,22,39,0.86) 100%);
    color: #fff;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    opacity: 0;
    transition: opacity 200ms ease;
    pointer-events: none;
  }

  .ach-gallery-item:hover figcaption,
  .ach-gallery-item:focus-visible figcaption {
    opacity: 1;
  }

  .ach-gallery-item:focus-visible {
    outline: 2px solid var(--gold-2);
    outline-offset: 4px;
  }

  /* Size accents — still controlled, but no cropping. */
  .ach-gallery-large {
    max-width: 390px;
  }
  .ach-gallery-large img {
    max-width: min(100%, 370px);
    max-height: 340px;
  }
  .ach-gallery-wide {
    max-width: 430px;
  }
  .ach-gallery-wide img {
    max-width: min(100%, 410px);
    max-height: 270px;
  }
  .ach-gallery-tall {
    max-width: 260px;
  }
  .ach-gallery-tall img {
    max-width: min(100%, 240px);
    max-height: 360px;
  }

  @media (max-width: 880px) {
    .ach-gallery {
      gap: 16px;
      justify-content: center;
    }
    .ach-gallery-item,
    .ach-gallery-large,
    .ach-gallery-wide,
    .ach-gallery-tall {
      max-width: min(100%, 340px);
    }
    .ach-gallery-item img,
    .ach-gallery-large img,
    .ach-gallery-wide img,
    .ach-gallery-tall img {
      max-width: min(100%, 320px);
      max-height: 320px;
    }
  }

  @media (max-width: 520px) {
    .ach-gallery {
      display: grid;
      grid-template-columns: 1fr;
      gap: 18px;
      justify-items: center;
    }
    .ach-gallery-item,
    .ach-gallery-large,
    .ach-gallery-wide,
    .ach-gallery-tall {
      width: 100%;
      max-width: 360px;
    }
    .ach-gallery-item img,
    .ach-gallery-large img,
    .ach-gallery-wide img,
    .ach-gallery-tall img {
      max-width: 100%;
      max-height: 360px;
      margin-left: auto;
      margin-right: auto;
    }
  }

  /* ── LIGHTBOX ── */
  .lightbox {
    position: fixed;
    inset: 0;
    z-index: 200;
    background: rgba(4, 22, 39, 0.92);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 48px;
    animation: navFade 220ms ease-out;
  }
  .lightbox.show { display: flex; }
  .lightbox-frame {
    position: relative;
    max-width: min(1100px, 96vw);
    max-height: 86vh;
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .lightbox-image {
    display: block;
    max-width: 100%;
    max-height: 80vh;
    border-radius: 6px;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.55);
    background: #222;
    object-fit: contain;
  }
  .lightbox-caption {
    margin-top: 14px;
    color: #ffddb5;
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    text-align: center;
  }
  .lightbox-close {
    position: absolute;
    top: 20px; right: 24px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.25);
    color: #fff;
    width: 44px; height: 44px;
    border-radius: 50%;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    transition: background 180ms, transform 180ms;
  }
  .lightbox-close:hover { background: rgba(255, 255, 255, 0.18); transform: scale(1.05); }
  .lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.22);
    color: #fff;
    width: 52px; height: 52px;
    border-radius: 50%;
    font-size: 32px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 180ms, transform 180ms;
  }
  .lightbox-nav:hover { background: rgba(255, 255, 255, 0.18); }
  .lightbox-prev { left: 24px; }
  .lightbox-next { right: 24px; }
  @media (max-width: 600px) {
    .lightbox { padding: 16px; }
    /* Obraz nie zachodzi na przyciski nawigacji u dołu */
    .lightbox-image { max-height: 74vh; }
    /* Przyciski nawigacji: przenosimy je na dół ekranu gdzie są zawsze widoczne
       i nigdy nie są zakryte przez zdjęcie (które zajmuje prawie całą szerokość) */
    .lightbox-nav {
      top: auto;
      bottom: 28px;
      transform: none;
      width: 56px; height: 56px;
      font-size: 30px;
      background: rgba(255, 221, 181, 0.95);
      border: 2px solid rgba(255, 255, 255, 0.8);
      color: var(--ink);
      box-shadow: 0 4px 16px rgba(0, 0, 0, 0.45);
    }
    .lightbox-nav:hover { background: #ffddb5; }
    .lightbox-prev { left: 28px; }
    .lightbox-next { right: 28px; }
    .lightbox-close {
      top: 12px; right: 12px; width: 40px; height: 40px; font-size: 18px;
      background: rgba(255, 221, 181, 0.85);
      border: 2px solid #fff;
      color: var(--ink);
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    }
    .lightbox-close:hover { background: #ffddb5; }
  }

  /* Split layout for "To nie stało się przypadkiem" — text left, timeline right */
  .ach-split {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
    gap: 56px;
    align-items: start;
  }
  .ach-split-text .contact-section-text {
    margin-top: 16px;
    margin-left: 0;
    margin-right: 0;
    text-align: left;
  }
  .ach-split-text .home-section-title {
    text-align: left;
    margin-top: 16px;
  }
  .ach-timeline {
    display: flex;
    flex-direction: column;
    gap: 18px;
  }
  .ach-timeline-card {
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 20px;
    background: var(--surface);
    border: 1px solid var(--gold-1);
    border-radius: var(--r-md);
    padding: 22px 26px;
    transition: transform 220ms ease, box-shadow 220ms ease;
  }
  .ach-timeline-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(184, 149, 106, 0.14);
  }
  .ach-timeline-number {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 56px;
    line-height: 1;
    color: var(--gold-2);
    letter-spacing: -0.04em;
    min-width: 60px;
    text-align: center;
  }
  .ach-timeline-body h3 {
    font-family: var(--font-display);
    font-size: 19px;
    font-weight: 700;
    color: var(--ink);
    margin: 0 0 6px;
    letter-spacing: -0.01em;
  }
  .ach-timeline-body p {
    font-size: 14.5px;
    line-height: 1.6;
    color: var(--ink-soft);
    margin: 0;
  }

  /* Section background — slightly tinted to mark "the journey" visually */
  .ach-timeline-section {
    background: linear-gradient(180deg, #fbf8f1 0%, #f6ecd9 100%);
    border-top: 1px solid var(--gold-1);
    border-bottom: 1px solid var(--gold-1);
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }

  @media (max-width: 900px) {
    .ach-split { grid-template-columns: 1fr; gap: 32px; }
    .ach-timeline-number { font-size: 44px; min-width: 50px; }
    #screen-achievements .home-hero,
    #screen-achievements .home-section,
    #screen-achievements .home-cta-section {
      padding-left: 20px;
      padding-right: 20px;
    }
  }

  /* ─────────────────────────────────────────────────────────
     CONTACT SCREEN
     ───────────────────────────────────────────────────────── */
  #screen-contact {
    padding: 0;
    align-self: stretch;
    max-width: none;
    width: 100%;
  }
  #screen-contact .home-hero,
  #screen-contact .home-section,
  #screen-contact .home-cta-section {
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 40px;
    box-sizing: border-box;
  }

  /* Contact illustration card — replaces Diana's photo on screen-contact */
  .home-hero-card.contact-card-illustration {
    aspect-ratio: 4 / 5;
    max-width: 380px;
    margin-left: auto;
    background: linear-gradient(160deg, #fffdf7 0%, #faecd1 65%, #f0d9a8 100%);
    border: 1.5px solid var(--gold-2);
    border-radius: var(--r-lg);
    box-shadow:
      0 24px 60px rgba(184, 149, 106, 0.18),
      0 2px 0 #fff inset,
      0 -1px 0 var(--gold-1) inset;
    overflow: hidden;
    position: relative;
  }
  .contact-illustration {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
  }
  .contact-illustration-label {
    position: absolute;
    inset: auto 0 0 0;
    padding: 14px 22px 18px;
    background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,253,247,0.95) 70%);
    text-align: right;
  }
  .contact-illustration-label .caption-name {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 20px;
    color: var(--ink);
    letter-spacing: -0.01em;
    margin-bottom: 2px;
  }
  .contact-illustration-label .caption-meta {
    font-family: var(--font-mono);
    font-size: 10.5px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--gold-3);
  }

  .contact-section-text {
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.65;
    color: var(--ink-soft);
    margin: 16px auto 0;
    max-width: 620px;
  }

  /* 2-column card grid */
  .contact-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px;
  }

  .contact-card {
    background: var(--surface);
    border: 1px solid var(--gold-1);
    border-radius: var(--r-md);
    padding: 36px 32px;
    transition: transform 220ms ease, box-shadow 220ms ease;
  }
  .contact-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(184, 149, 106, 0.14);
  }
  .contact-card h3 {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 700;
    color: var(--ink);
    margin: 0 0 12px;
    letter-spacing: -0.01em;
  }
  .contact-card p {
    font-size: 15px;
    line-height: 1.65;
    color: var(--ink-soft);
    margin: 0 0 20px;
  }
  /* Dark variant — navy background with amber accents (matches kontakt template) */
  .contact-card-dark {
    background: linear-gradient(160deg, #061726 0%, #102437 100%);
    border-color: #1a2c40;
    color: #fff;
  }
  .contact-card-dark h3 { color: #ffddb5; }
  .contact-card-dark p  { color: rgba(255,255,255,0.75); }

  /* Email box — large clickable area */
  .contact-mail-box {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 20px;
    background: rgba(255, 221, 181, 0.08);
    border: 1px solid rgba(255, 221, 181, 0.3);
    border-radius: var(--r-sm);
    text-decoration: none;
    color: #fff;
    transition: background 180ms ease, border-color 180ms ease, transform 180ms ease;
    margin-bottom: 18px;
  }
  .contact-mail-box:hover {
    background: rgba(255, 221, 181, 0.18);
    border-color: rgba(255, 221, 181, 0.55);
    transform: translateX(2px);
  }
  .contact-mail-icon {
    flex: 0 0 auto;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #ffddb5;
    color: var(--ink);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
  }
  .contact-mail-text {
    display: flex;
    flex-direction: column;
    line-height: 1.3;
    min-width: 0;
  }
  .contact-mail-label {
    font-family: var(--font-body);
    font-weight: 700;
    font-size: 14px;
    color: #fff;
    letter-spacing: 0.01em;
  }
  .contact-mail-address {
    font-family: var(--font-mono);
    font-size: 13px;
    color: #ffddb5;
    margin-top: 2px;
    word-break: break-all;
  }

  /* Notice / important box inside the dark card */
  .contact-note {
    padding: 14px 16px;
    background: rgba(255, 221, 181, 0.06);
    border-left: 3px solid #ffddb5;
    border-radius: 0 var(--r-sm) var(--r-sm) 0;
    font-size: 13.5px;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.85);
  }
  .contact-note strong { color: #ffddb5; }

  /* Help-topics list */
  .contact-list {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .contact-list li {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 12px 0;
    border-top: 1px solid var(--line-soft);
    font-size: 15px;
    line-height: 1.55;
    color: var(--ink-soft);
  }
  .contact-list li:first-child { border-top: 0; padding-top: 4px; }
  .contact-icon {
    flex: 0 0 auto;
    font-size: 20px;
    line-height: 1;
    margin-top: 1px;
  }

  /* Quote section override */
  .contact-quote-section {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }
  .home-quote.contact-quote {
    margin: 0 auto;
  }

  /* ─────────────────────────────────────────────────────────
     CONTACT SCREEN — REBUILT (2025-05)
     Marketing-friendly two-card layout: primary email card +
     help topics card. Replaces the older dark/light contact-card
     grid above (kept only for backward compatibility).
     ───────────────────────────────────────────────────────── */

  /* Hero on the contact screen — slightly tighter, removes leftover button row */
  .contact-hero {
    padding-bottom: 24px !important;
  }
  .contact-hero-text .home-title {
    margin-bottom: 18px;
  }

  /* Main grid section — pulls content closer to hero, less heavy gap */
  .contact-main-section {
    padding-top: 8px !important;
    padding-bottom: 72px !important;
  }
  .contact-main-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 24px;
    align-items: stretch;
  }

  /* Shared card shell — light, pastel, soft shadow, gold accent border */
  .contact-primary-card,
  .contact-help-card {
    background: linear-gradient(180deg, #fffdf7 0%, #fbf6ec 100%);
    border: 1px solid var(--gold-1);
    border-radius: var(--r-lg);
    padding: 32px 32px 28px;
    box-shadow: 0 14px 36px rgba(184, 149, 106, 0.10);
    display: flex;
    flex-direction: column;
  }
  .contact-primary-card .home-eyebrow,
  .contact-help-card .home-eyebrow {
    margin-bottom: 10px;
  }
  .contact-card-title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: clamp(22px, 2.2vw, 26px);
    line-height: 1.2;
    letter-spacing: -0.015em;
    color: var(--ink);
    margin: 0 0 12px;
  }
  .contact-card-lead {
    font-family: var(--font-body);
    font-size: 14.5px;
    line-height: 1.6;
    color: var(--ink-soft);
    margin: 0 0 22px;
  }

  /* Email CTA — main clickable element on the left card */
  .contact-email-cta {
    display: flex;
    align-items: center;
    gap: 14px;
    text-decoration: none;
    color: var(--ink);
    background: linear-gradient(135deg, #ffddb5 0%, #f5cb9a 100%);
    border: 1.5px solid var(--gold-2);
    border-radius: var(--r-md);
    padding: 18px 20px;
    margin-bottom: 14px;
    box-shadow: 0 6px 18px rgba(184, 149, 106, 0.15);
    transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
  }
  .contact-email-cta:hover,
  .contact-email-cta:focus-visible {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(184, 149, 106, 0.22);
    background: linear-gradient(135deg, #ffd09a 0%, #efbd83 100%);
    outline: none;
  }
  .contact-email-icon {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--ink);
    color: #ffddb5;
    font-size: 22px;
  }
  .contact-email-text {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
  }
  .contact-email-label {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--gold-3);
  }
  .contact-email-address {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 17px;
    color: var(--ink);
    word-break: break-all;
  }
  .contact-email-arrow {
    flex: 0 0 auto;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 22px;
    color: var(--ink);
    transition: transform 180ms ease;
  }
  .contact-email-cta:hover .contact-email-arrow {
    transform: translateX(3px);
  }

  .contact-reply-note {
    font-family: var(--font-body);
    font-size: 13.5px;
    color: var(--ink-soft);
    margin: 0 0 22px;
    padding-left: 4px;
  }

  /* Safety note — soft pastel box, no scary "WAŻNE!" tone */
  .contact-safety-note {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    background: rgba(255, 221, 181, 0.35);
    border: 1px solid rgba(184, 149, 106, 0.20);
    border-radius: var(--r-sm);
    padding: 12px 14px;
    font-family: var(--font-body);
    font-size: 13px;
    line-height: 1.55;
    color: var(--ink-soft);
    margin-top: auto;
  }
  .contact-safety-icon {
    flex: 0 0 auto;
    font-size: 16px;
    line-height: 1.4;
  }

  /* Topic list — 4 stacked tiles inside the right card */
  .contact-topic-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .contact-topic-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    background: rgba(255, 253, 247, 0.65);
    border: 1px solid var(--line-soft);
    border-radius: var(--r-sm);
    padding: 14px 16px;
    transition: background 180ms ease, border-color 180ms ease, transform 180ms ease;
  }
  .contact-topic-item:hover {
    background: #fffdf7;
    border-color: var(--gold-2);
    transform: translateX(2px);
  }
  .contact-topic-icon {
    flex: 0 0 auto;
    font-size: 22px;
    line-height: 1;
    margin-top: 2px;
  }
  .contact-topic-body {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
  }
  .contact-topic-title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 15px;
    color: var(--ink);
    letter-spacing: -0.005em;
  }
  .contact-topic-desc {
    font-family: var(--font-body);
    font-size: 13.5px;
    line-height: 1.5;
    color: var(--ink-soft);
  }

  /* Responsive — stack cards, tighter padding */
  @media (max-width: 880px) {
    .contact-main-grid {
      grid-template-columns: 1fr;
      gap: 18px;
    }
    .contact-primary-card,
    .contact-help-card {
      padding: 26px 22px 22px;
    }
    .contact-email-cta {
      padding: 16px;
      gap: 12px;
    }
    .contact-email-icon {
      width: 42px;
      height: 42px;
      font-size: 20px;
    }
    .contact-email-address {
      font-size: 15.5px;
    }
  }
  @media (max-width: 520px) {
    .contact-primary-card,
    .contact-help-card {
      padding: 22px 18px 20px;
    }
    .contact-card-title {
      font-size: 20px;
    }
    .contact-email-cta {
      padding: 14px;
    }
    .contact-email-icon {
      width: 38px;
      height: 38px;
      font-size: 18px;
    }
    .contact-topic-item {
      padding: 12px 14px;
    }
  }

  @media (max-width: 880px) {
    .contact-grid { grid-template-columns: 1fr; gap: 18px; }
    #screen-contact .home-hero,
    #screen-contact .home-section,
    #screen-contact .home-cta-section {
      padding-left: 20px;
      padding-right: 20px;
    }
  }

  /* Footer layout — now with link row */
  .footer-grid {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    width: 100%;
  }
  .footer-links-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 4px 0;
    font-size: 13px;
  }
  .footer-links-row .footer-link {
    margin: 0 12px;
  }
  .footer-links-row .sep {
    color: var(--ink-faint);
    opacity: 0.5;
  }

  /* Responsive */
  @media (max-width: 920px) {
    .home-hero {
      grid-template-columns: 1fr;
      gap: 40px;
      padding-top: 48px !important;
      padding-bottom: 56px !important;
    }
    .home-hero-card { max-width: 320px; margin: 0 auto; }
    .home-feature-grid,
    .home-step-grid {
      grid-template-columns: 1fr;
      gap: 18px;
    }
    .home-feature-grid.four {
      grid-template-columns: repeat(2, 1fr);
    }
    #screen-home .home-hero,
    #screen-home .home-section,
    #screen-home .home-cta-section {
      padding-left: 20px;
      padding-right: 20px;
    }
    .home-cta-section { padding: 40px 28px !important; }
  }
  @media (max-width: 560px) {
    .home-feature-grid.four { grid-template-columns: 1fr; }
  }

  main {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 30px 32px;
  }

  footer.bottombar {
    padding: 20px 40px;
    border-top: 1px solid var(--line-soft);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--ink-faint);
    text-align: center;
  }
  footer .footer-link {
    color: var(--gold-3);
    text-decoration: none;
    border-bottom: 1px dotted var(--gold-2);
    margin-left: 6px;
    transition: color 180ms ease, border-color 180ms ease;
  }
  footer .footer-link:hover {
    color: var(--ink);
    border-bottom-color: var(--ink);
  }

  /* ─────────────────────────────────────────────────────────
     SCREEN SYSTEM
     ───────────────────────────────────────────────────────── */
  .screen { display: none; width: 100%; max-width: 1180px; }
  .screen.active { display: block; animation: fade 320ms ease-out; }
  @keyframes fade {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  .screen-head {
    text-align: center;
    margin-bottom: 48px;
  }
  .screen-title {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 44px;
    letter-spacing: -0.02em;
    line-height: 1.05;
    margin: 0 0 12px;
    color: var(--ink);
  }
  .screen-sub {
    font-size: 16px;
    color: var(--ink-soft);
    margin: 0;
  }

  /* ─────────────────────────────────────────────────────────
     CARDS (mode / action selection)
     ───────────────────────────────────────────────────────── */
  .card-grid {
    display: grid;
    gap: 20px;
    margin: 0 auto;
  }
  .card-grid.two   { grid-template-columns: repeat(2, minmax(0, 1fr)); max-width: 760px; }
  .card-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); max-width: 1080px; }

  .opt-card {
    position: relative;
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: var(--r-lg);
    padding: 18px 28px;
    text-align: center;
    cursor: pointer;
    transition: transform 200ms ease, border-color 200ms ease, box-shadow 200ms ease, background 200ms ease;
    user-select: none;
  }
  .opt-card:hover {
    transform: translateY(-2px);
    border-color: var(--gold-2);
    box-shadow: var(--shadow-soft);
  }
  .opt-card.selected {
    border-color: var(--gold-2);
    box-shadow: 0 0 0 2px var(--gold-glow), var(--shadow-card);
    background: linear-gradient(180deg, #fffdf9 0%, #ffffff 100%);
  }
  .opt-card.selected::after {
    content: "";
    position: absolute; inset: 0;
    border-radius: var(--r-lg);
    border: 1px solid var(--gold-2);
    pointer-events: none;
  }

  .opt-icon {
    width: 50px; height: 50px;
    margin: 0 auto 18px;
    border-radius: 12px;
    background: var(--surface-2);
    display: grid; place-items: center;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 28px;
    color: var(--ink);
    border: 1px solid var(--line-soft);
  }
  .opt-card.selected .opt-icon {
    background: var(--ink);
    color: var(--gold-1);
    border-color: var(--ink);
  }
  .opt-title {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 20px;
    letter-spacing: 0.04em;
    margin: 4px 0 8px;
  }
  .opt-desc {
    font-size: 14px;
    color: var(--ink-soft);
    line-height: 1.5;
  }
  .opt-card.disabled {
    opacity: 0.5;
    cursor: not-allowed;
  }
  .opt-card.disabled:hover {
    transform: none;
    border-color: var(--line-soft);
    box-shadow: none;
  }
  .opt-badge {
    position: absolute;
    top: 12px; right: 12px;
    font-family: var(--font-mono);
    font-size: 9px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--ink-faint);
    background: var(--surface-2);
    padding: 4px 8px;
    border-radius: 100px;
    border: 1px solid var(--line-soft);
  }

  /* ─────────────────────────────────────────────────────────
     BUTTONS
     ───────────────────────────────────────────────────────── */
  .actions {
    display: flex;
    gap: 16px;
    justify-content: center;
    margin-top: 48px;
    flex-wrap: wrap;
  }
  .btn {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 16px 32px;
    border-radius: var(--r-md);
    border: 1px solid transparent;
    cursor: pointer;
    transition: transform 150ms ease, background 200ms ease, border-color 200ms ease, color 200ms ease;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-width: 180px;
    justify-content: center;
  }
  .btn:active { transform: translateY(1px); }

  .btn-primary {
    background: #ffddb5;
    color: var(--ink);
    border-color: #ffddb5;
    box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 6px 14px rgba(184, 149, 106, 0.22);
  }
  .btn-primary:hover {
    background: #f5cb9a;
    color: var(--ink);
  }

  .btn-secondary {
    background: var(--surface);
    color: var(--ink);
    border-color: var(--line);
  }
  .btn-secondary:hover {
    background: var(--surface-2);
    border-color: var(--ink-faint);
  }

  .btn-ink {
    background: var(--ink);
    color: var(--gold-1);
    border-color: var(--ink);
  }
  .btn-ink:hover { background: #11253d; }

  .btn .arrow { font-family: var(--font-body); font-weight: 600; font-size: 16px; }
  .btn:disabled,
  .btn.btn-disabled {
    opacity: 0.45;
    cursor: not-allowed;
    box-shadow: none;
    filter: saturate(0.7);
  }
  .btn:disabled:hover,
  .btn.btn-disabled:hover {
    background: #ffddb5;
    color: var(--ink);
  }

  /* ─────────────────────────────────────────────────────────
     CONFIG SCREEN — VERTICAL ANALOG SLIDERS
     ───────────────────────────────────────────────────────── */
  .slider-rail {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
    max-width: 1000px;
    margin: 0 auto;
  }

  .slider-card {
    position: relative;
    background:
      linear-gradient(180deg, #fffdf7 0%, #fbf8f1 100%);
    border-radius: var(--r-lg);
    padding: 26px 22px 22px;
    /* Gold frame */
    border: 2px solid transparent;
    background-clip: padding-box;
    box-shadow:
      0 0 0 1px var(--gold-3),
      0 0 0 4px var(--bg),
      0 0 0 5px var(--gold-2),
      0 1px 0 rgba(255,255,255,0.6) inset,
      0 18px 36px rgba(138, 106, 62, 0.12);
  }

  /* Corner brass nails (decorative) */
  .slider-card::before,
  .slider-card::after,
  .slider-card .nail-tl,
  .slider-card .nail-tr {
    content: "";
    position: absolute;
    width: 8px; height: 8px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, #f3d9a8, var(--gold-3) 70%);
    box-shadow: 0 1px 1px rgba(0,0,0,0.15);
  }
  .slider-card::before { top: 8px;  left: 8px;  }
  .slider-card::after  { bottom: 8px; right: 8px; }
  .slider-card .nail-tl { top: 8px; right: 8px; }
  .slider-card .nail-tr { bottom: 8px; left: 8px; }

  .slider-label {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold-3);
    background: rgba(217, 185, 133, 0.18);
    border: 1px solid var(--gold-2);
    padding: 6px 12px;
    border-radius: 100px;
    margin-bottom: 18px;
  }

  .slider-rig {
    position: relative;
    height: 340px;
    display: flex;
    align-items: stretch;
    justify-content: center;
    padding: 7px 0;
  }

  /* Inner rail/ruler element */
  .ruler {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: stretch;
    touch-action: none;
  }

  /* Scale axis (left side) */
  .ruler-axis {
    position: relative;
    flex: 0 0 auto;
    width: 78px;
    height: 100%;
    padding-right: 8px;
  }
  .ruler-axis .tick {
    position: absolute;
    right: 0;
    height: 1px;
    background: var(--ink-soft);
    /* Center the tick on its position so the extremes don't visually
       overflow past the axis edges. */
    transform: translateY(50%);
  }
  .ruler-axis .tick.major  { width: 16px; background: var(--ink); }
  .ruler-axis .tick.medium { width: 11px; opacity: 0.7; }
  .ruler-axis .tick.minor  { width: 6px;  opacity: 0.45; }
  .ruler-axis .tick-label {
    position: absolute;
    right: 22px;
    /* Positioned via `bottom: pct%`; transform centers the label vertically
       on the corresponding tick. */
    transform: translateY(50%);
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-soft);
    font-weight: 500;
    white-space: nowrap;
  }

  /* The vertical bar (track + fill + arrow) */
  .bar {
    position: relative;
    flex: 0 0 38px;
    height: 100%;
    cursor: pointer;
  }
  .bar-track {
    position: absolute;
    left: 50%;
    top: 0; bottom: 0;
    width: 26px;
    transform: translateX(-50%);
    background: #f1ece4;
    border: 1px solid var(--gold-2);
    border-radius: 4px;
    box-shadow: inset 0 1px 2px rgba(138, 106, 62, 0.18);
    overflow: hidden;
  }
  .bar-fill {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    background:
      linear-gradient(180deg, #ffe9cb 0%, #ffddb5 55%, #f3c89a 100%);
    transition: height 90ms ease-out;
    box-shadow: inset 0 -1px 0 rgba(255,255,255,0.35);
  }
  /* Subtle horizontal lines in the fill (analog gauge look) */
  .bar-fill::after {
    content: "";
    position: absolute; inset: 0;
    background-image: repeating-linear-gradient(
      to top,
      transparent 0,
      transparent 7px,
      rgba(138, 106, 62, 0.10) 7px,
      rgba(138, 106, 62, 0.10) 8px
    );
  }

  /* Black arrow indicator — kept in DOM (JS still moves it) but visually hidden.
     The slider position is now communicated only by the blue/amber fill. */
  .bar-arrow,
  .bar-arrow::after {
    display: none;
  }

  /* Right side: numeric step labels for discrete sliders */
  .ruler-side-labels {
    flex: 0 0 auto;
    width: 76px;
    height: 100%;
    position: relative;
    padding-left: 10px;
  }
  .ruler-side-labels .side-label {
    position: absolute;
    left: 10px;
    transform: translateY(50%);
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 600;
    color: var(--ink-soft);
    white-space: nowrap;
    transition: color 200ms;
  }
  .ruler-side-labels .side-label.active {
    color: var(--ink);
  }
  .ruler-side-labels .side-label.active::before {
    content: "›";
    margin-right: 4px;
    color: var(--gold-3);
    font-weight: 600;
  }

  .slider-value {
    margin-top: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
  }
  .slider-readout {
    text-align: center;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 30px;
    color: var(--ink);
    letter-spacing: -0.01em;
    line-height: 1;
    min-width: 90px;
  }
  .slider-readout .unit {
    font-family: var(--font-mono);
    font-size: 14px;
    color: var(--ink-soft);
    margin-left: 2px;
    font-weight: 500;
  }
  .slider-readout .sub {
    display: block;
    margin-top: 6px;
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--ink-faint);
    font-weight: 600;
  }
  .slider-step {
    flex: 0 0 auto;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid var(--gold-2);
    background: linear-gradient(180deg, #fffdf7 0%, #f6ecd9 100%);
    color: var(--ink);
    cursor: pointer;
    display: grid;
    place-items: center;
    box-shadow:
      0 1px 0 rgba(255,255,255,0.8) inset,
      0 1px 2px rgba(138, 106, 62, 0.18),
      0 4px 10px rgba(138, 106, 62, 0.10);
    transition: transform 120ms ease, background 200ms ease, color 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
    padding: 0;
  }
  .slider-step:hover:not(:disabled) {
    background: linear-gradient(180deg, var(--gold-1) 0%, var(--gold-2) 100%);
    border-color: var(--gold-3);
  }
  .slider-step:active:not(:disabled) {
    transform: translateY(1px);
    box-shadow: inset 0 1px 2px rgba(138, 106, 62, 0.3);
  }
  .slider-step:focus-visible {
    outline: 2px solid var(--blue);
    outline-offset: 2px;
  }
  .slider-step:disabled {
    opacity: 0.35;
    cursor: not-allowed;
  }
  .slider-step svg {
    width: 11px;
    height: 11px;
    pointer-events: none;
    stroke: var(--ink);
    stroke-width: 2.4;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  /* ─────────────────────────────────────────────────────────
     GAMEPLAY SCREEN
     ───────────────────────────────────────────────────────── */
  .progress-bar {
    position: fixed;
    top: 0; left: 0;
    height: 3px;
    background: var(--ink);
    z-index: 50;
    transition: width 80ms linear;
  }

  /* When the play screen is active, lay it out as a column with the
     number-display taking the available height and the WSTECZ button
     sitting in normal flow below it (above the footer, not over it). */
  #screen-play.active {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }
  .play-stage {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 auto;
    min-height: 56vh;
    width: 100%;
    gap: 0;
  }
  .play-col {
    flex: 1 1 0;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
  }
  /* Amber divider between the two columns in dual mode */
  .play-divider {
    width: 2px;
    align-self: stretch;
    background: linear-gradient(180deg, transparent 0%, #ffddb5 18%, #ffddb5 82%, transparent 100%);
    margin: 0 2vw;
    border-radius: 2px;
    flex: 0 0 auto;
  }
  /* By default (single mode) only the first column is shown */
  #screen-play:not(.dual) .play-divider,
  #screen-play:not(.dual) #numberDisplay2Cell { display: none; }
  /* Dual mode tweaks — font scales with viewport (clamp lets it shrink on
     narrow phones where 4-digit numbers from both columns would otherwise
     overlap the divider). */
  #screen-play.dual .number-display {
    font-size: clamp(56px, 13vw, 170px);
  }
  /* "FAZA DYNAMICZNA" label — visible only in dual mode */
  .play-phase-label {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--ink-faint);
    text-align: center;
    padding: 28px 16px 0;
    display: none;
  }
  #screen-play.dual .play-phase-label { display: block; }

  .play-back-wrap {
    display: flex;
    justify-content: center;
    padding: 24px 0 4px;
  }
  .number-display {
    font-family: "Roboto Condensed", var(--font-display), sans-serif;
    font-weight: 700;
    font-size: clamp(120px, 22vw, 280px);
    line-height: 1;
    letter-spacing: 0.05em;
    font-variant-numeric: tabular-nums;
    color: #0b1b2a;
    text-align: center;
    animation: numPop 250ms ease-out;
  }
  @keyframes numPop {
    from { opacity: 0; transform: scale(0.92); }
    to   { opacity: 1; transform: scale(1); }
  }
  .number-display .sign {
    color: var(--ink);
    margin-right: 0.05em;
  }
  .counter-chip {
    position: fixed;
    top: 80px;
    right: 32px;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--ink-soft);
    background: var(--surface);
    border: 1px solid var(--line-soft);
    padding: 8px 14px;
    border-radius: 100px;
  }
  .counter-chip b {
    color: var(--ink);
    font-weight: 700;
    margin-left: 6px;
  }

  /* ─────────────────────────────────────────────────────────
     ANSWER INPUT
     ───────────────────────────────────────────────────────── */
  .answer-wrap {
    max-width: 720px;
    width: 100%;
    margin: 0 auto;
  }
  .answer-label {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 32px;
    letter-spacing: 0.04em;
    text-align: center;
    margin: 0 0 28px;
  }
  .answer-field {
    position: relative;
    background: var(--surface);
    border: 2px solid var(--gold-2);
    border-radius: var(--r-md);
    padding: 6px;
    box-shadow: 0 0 0 4px var(--bg), 0 0 0 5px var(--gold-2), var(--shadow-soft);
  }
  .answer-cells {
    display: flex;
    align-items: stretch;
    gap: 0;
  }
  .answer-cells .answer-input { flex: 1 1 0; min-width: 0; }
  .answer-divider {
    width: 1px;
    align-self: stretch;
    background: linear-gradient(180deg, transparent 0%, #c4c8d0 20%, #c4c8d0 80%, transparent 100%);
    margin: 6px 8px;
    flex: 0 0 auto;
    display: none;
  }
  /* Single mode: second input + divider + right analysis hidden */
  #screen-answer:not(.dual) #answerInput2,
  #screen-answer:not(.dual) .answer-divider,
  #screen-answer:not(.dual) #analysisRight { display: none; }
  /* Dual mode: divider visible and inputs shrink so both fit */
  #screen-answer.dual .answer-divider { display: block; }
  #screen-answer.dual .answer-input {
    /* Scales down on phones — 4-digit answers in two boxes side-by-side
       must fit without overflow. */
    font-size: clamp(36px, 8vw, 96px);
    padding: 4px 8px;
  }

  .answer-input {
    width: 100%;
    height: 150px;
    border: 1px solid var(--line);
    border-radius: var(--r-sm);
    background: #fff;
    font-family: var(--font-display);
    font-weight: 700;
    /* Scales from ~56px on narrow phones to 130px on desktop. Prevents
       4-digit answers (e.g. 9999) from overflowing the box on mobile. */
    font-size: clamp(56px, 12vw, 130px);
    text-align: center;
    color: var(--ink);
    outline: none;
    transition: border-color 200ms, color 200ms;
    padding: 4px 12px;
  }
  .answer-input::placeholder {
    color: #d0cfce;
    font-weight: 500;
  }
  .answer-input.success { color: var(--success); border-color: var(--success); }
  .answer-input.error   { color: var(--error);   border-color: var(--error); }
  .answer-field.success { border-color: var(--success); box-shadow: 0 0 0 4px var(--bg), 0 0 0 5px var(--success), 0 18px 32px rgba(15, 138, 95, 0.12); }
  .answer-field.error   { border-color: var(--error);   box-shadow: 0 0 0 4px var(--bg), 0 0 0 5px var(--error),   0 18px 32px rgba(179, 36, 36, 0.12); }
  .answer-field.error { animation: shake 380ms ease-out; }
  @keyframes shake {
    0%, 100% { transform: translateX(0); }
    20%  { transform: translateX(-8px); }
    40%  { transform: translateX(7px); }
    60%  { transform: translateX(-5px); }
    80%  { transform: translateX(3px); }
  }

  /* ─────────────────────────────────────────────────────────
     RESULT SCREEN
     ───────────────────────────────────────────────────────── */
  .verdict-title {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: clamp(28px, 4.5vw, 40px);
    font-size: 20px;
    letter-spacing: -0.01em;
    text-align: center;
    margin: 0 0 24px;
    line-height: 1.15;
    color: var(--ink);
    transition: color 200ms;
  }
  .verdict-title.success { color: var(--success); }
  .verdict-title.error   { color: var(--error); }

  /* Result section, dynamically revealed below the answer field */
  .result-reveal {
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transition: max-height 420ms ease, opacity 320ms ease, margin-top 320ms ease;
    margin-top: 0;
  }
  .result-reveal.show {
    max-height: 2400px;
    opacity: 1;
    margin-top: 28px;
  }
  .result-reveal-inner > * { animation: slideUp 360ms ease-out both; }
  .result-reveal-inner > *:nth-child(2) { animation-delay: 60ms; }
  .result-reveal-inner > *:nth-child(3) { animation-delay: 120ms; }
  .result-reveal-inner > *:nth-child(4) { animation-delay: 180ms; }
  @keyframes slideUp {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  /* 3-2-1 countdown */
  .countdown-display {
    font-family: "Roboto Condensed", var(--font-display), sans-serif;
    font-weight: 700;
    font-size: clamp(180px, 30vw, 360px);
    line-height: 1;
    letter-spacing: 0.05em;
    font-variant-numeric: tabular-nums;
    color: #ffddb5;
    text-align: center;
    animation: cdFade 700ms ease-out both;
  }
  /* Calm fade in/out — no scale jumps, no letter-spacing pop */
  @keyframes cdFade {
    0%   { opacity: 0; }
    25%  { opacity: 1; }
    85%  { opacity: 1; }
    100% { opacity: 0.85; }
  }

  /* WSTECZ button during play — sits in the normal flow, centered,
     placed above the footer thanks to .play-back-wrap. */

  .stat-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    max-width: 720px;
    margin: 0 auto 22px;
  }
  .stat-cell {
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: var(--r-md);
    padding: 6px 22px;
    text-align: left;
  }
  .stat-cell .label {
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-faint);
  }
  .stat-cell .value {
    margin-top: 6px;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 28px;
    letter-spacing: -0.01em;
    color: var(--ink);
  }

  .analysis {
    max-width: 720px;
    margin: 0 auto;
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: var(--r-md);
    padding: 6px 22px;
  }
  .analysis-head {
    display: flex; align-items: center; gap: 8px;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-faint);
    margin-bottom: 10px;
  }
  .analysis-head .dot {
    width: 6px; height: 6px;
    background: var(--gold-2);
    border-radius: 50%;
  }
  .analysis-expr {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 22px;
    color: var(--ink);
    line-height: 1.35;
    word-break: break-word;
  }
  .analysis-expr .op    { color: var(--ink-soft); margin: 0 5px; }
  .analysis-expr .eq    { color: var(--ink); font-weight: 700; margin: 0 4px 0 8px; }
  .analysis-expr .total { font-weight: 800; color: var(--ink); }

  /* ─────────────────────────────────────────────────────────
     MISC
     ───────────────────────────────────────────────────────── */
  .center-actions {
    display: flex;
    gap: 16px;
    justify-content: center;
    margin-top: 36px;
    flex-wrap: wrap;
  }

  /* ─────────────────────────────────────────────────────────
     MULTIPLICATION — CONFIG (checkbox table)
     ───────────────────────────────────────────────────────── */
  .puzzle-mode-row {
    max-width: 1100px;
    margin: 0 auto 18px;
  }

  .mul-config-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    gap: 36px;
    max-width: 1100px;
    margin: 0 auto;
    align-items: start;
  }
  .mul-sliders-col { display: flex; flex-direction: column; gap: 24px; }
  .mul-sliders-col .slider-rail {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
    max-width: none;
  }
  .mul-sliders-col .slider-rig { height: 280px; }

  .mul-table {
    background: #fffdf7;
    border: 2px solid transparent;
    background-clip: padding-box;
    border-radius: var(--r-lg);
    padding: 22px 22px 18px;
    box-shadow:
      0 0 0 1px var(--gold-3),
      0 0 0 4px var(--bg),
      0 0 0 5px var(--gold-2),
      0 1px 0 rgba(255,255,255,0.6) inset,
      0 18px 36px rgba(138, 106, 62, 0.10);
    position: relative;
  }
  .mul-table-label {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold-3);
    background: rgba(217, 185, 133, 0.18);
    border: 1px solid var(--gold-2);
    padding: 6px 12px;
    border-radius: 100px;
    margin-bottom: 16px;
  }
  .mul-table-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px 14px;
  }

  /* Each checkbox row: native input + custom box + label */
  .mul-check {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 6px 8px;
    border-radius: var(--r-sm);
    cursor: pointer;
    user-select: none;
    transition: background 150ms ease;
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    color: var(--ink);
    -webkit-tap-highlight-color: transparent;
  }
  .mul-check:hover { background: rgba(255, 221, 181, 0.25); }
  .mul-check input { position: absolute; opacity: 0; pointer-events: none; }
  .mul-check .box {
    flex: 0 0 auto;
    width: 18px; height: 18px;
    border-radius: 4px;
    border: 1.5px solid #b8a98c;
    background: #fff;
    display: grid; place-items: center;
    transition: background 150ms ease, border-color 150ms ease;
  }
  .mul-check .box::after {
    content: "";
    width: 10px; height: 6px;
    border-left: 2px solid var(--ink);
    border-bottom: 2px solid var(--ink);
    transform: rotate(-45deg) translate(1px, -1px);
    opacity: 0;
    transition: opacity 120ms ease;
  }
  .mul-check input:checked + .box {
    background: #ffddb5;
    border-color: #c89a5a;
  }
  .mul-check input:checked + .box::after { opacity: 1; }
  .mul-check input:focus-visible + .box {
    outline: 2px solid var(--ink);
    outline-offset: 2px;
  }
  .mul-check.suppressed {
    opacity: 0.4;
    cursor: not-allowed;
  }
  .mul-check.suppressed .label-text {
    text-decoration: line-through;
    text-decoration-color: var(--ink-faint);
  }
  .mul-check.range .label-text {
    font-family: var(--font-mono);
    font-weight: 600;
    letter-spacing: 0.02em;
  }

  .mul-table-hint {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px dashed var(--line-soft);
    font-family: var(--font-body);
    font-size: 12px;
    color: var(--ink-faint);
    line-height: 1.5;
  }
  .mul-table-error {
    color: var(--error);
    font-weight: 600;
    margin-top: 4px;
    display: none;
  }
  .mul-table-error.show { display: block; }

  /* ─────────────────────────────────────────────────────────
     MULTIPLICATION — PLAY (problem grid)
     ───────────────────────────────────────────────────────── */
  .mul-grid {
    display: grid;
    gap: 16px;
    margin: 0 auto;
    width: 100%;
    max-width: 1180px;
    grid-template-columns: repeat(var(--mul-cols, 3), minmax(0, 1fr));
    justify-items: stretch;
  }
  /* When there's only one problem, center it and constrain its width */
  .mul-grid.single {
    grid-template-columns: minmax(0, 420px);
    justify-content: center;
  }

  .mul-card {
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: var(--r-md);
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    transition: border-color 200ms ease, box-shadow 200ms ease, background 200ms ease;
  }
  .mul-card.success {
    border-color: var(--success);
    background: linear-gradient(180deg, #f5fbf8 0%, #ffffff 100%);
    box-shadow: 0 0 0 1px var(--success) inset, 0 8px 22px rgba(15, 138, 95, 0.08);
  }
  .mul-card.error {
    border-color: var(--error);
    background: linear-gradient(180deg, #fdf5f4 0%, #ffffff 100%);
    box-shadow: 0 0 0 1px var(--error) inset, 0 8px 22px rgba(179, 36, 36, 0.08);
  }

  .mul-problem-row {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: nowrap;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: clamp(18px, 2.2vw, 28px);
    color: var(--ink);
    line-height: 1.1;
    overflow: hidden;
  }
  .mul-problem-row > span {
    white-space: nowrap;
    flex-shrink: 0;
  }
  .mul-card .op { color: var(--ink-soft); margin: 0 2px; }
  .mul-card .eq { color: var(--ink-soft); margin: 0 4px; }

  .mul-input {
    width: 90px;
    flex: 1 1 50px;
    min-width: 44px;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: clamp(22px, 2vw, 28px);
    text-align: center;
    border: 1.5px solid var(--line);
    border-radius: 6px;
    background: #fff;
    color: var(--ink);
    padding: 4px 8px;
    outline: none;
    transition: border-color 180ms ease, color 180ms ease;
  }
  .mul-input:focus { border-color: var(--gold-2); }
  .mul-input.success { color: var(--success); border-color: var(--success); background: #f7fcf9; }
  .mul-input.error   { color: var(--error);   border-color: var(--error);   background: #fff7f6; }
  .mul-input:disabled { cursor: default; }

  .mul-feedback-row {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .mul-feedback {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    min-height: 14px;
  }
  .mul-feedback.success { color: var(--success); }
  .mul-feedback.error   { color: var(--error); }
  .mul-feedback .correct-value {
    margin-left: 6px;
    color: var(--ink-soft);
    font-family: var(--font-display);
    font-weight: 700;
    text-transform: none;
    letter-spacing: 0;
    font-size: 14px;
  }

  .mul-check-btn {
    flex: 0 0 auto;
    border: 1px solid var(--gold-2);
    background: linear-gradient(180deg, #fffdf7 0%, #f6ecd9 100%);
    color: var(--ink);
    font-family: var(--font-display);
    font-weight: 800;
    /* Compact square button so the whole problem row (a × b = [input] btn)
       fits in a single line even with wider digits like 8 or 0. */
    font-size: 18px;
    line-height: 1;
    width: 38px;
    height: 38px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    cursor: pointer;
    transition: background 180ms ease, color 180ms ease, border-color 180ms ease, transform 120ms ease;
  }
  .mul-check-btn:hover {
    background: #ffddb5;
    border-color: #c89a5a;
    transform: translateY(-1px);
  }
  .mul-check-btn:disabled {
    opacity: 0.45;
    cursor: not-allowed;
  }

  /* Session summary chip */
  .mul-summary {
    max-width: 720px;
    margin: 0 auto 18px;
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: var(--r-md);
    padding: 14px 22px;
    display: flex;
    justify-content: space-around;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-faint);
  }
  .mul-summary b {
    font-family: var(--font-display);
    color: var(--ink);
    font-weight: 700;
    margin-left: 6px;
    font-size: 18px;
    letter-spacing: -0.01em;
    text-transform: none;
  }
  .mul-summary .success b { color: var(--success); }
  .mul-summary .error b   { color: var(--error); }

  /* ─────────────────────────────────────────────────────────
     COLUMNS (KOLUMNY) — PLAY
     ───────────────────────────────────────────────────────── */
  .col-grid {
    display: grid;
    gap: 18px 14px;
    margin: 0 auto;
    width: 100%;
    max-width: 1600px;
    grid-template-columns: repeat(var(--col-cols, 3), minmax(0, 1fr));
    justify-items: stretch;
  }
  /* When packed tightly (5 or 6 columns), keep the digit/answer fonts large
     (40px) per spec — only padding/timer/button chrome tightens. */
  .col-grid[style*="--col-cols: 5"] .col-card,
  .col-grid[style*="--col-cols: 6"] .col-card {
    padding: 12px 10px 14px;
    gap: 8px;
  }
  .col-grid[style*="--col-cols: 5"] .col-row,
  .col-grid[style*="--col-cols: 6"] .col-row {
    font-size: 40px;
    line-height: 1.1;
    padding: 0 6px;
  }
  .col-grid[style*="--col-cols: 5"] .col-input,
  .col-grid[style*="--col-cols: 6"] .col-input {
    font-size: 40px;
    line-height: 1.1;
    padding: 6px 10px;
  }
  .col-grid[style*="--col-cols: 5"] .col-check-btn,
  .col-grid[style*="--col-cols: 6"] .col-check-btn {
    padding: 6px 10px;
    font-size: 11px;
  }
  .col-grid[style*="--col-cols: 5"] .col-timer,
  .col-grid[style*="--col-cols: 6"] .col-timer {
    padding: 5px 10px;
    font-size: 11px;
    letter-spacing: 0.14em;
  }
  .col-grid[style*="--col-cols: 5"] .col-timer .value,
  .col-grid[style*="--col-cols: 6"] .col-timer .value {
    font-size: 13px;
  }
  /* On narrower viewports the 40px would overflow — gracefully scale down */
  @media (max-width: 1280px) {
    .col-grid[style*="--col-cols: 5"] .col-row,
    .col-grid[style*="--col-cols: 5"] .col-input { font-size: clamp(20px, 2.6vw, 32px); }
  }
  .col-grid.single {
    grid-template-columns: minmax(0, 360px);
    justify-content: center;
  }

  .col-card {
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: var(--r-md);
    padding: 14px 14px 16px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    transition: border-color 200ms ease, box-shadow 200ms ease, background 200ms ease;
  }
  .col-card.success {
    border-color: var(--success);
    background: linear-gradient(180deg, #f5fbf8 0%, #ffffff 100%);
    box-shadow: 0 0 0 1px var(--success) inset, 0 8px 22px rgba(15, 138, 95, 0.08);
  }
  .col-card.error {
    border-color: var(--error);
    background: linear-gradient(180deg, #fdf5f4 0%, #ffffff 100%);
    box-shadow: 0 0 0 1px var(--error) inset, 0 8px 22px rgba(179, 36, 36, 0.08);
  }

  /* Globalny timer sesji kolumn */
  .col-global-timer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: var(--font-mono);
    font-size: 22px;
    font-weight: 800;
    color: var(--ink);
    background: var(--card-bg, #fffdf9);
    border: 2px solid var(--border, #e8e0d0);
    border-radius: 14px;
    padding: 10px 20px;
    margin: 0 auto 14px;
    width: fit-content;
    min-width: 110px;
    letter-spacing: 0.03em;
    transition: border-color 0.3s, color 0.3s;
  }
  .col-global-timer.warning {
    border-color: #f0a500;
    color: #c87800;
  }
  .col-global-timer.danger {
    border-color: var(--error);
    color: var(--error);
  }
  .col-global-timer.done {
    border-color: var(--error);
    color: var(--error);
    opacity: 0.7;
  }
  .col-global-timer.finished {
    border-color: var(--border, #e8e0d0);
    color: var(--ink);
    opacity: 0.7;
  }
  .col-global-timer-icon { font-size: 18px; }

  /* Countdown timer above each column */
  .col-timer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-soft);
    padding: 6px 10px;
    border: 1px solid var(--line-soft);
    border-radius: 100px;
    background: linear-gradient(180deg, #fffdf7 0%, #f6ecd9 100%);
  }
  .col-timer .icon { font-size: 13px; opacity: 0.75; }
  .col-timer .value { font-size: 14px; color: var(--ink); letter-spacing: 0.04em; min-width: 22px; text-align: center; }
  .col-timer.warning { color: var(--gold-3); }
  .col-timer.warning .value { color: var(--gold-3); }
  .col-timer.danger {
    color: var(--error);
    border-color: var(--error);
    background: #fff7f6;
    animation: colPulse 700ms ease-in-out infinite;
  }
  .col-timer.danger .value { color: var(--error); }
  .col-timer.done {
    color: var(--ink-faint);
    background: var(--surface-2);
    animation: none;
  }
  @keyframes colPulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.55; }
  }

  /* Stack of signed numbers — the actual column */
  .col-stack {
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: stretch;
    padding: 12px 8px 10px;
    background: linear-gradient(180deg, #fbf9f6 0%, #ffffff 100%);
    border-radius: var(--r-sm);
    border: 1px solid var(--line-soft);
  }
  .col-row {
    display: flex;
    align-items: baseline;
    justify-content: flex-end;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: clamp(20px, 2vw, 28px);
    line-height: 1.15;
    color: var(--ink);
    padding: 1px 8px;
  }
  .col-row .op {
    color: var(--ink-soft);
    font-weight: 700;
    /* No margin/gap to value — sign stays glued to the digit (e.g. "+5") */
  }
  .col-row .val {
    font-variant-numeric: tabular-nums;
    padding-right: 2px;
  }
  /* First row has no operator: hide it entirely so the number sits flush right */
  /* First row also shows its + sign for visual consistency across the column */
  .col-rule {
    height: 2px;
    background: var(--ink);
    margin: 6px 8px 0;
    border-radius: 1px;
  }

  /* Answer area below the column */
  .col-answer {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
  }
  .col-input {
    flex: 1 1 auto;
    min-width: 0;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: clamp(20px, 2vw, 26px);
    text-align: right;
    border: 1.5px solid var(--line);
    border-radius: 6px;
    background: #fff;
    color: var(--ink);
    padding: 6px 10px;
    outline: none;
    transition: border-color 180ms ease, color 180ms ease;
    font-variant-numeric: tabular-nums;
  }
  .col-input:focus { border-color: var(--gold-2); }
  .col-input.success { color: var(--success); border-color: var(--success); background: #f7fcf9; }
  .col-input.error   { color: var(--error);   border-color: var(--error);   background: #fff7f6; }
  .col-check-btn {
    flex: 0 0 auto;
    border: 1px solid var(--gold-2);
    background: linear-gradient(180deg, #fffdf7 0%, #f6ecd9 100%);
    color: var(--ink);
    font-family: var(--font-body);
    font-weight: 700;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 6px 10px;
    border-radius: 6px;
    cursor: pointer;
    transition: background 180ms ease, border-color 180ms ease;
  }
  .col-check-btn:hover { background: #ffddb5; border-color: #c89a5a; }
  .col-check-btn:disabled { opacity: 0.45; cursor: not-allowed; }

  .col-feedback {
    font-family: var(--font-mono);
    font-size: 10.5px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    min-height: 12px;
    text-align: right;
    padding-right: 4px;
  }
  .col-feedback.success { color: var(--success); }
  .col-feedback.error   { color: var(--error); }
  .col-feedback .correct-value {
    margin-left: 6px;
    color: var(--ink-soft);
    font-family: var(--font-display);
    font-weight: 700;
    text-transform: none;
    letter-spacing: 0;
    font-size: 13px;
  }



  /* ─────────────────────────────────────────────────────────
     COLUMNS — result UX upgrade
     Better readability after checking answers: correct answer shown,
     cleaner locked state, finish message and safer action buttons.
     ───────────────────────────────────────────────────────── */
  #screen-play-col .screen-head {
    margin-bottom: 18px;
  }

  #screen-play-col .mul-summary {
    /* Pasek pokazuje się w normalnym flow — bez sticky.
       Wcześniej `position: sticky; top: 10px` powodował, że przy scrollu
       chip zasłaniał górne wiersze kolumn (timery, pierwsze cyfry). */
    max-width: 860px;
    margin-bottom: 22px;
    box-shadow: 0 14px 34px rgba(4, 22, 39, 0.07);
  }

  .col-finish-panel {
    max-width: 860px;
    margin: 0 auto 22px;
    padding: 16px 20px;
    display: grid;
    grid-template-columns: 46px 1fr;
    gap: 14px;
    align-items: center;
    border-radius: var(--r-md);
    border: 1px solid var(--gold-1);
    background: linear-gradient(180deg, #fffdf7 0%, #faecd1 100%);
    box-shadow: 0 10px 26px rgba(184, 149, 106, 0.12);
  }

  .col-finish-panel[hidden] { display: none; }

  .col-finish-panel.success {
    border-color: var(--success);
    background: linear-gradient(180deg, #f4fbf7 0%, #ffffff 100%);
  }

  .col-finish-panel.error {
    border-color: rgba(179, 36, 36, 0.38);
    background: linear-gradient(180deg, #fff7f6 0%, #ffffff 100%);
  }

  .col-finish-icon {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: var(--ink);
    color: #ffddb5;
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 800;
  }

  .col-finish-panel.success .col-finish-icon {
    background: var(--success);
    color: #fff;
  }

  .col-finish-panel.error .col-finish-icon {
    background: var(--error);
    color: #fff;
  }

  .col-finish-copy strong {
    display: block;
    font-family: var(--font-display);
    font-size: 20px;
    line-height: 1.15;
    color: var(--ink);
    margin-bottom: 3px;
  }

  .col-finish-copy span {
    display: block;
    font-size: 14px;
    line-height: 1.45;
    color: var(--ink-soft);
  }

  .col-card {
    box-shadow: 0 8px 24px rgba(4, 22, 39, 0.04);
  }

  .col-card.success,
  .col-card.error {
    transform: translateY(-1px);
  }

  .col-card.success .col-check-btn,
  .col-card.error .col-check-btn {
    display: none;
  }

  .col-card.success .col-input,
  .col-card.error .col-input {
    flex-basis: 100%;
    text-align: center;
  }

  .col-card.error .col-stack {
    background: linear-gradient(180deg, #fffafa 0%, #ffffff 100%);
  }

  .col-card.success .col-stack {
    background: linear-gradient(180deg, #f7fcf9 0%, #ffffff 100%);
  }

  .col-feedback {
    min-height: 28px;
    text-align: center;
    padding: 4px 2px 0;
  }

  .col-feedback .correct-value {
    display: inline-flex;
    align-items: center;
    margin-left: 8px;
    padding: 3px 8px;
    border-radius: 999px;
    background: rgba(179, 36, 36, 0.08);
    color: var(--error);
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: none;
  }

  .col-card.success .col-feedback,
  .col-card.success .col-input {
    color: var(--success);
  }

  .col-card.error .col-feedback,
  .col-card.error .col-input {
    color: var(--error);
  }

  #screen-play-col .actions .btn:disabled {
    opacity: 0.38;
    cursor: not-allowed;
    transform: none;
  }


  @media (max-width: 1200px) {
    .col-grid { grid-template-columns: repeat(min(var(--col-cols, 3), 4), minmax(0, 1fr)) !important; }
  }
  @media (max-width: 880px) {
    .col-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  }
  @media (max-width: 560px) {
    .col-grid { grid-template-columns: 1fr !important; }
  }

  /* ─────────────────────────────────────────────────────────
     RESPONSIVE
     ───────────────────────────────────────────────────────── */
  @media (max-width: 880px) {
    /* Tryb zagadki — na mobile bez karty, sam checkbox jako płaski rząd.
       !important wymagane — .pdf-section base rules (tło/ramka/cień) są
       zdefiniowane niżej w pliku i wygrywałyby kaskadę bez !important. */
    .puzzle-mode-row {
      background: none !important;
      border: none !important;
      box-shadow: none !important;
      padding: 0 4px !important;
      margin-bottom: 20px;
    }

    .mul-config-shell { grid-template-columns: 1fr; gap: 24px; }
    /* On mobile, mul/div sliders behave identically to all other sliders —
       single column, same compact rig height. Selectors must match the
       higher-specificity `.mul-sliders-col .slider-rig` definition above,
       so we restate it here to win the cascade. */
    .mul-sliders-col .slider-rail,
    .slider-rail {
      grid-template-columns: 1fr !important;
      gap: 18px !important;
      max-width: 460px !important;
    }
    .mul-sliders-col .slider-rig,
    .slider-rig {
      height: 240px !important;
    }
    .mul-grid { grid-template-columns: 1fr !important; }
  }
  @media (max-width: 720px) {
    /* Push the SPRAWDŹ button to the right edge of the mul/div problem row
       so it has breathing room from the input field */
    .mul-problem-row .mul-check-btn { margin-left: auto; }
  }
  @media (max-width: 560px) {
    .mul-table-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 4px 6px; }
    .mul-check { font-size: 13px; gap: 6px; padding: 4px 4px; }
    .mul-check .box { width: 16px; height: 16px; }
  }

  /* ─────────────────────────────────────────────────────────
     RESPONSIVE (existing)
     ───────────────────────────────────────────────────────── */
  @media (max-width: 880px) {
    header.topbar { padding: 16px 20px; }
    footer.bottombar { padding: 14px 20px; flex-wrap: wrap; gap: 8px; }
    main { padding: 20px 30px; }
    .screen-title { font-size: 32px; }
    .card-grid.two, .card-grid.three { grid-template-columns: 1fr; }
    /* Slider sizing (rail, rig) is enforced earlier with !important —
       these are the cosmetic refinements that apply equally to every
       slider on mobile (mul, div, kolumny, FLASH). */
    .slider-card {
      padding: 22px 18px 18px;
    }
    /* Slim ruler scale + side labels for narrow viewports */
    .ruler-axis { width: 64px; padding-right: 6px; }
    .ruler-side-labels { width: 68px; padding-left: 8px; }
    .ruler-side-labels .side-label { font-size: 11px; }
    .ruler-axis .tick-label { font-size: 10px; right: 18px; }
    /* Bar — keep generous but not huge so it fits two-up labels comfortably */
    .bar { flex: 0 0 32px; }
    .bar-track { width: 22px; }
    /* Wyrównanie baru: grid z 3 stałymi kolumnami.
       CSS Grid rezerwuje kolumnę 3 (side-labels) nawet gdy elementu nie ma w DOM,
       więc bar (kolumna 2) zawsze jest w tej samej pozycji X. */
    .ruler {
      display: grid !important;
      grid-template-columns: 64px 32px 68px !important;
      align-items: stretch;
      justify-content: center;
    }
    /* Slightly smaller readout — saves vertical space, looks balanced */
    .slider-readout { font-size: 24px; min-width: 78px; }
    .slider-readout .unit { font-size: 12px; }
    .slider-step { width: 30px; height: 30px; }

    .answer-input { font-size: 56px; height: 140px; }
    .answer-label { font-size: 24px; }
    .stat-row { grid-template-columns: 1fr; }
    .counter-chip { top: auto; bottom: 16px; right: 16px; }
    /* DALEJ na górze, WSTECZ pod spodem — układ pionowy */
    .actions {
      flex-direction: column;
      align-items: center;
    }
    .actions .btn {
      width: 100%;
      max-width: 340px;
      justify-content: center;
    }
    .actions .btn-primary { order: -1; }
  }

  /* ─────────────────────────────────────────────────────────
     TOUCH FIX — prevent the slider from triggering page-level
     pull-to-refresh / rubber-band scroll on iOS Safari and
     mobile Chrome. Without these declarations a drag on the
     bar causes the entire page to bounce/jump as if the
     background "slid down" from under the finger.
     ───────────────────────────────────────────────────────── */
  .slider-rig,
  .ruler,
  .bar,
  .bar-track,
  .bar-fill {
    touch-action: none;
    -webkit-user-select: none;
    user-select: none;
    overscroll-behavior: contain;
  }

  /* Diana photo card hardening */
  .home-hero-card.photo-card {
    position: relative;
    min-height: 520px;
  }
  @media (max-width: 920px) {
    .home-hero-card.photo-card {
      min-height: 480px;
    }
  }


  .ach-gallery-reminder-section {
    padding-top: 54px !important;
    padding-bottom: 18px !important;
    border-top: 1px solid var(--line-soft);
  }
  .ach-gallery-reminder-section .home-section-head {
    margin-bottom: 0;
  }


  /* ─────────────────────────────────────────────────────────
     ACHIEVEMENTS — MEDIA / TV / RADIO SECTION
     ───────────────────────────────────────────────────────── */
  .ach-media-section {
    padding-top: 76px !important;
    padding-bottom: 76px !important;
    border-top: 1px solid var(--line-soft);
    background:
      radial-gradient(circle at 12% 20%, rgba(255, 221, 181, 0.35), transparent 38%),
      linear-gradient(180deg, #fffdf7 0%, #fbf9fa 100%);
  }

  .ach-media-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
    gap: 52px;
    align-items: center;
    max-width: 1040px;
    margin: 0 auto;
  }

  .ach-media-photo-card {
    position: relative;
    aspect-ratio: 4 / 5;
    border-radius: var(--r-lg);
    overflow: hidden;
    background: var(--ink);
    border: 1.5px solid var(--gold-2);
    box-shadow:
      0 24px 60px rgba(184, 149, 106, 0.20),
      0 2px 0 #fff inset,
      0 -1px 0 var(--gold-1) inset;
  }

  .ach-media-photo-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .ach-media-photo-caption {
    position: absolute;
    inset: auto 0 0 0;
    padding: 52px 20px 16px;
    color: #fff;
    background: linear-gradient(180deg, rgba(4,22,39,0) 0%, rgba(4,22,39,0.88) 78%, rgba(4,22,39,0.96) 100%);
    pointer-events: none;
  }

  .ach-media-photo-caption .caption-name {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.01em;
  }

  .ach-media-photo-caption .caption-meta {
    margin-top: 4px;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #ffddb5;
    line-height: 1.4;
  }

  .ach-media-content .home-section-title {
    text-align: left;
    margin-bottom: 18px;
  }

  .ach-media-content .contact-section-text {
    margin-left: 0;
    margin-right: 0;
    text-align: left;
    max-width: 640px;
  }

  .ach-media-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-top: 28px;
  }

  .ach-media-pill {
    background: var(--surface);
    border: 1px solid var(--gold-1);
    border-radius: var(--r-md);
    padding: 16px 14px;
    box-shadow: 0 10px 24px rgba(184, 149, 106, 0.08);
  }

  .ach-media-pill strong {
    display: block;
    font-family: var(--font-display);
    font-size: 17px;
    line-height: 1.1;
    color: var(--ink);
    margin-bottom: 6px;
  }

  .ach-media-pill span {
    display: block;
    font-size: 13px;
    line-height: 1.45;
    color: var(--ink-soft);
  }

  @media (max-width: 880px) {
    .ach-media-grid {
      grid-template-columns: 1fr;
      gap: 32px;
    }

    .ach-media-photo-card {
      max-width: 360px;
      margin: 0 auto;
    }

    .ach-media-content .home-section-title,
    .ach-media-content .contact-section-text {
      text-align: center;
      margin-left: auto;
      margin-right: auto;
    }

    .ach-media-list {
      grid-template-columns: 1fr;
      max-width: 520px;
      margin-left: auto;
      margin-right: auto;
    }
  }


  /* ─────────────────────────────────────────────────────────
     ACHIEVEMENTS HERO V2 — fills the empty right side with a visual story panel
     ───────────────────────────────────────────────────────── */
  .ach-hero-v2 {
    grid-template-columns: minmax(0, 0.9fr) minmax(420px, 1.1fr) !important;
    gap: 64px !important;
    min-height: 680px;
    align-items: center !important;
  }

  .ach-hero-v2 .ach-hero-bg::after {
    height: 210px;
    bottom: auto;
    top: 46px;
    transform: skewY(-3deg);
    opacity: 0.94;
  }

  .ach-hero-v2 .ach-hero-text {
    max-width: 600px;
    padding-left: 18px;
  }

  .ach-hero-showcase {
    position: relative;
    min-height: 560px;
    width: 100%;
    max-width: 640px;
    justify-self: end;
  }

  .ach-showcase-photo-card {
    position: absolute;
    top: 42px;
    right: 90px;
    width: min(360px, 58vw);
    aspect-ratio: 2 / 3;
    border-radius: var(--r-lg);
    overflow: hidden;
    background: var(--ink);
    border: 1.5px solid var(--gold-2);
    box-shadow:
      0 32px 76px rgba(4, 22, 39, 0.30),
      0 2px 0 #fff inset,
      0 -1px 0 var(--gold-1) inset;
    transform: rotate(-2.5deg);
    z-index: 2;
  }

  .ach-showcase-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
  }

  .ach-showcase-caption {
    position: absolute;
    inset: auto 0 0 0;
    padding: 58px 22px 18px;
    color: #fff;
    background: linear-gradient(180deg, rgba(4,22,39,0) 0%, rgba(4,22,39,0.90) 76%, rgba(4,22,39,0.97) 100%);
  }

  .ach-showcase-caption strong {
    display: block;
    font-family: var(--font-display);
    font-size: 22px;
    letter-spacing: -0.01em;
    line-height: 1.1;
  }

  .ach-showcase-caption span {
    display: block;
    margin-top: 5px;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #ffddb5;
    line-height: 1.35;
  }

  .ach-hero-showcase .ach-medal-top {
    top: 10px;
    right: 18px;
    z-index: 5;
  }

  .ach-hero-showcase .ach-medal-bottom {
    left: 54px;
    bottom: 130px;
    z-index: 5;
  }

  .ach-showcase-note {
    position: absolute;
    z-index: 4;
    display: grid;
    grid-template-columns: 46px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    max-width: 270px;
    padding: 14px 16px;
    border-radius: var(--r-md);
    background: rgba(255, 253, 247, 0.92);
    border: 1px solid var(--gold-1);
    box-shadow: 0 18px 42px rgba(4, 22, 39, 0.12);
    backdrop-filter: blur(8px);
  }

  .ach-showcase-note strong {
    display: block;
    font-family: var(--font-display);
    font-size: 16px;
    line-height: 1.1;
    color: var(--ink);
    margin-bottom: 4px;
  }

  .ach-showcase-note p {
    margin: 0;
    font-size: 12.5px;
    line-height: 1.45;
    color: var(--ink-soft);
  }

  .ach-note-icon {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: linear-gradient(160deg, #ffddb5 0%, #d9b985 100%);
    border: 1px solid var(--gold-2);
    color: var(--ink);
    font-family: var(--font-mono);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.05em;
  }

  .ach-note-tv {
    left: 0;
    top: 115px;
  }

  .ach-note-radio {
    right: 0;
    bottom: 76px;
  }

  .ach-showcase-stats {
    position: absolute;
    left: 18px;
    right: 42px;
    bottom: 0;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
  }

  .ach-showcase-stats div {
    min-height: 92px;
    padding: 18px 12px;
    border-radius: var(--r-md);
    background: linear-gradient(180deg, #fffdf7 0%, #faecd1 100%);
    border: 1px solid var(--gold-1);
    text-align: center;
    box-shadow: 0 10px 26px rgba(184, 149, 106, 0.12);
  }

  .ach-showcase-stats strong {
    display: block;
    font-family: var(--font-display);
    font-size: 30px;
    line-height: 1;
    color: var(--ink);
    margin-bottom: 7px;
  }

  .ach-showcase-stats span {
    display: block;
    font-family: var(--font-mono);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--gold-3);
    line-height: 1.25;
  }

  @media (max-width: 1040px) {
    .ach-hero-v2 {
      grid-template-columns: 1fr !important;
      min-height: auto;
      padding-bottom: 84px !important;
    }

    .ach-hero-v2 .ach-hero-text {
      max-width: 720px;
      padding-left: 0;
    }

    .ach-hero-showcase {
      min-height: 570px;
      max-width: 620px;
      justify-self: center;
    }
  }

  @media (max-width: 620px) {
    .ach-hero-v2 {
      padding-top: 58px !important;
      gap: 36px !important;
    }

    .ach-hero-showcase {
      min-height: 610px;
    }

    .ach-showcase-photo-card {
      top: 44px;
      right: 50%;
      transform: translateX(50%) rotate(-1.5deg);
      width: min(320px, 82vw);
    }

    .ach-hero-showcase .ach-medal-top {
      top: 6px;
      right: 8px;
    }

    .ach-hero-showcase .ach-medal-bottom {
      left: 10px;
      bottom: 168px;
    }

    .ach-showcase-note {
      max-width: calc(100% - 24px);
      grid-template-columns: 42px 1fr;
      padding: 12px 14px;
    }

    .ach-note-tv {
      left: 12px;
      top: 380px;
    }

    .ach-note-radio {
      right: 12px;
      bottom: 82px;
    }

    .ach-showcase-stats {
      left: 12px;
      right: 12px;
      bottom: 0;
      grid-template-columns: repeat(3, 1fr);
    }

    .ach-showcase-stats div {
      min-height: 78px;
      padding: 14px 8px;
    }

    .ach-showcase-stats strong {
      font-size: 24px;
    }

    .ach-showcase-stats span {
      font-size: 8px;
    }
  }


  /* FIX: usuwa duży złoty prostokąt z góry sekcji Osiągnięcia
     i zostawia klasyczny układ: tekst po lewej, panel wizualny po prawej. */
  .ach-hero-v2 {
    grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr) !important;
    align-items: center !important;
  }

  .ach-hero-v2 .ach-hero-bg::after {
    display: none !important;
    content: none !important;
  }

  .ach-hero-v2 .ach-hero-bg {
    background:
      radial-gradient(ellipse 760px 420px at 82% 26%, rgba(255, 221, 181, 0.38) 0%, rgba(255, 221, 181, 0) 62%),
      radial-gradient(ellipse 520px 320px at 12% 18%, rgba(184, 149, 106, 0.13) 0%, rgba(184, 149, 106, 0) 62%),
      linear-gradient(180deg, #ffffff 0%, #fbf9fa 100%) !important;
  }

  .ach-hero-v2 .ach-hero-text {
    order: 1;
    justify-self: start;
  }

  .ach-hero-v2 .ach-hero-showcase {
    order: 2;
    justify-self: end;
  }

  @media (max-width: 1040px) {
    .ach-hero-v2 .ach-hero-text,
    .ach-hero-v2 .ach-hero-showcase {
      justify-self: center;
    }
  }


  /* ─────────────────────────────────────────────────────────
     ACHIEVEMENTS HERO V3 — no photo, achievement board instead
     ───────────────────────────────────────────────────────── */
  .ach-hero-v3 {
    grid-template-columns: minmax(0, 0.9fr) minmax(460px, 1.1fr) !important;
    gap: 62px !important;
    min-height: 660px;
    align-items: center !important;
  }

  .ach-hero-v3 .ach-hero-bg::after {
    display: none !important;
    content: none !important;
  }

  .ach-hero-v3 .ach-hero-bg {
    background:
      radial-gradient(ellipse 760px 440px at 78% 28%, rgba(255, 221, 181, 0.42) 0%, rgba(255, 221, 181, 0) 64%),
      radial-gradient(ellipse 540px 330px at 12% 18%, rgba(184, 149, 106, 0.13) 0%, rgba(184, 149, 106, 0) 62%),
      linear-gradient(180deg, #ffffff 0%, #fbf9fa 100%) !important;
  }

  .ach-hero-v3 .ach-hero-text {
    max-width: 620px;
    justify-self: start;
  }

  .ach-board {
    position: relative;
    width: 100%;
    max-width: 650px;
    justify-self: end;
    padding: 30px;
    border-radius: var(--r-lg);
    border: 1.5px solid var(--gold-2);
    background:
      linear-gradient(180deg, rgba(255, 253, 247, 0.96) 0%, rgba(250, 236, 209, 0.92) 100%);
    box-shadow:
      0 30px 74px rgba(184, 149, 106, 0.20),
      0 2px 0 #fff inset,
      0 -1px 0 var(--gold-1) inset;
    overflow: hidden;
  }

  .ach-board::before {
    content: "";
    position: absolute;
    width: 260px;
    height: 260px;
    right: -90px;
    top: -100px;
    border-radius: 50%;
    background: rgba(255, 221, 181, 0.55);
    filter: blur(2px);
  }

  .ach-board::after {
    content: "★";
    position: absolute;
    right: 28px;
    top: 22px;
    width: 78px;
    height: 78px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-family: var(--font-display);
    font-size: 34px;
    color: var(--gold-3);
    background: rgba(255, 255, 255, 0.68);
    border: 2px solid #fff;
    box-shadow: 0 14px 30px rgba(4, 22, 39, 0.12);
    transform: rotate(8deg);
  }

  .ach-board-head {
    position: relative;
    z-index: 1;
    max-width: 460px;
    margin-bottom: 22px;
  }

  .ach-board-head h2 {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(26px, 3vw, 36px);
    line-height: 1.08;
    letter-spacing: -0.02em;
    color: var(--ink);
  }

  .ach-board-stats {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 22px;
  }

  .ach-stat-card {
    min-height: 108px;
    padding: 18px 14px;
    border-radius: var(--r-md);
    background: var(--surface);
    border: 1px solid var(--gold-1);
    text-align: center;
    box-shadow: 0 10px 24px rgba(184, 149, 106, 0.08);
  }

  .ach-stat-card.featured {
    background: linear-gradient(180deg, #041627 0%, #102437 100%);
    border-color: #102437;
  }

  .ach-stat-card strong {
    display: block;
    margin-bottom: 8px;
    font-family: var(--font-display);
    font-size: 34px;
    line-height: 1;
    color: var(--ink);
    letter-spacing: -0.03em;
  }

  .ach-stat-card.featured strong {
    color: #ffddb5;
  }

  .ach-stat-card span {
    display: block;
    font-size: 12px;
    line-height: 1.35;
    color: var(--ink-soft);
  }

  .ach-stat-card.featured span {
    color: rgba(255,255,255,0.74);
  }

  .ach-year-list {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 10px;
  }

  .ach-year-card {
    display: grid;
    grid-template-columns: 76px 1fr;
    gap: 16px;
    align-items: start;
    padding: 16px;
    border-radius: var(--r-md);
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(216, 184, 137, 0.75);
  }

  .ach-year-card.highlight {
    background: rgba(255, 221, 181, 0.34);
    border-color: var(--gold-2);
  }

  .ach-year {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    border-radius: 100px;
    background: #ffddb5;
    border: 1px solid var(--gold-2);
    font-family: var(--font-mono);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    color: var(--ink);
  }

  .ach-year-body h3 {
    margin: 0 0 5px;
    font-family: var(--font-display);
    font-size: 18px;
    line-height: 1.14;
    letter-spacing: -0.01em;
    color: var(--ink);
  }

  .ach-year-body p {
    margin: 0;
    font-size: 13.5px;
    line-height: 1.55;
    color: var(--ink-soft);
  }

  .ach-full-list-section {
    padding-top: 68px !important;
    padding-bottom: 68px !important;
    background: linear-gradient(180deg, #fbf9fa 0%, #fffdf7 100%);
  }

  .ach-full-list {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
  }

  .ach-full-year {
    background: var(--surface);
    border: 1px solid var(--gold-1);
    border-radius: var(--r-md);
    padding: 22px 20px;
    box-shadow: 0 10px 26px rgba(184, 149, 106, 0.08);
  }

  .ach-full-year-featured {
    background: linear-gradient(180deg, #fffdf7 0%, #faecd1 100%);
    border-color: var(--gold-2);
  }

  .ach-full-year h3 {
    margin: 0 0 14px;
    font-family: var(--font-display);
    font-size: 26px;
    line-height: 1;
    color: var(--ink);
  }

  .ach-full-year ul {
    margin: 0;
    padding-left: 18px;
  }

  .ach-full-year li {
    margin: 0 0 10px;
    font-size: 14px;
    line-height: 1.55;
    color: var(--ink-soft);
  }

  .ach-full-year li:last-child {
    margin-bottom: 0;
  }

  @media (max-width: 1040px) {
    .ach-hero-v3 {
      grid-template-columns: 1fr !important;
      min-height: auto;
      gap: 40px !important;
      padding-bottom: 72px !important;
    }

    .ach-board,
    .ach-hero-v3 .ach-hero-text {
      justify-self: center;
      max-width: 760px;
    }

    .ach-full-list {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (max-width: 620px) {
    .ach-hero-v3 {
      padding-top: 56px !important;
    }

    .ach-board {
      padding: 22px 16px;
    }

    .ach-board::after {
      width: 58px;
      height: 58px;
      font-size: 26px;
      right: 16px;
      top: 16px;
    }

    .ach-board-head {
      max-width: calc(100% - 70px);
    }

    .ach-board-stats {
      grid-template-columns: 1fr;
    }

    .ach-stat-card {
      min-height: auto;
      text-align: left;
    }

    .ach-year-card {
      grid-template-columns: 1fr;
      gap: 10px;
    }

    .ach-year {
      width: max-content;
      padding: 0 18px;
    }

    .ach-full-list {
      grid-template-columns: 1fr;
    }
  }


  /* FIX V3.1: Osiągnięcia hero jako pełna szerokość + tabela/mapa pod spodem */
  .ach-hero-v3 {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 44px !important;
    min-height: auto !important;
    padding-top: 82px !important;
    padding-bottom: 78px !important;
  }

  .ach-hero-v3 .ach-hero-text {
    max-width: 1040px !important;
    width: 100%;
    justify-self: center !important;
    text-align: center;
  }

  .ach-hero-v3 .ach-hero-meta {
    justify-content: center;
  }

  .ach-hero-v3 .ach-hero-title {
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
    font-size: clamp(42px, 5.2vw, 72px);
    line-height: 1.02;
  }

  .ach-hero-v3 .ach-hero-lead {
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
    font-size: 18px;
  }

  .ach-hero-v3 .ach-hero-actions {
    justify-content: center;
  }

  .ach-hero-v3 .ach-board {
    max-width: 1040px !important;
    width: 100%;
    justify-self: center !important;
    margin-top: 10px;
  }

  .ach-hero-v3 .ach-board-head {
    max-width: 780px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }

  .ach-hero-v3 .ach-board-head .home-eyebrow {
    text-align: center;
  }

  .ach-hero-v3 .ach-board::after {
    right: 34px;
    top: 30px;
  }

  .ach-hero-v3 .ach-year-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .ach-hero-v3 .ach-year-card {
    min-height: 132px;
  }

  @media (max-width: 760px) {
    .ach-hero-v3 {
      padding-top: 56px !important;
      padding-bottom: 54px !important;
      gap: 30px !important;
    }

    .ach-hero-v3 .ach-hero-text {
      text-align: left;
    }

    .ach-hero-v3 .ach-hero-meta,
    .ach-hero-v3 .ach-hero-actions {
      justify-content: flex-start;
    }

    .ach-hero-v3 .ach-hero-title {
      font-size: clamp(36px, 12vw, 52px);
      margin-left: 0;
      margin-right: 0;
    }

    .ach-hero-v3 .ach-hero-lead {
      font-size: 16px;
      margin-left: 0;
      margin-right: 0;
    }

    .ach-hero-v3 .ach-board-head {
      text-align: left;
      max-width: calc(100% - 64px);
      margin-left: 0;
      margin-right: 0;
    }

    .ach-hero-v3 .ach-board-head .home-eyebrow {
      text-align: left;
    }

    .ach-hero-v3 .ach-year-list {
      grid-template-columns: 1fr;
    }
  }

/* ────────────────────────────────────────────────────────────────────────────
   PATH-CHOICE SCREEN (Arkusze do druku PDF / Trening)
   ──────────────────────────────────────────────────────────────────────────── */

#screen-path .path-card {
  /* Inherits .opt-card visual treatment — these tweaks just lift the hover state */
  position: relative;
  overflow: hidden;
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}
#screen-path .path-card:hover,
#screen-path .path-card:focus-visible {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(184, 149, 106, 0.18);
  border-color: var(--gold-2);
  outline: none;
}

/* ────────────────────────────────────────────────────────────────────────────
   PDF CONFIGURATOR SCREEN
   Reuses .slider-rail and .slider-card from the training config screen, so
   the sliders here are visually identical to those in the existing trainer.
   ──────────────────────────────────────────────────────────────────────────── */

.pdf-config {
  display: flex;
  flex-direction: column;
  gap: 28px;
  max-width: 980px;
  margin: 0 auto;
  padding: 8px 0 24px;
}

.pdf-section {
  background: linear-gradient(180deg, #fffdf7 0%, #fbf6ec 100%);
  border: 1px solid var(--gold-1);
  border-radius: var(--r-lg);
  padding: 24px 26px;
  box-shadow: 0 8px 22px rgba(184, 149, 106, 0.08);
}

.pdf-section-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 32px;
  align-items: center;
}

.pdf-section-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-3);
  margin-bottom: 14px;
}

.pdf-section-help {
  font-family: var(--font-body);
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.55;
  margin-top: -8px;
  margin-bottom: 16px;
}

/* Warning shown when user tries to uncheck the last action type.
   Hidden by default; .show triggers a brief shake animation. */
.pdf-min-warning {
  font-family: var(--font-body);
  font-size: 13.5px;
  font-weight: 600;
  color: #a23a1f;
  background: #fdecdc;
  border: 1px solid #f1b994;
  border-radius: var(--r-sm);
  padding: 10px 14px;
  margin: -8px 0 14px;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity 200ms ease, max-height 200ms ease, padding 200ms ease, margin 200ms ease;
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
  margin-bottom: 0;
  border-width: 0;
}
.pdf-min-warning.show {
  opacity: 1;
  max-height: 60px;
  padding: 10px 14px;
  margin: -4px 0 14px;
  border-width: 1px;
  animation: pdf-warning-shake 400ms ease;
}
@keyframes pdf-warning-shake {
  0%, 100% { transform: translateX(0); }
  20%      { transform: translateX(-4px); }
  40%      { transform: translateX(4px); }
  60%      { transform: translateX(-2px); }
  80%      { transform: translateX(2px); }
}

/* ── Checkboxy typów działań ── */
.pdf-actions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.pdf-check {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: rgba(255, 253, 247, 0.7);
  border: 1.5px solid var(--line-soft);
  border-radius: var(--r-sm);
  cursor: pointer;
  user-select: none;
  transition: background 180ms ease, border-color 180ms ease, transform 180ms ease;
}
.pdf-check:hover {
  background: #fffdf7;
  border-color: var(--gold-2);
  transform: translateX(2px);
}
.pdf-check input[type="checkbox"] {
  /* Native checkbox hidden — visual state shown via .pdf-check-box */
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
/* Empty box by default — pseudo-element ::after holds the ✓ that only shows
   when the checkbox is :checked. So unchecking actually HIDES the mark. */
.pdf-check-box {
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 2px solid var(--line);
  border-radius: 6px;
  position: relative;
  transition: background 180ms ease, border-color 180ms ease;
}
.pdf-check-box::after {
  content: '✓';
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 18px;
  color: var(--ink);
  opacity: 0;
  transform: scale(0.6);
  transition: opacity 160ms ease, transform 160ms ease;
}
.pdf-check input:checked ~ .pdf-check-box {
  background: linear-gradient(135deg, #ffddb5 0%, #f5cb9a 100%);
  border-color: var(--gold-2);
}
.pdf-check input:checked ~ .pdf-check-box::after {
  opacity: 1;
  transform: scale(1);
}
.pdf-check input:focus-visible ~ .pdf-check-box {
  box-shadow: 0 0 0 3px rgba(232, 213, 178, 0.45);
}
.pdf-check-label {
  font-family: var(--font-body);
  font-size: 14.5px;
  font-weight: 600;
  color: var(--ink);
}
.pdf-check-wide {
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
}

/* ── Wybór typu działań — wyraźne kafelki z dużym kwadratem checkboxa
   po lewej (visually obvious что-zaznaczone), znakiem działania i nazwą ── */
.pdf-action {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: #fff;
  border: 2px solid var(--line-soft);
  border-radius: 10px;
  cursor: pointer;
  user-select: none;
  transition: background 180ms ease, border-color 180ms ease, transform 180ms ease;
  position: relative;
}
.pdf-action:hover {
  background: #fffdf7;
  border-color: var(--gold-2);
  transform: translateY(-1px);
}
.pdf-action input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.pdf-action-box {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 2px solid var(--ink-soft);
  border-radius: 6px;
  position: relative;
  transition: background 180ms ease, border-color 180ms ease;
}
.pdf-action-box::after {
  content: '✓';
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 20px;
  color: #fff;
  opacity: 0;
  transform: scale(0.4);
  transition: opacity 160ms ease, transform 160ms ease;
}
.pdf-action input:checked ~ .pdf-action-box {
  background: var(--ink);
  border-color: var(--ink);
}
.pdf-action input:checked ~ .pdf-action-box::after {
  opacity: 1;
  transform: scale(1);
}
.pdf-action input:focus-visible ~ .pdf-action-box {
  box-shadow: 0 0 0 3px rgba(232, 213, 178, 0.55);
}
/* Stan "zaznaczony" wyraźnie podświetla całą kafelkę — od razu widać co wybrałeś */
.pdf-action:has(input:checked) {
  background: linear-gradient(135deg, #fffdf7 0%, #fdeece 100%);
  border-color: var(--gold-2);
  box-shadow: 0 4px 12px rgba(184, 149, 106, 0.18);
}
.pdf-action-text {
  display: flex;
  align-items: baseline;
  gap: 10px;
  min-width: 0;
}
.pdf-action-sign {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 22px;
  color: var(--gold-3);
  line-height: 1;
  min-width: 22px;
  text-align: center;
}
.pdf-action:has(input:checked) .pdf-action-sign {
  color: var(--ink);
}
.pdf-action-name {
  font-family: var(--font-body);
  font-size: 14.5px;
  font-weight: 600;
  color: var(--ink);
}

.pdf-btn-icon {
  font-size: 18px;
  margin-right: 6px;
}

.pdf-layout-warning {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff3cd;
  border: 1.5px solid #f0a500;
  border-radius: 10px;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 13.5px;
  color: #7a4f00;
  margin: 0 0 12px;
  line-height: 1.45;
}
.pdf-layout-warning svg {
  flex-shrink: 0;
  color: #c87800;
}

.pdf-foot-note {
  text-align: center;
  font-family: var(--font-body);
  font-size: 12.5px;
  color: var(--ink-soft);
  margin: 8px 0 0;
}

/* ═══════════════════════════════════════════════
   KREATOR PDF — bloki treningowe
   ═══════════════════════════════════════════════ */

.pdf-blocks-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 20px;
}

/* ── Pojedynczy blok treningowy ─────────────── */
.pdf-block {
  background: linear-gradient(135deg, #fffdf7 0%, #fef6e4 100%);
  border: 1.5px solid var(--gold-1);
  border-radius: var(--r-md);
  box-shadow: 0 4px 16px rgba(184,149,106,0.12);
  overflow: hidden;
  animation: blockIn 220ms cubic-bezier(.22,.68,0,1.2) both;
}

@keyframes blockIn {
  from { opacity: 0; transform: translateY(-10px) scale(0.98); }
  to   { opacity: 1; transform: none; }
}

.pdf-block.removing {
  animation: blockOut 180ms ease-in both;
}

@keyframes blockOut {
  from { opacity: 1; transform: scale(1); max-height: 600px; overflow: hidden; }
  to   { opacity: 0; transform: scale(0.97); max-height: 0; padding: 0; }
}

/* Pasek nagłówka */
.pdf-block-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px 12px;
  border-bottom: 1px solid rgba(184,149,106,0.18);
  background: rgba(255,243,220,0.55);
}

.pdf-block-num {
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-3);
  background: rgba(184,149,106,0.15);
  border-radius: 20px;
  padding: 4px 12px;
  flex-shrink: 0;
}

.pdf-block-title {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  color: var(--ink);
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pdf-block-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  background: transparent;
  color: var(--ink-faint);
  cursor: pointer;
  transition: background 160ms, color 160ms;
  flex-shrink: 0;
  padding: 0;
}

.pdf-block-remove:hover {
  background: rgba(220,60,60,0.12);
  color: #c0392b;
}

/* Treść bloku — siatka */
.pdf-block-body {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0;
}

/* Pole "Typ działań" — rozciąga się na całą szerokość */
.pdf-block-field-ops {
  grid-column: 1 / -1;
  border-bottom: 1px solid rgba(184,149,106,0.13);
}

.pdf-block-field {
  padding: 18px 20px;
  border-right: 1px solid rgba(184,149,106,0.13);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.pdf-block-field:last-child {
  border-right: none;
}

.pdf-block-field-label {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold-3);
}

/* Typ działań — kafelki */
.pdf-op-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.pdf-op-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  border-radius: 24px;
  border: 1.5px solid var(--gold-1);
  background: var(--surface);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-soft);
  cursor: pointer;
  transition: background 140ms, color 140ms, border-color 140ms, box-shadow 140ms;
  user-select: none;
  line-height: 1.2;
}

.pdf-op-btn:hover {
  border-color: var(--gold-2);
  color: var(--ink);
  background: rgba(255,243,220,0.6);
}

.pdf-op-btn.active {
  background: var(--gold-2);
  border-color: var(--gold-2);
  color: #fff;
  box-shadow: 0 3px 10px rgba(184,149,106,0.35);
}

.pdf-op-sign {
  font-weight: 800;
  font-size: 16px;
  line-height: 1;
}

/* Stepper */
.pdf-stepper {
  display: flex;
  align-items: center;
  background: var(--surface);
  border: 1.5px solid var(--gold-1);
  border-radius: var(--r-sm);
  overflow: hidden;
  width: fit-content;
}

.pdf-stepper-btn {
  width: 40px;
  height: 44px;
  border: none;
  background: transparent;
  color: var(--gold-2);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  transition: background 120ms;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.pdf-stepper-btn:hover:not(:disabled) {
  background: rgba(184,149,106,0.14);
}

.pdf-stepper-btn:disabled {
  opacity: 0.28;
  cursor: not-allowed;
}

.pdf-stepper-val {
  min-width: 48px;
  text-align: center;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  color: var(--ink);
  padding: 0 4px;
  border-left: 1px solid var(--gold-1);
  border-right: 1px solid var(--gold-1);
  line-height: 44px;
}
input.pdf-stepper-input {
  min-width: 58px;
  width: 58px;
  height: 44px;
  line-height: 44px;
  text-align: center;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  color: var(--ink);
  padding: 0 4px;
  border: none;
  border-left: 1px solid var(--gold-1);
  border-right: 1px solid var(--gold-1);
  border-radius: 0;
  background: transparent;
  outline: none;
  -moz-appearance: textfield;
}
input.pdf-stepper-input::-webkit-inner-spin-button,
input.pdf-stepper-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
input.pdf-stepper-input:focus {
  background: var(--surface);
  color: var(--accent);
}

.pdf-stepper-sub {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--ink-faint);
  margin-top: 2px;
}

/* Poziom trudności — pills */
.pdf-range-pills {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.pdf-range-pill {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  border-radius: 24px;
  border: 1.5px solid var(--gold-1);
  background: var(--surface);
  cursor: pointer;
  transition: background 130ms, border-color 130ms;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-soft);
  user-select: none;
}

.pdf-range-pill:hover {
  border-color: var(--gold-2);
  background: rgba(255,243,220,0.6);
}

.pdf-range-pill.active {
  background: var(--gold-2);
  border-color: var(--gold-2);
  color: #fff;
}

.pdf-range-pill-num {
  font-family: var(--font-mono);
  font-size: 11px;
  opacity: 0.70;
}

/* Układ poziomy toggle */
.pdf-block-horizontal-toggle {
  margin-top: 6px !important;
  font-size: 13.5px !important;
}

/* Przycisk dodaj sekcję */
.pdf-add-block-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 16px 24px;
  border-radius: var(--r-md);
  border: 2px dashed var(--gold-1);
  background: rgba(255,243,220,0.25);
  color: var(--gold-2);
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: background 150ms, border-color 150ms, color 150ms;
}

.pdf-add-block-btn:hover {
  background: rgba(255,243,220,0.7);
  border-color: var(--gold-2);
  color: var(--gold-3);
}

/* Podsumowanie */
.pdf-summary-section {
  background: linear-gradient(180deg, #fffdf7 0%, #fdf3e3 100%);
}

.pdf-summary-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 14px;
}

.pdf-summary-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  border-radius: var(--r-sm);
  background: rgba(255,255,255,0.75);
  border: 1px solid rgba(184,149,106,0.16);
  font-size: 14.5px;
  color: var(--ink);
}

.pdf-summary-row-sign {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--gold-2);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 800;
  flex-shrink: 0;
}

.pdf-summary-row-desc {
  flex: 1;
  font-weight: 500;
}

.pdf-summary-row-count {
  font-family: var(--font-mono);
  font-size: 12.5px;
  font-weight: 700;
  color: var(--gold-3);
  background: rgba(184,149,106,0.10);
  border-radius: 12px;
  padding: 3px 11px;
  white-space: nowrap;
}

.pdf-summary-empty {
  font-size: 14px;
  color: var(--ink-faint);
  font-style: italic;
  text-align: center;
  padding: 12px 0;
}

.pdf-summary-totals {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  padding-top: 12px;
  border-top: 1px dashed rgba(184,149,106,0.30);
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink-soft);
}

.pdf-summary-totals strong {
  color: var(--ink);
  font-weight: 700;
}

/* ── Responsive — tablet ────────────────────── */
@media (max-width: 960px) {
  .pdf-block-body {
    grid-template-columns: 1fr 1fr;
  }
  .pdf-block-field-ops {
    grid-column: 1 / -1;
  }
}

/* ── Responsive — mobile ────────────────────── */
@media (max-width: 680px) {
  .pdf-section {
    padding: 20px 18px;
  }
  .pdf-block-body {
    grid-template-columns: 1fr;
  }
  .pdf-block-field-ops {
    grid-column: 1 / -1;
  }
  .pdf-block-field {
    border-right: none;
    border-bottom: 1px solid rgba(184,149,106,0.13);
    padding: 16px 18px;
  }
  .pdf-block-field:last-child {
    border-bottom: none;
  }
  .pdf-range-pills {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .pdf-range-pill {
    padding: 7px 12px;
    font-size: 13.5px;
  }
  .pdf-op-btn {
    padding: 7px 14px;
    font-size: 13.5px;
  }
  .pdf-block-header {
    padding: 12px 16px 10px;
  }
  .pdf-block-title {
    font-size: 14px;
  }
}

@media (max-width: 480px) {
  .pdf-config { gap: 18px; }
  .pdf-section { padding: 16px 14px; }
  .pdf-check { padding: 12px 14px; gap: 10px; }
  .pdf-check-label { font-size: 14px; }
  .pdf-add-block-btn { padding: 14px 18px; font-size: 14px; }
  .pdf-stepper-val { min-width: 42px; font-size: 18px; }
  .pdf-stepper-btn { width: 36px; height: 40px; font-size: 20px; }
  .pdf-stepper-val { line-height: 40px; }
  .pdf-summary-row { font-size: 13.5px; }
}

/* ══════════════════════════════════════════════════════════════
   NOWY UI — NUMEROWANE KROKI (v11)
   ══════════════════════════════════════════════════════════════ */

/* ── Blok sekcji ─────────────────────────────────────────────── */
.pdf-block {
  background: #fff;
  border: 1.5px solid #e8e0d0;
  border-radius: 14px;
  margin-bottom: 18px;
  overflow: hidden;
  transition: box-shadow .18s, transform .18s;
}
.pdf-block:hover {
  box-shadow: 0 4px 24px rgba(180,140,40,.10);
}
.pdf-block.removing {
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity .18s, transform .18s;
}

/* ── Nagłówek bloku ───────────────────────────────────────────── */
.pdf-block-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 18px 12px;
  background: linear-gradient(90deg, #f9f4ea 0%, #fdf8f0 100%);
  border-bottom: 1.5px solid #e8e0d0;
}
.pdf-block-num {
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #8c6b2a;
}
.pdf-block-remove {
  background: none;
  border: none;
  cursor: pointer;
  color: #b89a4a;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  transition: background .15s, color .15s;
  padding: 0;
}
.pdf-block-remove:hover {
  background: #fbebd0;
  color: #c0392b;
}

/* ── Krok (pdf-step) ─────────────────────────────────────────── */
.pdf-step {
  display: flex;
  gap: 0;
  padding: 0;
  border-bottom: 1px solid #f0e8d8;
}
.pdf-step-last {
  border-bottom: none;
}

/* Lewa kolumna — koło z numerem */
.pdf-step-circle {
  flex: 0 0 52px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 18px;
  padding-bottom: 18px;
}
.pdf-step-circle::before {
  content: attr(data-n, '');
  display: none;
}
.pdf-step-circle {
  font-size: 13px;
  font-weight: 800;
  color: #fff;
  position: relative;
}
.pdf-step-circle::after {
  display: none;
}
/* Styl kółka przez własny element — używamy ::before z counter-reset */
.pdf-step-circle {
  /* Kółko budowane jako background */
}
.pdf-step-circle {
  background: none;
  /* Kółko robimy jako inline-flex z pseudo-elementem */
}
/* Prostsze rozwiązanie: sam element ma display:flex i zawiera cyfry jako tekst */
.pdf-step-circle {
  flex: 0 0 52px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 18px;
  padding-bottom: 14px;
  font-size: 0; /* ukryj tekst dziedziczony */
}
/* Tworzymy kółko przez box na samym tekście */
.pdf-step > .pdf-step-circle {
  font-size: 13px;
  font-weight: 800;
  color: #fff;
}
/* Owijamy cyfrę w kółko używając CSS — nadpisujemy całość */
.pdf-steps-wrap .pdf-step-circle,
.pdf-block .pdf-step-circle {
  flex: 0 0 52px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 16px;
  padding-bottom: 14px;
}
/* Styl kółka jako direct child span lub tekst */
.pdf-block .pdf-step-circle {
  position: relative;
}
.pdf-block .pdf-step-circle {
  font-size: 13px;
  font-weight: 800;
  color: #8c6b2a;
  /* Kółko za pomocą background na pseudo */
}

/* FINALNA implementacja kółka: cyfra + tło */
.pdf-step-circle {
  flex: 0 0 52px !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
  padding-top: 16px !important;
  padding-bottom: 14px !important;
  font-size: 0 !important;   /* zawartość tekstowa = cyfra */
  position: relative;
}
/* Cyfra w kółku przez pseudo-element nie działa dla dynamic content.
   Użyjemy więc stylu bezpośrednio na tekście wewnątrz: */
.pdf-step > .pdf-step-circle {
  font-size: 13px !important;
  font-weight: 800;
  color: transparent;
}
/* Tło + tekst kółka — przez samo ustawienie tła na elemencie */
.pdf-step-circle {
  width: 28px !important;
  flex: none !important;
  /* Kółko realizowane przez margin-left na pdf-step-body i absolute positioning */
}

/* Uproszczone — bezpośrednia implementacja bez pseudo */
.pdf-step {
  display: flex;
  align-items: flex-start;
  padding: 18px 20px 18px 18px;
  gap: 14px;
  border-bottom: 1px solid #f0e8d8;
}
.pdf-step-last {
  border-bottom: none;
}
.pdf-step-circle {
  width: 30px !important;
  height: 30px !important;
  flex: 0 0 30px !important;
  background: #b8890a;
  color: #fff !important;
  border-radius: 50%;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 0;
  box-shadow: 0 2px 8px rgba(184,137,10,.25);
}
.pdf-step-body {
  flex: 1;
  min-width: 0;
}
.pdf-step-title {
  font-size: 14px;
  font-weight: 700;
  color: #3a2c10;
  margin-bottom: 4px;
  margin-top: 3px;
}
.pdf-step-desc {
  font-size: 12.5px;
  color: #7a6640;
  margin-bottom: 12px;
  line-height: 1.4;
}

/* ── Siatka kart zakresów ────────────────────────────────────── */
.pdf-range-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 10px;
}
@media (max-width: 640px) {
  .pdf-range-grid { grid-template-columns: repeat(2, 1fr); }
}

.pdf-range-card {
  border: 1.5px solid #e0d4b8;
  border-radius: 10px;
  padding: 10px 8px;
  text-align: center;
  background: #fdfaf3;
  transition: border-color .15s, background .15s, box-shadow .15s;
  cursor: default;
}
.pdf-range-card.active {
  border-color: #b8890a;
  background: #fffbf0;
  box-shadow: 0 0 0 2px rgba(184,137,10,.15);
}

/* Karta zakresu dla mul/div (klikalna, radio-style) */
.pdf-range-card-simple {
  border: 1.5px solid #e0d4b8;
  border-radius: 10px;
  padding: 10px 8px;
  text-align: center;
  background: #fdfaf3;
  cursor: pointer;
  transition: border-color .15s, background .15s, box-shadow .15s;
  width: 100%;
  font: inherit;
  user-select: none;
}
.pdf-range-card-simple:not(.pdf-range-card-clickable):hover {
  border-color: #c9a03a;
  background: #fdf6e3;
}
.pdf-range-card-simple.active {
  border-color: #b8890a;
  background: #fffbf0;
  box-shadow: 0 0 0 2px rgba(184,137,10,.20);
}

.pdf-range-card-name {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .07em;
  color: #8c6b2a;
  margin-bottom: 6px;
}
.pdf-range-card-desc {
  font-size: 10.5px;
  color: #9a8050;
  margin-top: 6px;
  line-height: 1.3;
}

/* Stepper wewnątrz karty zakresu */
.pdf-stepper-dist {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.pdf-stepper-dist .pdf-stepper-btn {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  padding: 0;
  border: 1.5px solid #d4c090;
  background: #fff;
  color: #8c6b2a;
  cursor: pointer;
  transition: background .13s, border-color .13s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pdf-stepper-dist .pdf-stepper-btn:hover:not(:disabled) {
  background: #fbebd0;
  border-color: #b8890a;
}
.pdf-stepper-dist .pdf-stepper-btn:disabled {
  opacity: .35;
  cursor: not-allowed;
}
.pdf-stepper-dist .pdf-stepper-val {
  min-width: 22px;
  text-align: center;
  font-size: 15px;
  font-weight: 700;
  color: #3a2c10;
}

/* ── Pasek postępu (usage bar) ───────────────────────────────── */
.pdf-usage-bar {
  margin-bottom: 10px;
  background: #fdf8f0;
  border: 1px solid #e8dcc8;
  border-radius: 8px;
  padding: 8px 12px;
}
.pdf-usage-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
}
.pdf-usage-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #9a8050;
}
.pdf-usage-val {
  font-size: 12px;
  font-weight: 700;
  color: #3a2c10;
}
.pdf-usage-track {
  height: 6px;
  background: #e8dcc8;
  border-radius: 99px;
  overflow: hidden;
}
.pdf-usage-fill {
  height: 100%;
  border-radius: 99px;
  background: #c9a03a;
  transition: width .25s ease;
}
.pdf-usage-bar.usage-full .pdf-usage-fill { background: #27ae60; }
.pdf-usage-bar.usage-ok  .pdf-usage-fill { background: #c9a03a; }
.pdf-usage-bar.usage-low .pdf-usage-fill { background: #e0b060; }
.pdf-usage-bar.usage-full .pdf-usage-val { color: #1e8449; }

/* ── Stepper operandów i przykładów ─────────────────────────── */
.pdf-stepper-operands,
.pdf-stepper-count {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border: 1.5px solid #d4c090;
  border-radius: 10px;
  background: #fff;
  overflow: hidden;
  margin-top: 4px;
}
.pdf-stepper-operands .pdf-stepper-btn,
.pdf-stepper-count   .pdf-stepper-btn {
  width: 36px;
  height: 36px;
  border: none;
  background: #fdf8f0;
  color: #8c6b2a;
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  transition: background .13s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.pdf-stepper-operands .pdf-stepper-btn:hover:not(:disabled),
.pdf-stepper-count   .pdf-stepper-btn:hover:not(:disabled) {
  background: #fbebd0;
}
.pdf-stepper-operands .pdf-stepper-btn:disabled,
.pdf-stepper-count   .pdf-stepper-btn:disabled {
  opacity: .35;
  cursor: not-allowed;
}
.pdf-stepper-operands .pdf-stepper-val,
.pdf-stepper-count   .pdf-stepper-val {
  min-width: 44px;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  color: #3a2c10;
  border-left: 1px solid #e8dcc8;
  border-right: 1px solid #e8dcc8;
  padding: 0 4px;
  line-height: 36px;
  user-select: none;
}

/* ── Podgląd przykładu (krok 5) ─────────────────────────────── */
.pdf-preview-box-big {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #fdf8f0 0%, #fff9ec 100%);
  border: 1.5px solid #e0d0a8;
  border-radius: 12px;
  padding: 20px 24px;
  margin: 10px 0 8px;
  min-height: 64px;
}
.pdf-preview-expr-big {
  font-size: 22px;
  font-weight: 700;
  color: #3a2c10;
  letter-spacing: .02em;
  text-align: center;
  font-family: 'Courier New', monospace;
  word-break: break-all;
}
.pdf-preview-fmt {
  font-size: 11.5px;
  color: #9a8050;
  text-align: center;
  margin-top: 2px;
}

/* ── Przycisk "Dodaj nową sekcję" (wewnątrz kroku 4) ─────────── */
.pdf-add-section-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 14px;
  padding: 9px 16px;
  border: 1.5px dashed #c9a03a;
  border-radius: 10px;
  background: transparent;
  color: #8c6b2a;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  font: inherit;
}
.pdf-add-section-btn:hover {
  background: #fdf3dc;
  border-color: #b8890a;
  color: #6b4e10;
}
.pdf-add-section-btn svg {
  flex-shrink: 0;
}

/* ── Siatka przycisków operacji ──────────────────────────────── */
.pdf-op-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-bottom: 10px;
}
.pdf-op-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 13px;
  border: 1.5px solid #ddd0b0;
  border-radius: 8px;
  background: #fdfaf3;
  color: #6a5520;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  transition: background .14s, border-color .14s, color .14s;
  font: inherit;
  line-height: 1.2;
  white-space: nowrap;
}
.pdf-op-btn:hover:not(.active) {
  background: #fdf0d0;
  border-color: #c9a03a;
}
.pdf-op-btn.active {
  background: #b8890a;
  border-color: #b8890a;
  color: #fff;
}
.pdf-op-sign {
  font-size: 15px;
  font-weight: 800;
  line-height: 1;
}

/* ── Checkbox "Układ poziomy" ────────────────────────────────── */
.pdf-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 12.5px;
  color: #6a5520;
  user-select: none;
  margin-top: 4px;
}
.pdf-check input[type="checkbox"] { display: none; }
.pdf-check-box {
  width: 16px;
  height: 16px;
  border: 1.5px solid #c9a03a;
  border-radius: 4px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background .14s;
}
.pdf-check input:checked + .pdf-check-box {
  background: #b8890a;
  border-color: #b8890a;
}
.pdf-check input:checked + .pdf-check-box::after {
  content: '';
  width: 8px;
  height: 5px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg) translateY(-1px);
}
.pdf-check-label {
  font-weight: 600;
}

/* ── Pasek podsumowania (updateSummary) ──────────────────────── */
/* Istniejące klasy z pliku bazowego — tylko drobne nadpisania */
.pdf-usage-wrap {
  margin-bottom: 0;
}

/* ══════════════════════════════════════════════════════════════
   UX POLISH v2 — kompaktowe kroki, multi-select, segmented bar
   ══════════════════════════════════════════════════════════════ */

/* ── Kompaktowy blok ─────────────────────────────────────────── */
.pdf-block {
  border-radius: 12px !important;
  margin-bottom: 12px !important;
}
.pdf-block-header {
  padding: 10px 16px !important;
}
.pdf-block-num {
  font-size: 11px !important;
  letter-spacing: .1em !important;
}

/* ── Kompaktowe kroki ────────────────────────────────────────── */
.pdf-step {
  padding: 12px 16px 12px 14px !important;
  gap: 12px !important;
  align-items: flex-start;
}
/* Krok inline (2 i 4) — poziomy układ tytuł + controls */
.pdf-step.pdf-step-inline {
  align-items: center !important;
  padding: 10px 16px !important;
}
.pdf-step.pdf-step-inline .pdf-step-body {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}
.pdf-step.pdf-step-inline .pdf-step-title {
  margin-bottom: 0 !important;
  white-space: nowrap;
  flex-shrink: 0;
}
.pdf-step-circle {
  width: 26px !important;
  height: 26px !important;
  flex: 0 0 26px !important;
  font-size: 12px !important;
}
.pdf-step-title {
  font-size: 13px !important;
  margin-bottom: 6px !important;
  margin-top: 0 !important;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.pdf-step-hint {
  font-size: 11.5px;
  color: #9a8050;
  margin-bottom: 8px;
  line-height: 1.35;
}
.pdf-step-hint-inline {
  font-size: 11.5px;
  font-weight: 400;
  color: #9a8050;
}

/* Krok podglądu — kompaktowy */
.pdf-step.pdf-step-last {
  padding: 10px 16px !important;
  border-bottom: none;
  align-items: center !important;  /* wycentruj kółko 5 z tekstem */
}
.pdf-step.pdf-step-last > .pdf-step-circle {
  align-items: center !important;  /* kółko nie u góry, tylko na środku */
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.pdf-step-preview-body {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap;
}
.pdf-step-preview-body .pdf-step-title {
  margin-bottom: 0 !important;
  flex-shrink: 0;
  width: auto;
}
.pdf-preview-box-big {
  flex: 1;
  min-height: 44px !important;
  padding: 10px 18px !important;
  margin: 0 !important;
  min-width: 180px;
}
.pdf-preview-expr-big {
  font-size: 20px !important;
}
.pdf-preview-fmt { display: none; }

/* ── Przycisk dodaj sekcję — poza krokami ────────────────────── */
.pdf-block-add-row {
  padding: 0 16px 14px;
  display: flex;
  justify-content: flex-start;
}
.pdf-add-section-btn {
  padding: 9px 18px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border-width: 2px !important;
  letter-spacing: .02em;
  gap: 8px !important;
  background: #fffbf2 !important;
  border-color: #b8890a !important;
  color: #7a5a00 !important;
  box-shadow: 0 1px 4px rgba(184,137,10,.15);
  transition: background .15s, transform .1s, box-shadow .15s !important;
}
.pdf-add-section-btn:hover {
  background: #fdf0cf !important;
  border-color: #9a6e00 !important;
  color: #5a4000 !important;
  transform: translateY(-1px);
  box-shadow: 0 3px 10px rgba(184,137,10,.2) !important;
}

/* ── Multi-select op buttons ─────────────────────────────────── */
.pdf-op-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px !important;
  margin-bottom: 8px !important;
}
.pdf-op-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 12px !important;
  font-size: 12.5px !important;
  border-radius: 8px !important;
  transition: background .13s, border-color .13s, color .13s !important;
  position: relative;
}
/* Checkbox-style (add/sub) */
.pdf-op-btn.pdf-op-chk {
  border: 1.5px solid #ddd0b0;
  background: #fdfaf3;
  color: #6a5520;
}
.pdf-op-btn.pdf-op-chk.active {
  border-color: #b8890a !important;
  background: #fff8e7 !important;
  color: #5a3e00 !important;
  box-shadow: 0 0 0 2px rgba(184,137,10,.15);
}
.pdf-op-btn.pdf-op-chk:hover:not(.active) {
  background: #fdf0d0;
  border-color: #c9a03a;
}
/* Radio-style (mul/div) */
.pdf-op-btn.pdf-op-radio {
  border: 1.5px solid #ddd0b0;
  background: #fdfaf3;
  color: #6a5520;
}
.pdf-op-btn.pdf-op-radio.active {
  background: #b8890a !important;
  border-color: #b8890a !important;
  color: #fff !important;
}
.pdf-op-btn.pdf-op-radio:hover:not(.active) {
  background: #fdf0d0;
  border-color: #c9a03a;
}
.pdf-chk-icon {
  font-size: 11px;
  font-weight: 900;
  width: 14px;
  height: 14px;
  border: 1.5px solid currentColor;
  border-radius: 3px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  flex-shrink: 0;
  background: transparent;
  transition: background .12s, border-color .12s;
}
.pdf-op-btn.active .pdf-chk-icon {
  background: #b8890a;
  border-color: #b8890a;
  color: #fff;
}

/* Helper text w checkboxie "Układ poziomy" */
.pdf-check {
  display: flex !important;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 6px;
  margin-top: 6px !important;
}
.pdf-check-hint {
  font-size: 11px;
  color: #9a8050;
  width: 100%;
  margin-left: 22px;
  line-height: 1.35;
}

/* ── Stepper — duże przyciski ────────────────────────────────── */
.pdf-stepper-operands,
.pdf-stepper-count {
  border-radius: 10px !important;
}
.pdf-stepper-operands .pdf-stepper-btn,
.pdf-stepper-count   .pdf-stepper-btn {
  width: 42px !important;
  height: 42px !important;
  font-size: 20px !important;
  cursor: pointer;
}
.pdf-stepper-operands .pdf-stepper-val,
.pdf-stepper-count   .pdf-stepper-val {
  min-width: 48px !important;
  font-size: 17px !important;
  line-height: 42px !important;
}

/* Mały stepper w kartach zakresów */
.pdf-stepper-dist .pdf-stepper-btn {
  width: 28px !important;
  height: 28px !important;
  font-size: 16px !important;
}
.pdf-stepper-dist .pdf-stepper-val {
  font-size: 16px !important;
  min-width: 24px !important;
}

/* ── Siatka kart zakresów — kompaktowa ───────────────────────── */
.pdf-range-grid {
  gap: 6px !important;
  margin-top: 8px !important;
}
.pdf-range-card,
.pdf-range-card-simple {
  padding: 8px 6px !important;
  border-radius: 8px !important;
}
.pdf-range-card-name {
  font-size: 9.5px !important;
  margin-bottom: 5px !important;
}
.pdf-range-card-desc {
  font-size: 10px !important;
  margin-top: 5px !important;
}

/* ── Segmentowy pasek rozkładu ───────────────────────────────── */
.pdf-usage-bar {
  padding: 7px 10px !important;
  margin-bottom: 8px !important;
  border-radius: 8px !important;
}
.pdf-usage-info {
  margin-bottom: 5px !important;
}
.pdf-usage-label {
  font-size: 9.5px !important;
  letter-spacing: .09em !important;
}
.pdf-usage-val {
  font-size: 12px !important;
  font-weight: 800 !important;
}
.pdf-seg-bar {
  display: flex;
  gap: 3px;
  flex-wrap: wrap;
  align-items: center;
}
.pdf-seg {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 3px;
  flex-shrink: 0;
  transition: background .2s, transform .1s;
}
.pdf-seg-r0 { background: #27ae60; }   /* Jedności — zielony */
.pdf-seg-r1 { background: #2980b9; }   /* Dziesiątki — niebieski */
.pdf-seg-r2 { background: #e67e22; }   /* Setki — pomarańczowy */
.pdf-seg-r3 { background: #8e44ad; }   /* Tysiące — fioletowy */
.pdf-seg-empty {
  background: #e8dcc8;
  border: 1px dashed #c9b890;
}
.pdf-usage-bar.usage-full .pdf-seg-empty { background: #d4edd4; border-color: #27ae60; }
.pdf-usage-bar.usage-full .pdf-usage-val { color: #1e8449; font-weight: 800; }

/* Legenda zakresów pod siatką */
.pdf-range-card.active .pdf-range-card-name { color: #3a2c10; }
.pdf-range-card-simple.active .pdf-range-card-name { color: #3a2c10; }

/* ── Podsumowanie — nowy format ──────────────────────────────── */
.pdf-summary-row {
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.pdf-summary-row:last-child { border-bottom: none; }
.pdf-sr-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}
.pdf-sr-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: rgba(255,255,255,.15);
  border-radius: 6px;
  font-size: 14px;
  font-weight: 800;
  flex-shrink: 0;
}
.pdf-sr-name {
  flex: 1;
  font-size: 12.5px;
}
.pdf-sr-pages {
  font-size: 11px;
  opacity: .7;
  white-space: nowrap;
}
.pdf-sr-detail {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  align-items: center;
  margin-left: 32px;
}
.pdf-sr-ranges {
  font-size: 11.5px;
  opacity: .85;
}
.pdf-sr-tag {
  font-size: 10.5px;
  background: rgba(255,255,255,.12);
  border-radius: 4px;
  padding: 2px 6px;
  opacity: .9;
  white-space: nowrap;
}
.pdf-sr-count {
  font-size: 11.5px;
  font-weight: 700;
  opacity: .9;
  margin-left: auto;
}
.pdf-totals-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 12.5px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,.15);
  margin-top: 4px;
}

/* ── Mobile ──────────────────────────────────────────────────── */
@media (max-width: 560px) {
  .pdf-step { padding: 10px 12px !important; gap: 9px !important; }
  .pdf-step.pdf-step-inline { padding: 9px 12px !important; }
  .pdf-op-btn { font-size: 11.5px !important; padding: 6px 10px !important; }
  .pdf-preview-expr-big { font-size: 17px !important; }
  .pdf-stepper-operands .pdf-stepper-btn,
  .pdf-stepper-count   .pdf-stepper-btn { width: 38px !important; height: 38px !important; }
  .pdf-range-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .pdf-seg { width: 12px !important; height: 12px !important; }
  .pdf-add-section-btn { width: 100%; justify-content: center; }
}

/* ══════════════════════════════════════════════════════════════
   POPRAWKI UX v3 — okrągłe kółka, wyśrodkowane karty, luźniejszy układ
   ══════════════════════════════════════════════════════════════ */

/* ── 1. Kółka kroków — idealnie okrągłe ─────────────────────── */
.pdf-step-circle,
.pdf-block .pdf-step-circle,
.pdf-steps-wrap .pdf-step-circle {
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  max-width: 28px !important;
  min-height: 28px !important;
  max-height: 28px !important;
  flex: 0 0 28px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 12px !important;
  line-height: 1 !important;
  padding: 0 !important;
  box-sizing: border-box !important;
}

/* ── 2. Karty zakresów — wyśrodkowane, ładniej zaokrąglone ──── */
.pdf-range-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr)) !important;
  gap: 8px !important;
  justify-items: center !important;
  margin-top: 10px !important;
}
.pdf-range-card,
.pdf-range-card-simple {
  border-radius: 14px !important;
  padding: 10px 8px !important;
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
}
.pdf-range-card .pdf-stepper-dist,
.pdf-range-card-simple .pdf-stepper-dist {
  justify-content: center !important;
  margin: 4px auto !important;
}
.pdf-range-card-name,
.pdf-range-card-desc {
  text-align: center !important;
}

/* ── 3. Luźniejszy układ sekcji ─────────────────────────────── */
.pdf-block {
  padding: 0 !important;
  margin-bottom: 18px !important;
  border-radius: 16px !important;
}
.pdf-step {
  padding: 14px 20px !important;
  gap: 14px !important;
}
.pdf-step.pdf-step-inline {
  padding: 12px 20px !important;
}
.pdf-step.pdf-step-last {
  padding: 12px 20px 14px !important;
}
.pdf-step + .pdf-step {
  border-top: 1px solid rgba(0,0,0,.06);
}
.pdf-step-body {
  width: 100%;
}
.pdf-step-title {
  font-size: 13.5px !important;
  font-weight: 700 !important;
  margin-bottom: 8px !important;
}
.pdf-step-hint {
  margin-bottom: 10px !important;
}
.pdf-block-header {
  padding: 12px 20px !important;
  border-radius: 16px 16px 0 0 !important;
}
.pdf-block-add-row {
  padding: 4px 20px 18px !important;
}

/* ── Mobile ──────────────────────────────────────────────────── */
@media (max-width: 560px) {
  .pdf-step { padding: 12px 14px !important; }
  .pdf-step.pdf-step-inline { padding: 10px 14px !important; }
  .pdf-block-header { padding: 10px 14px !important; }
  .pdf-block-add-row { padding: 4px 14px 14px !important; }
}

/* ══════════════════════════════════════════════════════════════
   SEGMENTY — stonowana paleta spójna ze stroną (gold/warm)
   ══════════════════════════════════════════════════════════════ */
.pdf-seg-r0 { background: #c49a3c !important; }   /* Jedności   — szałwiowa zieleń  */
.pdf-seg-r1 { background: #c49a3c !important; }   /* Dziesiątki — stalowy błękit    */
.pdf-seg-r2 { background: #c49a3c !important; }   /* Setki      — złoto/amber       */
.pdf-seg-r3 { background: #c49a3c !important; }   /* Tysiące    — ciepły fiolet     */

/* ══════════════════════════════════════════════════════════════
   KARTY ZAKRESÓW — czystszy układ, mniej ramek
   ══════════════════════════════════════════════════════════════ */

/* Siatka — równe kolumny, bez justify-items center (rozciągnij) */
.pdf-range-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 8px !important;
  margin-top: 10px !important;
}
@media (max-width: 560px) {
  .pdf-range-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

/* Karta — bez wielu ramek, samo delikatne tło */
.pdf-range-card,
.pdf-range-card-simple {
  border: none !important;
  border-radius: 14px !important;
  background: #faf5ea !important;
  padding: 12px 8px 10px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  gap: 6px !important;
  box-shadow: none !important;
  transition: background .15s !important;
}
.pdf-range-card:not(.pdf-range-card-clickable):hover,
.pdf-range-card-simple:not(.pdf-range-card-clickable):hover {
  background: #f5edd8 !important;
}
.pdf-range-card.active,
.pdf-range-card-simple.active {
  background: #fdefc8 !important;
  box-shadow: 0 0 0 2px #c9a030 !important;
}

/* Nazwa zakresu */
.pdf-range-card-name {
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: .09em !important;
  color: #7a5c18 !important;
  margin-bottom: 2px !important;
}

/* Opis */
.pdf-range-card-desc {
  font-size: 10px !important;
  color: #b09060 !important;
  margin-top: 2px !important;
  line-height: 1.3 !important;
}

/* Stepper wewnątrz karty — bez własnej ramki, flat */
.pdf-stepper-dist {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Przyciski − i + — płaskie, bez ramki */
.pdf-stepper-dist .pdf-stepper-btn {
  width: 30px !important;
  height: 30px !important;
  border-radius: 8px !important;
  border: none !important;
  background: rgba(184, 137, 10, .12) !important;
  color: #8a6010 !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background .12s !important;
  box-shadow: none !important;
  line-height: 1 !important;
}
.pdf-stepper-dist .pdf-stepper-btn:hover:not(:disabled) {
  background: rgba(184, 137, 10, .25) !important;
}
.pdf-stepper-dist .pdf-stepper-btn:disabled {
  opacity: .3 !important;
  cursor: default !important;
}

/* Wartość licznika */
.pdf-stepper-dist .pdf-stepper-val {
  font-size: 18px !important;
  font-weight: 800 !important;
  color: #3a2c10 !important;
  min-width: 28px !important;
  text-align: center !important;
  line-height: 1 !important;
  background: none !important;
  border: none !important;
}

/* ══════════════════════════════════════════════════════════════
   KARTY ZAKRESÓW — kolorowe tła per zakres + lepszy kontrast
   ══════════════════════════════════════════════════════════════ */

.pdf-range-grid > *:nth-child(1) {
  background: #e8f2e4 !important;
}
.pdf-range-grid > *:nth-child(1).active,
.pdf-range-grid > *:nth-child(1):has(.pdf-stepper-val:not(:empty)) {
  box-shadow: 0 0 0 2px #c49a3c !important;
  background: #fdefc8 !important;
}
.pdf-range-grid > *:nth-child(1) .pdf-range-card-name { color: #3d7030 !important; }
.pdf-range-grid > *:nth-child(1) .pdf-stepper-btn {
  background: rgba(127,168,106,.25) !important;
  color: #3d7030 !important;
}
.pdf-range-grid > *:nth-child(1) .pdf-stepper-btn:hover:not(:disabled) {
  background: rgba(127,168,106,.45) !important;
}

/* Dziesiątki — stalowy błękit */
.pdf-range-grid > *:nth-child(2) {
  background: #e4edf5 !important;
}
.pdf-range-grid > *:nth-child(2).active {
  box-shadow: 0 0 0 2px #6e90ad !important;
  background: #d4e2ef !important;
}
.pdf-range-grid > *:nth-child(2) .pdf-range-card-name { color: #2d5a7a !important; }
.pdf-range-grid > *:nth-child(2) .pdf-stepper-btn {
  background: rgba(110,144,173,.25) !important;
  color: #2d5a7a !important;
}
.pdf-range-grid > *:nth-child(2) .pdf-stepper-btn:hover:not(:disabled) {
  background: rgba(110,144,173,.45) !important;
}

/* Setki — amber/złoto */
.pdf-range-grid > *:nth-child(3) {
  background: #faefd4 !important;
}
.pdf-range-grid > *:nth-child(3).active {
  box-shadow: 0 0 0 2px #c49a3c !important;
  background: #f5e4b8 !important;
}
.pdf-range-grid > *:nth-child(3) .pdf-range-card-name { color: #8a6010 !important; }
.pdf-range-grid > *:nth-child(3) .pdf-stepper-btn {
  background: rgba(196,154,60,.25) !important;
  color: #8a6010 !important;
}
.pdf-range-grid > *:nth-child(3) .pdf-stepper-btn:hover:not(:disabled) {
  background: rgba(196,154,60,.45) !important;
}

/* Tysiące — ciepły fiolet */
.pdf-range-grid > *:nth-child(4) {
  background: #ede8f4 !important;
}
.pdf-range-grid > *:nth-child(4).active {
  box-shadow: 0 0 0 2px #9178a4 !important;
  background: #e0d8ec !important;
}
.pdf-range-grid > *:nth-child(4) .pdf-range-card-name { color: #5a3e7a !important; }
.pdf-range-grid > *:nth-child(4) .pdf-stepper-btn {
  background: rgba(145,120,164,.25) !important;
  color: #5a3e7a !important;
}
.pdf-range-grid > *:nth-child(4) .pdf-stepper-btn:hover:not(:disabled) {
  background: rgba(145,120,164,.45) !important;
}

/* Wartość licznika — ciemniejsza dla lepszego kontrastu */
.pdf-stepper-dist .pdf-stepper-val {
  color: #1a1408 !important;
  font-size: 20px !important;
}

/* Opis zakresu — nieco ciemniejszy */
.pdf-range-card-desc {
  color: #8a7040 !important;
}

/* Aktywna karta (active class) — wyraźniejsze tło */
.pdf-range-card.active,
.pdf-range-card-simple.active {
  background: inherit !important;
}

/* ══════════════════════════════════════════════════════════════
   KARTY ZAKRESÓW — ujednolicona paleta gold/cream jak reszta strony
   ══════════════════════════════════════════════════════════════ */

/* Reset kolorów per-range — jedna paleta dla wszystkich */
.pdf-range-grid > *:nth-child(1),
.pdf-range-grid > *:nth-child(2),
.pdf-range-grid > *:nth-child(3),
.pdf-range-grid > *:nth-child(4) {
  background: #faf4e8 !important;
  box-shadow: none !important;
}
.pdf-range-grid > *:nth-child(1):hover,
.pdf-range-grid > *:nth-child(2):hover,
.pdf-range-grid > *:nth-child(3):hover,
.pdf-range-grid > *:nth-child(4):hover {
  background: #f3e9d2 !important;
}
.pdf-range-grid > *:nth-child(1).active,
.pdf-range-grid > *:nth-child(2).active,
.pdf-range-grid > *:nth-child(3).active,
.pdf-range-grid > *:nth-child(4).active {
  background: #fdefc8 !important;
  box-shadow: 0 0 0 2px #c49a3c !important;
}

/* Nazwy zakresów — jeden kolor */
.pdf-range-grid > *:nth-child(1) .pdf-range-card-name,
.pdf-range-grid > *:nth-child(2) .pdf-range-card-name,
.pdf-range-grid > *:nth-child(3) .pdf-range-card-name,
.pdf-range-grid > *:nth-child(4) .pdf-range-card-name {
  color: #7a5c18 !important;
}

/* Przyciski − + — jeden styl amber */
.pdf-range-grid > *:nth-child(1) .pdf-stepper-btn,
.pdf-range-grid > *:nth-child(2) .pdf-stepper-btn,
.pdf-range-grid > *:nth-child(3) .pdf-stepper-btn,
.pdf-range-grid > *:nth-child(4) .pdf-stepper-btn {
  background: rgba(196,154,60,.18) !important;
  color: #8a6010 !important;
}
.pdf-range-grid > *:nth-child(1) .pdf-stepper-btn:hover:not(:disabled),
.pdf-range-grid > *:nth-child(2) .pdf-stepper-btn:hover:not(:disabled),
.pdf-range-grid > *:nth-child(3) .pdf-stepper-btn:hover:not(:disabled),
.pdf-range-grid > *:nth-child(4) .pdf-stepper-btn:hover:not(:disabled) {
  background: rgba(196,154,60,.38) !important;
}

/* Opis */
.pdf-range-card-desc {
  color: #a08040 !important;
}

/* fix — Jedności green override */
.pdf-range-grid > *:nth-child(1),
.pdf-range-grid > *:nth-child(1).active,
.pdf-range-grid > *:nth-child(1):has(.pdf-stepper-val) {
  background: none !important;
  box-shadow: none !important;
}
.pdf-range-grid > *:nth-child(1).active {
  background: #fdefc8 !important;
  box-shadow: 0 0 0 2px #faf4e8 !important;
}

/* ══════════════════════════════════════════════════════════════
   WALIDACJA — komunikat błędu "min 2 zakresy"
   ══════════════════════════════════════════════════════════════ */
.pdf-range-warning {
  display: none;
  align-items: center;
  gap: 9px;
  padding: 10px 14px;
  margin-bottom: 10px;
  background: #fdf1f1;
  border: 1px solid #e8a0a0;
  border-radius: 8px;
  color: #8b1a1a;
  font-family: var(--font-body, sans-serif);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.4;
  cursor: pointer;
  transition: background 160ms;
}
.pdf-range-warning:hover { background: #fde4e4; }
.pdf-range-warning svg { color: #b32424; }
.pdf-rwarn-text { flex: 1; }

/* ══ Ukrycie "Układ poziomy" dla mn/dz (nadpisuje display:flex !important) ══ */
.pdf-block-horizontal-toggle.pdf-horz-hidden { display: none !important; }
.pdf-block-rhythmic-toggle.pdf-horz-hidden { display: none !important; }

/* ══ Status rozkładu liczb ══ */
.pdf-usage-status { font-size: 11px; margin-top: 5px; font-weight: 500; }
.usage-status-ok  { color: #3a7d44; }
.usage-status-warn{ color: #b36b00; }
.usage-status-err { color: #c0392b; }

/* ══ Podsumowanie — nowy format czytelny ══ */
.pdf-sr-body { display: flex; flex-direction: column; gap: 2px; margin-top: 2px; }
.pdf-sr-line { font-size: 12.5px; color: #444; }
.pdf-sr-line.pdf-sr-op { font-weight: 600; color: #222; font-size: 13px; }
.pdf-sr-line.pdf-sr-count { color: #6b4f00; font-weight: 600; }
.pdf-sr-line.pdf-sr-line-tag { display: inline-block; background: #f5ead6; color: #7a5500; border-radius: 4px; padding: 0 6px; font-size: 11px; margin-top: 1px; }

/* ══ Tooltip pod nazwą — wrapper kolumnowy ══ */
.pdf-step-label-wrap { display: flex; flex-direction: column; gap: 2px; }

/* ══ Rytmika — zawsze włączona (badge) ══ */
.pdf-rhythmic-badge {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 10px; border-radius: 6px;
  background: #f0f7f0; border: 1px solid #c3dfc3;
  font-size: 12px; color: #2e6b2e; font-weight: 500;
  margin-top: 4px;
}
.pdf-rhythmic-icon { font-size: 14px; }

/* ══ Podsumowanie — kompaktowy układ ══ */
.pdf-summary-row {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 8px 12px; border-bottom: 1px solid #ede8df;
}
.pdf-summary-row:last-child { border-bottom: none; }
.pdf-sr-content { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }
.pdf-sr-top { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; font-size: 13.5px; }
.pdf-sr-top strong { font-size: 13.5px; }
.pdf-sr-dot { color: #bbb; font-size: 12px; }
.pdf-sr-op { color: #444; }
.pdf-sr-bottom { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.pdf-sr-meta { font-size: 12px; color: #666; }
.pdf-sr-count { font-size: 12.5px; font-weight: 700; color: #9a6f00; margin-left: auto; white-space: nowrap; }
.pdf-sr-chip { font-size: 11px; background: #f0f0f0; color: #555; border-radius: 4px; padding: 1px 6px; }

/* ══ Dual v2 layout — mnożenie/dzielenie ══ */
.pdf-dual-v2 {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pdf-dual-v2-cols {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 10px;
}
.pdf-dual-v2-card {
  flex: 1;
  background: #faf9f6;
  border: 1.5px solid #e4d9c4;
  border-radius: 10px;
  padding: 14px 12px 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
}
.pdf-dual-v2-hdr {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: #9a7e50;
  text-align: center;
}
.pdf-dual-v2-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}
.pdf-dual-v2-btn {
  padding: 9px 6px;
  border: 2px solid #ddd3bb;
  border-radius: 7px;
  background: #fff;
  color: #5c4a2a;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  text-align: center;
  line-height: 1.2;
  transition: border-color .15s, background .15s, color .15s, box-shadow .15s;
  font-family: inherit;
  white-space: nowrap;
}
.pdf-dual-v2-btn:hover:not(:disabled) {
  border-color: #c8a830;
  background: #fef6db;
  color: #3a2800;
}
.pdf-dual-v2-btn.active {
  background: #b88a0c;
  border-color: #b88a0c;
  color: #fff;
  font-weight: 700;
  box-shadow: 0 2px 6px rgba(184,138,12,.28);
}
.pdf-dual-v2-btn.active::after {
  content: ' ✓';
  font-size: 11px;
  opacity: .85;
}
.pdf-dual-v2-btn:disabled,
.pdf-dual-v2-btn.pdf-range-card-disabled {
  opacity: 0.28;
  cursor: not-allowed;
  pointer-events: none;
}
.pdf-dual-v2-desc {
  font-size: 11.5px;
  color: #7a6540;
  text-align: center;
  min-height: 16px;
  line-height: 1.4;
}
.pdf-dual-v2-sign {
  font-size: 28px;
  font-weight: 700;
  color: #c8a830;
  align-self: center;
  flex-shrink: 0;
  padding: 0 2px;
  user-select: none;
  line-height: 1;
}
.pdf-dual-v2-variant {
  background: #f7f2e5;
  border: 1.5px solid #ddd3bb;
  border-radius: 8px;
  padding: 9px 16px;
  text-align: center;
  font-size: 12.5px;
  color: #6b5530;
}
.pdf-dual-v2-variant strong {
  color: #8b6914;
  font-size: 14px;
  letter-spacing: .03em;
}
.pdf-dual-v2-preview {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 14px 16px;
  background: #fff;
  border: 1.5px solid #e4d9c4;
  border-radius: 10px;
  text-align: center;
}
.pdf-dual-v2-preview-label {
  font-size: 10.5px;
  color: #9a8060;
  text-transform: uppercase;
  letter-spacing: .07em;
  font-weight: 600;
}
.pdf-dual-v2-preview-expr {
  font-size: 32px;
  font-weight: 700;
  color: #2a1f0a;
  letter-spacing: .03em;
  line-height: 1.1;
  font-family: inherit;
}

/* Mobile */
@media (max-width: 620px) {
  .pdf-dual-v2-cols {
    flex-direction: column;
    align-items: stretch;
  }
  .pdf-dual-v2-sign {
    text-align: center;
    align-self: center;
    padding: 2px 0;
  }
  .pdf-dual-v2-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 340px) {
  .pdf-dual-v2-grid {
    grid-template-columns: 1fr;
  }
}

/* ══ Nadpisanie base CSS — aktywny stan kart w pdf-dual-v2 ══ */
/* Lewa karta (A): wygląd taki sam jak prawa — złote wypełnienie */
.pdf-dual-v2 .pdf-range-card-simple,
.pdf-dual-v2 .pdf-range-card-b-simple {
  border: 2px solid #ddd3bb !important;
  border-radius: 7px !important;
  padding: 9px 6px !important;
  background: #fff !important;
  color: #5c4a2a !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  box-shadow: none !important;
  width: auto !important;
}
.pdf-dual-v2 .pdf-range-card-simple:hover:not(:disabled),
.pdf-dual-v2 .pdf-range-card-b-simple:hover:not(:disabled) {
  border-color: #c8a830 !important;
  background: #fef6db !important;
  color: #3a2800 !important;
  box-shadow: none !important;
}
.pdf-dual-v2 .pdf-range-card-simple.active,
.pdf-dual-v2 .pdf-range-card-b-simple.active {
  background: #b88a0c !important;
  border-color: #b88a0c !important;
  color: #fff !important;
  font-weight: 700 !important;
  box-shadow: 0 2px 6px rgba(184,138,12,.28) !important;
}
.pdf-dual-v2 .pdf-range-card-simple.active::after,
.pdf-dual-v2 .pdf-range-card-b-simple.active::after {
  content: ' ✓';
  font-size: 11px;
  opacity: .85;
}
.pdf-dual-v2 .pdf-range-card-b-simple:disabled,
.pdf-dual-v2 .pdf-range-card-b-simple.pdf-range-card-disabled {
  opacity: 0.28 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  background: #fff !important;
  color: #5c4a2a !important;
  box-shadow: none !important;
}
/* Ukryj nazwę zakresu jako osobny div wewnątrz karty (nie potrzebna) */
.pdf-dual-v2 .pdf-range-card-name {
  display: none !important;
}

/* ══ Segmented selector v3 (mul/div) ══════════════════════════════ */
.pdf-seg-v3 {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pdf-seg-row {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.pdf-seg-hdr {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: #9a7e50;
  margin-bottom: 12px;
}
/* Track: rail + nodes */
.pdf-seg-track {
  position: relative;
  padding: 8px 0 4px;
}
.pdf-seg-rail {
  position: absolute;
  left: 12.5%;
  right: 12.5%;
  top: 22px;
  height: 2px;
  background: #ddd3bb;
  border-radius: 1px;
  z-index: 0;
}
.pdf-seg-nodes {
  display: flex;
  align-items: flex-start;
  position: relative;
  z-index: 1;
}
.pdf-seg-node {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
}
/* The circular dot button */
.pdf-seg-btn {
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  min-height: 28px !important;
  border-radius: 50% !important;
  border: 2px solid #ccc3aa !important;
  background: #fff !important;
  color: transparent !important;
  cursor: pointer !important;
  transition: border-color .15s, background .15s, box-shadow .15s, transform .15s !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: none !important;
  font-size: 0 !important;
  line-height: 0 !important;
  flex-shrink: 0 !important;
}
.pdf-seg-btn::after {
  content: '' !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: #ccc3aa !important;
  display: block !important;
}
.pdf-seg-btn:hover:not(:disabled) {
  border-color: #c8a830 !important;
  background: #fef6db !important;
  transform: scale(1.12) !important;
  box-shadow: none !important;
}
.pdf-seg-btn:hover:not(:disabled)::after {
  background: #c8a830 !important;
}
.pdf-seg-btn.active {
  width: 32px !important;
  height: 32px !important;
  min-width: 32px !important;
  min-height: 32px !important;
  background: #b88a0c !important;
  border-color: #b88a0c !important;
  box-shadow: 0 2px 8px rgba(184,138,12,.40) !important;
  transform: none !important;
}
.pdf-seg-btn.active::after {
  width: 10px !important;
  height: 10px !important;
  background: #fff !important;
}
/* Override aggressive base-CSS rules for pdf-range-card-simple */
.pdf-seg-v3 .pdf-range-card-simple,
.pdf-seg-v3 .pdf-range-card-b-simple {
  border-radius: 50% !important;
  padding: 0 !important;
  text-align: center !important;
  background: #fff !important;
  box-shadow: none !important;
  width: 28px !important;
}
.pdf-seg-v3 .pdf-range-card-simple.active,
.pdf-seg-v3 .pdf-range-card-b-simple.active {
  background: #b88a0c !important;
  border-color: #b88a0c !important;
  box-shadow: 0 2px 8px rgba(184,138,12,.40) !important;
}
.pdf-seg-v3 .pdf-range-card-simple.active::after,
.pdf-seg-v3 .pdf-range-card-b-simple.active::after {
  content: '' !important;
  font-size: 0 !important;
  width: 10px !important;
  height: 10px !important;
  border-radius: 50% !important;
  background: #fff !important;
  display: block !important;
  opacity: 1 !important;
}
.pdf-seg-v3 .pdf-range-card-name {
  display: none !important;
}
/* Disabled node */
.pdf-seg-btn.pdf-seg-disabled {
  opacity: 0.28 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}
.pdf-seg-name {
  font-size: 11px;
  font-weight: 600;
  color: #7a6540;
  text-align: center;
  line-height: 1.2;
  white-space: nowrap;
}
.pdf-seg-name-dim {
  opacity: 0.35;
}
.pdf-seg-desc {
  font-size: 12px;
  color: #7a6540;
  margin-top: 10px;
  min-height: 16px;
  text-align: center;
  line-height: 1.4;
}
.pdf-seg-div-hint {
  font-size: 10.5px;
  color: #b87040;
  margin-top: 5px;
  text-align: center;
  font-style: italic;
}
/* Sign between two rows */
.pdf-seg-sign {
  font-size: 26px;
  font-weight: 700;
  color: #c8a830;
  text-align: center;
  padding: 4px 0;
  user-select: none;
  line-height: 1;
  letter-spacing: -.01em;
}
/* Variant bar */
.pdf-seg-variant {
  background: #f7f2e5;
  border: 1.5px solid #ddd3bb;
  border-radius: 8px;
  padding: 9px 16px;
  text-align: center;
  font-size: 12.5px;
  color: #6b5530;
  margin-top: 2px;
}
.pdf-seg-variant strong {
  color: #8b6914;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .02em;
}
/* Mobile: scale down labels if needed */
@media (max-width: 420px) {
  .pdf-seg-name {
    font-size: 9.5px;
  }
  .pdf-seg-btn {
    width: 24px !important;
    height: 24px !important;
    min-width: 24px !important;
    min-height: 24px !important;
  }
  .pdf-seg-btn.active {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    min-height: 28px !important;
  }
  .pdf-seg-rail {
    top: 20px;
  }
}

/* ══ Podsumowanie — mobile fix ══ */
@media (max-width: 500px) {
  .pdf-summary-row {
    padding: 8px 10px !important;
    gap: 8px !important;
  }
  .pdf-sr-content {
    min-width: 0;
  }
  .pdf-sr-top {
    font-size: 13px !important;
    flex-wrap: wrap;
    row-gap: 2px;
  }
  .pdf-sr-bottom {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 3px !important;
    flex-wrap: nowrap !important;
  }
  .pdf-sr-meta {
    font-size: 11.5px !important;
    color: #666 !important;
    line-height: 1.5 !important;
    word-break: break-word;
  }
  .pdf-sr-count {
    margin-left: 0 !important;
    font-size: 12px !important;
  }
}

/* ══ Radio-pill selector (mul/div) ════════════════════════════════ */
.pdf-rpill-wrap {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pdf-rpill-group {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.pdf-rpill-hdr {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #9a7e50;
  margin-bottom: 8px;
}
.pdf-rpill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
/* Base pill style */
.pdf-rpill {
  padding: 7px 16px !important;
  border: 1.5px solid #ddd3bb !important;
  border-radius: 100px !important;
  background: #fff !important;
  color: #5c4a2a !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  line-height: 1.2 !important;
  transition: border-color .15s, background .15s, color .15s, box-shadow .15s !important;
  font-family: inherit !important;
  white-space: nowrap !important;
  box-shadow: none !important;
  width: auto !important;
  text-align: center !important;
  letter-spacing: .01em !important;
}
.pdf-rpill:hover:not(:disabled) {
  border-color: #c8a830 !important;
  background: #fef6db !important;
  color: #3a2400 !important;
}
/* Active pill */
.pdf-rpill.active,
.pdf-rpill-wrap .pdf-range-card-simple.active,
.pdf-rpill-wrap .pdf-range-card-b-simple.active {
  background: #b88a0c !important;
  border-color: #b88a0c !important;
  color: #fff !important;
  font-weight: 700 !important;
  box-shadow: 0 2px 6px rgba(184,138,12,.28) !important;
}
/* No checkmark — pills don't need ::after text */
.pdf-rpill-wrap .pdf-range-card-simple.active::after,
.pdf-rpill-wrap .pdf-range-card-b-simple.active::after {
  content: '' !important;
  font-size: 0 !important;
}
/* Disabled pill */
.pdf-rpill:disabled,
.pdf-rpill.pdf-rpill-disabled {
  opacity: 0.32 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  background: #f5f2ec !important;
  color: #aaa !important;
  border-color: #e0dcd4 !important;
  box-shadow: none !important;
}
/* Description under active pill */
.pdf-rpill-desc {
  margin-top: 8px;
  font-size: 12px;
  color: #8a7050;
  min-height: 16px;
  line-height: 1.4;
}
/* Division helper */
.pdf-rpill-hint {
  margin-top: 4px;
  font-size: 11px;
  color: #b87040;
  font-style: italic;
}
/* Variant box */
.pdf-rpill-variant {
  background: #f7f2e5;
  border: 1.5px solid #ddd3bb;
  border-radius: 8px;
  padding: 9px 16px;
  text-align: center;
  font-size: 12.5px;
  color: #6b5530;
  margin-top: 2px;
}
.pdf-rpill-variant strong {
  color: #8b6914;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .02em;
  display: block;
  margin-top: 3px;
}
/* Live preview */
.pdf-rpill-preview {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 14px 16px;
  background: #fff;
  border: 1.5px solid #e4d9c4;
  border-radius: 10px;
  text-align: center;
}
.pdf-rpill-preview-lbl {
  font-size: 10px;
  color: #9a8060;
  text-transform: uppercase;
  letter-spacing: .09em;
  font-weight: 700;
}
.pdf-rpill-preview-expr {
  font-size: 34px;
  font-weight: 700;
  color: #1a1400;
  letter-spacing: .02em;
  line-height: 1.1;
}
/* Mobile: 2×2 grid */
@media (max-width: 480px) {
  .pdf-rpill-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 7px !important;
  }
  .pdf-rpill {
    width: 100% !important;
    text-align: center !important;
  }
}

/* ══ Radio-pill — single row layout ══ */
.pdf-rpill-row {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 8px !important;
}
.pdf-rpill {
  flex: 1 1 0 !important;
  min-width: 0 !important;
}
/* Mobile override: 2×2 tylko na bardzo małych ekranach */
@media (max-width: 340px) {
  .pdf-rpill-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    flex-wrap: unset !important;
  }
  .pdf-rpill {
    flex: unset !important;
    width: 100% !important;
  }
}

/* ══ Radio-pill — radio circle + białe tło ══ */
/* Białe tło sekcji zakresów dla mul/div */
.pdf-rpill-wrap {
  background: #fff !important;
  border-radius: 10px !important;
  padding: 4px 0 !important;
}
.pdf-rpill-group {
  padding: 0 !important;
  margin-bottom: 4px !important;
}
/* Radio circle przed etykietą */
.pdf-rpill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 8px 18px 8px 14px !important;
  background: #fff !important;
  border: 1.5px solid #ddd3bb !important;
  border-radius: 100px !important;
  color: #4a3c1e !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
}
/* Pseudo-element: kółko radio */
.pdf-rpill::before {
  content: '';
  display: block;
  width: 14px;
  height: 14px;
  min-width: 14px;
  border-radius: 50%;
  border: 1.5px solid #b0a080;
  background: #fff;
  box-sizing: border-box;
  transition: border-color .15s, box-shadow .15s;
  flex-shrink: 0;
}
.pdf-rpill:hover:not(:disabled)::before {
  border-color: #c8a830 !important;
}
/* Aktywny — wypełnione kółko */
.pdf-rpill.active::before,
.pdf-rpill-wrap .pdf-range-card-simple.active::before,
.pdf-rpill-wrap .pdf-range-card-b-simple.active::before {
  border: 5px solid #b88a0c !important;
  background: #fff !important;
  box-shadow: none !important;
}
/* Aktywny pill: złota ramka, brak wypełnienia tła */
.pdf-rpill.active,
.pdf-rpill-wrap .pdf-range-card-simple.active,
.pdf-rpill-wrap .pdf-range-card-b-simple.active {
  background: #fffbf0 !important;
  border-color: #b88a0c !important;
  color: #3a2400 !important;
  font-weight: 700 !important;
  box-shadow: 0 0 0 2px rgba(184,138,12,.15) !important;
}
/* Wyłącz stary ::after checkmark */
.pdf-rpill-wrap .pdf-range-card-simple.active::after,
.pdf-rpill-wrap .pdf-range-card-b-simple.active::after {
  display: none !important;
  content: '' !important;
}
/* Disabled */
.pdf-rpill:disabled,
.pdf-rpill.pdf-rpill-disabled {
  opacity: 0.35 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  background: #fff !important;
  color: #9a8870 !important;
  border-color: #e8e2d8 !important;
  box-shadow: none !important;
}

/* ══ Radio-pill — BRAK BOXÓW, tylko kółko + etykieta ══ */
.pdf-rpill {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 4px 0 !important;
  color: #4a3c1e !important;
  font-size: 13.5px !important;
  font-weight: 400 !important;
  gap: 7px !important;
  cursor: pointer !important;
}
.pdf-rpill:hover:not(:disabled) {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: #1a1000 !important;
}
.pdf-rpill.active,
.pdf-rpill-wrap .pdf-range-card-simple.active,
.pdf-rpill-wrap .pdf-range-card-b-simple.active {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: #3a2400 !important;
  font-weight: 700 !important;
}
/* Brak tła na całym wrapperze */
.pdf-rpill-wrap {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  box-shadow: none !important;
}
/* Więcej odstępu między opcjami */
.pdf-rpill-row {
  gap: 20px !important;
}

/* ══ Radio-pill — final cleanup: mały tekst wariantu, brak boxów ══ */
/* Usuń stary box wariantu */
.pdf-rpill-variant {
  display: none !important;
}
/* Mały tekst "Wybrano: SETKI × JEDNOŚCI" */
.pdf-rpill-chosen {
  font-size: 12px;
  color: #9a7e50;
  margin-top: 6px;
  padding: 0;
  background: none;
  border: none;
  box-shadow: none;
}
.pdf-rpill-chosen strong {
  color: #7a5c14;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .03em;
  display: inline;
}
/* Sekcja zajmuje pełną szerokość kontenera */
.pdf-rpill-wrap {
  width: 100% !important;
  box-sizing: border-box !important;
}
/* Pillsy — pełna szerokość rzędu */
.pdf-rpill-row {
  width: 100% !important;
}

/* ══ Radio-pill — brak hover, "Wybrano" po prawej ══ */
/* Brak hover na pillsach */
.pdf-rpill:hover,
.pdf-rpill:hover:not(:disabled) {
  background: transparent !important;
  border-color: #ddd3bb !important;
  color: #4a3c1e !important;
  box-shadow: none !important;
  border: none !important;
}
.pdf-rpill:hover:not(:disabled)::before {
  border-color: #b0a080 !important;
}
/* Brak hover na kartach z base CSS */
.pdf-rpill-wrap .pdf-range-card-simple:hover,
.pdf-rpill-wrap .pdf-range-card-b-simple:hover {
  background: transparent !important;
  box-shadow: none !important;
  border-color: inherit !important;
}
/* Nadpisanie nth-child kolorów z base CSS */
.pdf-rpill-wrap .pdf-range-grid > *:nth-child(1),
.pdf-rpill-wrap .pdf-range-grid > *:nth-child(1).active,
.pdf-rpill-wrap .pdf-range-grid > *:nth-child(1):hover {
  background: none !important;
  box-shadow: none !important;
}
/* Layout: grupy po lewej, "Wybrano" po prawej */
.pdf-rpill-wrap {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 20px !important;
}
.pdf-rpill-main {
  flex: 1 !important;
  min-width: 0 !important;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
/* "Wybrano" po prawej — pionowo wyśrodkowany */
.pdf-rpill-chosen {
  flex-shrink: 0 !important;
  text-align: center !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 3px !important;
  min-width: 110px !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.pdf-rpill-chosen-lbl {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: #9a7e50;
}
.pdf-rpill-chosen strong {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #7a5c14 !important;
  display: block !important;
  line-height: 1.3 !important;
  letter-spacing: .02em !important;
}
/* Mobile: wróć do kolumny */
@media (max-width: 560px) {
  .pdf-rpill-wrap {
    flex-direction: column !important;
    align-items: flex-start !important;
  }
  .pdf-rpill-chosen {
    align-self: flex-start !important;
    text-align: left !important;
    align-items: flex-start !important;
    min-width: 0 !important;
  }
}

/* ══ Cofnięcie: "Wybrano" z powrotem pod radio buttonami ══ */
.pdf-rpill-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 10px !important;
}
.pdf-rpill-chosen {
  flex-shrink: unset !important;
  text-align: left !important;
  display: block !important;
  min-width: unset !important;
  font-size: 12px !important;
  color: #9a7e50 !important;
  margin-top: 2px !important;
  padding: 0 !important;
}
.pdf-rpill-chosen strong {
  font-size: 12px !important;
  display: inline !important;
  color: #7a5c14 !important;
}

/* ══ Krok 3 — titlerow z badge po prawej ══ */
.pdf-step3-titlerow {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}
.pdf-step3-titlecol {
  flex: 1;
  min-width: 0;
}
.pdf-step3-badge {
  flex-shrink: 0;
  background: #1a1e2e;
  color: #fff;
  border-radius: 100px;
  padding: 7px 18px;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  letter-spacing: .02em;
  align-self: center;
}
.pdf-step3-badge strong {
  font-weight: 700;
  color: #fff;
  letter-spacing: .04em;
}

/* ══ Karty wyboru zakresów (mul/div) — pdf-cv4 ══ */
.pdf-cv4 {
  display: flex;
  flex-direction: column;
  gap: 18px;
  width: 100%;
}
.pdf-cv4-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pdf-cv4-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #8a7050;
}
.pdf-cv4-row {
  display: flex;
  gap: 12px;
  width: 100%;
}
/* Wiersz z kartami (mul/div) - cztery równe kolumny jak add/sub */
.pdf-cv4-row-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
/* Klikalne karty mul/div - bazują na .pdf-range-card ale bez steppera */
.pdf-range-card-clickable {
  cursor: pointer;
  user-select: none;
}
/* Brak efektu hover - karta nie podnosi się ani nie zmienia tła */
.pdf-range-card-clickable:hover:not(.pdf-range-card-disabled) {
  transform: none;
}
/* Disabled (dzielnik > dzielna) - wyszarzona karta */
.pdf-range-card-disabled {
  opacity: 0.35;
  cursor: not-allowed;
  pointer-events: none;
  filter: grayscale(0.5);
}
/* Hint dzielenia */
.pdf-cv4-hint {
  font-size: 12px;
  color: #b07840;
  font-style: normal;
  padding: 4px 2px 0;
}
/* Podsumowanie wybranego wariantu */
.pdf-cv4-summary {
  background: #fff;
  border: 1.5px solid #e0dbd0;
  border-radius: 10px;
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 4px;
}
.pdf-cv4-summary-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #8a7050;
}
.pdf-cv4-summary-variant {
  font-size: 18px;
  font-weight: 800;
  color: #1a1e2e;
  letter-spacing: .03em;
}
/* Mobile: 2×2 */
@media (max-width: 500px) {
  .pdf-cv4-row-cards {
    grid-template-columns: repeat(2, 1fr);
  }
  .pdf-cv4-summary-variant {
    font-size: 16px;
  }
}

/* ══════════════════════════════════════════════════════════════
   MUL/DIV (pdf-cv4) — pełna szerokość + neutralizacja kolorowych teł
   .pdf-cv4 jest wewnątrz .pdf-range-grid (grid 4 kolumn), więc bez
   tej reguły zajmowałoby tylko jedną kolumnę i było wąskie.
   Dodatkowo :nth-child reguły z add/sub kolorowały karty na zielono,
   niebiesko itd. — zerujemy to.
   ══════════════════════════════════════════════════════════════ */

/* 1. pdf-cv4 rozciąga się na całą szerokość grid'a (span all columns) */
.pdf-range-grid:has(.pdf-cv4) {
  grid-template-columns: 1fr !important;
}

/* 2. Karty wewnątrz pdf-cv4 — neutralizacja kolorowych teł z :nth-child reguł */
.pdf-cv4-row-cards > .pdf-range-card,
.pdf-cv4-row-cards > .pdf-range-card-simple,
.pdf-cv4-row-cards > .pdf-range-card-b-simple {
  background: #fdfaf3 !important;
  box-shadow: none !important;
  color: inherit !important;
}
.pdf-cv4-row-cards > .pdf-range-card .pdf-range-card-name,
.pdf-cv4-row-cards > .pdf-range-card-simple .pdf-range-card-name,
.pdf-cv4-row-cards > .pdf-range-card-b-simple .pdf-range-card-name {
  color: #8c6b2a !important;
}
.pdf-cv4-row-cards > .pdf-range-card .pdf-range-card-desc,
.pdf-cv4-row-cards > .pdf-range-card-simple .pdf-range-card-desc,
.pdf-cv4-row-cards > .pdf-range-card-b-simple .pdf-range-card-desc {
  color: #9a8050 !important;
}

/* 3. Hover - bez efektu (taki sam jak na pierwszym dziecku add/sub) */
.pdf-cv4-row-cards > .pdf-range-card:hover:not(.pdf-range-card-disabled):not(.active),
.pdf-cv4-row-cards > .pdf-range-card-simple:hover:not(.pdf-range-card-disabled):not(.active),
.pdf-cv4-row-cards > .pdf-range-card-b-simple:hover:not(.pdf-range-card-disabled):not(.active) {
  background: #fdfaf3 !important;
  box-shadow: none !important;
  transform: none !important;
}

/* 4. Active state - złoty (taki sam jak w add/sub) */
.pdf-cv4-row-cards > .pdf-range-card.active,
.pdf-cv4-row-cards > .pdf-range-card-simple.active,
.pdf-cv4-row-cards > .pdf-range-card-b-simple.active {
  background: #fdefc8 !important;
  border-color: #c49a3c !important;
  box-shadow: 0 0 0 2px #c49a3c !important;
}
.pdf-cv4-row-cards > .pdf-range-card.active .pdf-range-card-name,
.pdf-cv4-row-cards > .pdf-range-card-simple.active .pdf-range-card-name,
.pdf-cv4-row-cards > .pdf-range-card-b-simple.active .pdf-range-card-name {
  color: #8a6010 !important;
}

/* 5. Disabled state - dla dzielnika większego niż dzielna */
.pdf-cv4-row-cards > .pdf-range-card-disabled {
  background: #faf6ec !important;
  opacity: 0.4 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}

/* ══ pdf-cv4 — karty zakresów dla mnożenia/dzielenia ══ */
.pdf-cv4 {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
}
.pdf-cv4-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pdf-cv4-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--gold-3, #8a6a3e);
}
.pdf-cv4-row {
  display: flex;
  gap: 10px;
  width: 100%;
}
.pdf-cv4-row-cards {
  display: flex;
  gap: 10px;
}
/* Clickable variant — nadpisuje stały kursor z base */
.pdf-range-card-clickable {
  cursor: pointer !important;
  user-select: none;
}
.pdf-range-card-clickable:hover:not(.pdf-range-card-disabled) {
  border-color: #e0d4b8 !important;
  background: #faf5ea !important;
}
/* Disabled — dla dzielnika > dzielna */
.pdf-range-card-disabled {
  opacity: 0.32 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}
/* Neutralizuj nth-child kolory w cv4 (nie mylić z add/sub) */
.pdf-cv4 .pdf-range-card-name {
  color: var(--ink, #041627) !important;
}
.pdf-cv4 .pdf-range-card-desc {
  color: var(--ink-faint, #74777d) !important;
}
/* Hint "Dzielnik nie może być..." */
.pdf-cv4-hint {
  font-size: 11px;
  color: #b07840;
  font-style: italic;
  margin-top: -2px;
}
/* Summary "Wybrany wariant" */
.pdf-cv4-summary {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
}
.pdf-cv4-summary-label {
  font-size: 11px;
  color: var(--ink-faint, #74777d);
  font-weight: 500;
}
.pdf-cv4-summary-variant {
  font-size: 12px;
  font-weight: 700;
  color: var(--ink, #041627);
  letter-spacing: .04em;
}
/* Mobile: 2×2 */
@media (max-width: 500px) {
  .pdf-cv4-row,
  .pdf-cv4-row-cards {
    flex-wrap: wrap;
  }
  .pdf-cv4-row .pdf-range-card,
  .pdf-cv4-row .pdf-range-card-simple {
    flex: 1 1 calc(50% - 5px);
  }
}

/* ══ Krok 3 — titlerow z badge "Wariant" po prawej ══ */
.pdf-step3-titlerow {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 4px;
}
.pdf-step3-titlecol {
  flex: 1;
  min-width: 0;
}
.pdf-step3-badge {
  flex-shrink: 0;
  background: #1a1e2e;
  color: #fff;
  border-radius: 100px;
  padding: 7px 18px;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  letter-spacing: .02em;
  align-self: center;
}
.pdf-step3-badge strong {
  font-weight: 700;
  color: #fff;
  letter-spacing: .04em;
}
@media (max-width: 560px) {
  .pdf-step3-titlerow {
    flex-direction: column;
    gap: 8px;
  }
  .pdf-step3-badge {
    align-self: flex-start;
    font-size: 11px;
    padding: 5px 14px;
  }
}

/* ══ Aktywna karta podczas hover — pokazuj active od razu ══ */
.pdf-cv4 .pdf-range-card-clickable.active:hover,
.pdf-cv4 .pdf-range-card-clickable.pdf-range-card-simple.active:hover,
.pdf-cv4 .pdf-range-card-clickable.pdf-range-card-b-simple.active:hover {
  background: #fdefc8 !important;
  border-color: #b8890a !important;
  box-shadow: 0 0 0 2px rgba(184,137,10,.20) !important;
}

/* ══ Neutralizuj hover na kontenerze pdf-cv4 (nth-child zmienia tło rodzica) ══ */
.pdf-range-grid > .pdf-cv4:nth-child(1):hover,
.pdf-range-grid > .pdf-cv4:nth-child(2):hover,
.pdf-range-grid > .pdf-cv4:nth-child(3):hover,
.pdf-range-grid > .pdf-cv4:nth-child(4):hover {
  background: #e8f2e4 !important;
}

/* ══ Picker mnożników / dzielników ══ */
.pdf-mult-picker {
  margin-top: 16px;
  background: #fff;
  border: 1.5px solid #d9c07a;
  border-radius: 12px;
  padding: 14px 16px 12px;
}

.pdf-mult-picker-header {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  color: #7a6a3a;
  background: #f5edcf;
  border: 1px solid #d9c07a;
  border-radius: 20px;
  display: inline-block;
  padding: 3px 12px;
  margin-bottom: 12px;
}

.pdf-mult-picker-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px 12px;
}

.pdf-mult-col {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pdf-mult-cb-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
  color: #2d2d2d;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 6px;
  transition: background .12s;
  user-select: none;
}

.pdf-mult-cb-label:hover {
  background: #fdf6e3;
}

.pdf-mult-cb-label-dis {
  opacity: .38;
  cursor: not-allowed;
}

.pdf-mult-cb-label-dis:hover {
  background: transparent;
}

.pdf-mult-cb {
  width: 18px;
  height: 18px;
  accent-color: #b8890a;
  cursor: pointer;
  flex-shrink: 0;
}

.pdf-mult-cb-label-dis .pdf-mult-cb {
  cursor: not-allowed;
}

.pdf-mult-hint {
  margin-top: 10px;
  font-size: 11.5px;
  color: #888;
  line-height: 1.5;
  border-top: 1px solid #ede5c8;
  padding-top: 8px;
}

/* ══ Kolumny 6-8 — mniejsza czcionka żeby zmieścić w wierszu ══ */
.col-grid[style*="--col-cols: 6"] .col-card,
.col-grid[style*="--col-cols: 7"] .col-card,
.col-grid[style*="--col-cols: 8"] .col-card {
  padding: 10px 8px 12px;
  gap: 6px;
}
.col-grid[style*="--col-cols: 6"] .col-row,
.col-grid[style*="--col-cols: 7"] .col-row,
.col-grid[style*="--col-cols: 8"] .col-row {
  font-size: 28px;
  line-height: 1.1;
  padding: 0 4px;
}
.col-grid[style*="--col-cols: 6"] .col-input,
.col-grid[style*="--col-cols: 7"] .col-input,
.col-grid[style*="--col-cols: 8"] .col-input {
  font-size: 28px;
  line-height: 1.1;
  padding: 5px 8px;
}
.col-grid[style*="--col-cols: 6"] .col-check-btn,
.col-grid[style*="--col-cols: 7"] .col-check-btn,
.col-grid[style*="--col-cols: 8"] .col-check-btn {
  padding: 5px 8px;
  font-size: 11px;
}
.col-grid[style*="--col-cols: 6"] .col-timer,
.col-grid[style*="--col-cols: 7"] .col-timer,
.col-grid[style*="--col-cols: 8"] .col-timer {
  padding: 4px 8px;
  font-size: 10px;
  letter-spacing: 0.12em;
}
.col-grid[style*="--col-cols: 6"] .col-timer .value,
.col-grid[style*="--col-cols: 7"] .col-timer .value,
.col-grid[style*="--col-cols: 8"] .col-timer .value {
  font-size: 12px;
}
@media (max-width: 1280px) {
  .col-grid[style*="--col-cols: 7"] .col-row,
  .col-grid[style*="--col-cols: 7"] .col-input,
  .col-grid[style*="--col-cols: 8"] .col-row,
  .col-grid[style*="--col-cols: 8"] .col-input { font-size: clamp(16px, 2.2vw, 26px); }
}

/* ══ Kolumny > konfiguracja — 4 suwaki w jednym wierszu ══ */
#screen-config-col .slider-rail {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 16px;
  max-width: none;
}
#screen-config-col .slider-rig {
  height: 260px !important;
}
@media (max-width: 1000px) {
  #screen-config-col .slider-rail {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 560px) {
  #screen-config-col .slider-rail {
    grid-template-columns: 1fr !important;
  }
}

/* ══ Mobile — większy input i przycisk w FLASH/KOLUMNY i MUL/DIV ══ */
@media (max-width: 600px) {
  /* Pole na wynik — wyższe, większa czcionka */
  .col-input {
    font-size: 22px !important;
    padding: 10px 12px !important;
    min-height: 48px !important;
    border-radius: 8px !important;
    border-width: 2px !important;
  }

  /* Przycisk ✓ w kolumnach — wyraźnie większy obszar dotyku */
  .col-check-btn {
    width: 52px !important;
    height: 48px !important;
    font-size: 22px !important;
    padding: 0 !important;
    border-radius: 8px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-width: 2px !important;
  }

  /* Przycisk ✓ w mnożeniu/dzieleniu */
  .mul-check-btn {
    width: 52px !important;
    height: 48px !important;
    font-size: 24px !important;
    border-radius: 8px !important;
    border-width: 2px !important;
  }

  /* Rząd z inputem — trochę więcej oddechu */
  .col-answer {
    gap: 10px !important;
    margin-top: 8px !important;
  }
}

/* ══ Mobile — cyfry w kolumnach FLASH ══ */
@media (max-width: 600px) {
  .col-row {
    font-size: 22px !important;
    line-height: 1.2 !important;
    padding: 2px 6px !important;
  }
}

/* ══ Mobile — większe cyfry w mnożeniu/dzieleniu FLASH ══ */
@media (max-width: 600px) {
  .mul-problem-row {
    font-size: 28px !important;
    gap: 8px !important;
  }
  .mul-input {
    font-size: 26px !important;
    padding: 8px 10px !important;
    min-height: 48px !important;
    border-radius: 8px !important;
    border-width: 2px !important;
  }
}


/* ── Desktop: przycisk ✓ pod polem wpisywania w kolumnach ─────────────────── */
@media (min-width: 601px) {
  .col-answer {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .col-check-btn {
    width: 100% !important;
    height: 36px !important;
  }
}

/* ── Desktop: mniej przestrzeni pod kartami kolumn ──────────────────────────── */
@media (min-width: 601px) {
  .col-card {
    padding-bottom: 4px !important;
    gap: 6px !important;
  }
  .col-feedback {
    min-height: 0 !important;
    padding: 0 2px 2px !important;
    line-height: 1.2 !important;
  }
}

/* ── Karty kolumn: nie rozciągaj do wysokości sąsiada ────────────────────── */
.col-grid {
  align-items: start !important;
}


/* ═══════════════════════════════════════════════════════════════════════════════
   SOROBAN — Interaktywny moduł
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ── Kolory sorobanu ─────────────────────────────────────────────────────────── */
:root {
  --sor-navy:        #2C3E6B;
  --sor-navy-dark:   #1a2d50;
  --sor-navy-light:  #3a4f85;
  --sor-navy-bg:     #e8ecf5;
  --sor-red:         #ad2c00;
  --sor-red-light:   #ffdbd1;
  --sor-gold:        #ffb300;
  --sor-gold-light:  #ffdf9e;
  --sor-gold-bg:     #fff8e1;
  --sor-rod-color:   #b71c1c;
  --sor-frame-bg:    #2C3E6B;
  --sor-beam-bg:     #2C3E6B;
  --sor-surface:     #ffffff;
  --sor-surface-low: #f5f2fb;
  --sor-outline:     #c6c5d4;
  --sor-ink:         #1b1b21;
  --sor-ink-soft:    #454652;
}

/* ── Layout strony sorobanu ──────────────────────────────────────────────────── */
#screen-soroban.active {
  display: block;
}

.sor-page {
  display: flex;
  flex-direction: row;
  gap: 28px;
  align-items: flex-start;
  max-width: 1280px;
  margin: 0 auto;
  padding: 32px 40px;
}

.sor-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.sor-sidebar {
  width: 340px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

/* ── Zakładki trybów ─────────────────────────────────────────────────────────── */
.sor-mode-tabs {
  display: flex;
  background: var(--sor-surface-low);
  border-radius: 999px;
  padding: 4px;
  gap: 2px;
  width: fit-content;
  margin-bottom: 16px;
}

.sor-mode-tab {
  padding: 10px 22px;
  border-radius: 999px;
  border: none;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  color: var(--ink-soft);
  background: transparent;
  transition: background 160ms, color 160ms, box-shadow 160ms;
}

.sor-mode-tab:hover {
  background: var(--surface-2);
  color: var(--sor-navy);
}

.sor-mode-tab.active {
  background: var(--sor-navy);
  color: #ffffff;
  box-shadow: 0 2px 8px rgba(0, 6, 102, 0.25);
}

/* ── Karty ───────────────────────────────────────────────────────────────────── */
.sor-card {
  background: var(--sor-surface);
  border-radius: 20px;
  padding: 28px;
  box-shadow: 0 4px 20px rgba(26, 35, 126, 0.08);
  border: 1px solid var(--sor-outline);
}

.sor-card-main {
  border-top: 4px solid var(--sor-navy);
}

.sor-card-info {
  border-top: 4px solid var(--sor-gold);
  background: #fffdf7;
}

.sor-card-controls {
  border-top: 4px solid var(--sor-navy);
}

.sor-card-stats {
  border-top: 4px solid var(--sor-red);
}

.sor-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.sor-title {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  color: var(--sor-navy);
  margin: 0 0 4px;
}

.sor-subtitle {
  font-size: 15px;
  color: var(--ink-soft);
  margin: 0;
}

.sor-card-title {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 700;
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.sor-card-title-navy  { color: var(--sor-navy); }
.sor-card-title-gold  { color: #7a5c00; }
.sor-card-title-red   { color: var(--sor-red); }

/* ── Kontrola liczby słupków ─────────────────────────────────────────────────── */
.sor-col-control {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--sor-surface-low);
  border: 1px solid var(--sor-outline);
  border-radius: 12px;
  padding: 10px 14px;
  flex-shrink: 0;
}

.sor-col-control-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--sor-ink-soft);
  white-space: nowrap;
}

.sor-col-stepper {
  display: flex;
  align-items: center;
  gap: 4px;
  background: var(--sor-surface);
  border: 1px solid var(--sor-outline);
  border-radius: 8px;
  padding: 2px;
}

.sor-stepper-btn {
  width: 30px;
  height: 30px;
  border: none;
  background: transparent;
  border-radius: 6px;
  font-size: 20px;
  font-weight: 700;
  color: var(--sor-navy);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: background 140ms;
}

.sor-stepper-btn:hover { background: var(--sor-navy-bg); }
.sor-stepper-btn:disabled { color: var(--ink-faint); cursor: not-allowed; }

.sor-stepper-val {
  font-family: var(--font-mono);
  font-size: 17px;
  font-weight: 700;
  color: var(--sor-navy);
  min-width: 28px;
  text-align: center;
}

.sor-col-range {
  font-size: 12px;
  color: var(--ink-faint);
  font-family: var(--font-mono);
  background: var(--surface-2);
  padding: 3px 8px;
  border-radius: 999px;
}

/* ── Panele trybów ───────────────────────────────────────────────────────────── */
.sor-mode-panel { display: none; margin-bottom: 16px; }
.sor-mode-panel.active { display: block; }

.sor-mode-hint {
  font-size: 14px;
  color: var(--ink-soft);
  background: var(--sor-navy-bg);
  border-radius: 10px;
  padding: 10px 14px;
  margin: 0;
}

/* Wpisz liczbę */
.sor-enter-row {
  display: flex;
  gap: 10px;
  align-items: center;
}

.sor-enter-input {
  flex: 1;
  height: 46px;
  padding: 0 14px;
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 700;
  border: 2px solid var(--sor-outline);
  border-radius: 10px;
  background: var(--sor-surface);
  color: var(--sor-navy);
  text-align: center;
  outline: none;
  transition: border-color 160ms;
  -moz-appearance: textfield;
}
.sor-enter-input::-webkit-outer-spin-button,
.sor-enter-input::-webkit-inner-spin-button { -webkit-appearance: none; }
.sor-enter-input:focus { border-color: var(--sor-navy); }

.sor-enter-msg {
  font-size: 13px;
  margin: 6px 0 0;
}
.sor-enter-msg.ok    { color: var(--success); }
.sor-enter-msg.error { color: var(--error); }

/* Zadanie (quiz) */
.sor-quiz-box {
  text-align: center;
}

.sor-quiz-instruction {
  font-size: 14px;
  color: var(--ink-soft);
  margin: 0 0 6px;
}

.sor-quiz-target {
  font-family: var(--font-mono);
  font-size: 42px;
  font-weight: 700;
  color: var(--sor-navy);
  letter-spacing: -0.02em;
  margin-bottom: 10px;
}

.sor-quiz-feedback {
  min-height: 24px;
  font-size: 14px;
  font-weight: 600;
  border-radius: 8px;
  padding: 0 12px;
  margin-bottom: 10px;
  transition: all 200ms;
}
.sor-quiz-feedback.correct {
  background: var(--success-soft);
  color: var(--success);
  padding: 8px 12px;
}
.sor-quiz-feedback.wrong {
  background: var(--error-soft);
  color: var(--error);
  padding: 8px 12px;
}

.sor-quiz-actions {
  display: flex;
  justify-content: center;
  gap: 10px;
}

/* ── Przyciski ───────────────────────────────────────────────────────────────── */
.sor-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 22px;
  height: 44px;
  border-radius: 10px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: all 120ms;
}

.sor-btn-primary {
  background: var(--sor-navy);
  color: #ffffff;
  border-bottom: 3px solid var(--sor-navy-dark);
}
.sor-btn-primary:hover { background: var(--sor-navy-light); }
.sor-btn-primary:active { border-bottom-width: 0; transform: translateY(3px); }
.sor-btn-primary:disabled { opacity: 0.4; cursor: not-allowed; transform: none; }

.sor-btn-secondary {
  background: var(--sor-navy-bg);
  color: var(--sor-navy);
  border: 1px solid var(--sor-outline);
}
.sor-btn-secondary:hover { background: #d0d3f0; }

.sor-btn-ghost {
  background: var(--surface-2);
  color: var(--ink-soft);
  border: 1px solid var(--line-soft);
  width: 100%;
}
.sor-btn-ghost:hover { background: var(--sor-outline); color: var(--sor-ink); }

.sor-btn-light {
  background: var(--sor-red-light);
  color: #5a1500;
  border: 1px solid #f0b9aa;
  width: 100%;
}
.sor-btn-light:hover { background: #ffb5a0; }

/* ── SOROBAN — rama, pręty, koraliki ────────────────────────────────────────── */
.sor-abacus-wrapper {
  margin: 20px 0;
  border: 1px solid var(--sor-outline);
  border-radius: 18px;
  overflow: hidden;
  background: var(--sor-surface);
}

.sor-frame {
  background: var(--sor-frame-bg);
  padding: 14px 14px 0;
  border-radius: 16px 16px 0 0;
  box-shadow: inset 0 0 24px rgba(0,0,0,0.45);
}

.sor-scroll-area {
  overflow-x: auto;
  background: #f5f2fb;
  border-radius: 12px 12px 0 0;
  scrollbar-width: thin;
  scrollbar-color: var(--sor-outline) transparent;
}
.sor-scroll-area::-webkit-scrollbar { height: 6px; }
.sor-scroll-area::-webkit-scrollbar-thumb { background: var(--sor-outline); border-radius: 3px; }

.sor-abacus-inner {
  display: flex;
  align-items: stretch;
  padding: 18px 10px 0;
  min-height: 300px;
  width: max-content;
  min-width: 100%;
  justify-content: center;
}

.sor-column {
  position: relative;
  width: 80px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.sor-col-divider {
  width: 2px;
  background: rgba(198, 197, 212, 0.35);
  align-self: stretch;
  flex-shrink: 0;
}

/* Pręt */
.sor-rod {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 7px;
  background: linear-gradient(to right, #b71c1c, #e53935, #b71c1c);
  left: 50%;
  transform: translateX(-50%);
  border-radius: 3px;
  box-shadow: inset 2px 0 4px rgba(0,0,0,0.2);
  z-index: 0;
}

/* Górna sekcja */
.sor-upper-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  height: 88px;
  position: relative;
  z-index: 1;
  justify-content: flex-end;
  padding-bottom: 4px;
}

.sor-top-spacer { flex: 1; }
.sor-upper-bottom-spacer { height: 0; }

/* Belka */
.sor-beam {
  width: 100%;
  height: 12px;
  background: var(--sor-beam-bg);
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.3), 0 3px 6px rgba(0,0,0,0.2);
  z-index: 2;
  position: relative;
}

/* Dolna sekcja */
.sor-lower-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  height: 176px;
  position: relative;
  z-index: 1;
  justify-content: flex-end;
  padding-bottom: 14px;
  gap: 4px;
}

/* Koraliki */
.sor-bead {
  width: 62px;
  height: 28px;
  border-radius: 999px;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  z-index: 3;
  transition: transform 160ms cubic-bezier(0.34, 1.56, 0.64, 1), opacity 120ms;
  user-select: none;
}

/* Górny koralik — nieaktywny: przy górze (z dala od belki) */
.sor-bead-upper {
  background: radial-gradient(circle at 30% 30%, #f0956a, #E8652A, #c04010);
  box-shadow: inset -2px -2px 5px rgba(0,0,0,0.3), 0 3px 6px rgba(0,0,0,0.2);
  align-self: flex-start;
  margin-top: 10px;
  /* nieaktywny → przy górze */
  transform: translateY(0);
}

/* Górny koralik aktywny: dosunięty do belki (translateY w dół) */
.sor-bead-upper.active {
  transform: translateY(46px);
}

/* Dolne koraliki — nieaktywne: przy dole */
.sor-bead-lower {
  background: radial-gradient(circle at 30% 30%, #fde87a, #F5C842, #e0a500);
  box-shadow: inset -2px -2px 5px rgba(0,0,0,0.3), 0 3px 6px rgba(0,0,0,0.2);
}

/* Dolny koralik aktywny: dosunięty do belki (translateY w górę) */
.sor-bead-lower.active {
  transform: translateY(-4px);
}

.sor-bead:hover { filter: brightness(1.12); }
.sor-bead:active { filter: brightness(0.9); }

/* ── Etykiety pod sorobanem ──────────────────────────────────────────────────── */
.sor-labels-scroll {
  overflow-x: auto;
  background: #f0edf8;
  border-top: 2px solid var(--sor-navy);
  scrollbar-width: none;
}
.sor-labels-scroll::-webkit-scrollbar { display: none; }

.sor-labels-inner {
  display: flex;
  align-items: flex-start;
  padding: 10px 10px 14px;
  width: max-content;
  min-width: 100%;
  justify-content: center;
}

.sor-label-spacer {
  width: 2px;
  flex-shrink: 0;
}

.sor-label-cell {
  width: 80px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.sor-digit-badge {
  width: 46px;
  height: 46px;
  background: var(--sor-navy);
  color: #ffffff;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 700;
  box-shadow: 0 2px 8px rgba(0,6,102,0.22);
}

.sor-col-name {
  font-size: 10px;
  font-weight: 700;
  color: var(--sor-ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-align: center;
  line-height: 1.3;
}

/* ── Wynik ───────────────────────────────────────────────────────────────────── */
.sor-result-box {
  background: var(--sor-navy-bg);
  border: 1px solid #c5cae9;
  border-radius: 16px;
  padding: 20px 24px;
  text-align: center;
}

.sor-result-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--sor-ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 6px;
}

.sor-result-number {
  font-family: var(--font-mono);
  font-size: 48px;
  font-weight: 700;
  color: var(--sor-navy);
  letter-spacing: -0.02em;
  line-height: 1;
  transition: color 200ms;
}

.sor-result-number.sor-result-correct { color: var(--success); }
.sor-result-number.sor-result-wrong   { color: var(--error); }

.sor-result-desc {
  font-size: 13px;
  color: var(--ink-soft);
  margin-top: 6px;
  line-height: 1.5;
}

/* ── Panel info (co oznaczają koraliki) ──────────────────────────────────────── */
.sor-info-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.sor-info-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.sor-info-list p {
  font-size: 14px;
  color: var(--ink-soft);
  margin: 0;
  line-height: 1.5;
}

.sor-info-badge {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  flex-shrink: 0;
  margin-top: 1px;
}

.sor-badge-upper { background: #E8652A; color: #fff; }
.sor-badge-lower { background: #ffb300; color: #3e2700; }
.sor-badge-col   { background: var(--sor-navy); color: #fff; font-size: 11px; }
.sor-badge-sum   { background: var(--success); color: #fff; font-size: 16px; }

/* ── Panel sterowania ────────────────────────────────────────────────────────── */
.sor-controls-hint {
  font-size: 14px;
  color: var(--ink-soft);
  margin: 0 0 14px;
  line-height: 1.5;
}

.sor-controls-btns {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* ── Panel statystyk ─────────────────────────────────────────────────────────── */
.sor-stats-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sor-stat-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 8px;
  border-bottom: 1px dashed var(--line-soft);
}

.sor-stat-row:last-child { border-bottom: none; padding-bottom: 0; }

.sor-stat-label {
  font-size: 14px;
  color: var(--ink-soft);
}

.sor-stat-val {
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 700;
  color: var(--sor-red);
}

/* ── Responsywność ────────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .sor-page {
    flex-direction: column;
    padding: 20px 18px 32px;
    gap: 20px;
  }

  .sor-sidebar {
    width: 100%;
  }

  .sor-card {
    padding: 20px 16px;
  }

  .sor-card-header {
    flex-direction: column;
    gap: 12px;
  }

  .sor-result-number {
    font-size: 36px;
  }
}

@media (max-width: 480px) {
  .sor-mode-tabs {
    width: 100%;
  }
  .sor-mode-tab {
    flex: 1;
    padding: 10px 10px;
    font-size: 12px;
    text-align: center;
  }
  .sor-title { font-size: 20px; }
  .sor-bead  { width: 52px; height: 24px; }
  .sor-column { width: 66px; }
  .sor-label-cell { width: 66px; }
  .sor-digit-badge { width: 38px; height: 38px; font-size: 16px; }
}

/* ═══ /SOROBAN ══════════════════════════════════════════════════════════════ */

/* ── Segmentowane przyciski liczby słupków (zastępują stepper +/-) ────────── */
.sor-col-presets {
  display: flex;
  gap: 3px;
  background: var(--sor-surface);
  border: 1px solid var(--sor-outline);
  border-radius: 10px;
  padding: 3px;
}

.sor-preset-btn {
  min-width: 36px;
  height: 34px;
  padding: 0 10px;
  border: none;
  border-radius: 7px;
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  color: var(--sor-ink-soft);
  background: transparent;
  cursor: pointer;
  transition: background 140ms, color 140ms;
}

.sor-preset-btn:hover  { background: var(--sor-navy-bg); color: var(--sor-navy); }
.sor-preset-btn.active { background: var(--sor-navy); color: #ffffff; }
/* ═══ /SOROBAN PRESET BUTTONS ══════════════════════════════════════════════ */

/* ── Podświetlenie błędnych kolumn w quizie ──────────────────────────────── */
.sor-column-wrong > .sor-rod {
  background: #E8652A;
  box-shadow: 0 0 6px rgba(232,101,42,.5);
}
.sor-column-wrong {
  outline: 2px solid #E8652A;
  outline-offset: 3px;
  border-radius: 4px;
}

.sor-digit-badge.wrong {
  background: #E8652A;
  color: #fff;
}

/* ── Kolory feedbacku quizu (poprawny / błędny / podpowiedź) ─────────────── */
.sor-quiz-feedback.correct  { background: #e6f4ea; color: #256029; border-color: #81c784; }
.sor-quiz-feedback.wrong    { background: #fde8e8; color: #8b0000; border-color: #ef9a9a; }
.sor-quiz-feedback.hint1    { background: #fff8e1; color: #5d4037; border-color: #ffe082; }
.sor-quiz-feedback.hint2    { background: #fff8e1; color: #5d4037; border-color: #ffe082; }
.sor-quiz-feedback.hint3    { background: #e3f2fd; color: #0d47a1; border-color: #90caf9; }

/* ── Przycisk podpowiedzi ────────────────────────────────────────────────── */
.sor-btn-hint {
  background: transparent;
  color: var(--sor-navy);
  border: 1.5px solid var(--sor-navy);
  font-size: 13px;
}
.sor-btn-hint:hover { background: var(--sor-navy-bg); }
/* ═══ /SOROBAN WRONG-COL + HINT ════════════════════════════════════════════ */

/* ── Tryb eksperta — własna liczba słupków (4–30) ────────────────────────── */
.sor-expert-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
  flex-wrap: wrap;
}

.sor-expert-label {
  font-size: 12px;
  color: var(--sor-ink-soft);
  white-space: nowrap;
}

.sor-expert-input {
  width: 70px;
  height: 30px;
  padding: 0 8px;
  border: 1.5px solid var(--sor-outline);
  border-radius: 7px;
  font-family: var(--font-mono);
  font-size: 13px;
  text-align: center;
  background: #fff;
  color: var(--sor-ink);
  outline: none;
  transition: border-color 140ms;
}

.sor-expert-input:focus { border-color: var(--sor-navy); }
.sor-expert-input.sor-input-error { border-color: #E8652A; animation: sor-shake 0.3s; }

@keyframes sor-shake {
  0%,100% { transform: translateX(0); }
  25%      { transform: translateX(-4px); }
  75%      { transform: translateX(4px); }
}

.sor-btn-sm {
  height: 30px;
  padding: 0 10px;
  font-size: 12px;
}

/* ── Opis zakresu kolumn ─────────────────────────────────────────────────── */
.sor-col-desc {
  margin-top: 5px;
  font-size: 11px;
  color: var(--sor-ink-soft);
  font-style: italic;
}

/* ── Karty statystyk — przełączanie per tryb ─────────────────────────────── */
.sor-stats-panel { transition: none; }

/* ── Wskazówki kontekstowe per tryb w sidebarze ──────────────────────────── */
.sor-mode-ctx { display: none; }
.sor-mode-ctx.active { display: block; }
/* ═══ /SOROBAN EXPERT MODE + PER-MODE STATS ════════════════════════════════ */

/* ══════════════════════════════════════════════════════════════════════════════
   SOROBAN REDESIGN v2 — pełna szerokość + ujednolicony styl strony
   ══════════════════════════════════════════════════════════════════════════════ */

/* Nadpisanie tokenów sorobanu — mapowanie na tokeny strony */
:root {
  --sor-navy:        #1a3f7d;
  --sor-navy-dark:   #102c5e;
  --sor-navy-light:  #2f5fb0;
  --sor-navy-bg:     #eef2fb;
  --sor-frame-bg:    #1a3f7d;
  --sor-beam-bg:     #1a3f7d;
  --sor-gold:        #b8956a;
  --sor-gold-light:  #fde0bd;
  --sor-gold-bg:     #fffbf0;
  --sor-surface:     #ffffff;
  --sor-surface-low: #f5f3f2;
  --sor-outline:     #d8d4cf;
  --sor-ink:         #041627;
  --sor-ink-soft:    #44474c;
}

/* ── Nowy layout strony — pionowy ─────────────────────────────────────────── */
.sor-page {
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 28px 32px 48px;
}

/* Stara siatka 2-kolumnowa — neutralizacja */
.sor-main  { all: unset; display: contents; }
.sor-sidebar { display: none !important; }

/* ── Nagłówek ─────────────────────────────────────────────────────────────── */
.sor-header-bar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.sor-header-controls {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  flex-wrap: wrap;
}

.sor-col-control {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 10px 16px;
  box-shadow: var(--shadow-soft);
}

.sor-title {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 4px;
}

.sor-subtitle {
  font-size: 15px;
  color: var(--ink-soft);
  margin: 0;
}

/* ── Soroban widget — pełna szerokość ─────────────────────────────────────── */
.sor-abacus-wrapper {
  margin: 0;
  border: 2px solid var(--blue-deep);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  background: var(--surface);
}

.sor-frame {
  border-radius: 0;
  padding: 14px 14px 0;
}

.sor-scroll-area {
  background: #182d52;
  border-radius: 8px 8px 0 0;
}

/* ── Pasek zerowania "na belce" ────────────────────────────────────────────── */
.sor-zero-bar {
  background: var(--blue-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 7px 14px;
  border-top: 1px solid rgba(255,255,255,0.12);
}

.sor-zero-btn {
  height: 30px;
  padding: 0 22px;
  background: rgba(255,255,255,0.13);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.28);
  border-radius: 999px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: background 140ms;
}
.sor-zero-btn:hover { background: rgba(255,255,255,0.26); }
.sor-zero-btn:active { background: rgba(255,255,255,0.1); }

/* Etykiety cyfr */
.sor-labels-scroll {
  background: var(--surface-2);
  border-top: 2px solid var(--blue-deep);
}

/* ── Wynik — pełna szerokość, poziomy ──────────────────────────────────────── */
.sor-result-box {
  background: var(--surface);
  border: 1px solid var(--line-soft);
  border-radius: var(--r-lg);
  padding: 20px 28px;
  display: flex;
  align-items: center;
  gap: 20px;
  box-shadow: var(--shadow-soft);
  text-align: left;
}

.sor-result-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--ink-faint);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  white-space: nowrap;
  margin: 0;
  flex-shrink: 0;
}

.sor-result-number {
  font-family: var(--font-mono);
  font-size: 52px;
  font-weight: 700;
  color: var(--blue-deep);
  letter-spacing: -0.02em;
  line-height: 1;
  transition: color 200ms;
  flex-shrink: 0;
}

.sor-result-desc {
  font-size: 14px;
  color: var(--ink-soft);
  margin: 0;
  line-height: 1.5;
}

/* ── Trzy kolumny poniżej ──────────────────────────────────────────────────── */
.sor-bottom-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 20px;
  align-items: start;
}

.sor-bottom-main {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.sor-bottom-stats {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* ── Zakładki — "połączone" z kartą poniżej ─────────────────────────────────── */
.sor-mode-tabs {
  display: flex;
  background: var(--surface-2);
  border: 1px solid var(--line-soft);
  border-bottom: none;
  border-radius: var(--r-lg) var(--r-lg) 0 0;
  padding: 6px 6px 0;
  gap: 4px;
  width: 100%;
  margin-bottom: 0;
}

.sor-mode-tab {
  flex: 1;
  padding: 10px 12px;
  border-radius: var(--r-md) var(--r-md) 0 0;
  border: none;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  color: var(--ink-soft);
  background: transparent;
  transition: background 140ms, color 140ms;
}

.sor-mode-tab:hover:not(.active) {
  background: var(--surface);
  color: var(--ink);
}

.sor-mode-tab.active {
  background: var(--surface);
  color: var(--blue-deep);
  box-shadow: none;
  border-bottom: 2px solid var(--blue-deep);
}

/* ── Karty — ujednolicone z resztą strony ───────────────────────────────────── */
.sor-card {
  background: var(--surface);
  border-radius: var(--r-lg);
  padding: 22px 24px;
  box-shadow: var(--shadow-soft);
  border: 1px solid var(--line-soft);
}

.sor-card-main {
  border-top: 3px solid var(--blue-deep);
  border-radius: 0 0 var(--r-lg) var(--r-lg);
  border-left: 1px solid var(--line-soft);
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  box-shadow: var(--shadow-soft);
}

.sor-card-info {
  border-top: 3px solid var(--gold-2);
  background: #fffcf7;
}

.sor-card-stats {
  border-top: 3px solid var(--error);
}

.sor-card-controls {
  border-top: 3px solid var(--blue-deep);
}

/* ── Koraliki — wyraźny kontrast aktywne/nieaktywne ──────────────────────── */
.sor-bead {
  width: 64px;
  height: 30px;
  border-radius: 999px;
  transition: transform 190ms cubic-bezier(0.34, 1.56, 0.64, 1),
              box-shadow 150ms,
              opacity 130ms;
}

/* Górny koralik nieaktywny — przygaszony, z dala od belki */
.sor-bead-upper {
  background: radial-gradient(circle at 35% 30%, #ffb090, #E86030, #b02800);
  box-shadow: inset -2px -3px 6px rgba(0,0,0,0.30), 0 3px 8px rgba(200,70,20,0.25);
  opacity: 0.38;
  transform: translateY(0);
}

/* Górny koralik aktywny — pełny, dosunięty do belki */
.sor-bead-upper.active {
  opacity: 1;
  transform: translateY(46px);
  box-shadow: inset -2px -3px 6px rgba(0,0,0,0.30), 0 6px 18px rgba(220,80,20,0.55);
}

/* Dolne koraliki nieaktywne — przygaszone */
.sor-bead-lower {
  background: radial-gradient(circle at 35% 30%, #fff5b0, #F5C830, #c89000);
  box-shadow: inset -2px -3px 6px rgba(0,0,0,0.25), 0 3px 7px rgba(220,180,0,0.22);
  opacity: 0.38;
}

/* Dolne koraliki aktywne — pełne, dosunięte do belki */
.sor-bead-lower.active {
  opacity: 1;
  transform: translateY(-6px);
  box-shadow: inset -2px -3px 6px rgba(0,0,0,0.25), 0 6px 16px rgba(220,175,0,0.50);
}

.sor-bead:hover { filter: brightness(1.1); opacity: 1 !important; }
.sor-bead:active { filter: brightness(0.88); }

/* ── Responsywność ────────────────────────────────────────────────────────── */
@media (max-width: 1050px) {
  .sor-bottom-row {
    grid-template-columns: 1fr 1fr;
  }
  .sor-bottom-main { grid-column: 1 / -1; }
}

@media (max-width: 680px) {
  .sor-page { padding: 16px 14px 40px; }
  .sor-bottom-row { grid-template-columns: 1fr; }
  .sor-header-bar { flex-direction: column; }
  .sor-result-box { flex-direction: column; gap: 8px; text-align: center; }
  .sor-result-number { font-size: 44px; }
}

/* ══ /SOROBAN REDESIGN v2 ═══════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════════════════════════════════
   SOROBAN — absolutne pozycjonowanie koralików (v3)
   Aktywne koraliki przy belce, nieaktywne przy dole — jak prawdziwy soroban
   ══════════════════════════════════════════════════════════════════════════════ */

/* Górna sekcja — kontener absolutny */
.sor-upper-area {
  position: relative;
  display: block;
  width: 100%;
  height: 88px;
  flex-shrink: 0;
}

/* Dolna sekcja — kontener absolutny */
.sor-lower-area {
  position: relative;
  display: block;
  width: 100%;
  height: 176px;
  flex-shrink: 0;
}

/* Wszystkie koraliki — absolutne, wyśrodkowane w poziomie */
.sor-bead-upper,
.sor-bead-lower {
  position: absolute;
  left: 50%;
  width: 64px;
  height: 30px;
  /* Usuń stare transformy z translateY */
  transform: translateX(-50%) !important;
}

/* Górny koralik — kolory + cień (bez translateY — pozycja z JS) */
.sor-bead-upper {
  background: radial-gradient(circle at 35% 30%, #ffb090, #E86030, #b02800);
  box-shadow: inset -2px -3px 6px rgba(0,0,0,0.30), 0 4px 12px rgba(200,70,20,0.30);
  margin-top: 0;
  align-self: unset;
  opacity: 0.42;
}

.sor-bead-upper.active {
  opacity: 1;
  box-shadow: inset -2px -3px 6px rgba(0,0,0,0.30), 0 6px 18px rgba(220,80,20,0.55);
}

/* Dolne koraliki — kolory + cień */
.sor-bead-lower {
  background: radial-gradient(circle at 35% 30%, #fff5b0, #F5C830, #c89000);
  box-shadow: inset -2px -3px 6px rgba(0,0,0,0.25), 0 3px 7px rgba(220,180,0,0.22);
  opacity: 0.38;
}

.sor-bead-lower.active {
  opacity: 1;
  box-shadow: inset -2px -3px 6px rgba(0,0,0,0.25), 0 5px 14px rgba(220,175,0,0.50);
}

/* Hover — rozjaśnienie i pełna widoczność */
.sor-bead:hover {
  filter: brightness(1.12);
  opacity: 1 !important;
  z-index: 10;
}

/* ══ /SOROBAN absolutne pozycjonowanie v3 ══════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V4 — REDESIGN (pasek sterowania + wielki soroban + ciemne tło)
   Zgodny z screen image_1779451256879.png
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Sekcja: tło i wrapper strony ───────────────────────────────────────── */
#screen-soroban {
  background: #111110 !important;
  padding: 0 !important;
  min-height: 100vh !important;
}

.sor-page {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 18px !important;
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 52px 28px 64px !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

/* ── Nagłówek ───────────────────────────────────────────────────────────── */
.sor-page-head {
  text-align: center !important;
  margin-bottom: 4px !important;
}
.sor-page-title {
  font-family: var(--font-display, 'Bricolage Grotesque', sans-serif) !important;
  font-size: clamp(28px, 4vw, 40px) !important;
  font-weight: 700 !important;
  color: #ccc8c0 !important;
  margin: 0 0 10px !important;
  letter-spacing: -0.02em !important;
  line-height: 1.15 !important;
}
.sor-page-desc {
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  font-size: 15px !important;
  color: #6e6b65 !important;
  line-height: 1.65 !important;
  max-width: 520px !important;
  margin: 0 auto !important;
}

/* ── Pasek sterowania ───────────────────────────────────────────────────── */
.sor-ctrl-bar {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  background: #ffffff !important;
  border-radius: 18px !important;
  padding: 14px 18px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  box-shadow: 0 6px 28px rgba(0,0,0,0.28) !important;
}

/* Zakładki */
.sor-tabs {
  display: flex !important;
  background: #f0ede8 !important;
  border-radius: 12px !important;
  padding: 4px !important;
  gap: 3px !important;
  flex-shrink: 0 !important;
}
.sor-mode-tab {
  padding: 9px 14px !important;
  border-radius: 9px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  background: transparent !important;
  color: #7a7770 !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  transition: all 130ms ease !important;
  white-space: nowrap !important;
}
.sor-mode-tab.active {
  background: #ffffff !important;
  color: #1a1a18 !important;
  box-shadow: 0 1px 6px rgba(0,0,0,0.13) !important;
}
.sor-mode-tab:hover:not(.active) {
  background: rgba(255,255,255,0.55) !important;
  color: #3a3830 !important;
}

/* Wynik z chipami */
.sor-num-display {
  flex: 1 !important;
  background: #f9f6f1 !important;
  border-radius: 13px !important;
  padding: 10px 18px 12px !important;
  text-align: center !important;
  border: 1px solid #e8e3dc !important;
  min-width: 0 !important;
}
.sor-num-label {
  font-size: 9px !important;
  font-weight: 700 !important;
  color: #aaa49c !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  margin-bottom: 2px !important;
}
.sor-result-number {
  font-family: var(--font-display, 'Bricolage Grotesque', sans-serif) !important;
  font-size: clamp(32px, 4vw, 48px) !important;
  font-weight: 800 !important;
  color: #1a1a18 !important;
  letter-spacing: -0.02em !important;
  line-height: 1 !important;
  margin-bottom: 8px !important;
}
.sor-result-number.sor-result-correct { color: #228b22 !important; }
.sor-result-number.sor-result-wrong   { color: #c0392b !important; }

/* Chipy rozbicia pozycyjnego */
.sor-chips-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 5px !important;
  justify-content: center !important;
  min-height: 20px !important;
}
.sor-chip {
  display: inline-block !important;
  padding: 3px 8px !important;
  border-radius: 20px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  color: #3a3830 !important;
  letter-spacing: 0.06em !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
}
.sor-chip-zero {
  background: #ececea !important;
  color: #8a8880 !important;
}

/* Przyciski akcji */
.sor-actions {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  flex-shrink: 0 !important;
}
.sor-act-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  height: 38px !important;
  padding: 0 14px !important;
  background: #ffffff !important;
  border: 1.5px solid #dedad4 !important;
  border-radius: 10px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  color: #4a4840 !important;
  letter-spacing: 0.06em !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  transition: background 120ms, border-color 120ms !important;
  white-space: nowrap !important;
}
.sor-act-btn:hover {
  background: #f4f1ed !important;
  border-color: #c4c0ba !important;
}
.sor-act-round {
  width: 38px !important;
  padding: 0 !important;
  justify-content: center !important;
  border-radius: 50% !important;
  font-size: 15px !important;
  font-weight: 700 !important;
}

/* ── Panele trybów ──────────────────────────────────────────────────────── */
#screen-soroban .sor-mode-panel {
  display: none !important;
  width: 100% !important;
}
#screen-soroban .sor-mode-panel.active { display: block !important; }

.sor-enter-card,
.sor-quiz-card {
  background: #1c1c1a !important;
  border: 1px solid #2e2e2b !important;
  border-radius: 16px !important;
  padding: 18px 22px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.sor-enter-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
}
.sor-enter-input {
  flex: 1 !important;
  min-width: 180px !important;
  height: 42px !important;
  padding: 0 14px !important;
  background: #2a2a27 !important;
  border: 1.5px solid #3a3a37 !important;
  border-radius: 10px !important;
  font-size: 15px !important;
  color: #e0dcd6 !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  outline: none !important;
}
.sor-enter-input:focus {
  border-color: #b8956a !important;
  background: #2e2e2b !important;
}
.sor-enter-msg {
  margin: 8px 0 0 !important;
  font-size: 13px !important;
  color: #8a8880 !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
}
.sor-enter-msg.ok    { color: #4db36a !important; }
.sor-enter-msg.error { color: #e05550 !important; }

/* Przyciski w panelach */
#screen-soroban .sor-btn {
  height: 42px !important;
  padding: 0 16px !important;
  border-radius: 10px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  transition: opacity 130ms !important;
  white-space: nowrap !important;
}
#screen-soroban .sor-btn:hover { opacity: 0.88 !important; }
#screen-soroban .sor-btn-primary   { background: #b8956a !important; color: #fff !important; }
#screen-soroban .sor-btn-secondary { background: #2e2e2b !important; color: #c8c4be !important; border: 1px solid #3e3e3b !important; }
#screen-soroban .sor-btn-hint      { background: #1e3a5a !important; color: #7ab8e8 !important; }
#screen-soroban .sor-btn-sm        { height: 34px !important; padding: 0 12px !important; font-size: 12px !important; }

/* Panel quiz */
.sor-quiz-box {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 10px !important;
}
.sor-quiz-instruction {
  font-size: 14px !important;
  color: #8a8880 !important;
  margin: 0 !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
}
.sor-quiz-target {
  font-family: var(--font-display, 'Bricolage Grotesque', sans-serif) !important;
  font-size: 42px !important;
  font-weight: 800 !important;
  color: #f0ece6 !important;
  letter-spacing: -0.02em !important;
}
.sor-quiz-feedback {
  font-size: 14px !important;
  min-height: 20px !important;
  color: #a0a89c !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
}
.sor-quiz-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  justify-content: center !important;
}

/* ── Pasek rozmiaru ─────────────────────────────────────────────────────── */
.sor-size-bar {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  width: 100% !important;
}
.sor-size-label {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #5a5850 !important;
  letter-spacing: 0.04em !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  white-space: nowrap !important;
}
.sor-preset-group {
  display: flex !important;
  gap: 5px !important;
}
.sor-preset-btn {
  padding: 6px 14px !important;
  border-radius: 20px !important;
  border: 1.5px solid #2e2e2b !important;
  background: #1c1c1a !important;
  color: #6a6860 !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  transition: all 120ms !important;
}
.sor-preset-btn:hover {
  border-color: #b8956a !important;
  color: #c8b08a !important;
}
.sor-preset-btn.active {
  background: #b8956a !important;
  border-color: #b8956a !important;
  color: #fff !important;
}
.sor-expert-row {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.sor-expert-label {
  font-size: 11px !important;
  color: #5a5850 !important;
  white-space: nowrap !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
}
.sor-expert-input {
  width: 60px !important;
  height: 32px !important;
  padding: 0 8px !important;
  background: #1c1c1a !important;
  border: 1.5px solid #2e2e2b !important;
  border-radius: 8px !important;
  color: #c8c4be !important;
  font-size: 12px !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
}
.sor-col-desc {
  font-size: 11px !important;
  color: #5a5850 !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  margin: 0 !important;
}

/* Statystyki ghost — niewidoczne, ale JS może je aktualizować */
.sor-stats-ghost { display: none !important; }

/* ── Karta sorobanu ─────────────────────────────────────────────────────── */
.sor-abacus-card {
  width: 100% !important;
  background: #ffffff !important;
  border-radius: 20px !important;
  padding: 0 !important;
  overflow: hidden !important;
  box-shadow: 0 8px 36px rgba(0,0,0,0.35) !important;
}

/* Zewnętrzna rama — krem/beż */
.sor-frame-wrap {
  width: 100% !important;
}
.sor-abacus-card .sor-frame {
  background: #e8dfd0 !important;
  border-radius: 20px !important;
  padding: 20px 20px 0 !important;
  position: relative !important;
  box-shadow: inset 0 0 40px rgba(100,70,30,0.15) !important;
  /* Wkręty w rogach */
  --screw-size: 10px !important;
}
/* Wkręty w narożnikach ramy */
.sor-abacus-card .sor-frame::before,
.sor-abacus-card .sor-frame::after {
  content: '◎' !important;
  position: absolute !important;
  font-size: 12px !important;
  color: #c0b090 !important;
  line-height: 1 !important;
}
.sor-abacus-card .sor-frame::before { top: 7px; left: 10px !important; }
.sor-abacus-card .sor-frame::after  { top: 7px; right: 10px !important; }

/* Obszar przewijania (cyfry + koraliki w jednym) */
.sor-abacus-card .sor-scroll-area {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  background: transparent !important;
  scrollbar-width: thin !important;
  scrollbar-color: #c0b090 transparent !important;
  border-radius: 0 !important;
  padding-bottom: 0 !important;
}
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar { height: 4px !important; }
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar-thumb { background: #c0b090 !important; border-radius: 2px !important; }

/* ── Cyfry nad słupkami ─────────────────────────────────────────────────── */
.sor-digit-row {
  display: flex !important;
  align-items: center !important;
  padding: 0 !important;
  margin: 0 !important;
  min-width: max-content !important;
}
.sor-digit-cell {
  font-family: var(--font-display, 'Bricolage Grotesque', sans-serif) !important;
  font-size: 26px !important;
  font-weight: 800 !important;
  color: #2a2520 !important;
  text-align: center !important;
  line-height: 1 !important;
  padding: 12px 0 10px !important;
  /* width matched by JS flex, same as .sor-column */
  flex-shrink: 0 !important;
}
.sor-digit-cell.zero  { color: #bbb4a8 !important; }
.sor-digit-cell.wrong { color: #c0392b !important; font-weight: 900 !important; }

/* Spacer między cyframi = szerokość .sor-col-divider */
.sor-digit-row .sor-label-spacer {
  flex-shrink: 0 !important;
}

/* ── Koraliki ────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-abacus-inner {
  display: flex !important;
  align-items: stretch !important;
  background: #f5ede0 !important;
  border-radius: 10px 10px 0 0 !important;
  padding: 0 !important;
  min-width: max-content !important;
}

/* Kolumna */
.sor-abacus-card .sor-column {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  position: relative !important;
  flex-shrink: 0 !important;
}

/* Pręt – metaliczny złoto-brąz */
.sor-abacus-card .sor-rod {
  background: linear-gradient(to right, #9a7040 10%, #d4a450 50%, #9a7040 90%) !important;
  border-radius: 3px !important;
  box-shadow: none !important;
}

/* Belka środkowa */
.sor-abacus-card .sor-beam {
  background: #f5ede0 !important;
  border-top: 2px solid #d0c4a8 !important;
  border-bottom: 2px solid #d0c4a8 !important;
  box-shadow: none !important;
}

/* Górna sekcja (tło) */
.sor-abacus-card .sor-upper-area {
  background: #f0e8d8 !important;
  border-bottom: 3px solid #d8cdb8 !important;
}

/* Dolna sekcja (tło) */
.sor-abacus-card .sor-lower-area {
  background: #f5ede0 !important;
}

/* Górny koralik — koralowy/łososiowy */
.sor-abacus-card .sor-bead-upper {
  background: radial-gradient(circle at 38% 32%, #ffc8b0, #dd6040 55%, #b03020) !important;
  opacity: 0.42 !important;
  border: none !important;
  box-shadow: 0 2px 6px rgba(180,60,30,0.20) !important;
}
.sor-abacus-card .sor-bead-upper.active {
  background: radial-gradient(circle at 38% 32%, #ffd8c0, #ee7050 55%, #c84030) !important;
  opacity: 1 !important;
  box-shadow: 0 3px 12px rgba(200,60,30,0.45) !important;
}

/* Dolne koraliki — złocisty bursztyn */
.sor-abacus-card .sor-bead-lower {
  background: radial-gradient(circle at 38% 32%, #fff0a0, #e8b020 55%, #b07808) !important;
  opacity: 0.38 !important;
  border: none !important;
  box-shadow: 0 2px 5px rgba(160,110,10,0.18) !important;
}
.sor-abacus-card .sor-bead-lower.active {
  background: radial-gradient(circle at 38% 32%, #fff8b0, #f8c828 55%, #c89010) !important;
  opacity: 1 !important;
  box-shadow: 0 3px 10px rgba(190,140,10,0.45) !important;
}

/* Kolumna z błędem (tryb quiz) */
.sor-abacus-card .sor-column-wrong .sor-bead { outline: 2px solid #e05550 !important; }

/* Separator kolumn */
.sor-abacus-card .sor-col-divider {
  background: rgba(0,0,0,0.06) !important;
  flex-shrink: 0 !important;
}

/* ── Przycisk Wstecz ────────────────────────────────────────────────────── */
.sor-back-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  height: 46px !important;
  padding: 0 28px !important;
  background: #ffffff !important;
  border: none !important;
  border-radius: 23px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #1a1a18 !important;
  cursor: pointer !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.22) !important;
  transition: box-shadow 140ms, transform 140ms !important;
  margin-top: 10px !important;
}
.sor-back-btn:hover {
  box-shadow: 0 4px 22px rgba(0,0,0,0.35) !important;
  transform: translateY(-1px) !important;
}

/* ── Responsywność ──────────────────────────────────────────────────────── */
@media (max-width: 760px) {
  .sor-ctrl-bar {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .sor-tabs { justify-content: center !important; }
  .sor-actions { justify-content: center !important; }
  .sor-num-display { text-align: center !important; }
  .sor-size-bar { justify-content: center !important; }
  .sor-preset-group { flex-wrap: wrap !important; justify-content: center !important; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5 — pełna korekta (jasne tło, rozmby koraliki 64×32, cyfry nad)
   Nadpisuje V4. Bazuje na reference code.html (dobry_widok.zip).
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Tło sekcji — JASNE (nie ciemne) ────────────────────────────────────── */
#screen-soroban {
  background: #fff8f5 !important;
  padding: 0 !important;
  min-height: 100vh !important;
}

.sor-page {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 20px !important;
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 48px 28px 64px !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

/* ── Nagłówek ────────────────────────────────────────────────────────────── */
.sor-page-head { text-align: center !important; }
.sor-page-title {
  font-size: clamp(26px, 4vw, 38px) !important;
  font-weight: 700 !important;
  color: #1d1b19 !important;
  margin: 0 0 10px !important;
  letter-spacing: -0.02em !important;
  line-height: 1.2 !important;
}
.sor-page-desc {
  font-size: 16px !important;
  color: #4e453e !important;
  line-height: 1.65 !important;
  max-width: 520px !important;
  margin: 0 auto !important;
}

/* ── Pasek sterowania ─────────────────────────────────────────────────────  */
.sor-ctrl-bar {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  background: #ffffff !important;
  border-radius: 16px !important;
  padding: 14px 18px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  box-shadow: 0 4px 20px rgba(26,35,126,.07), 0 1px 4px rgba(0,0,0,.06) !important;
  border: 1px solid #e8e1de !important;
}

/* Zakładki */
.sor-tabs {
  display: flex !important;
  background: #f3ece9 !important;
  border-radius: 10px !important;
  padding: 4px !important;
  gap: 3px !important;
  flex-shrink: 0 !important;
}
.sor-mode-tab {
  padding: 9px 14px !important;
  border-radius: 7px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  background: transparent !important;
  color: #80756d !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: all 130ms !important;
  white-space: nowrap !important;
}
.sor-mode-tab.active {
  background: #fff !important;
  color: #1d1b19 !important;
  box-shadow: 0 1px 5px rgba(0,0,0,.11) !important;
}
.sor-mode-tab:hover:not(.active) {
  background: rgba(255,255,255,.6) !important;
  color: #3a3028 !important;
}

/* Wynik z chipami */
.sor-num-display {
  flex: 1 !important;
  background: #f9f2ef !important;
  border-radius: 12px !important;
  padding: 10px 18px 12px !important;
  text-align: center !important;
  border: 1px solid #e0d8d4 !important;
  min-width: 0 !important;
}
.sor-num-label {
  font-size: 9px !important;
  font-weight: 700 !important;
  color: #a09890 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  margin-bottom: 3px !important;
}
.sor-result-number {
  font-family: var(--font-display,'Bricolage Grotesque',sans-serif) !important;
  font-size: clamp(30px, 4vw, 46px) !important;
  font-weight: 800 !important;
  color: #1d1b19 !important;
  letter-spacing: -0.02em !important;
  line-height: 1 !important;
  margin-bottom: 8px !important;
}
.sor-result-number.sor-result-correct { color: #228b22 !important; }
.sor-result-number.sor-result-wrong   { color: #c0392b !important; }

/* Chipy */
.sor-chips-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 5px !important;
  justify-content: center !important;
  min-height: 20px !important;
}
.sor-chip {
  display: inline-block !important;
  padding: 3px 9px !important;
  border-radius: 20px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  color: #3a3028 !important;
  letter-spacing: .06em !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
.sor-chip-zero {
  background: #ede7e4 !important;
  color: #80756d !important;
}

/* Przyciski akcji */
.sor-actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
}
.sor-act-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  height: 38px !important;
  padding: 0 14px !important;
  background: #fff !important;
  border: 1.5px solid #d8d1cc !important;
  border-radius: 9px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  color: #4e453e !important;
  letter-spacing: .06em !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: background 120ms, border-color 120ms !important;
  white-space: nowrap !important;
}
.sor-act-btn:hover {
  background: #f9f2ef !important;
  border-color: #b8956a !important;
}
.sor-act-round {
  width: 38px !important;
  padding: 0 !important;
  justify-content: center !important;
  border-radius: 50% !important;
  font-size: 16px !important;
}

/* ── Panele trybów ────────────────────────────────────────────────────────  */
#screen-soroban .sor-mode-panel {
  display: none !important;
  width: 100% !important;
}
#screen-soroban .sor-mode-panel.active { display: block !important; }

.sor-enter-card, .sor-quiz-card {
  background: #f9f2ef !important;
  border: 1px solid #e0d8d4 !important;
  border-radius: 14px !important;
  padding: 18px 22px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.sor-enter-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
}
.sor-enter-input {
  flex: 1 !important;
  min-width: 180px !important;
  height: 42px !important;
  padding: 0 14px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 9px !important;
  font-size: 15px !important;
  color: #1d1b19 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  outline: none !important;
}
.sor-enter-input:focus { border-color: #6f5a48 !important; }
.sor-enter-msg {
  margin: 8px 0 0 !important;
  font-size: 13px !important;
  color: #80756d !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
.sor-enter-msg.ok    { color: #2e7d32 !important; }
.sor-enter-msg.error { color: #c62828 !important; }

/* Przyciski w panelach */
#screen-soroban .sor-btn {
  height: 42px !important;
  padding: 0 16px !important;
  border-radius: 9px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: opacity 130ms, transform 100ms !important;
  white-space: nowrap !important;
}
#screen-soroban .sor-btn:hover  { opacity: .88 !important; }
#screen-soroban .sor-btn:active { transform: scale(.97) !important; }
#screen-soroban .sor-btn-primary   { background: linear-gradient(to right,#f9dcc4,#f4c19a) !important; color: #27180a !important; }
#screen-soroban .sor-btn-secondary { background: #fff !important; color: #4e453e !important; border: 1.5px solid #d1c4ba !important; }
#screen-soroban .sor-btn-hint      { background: #e0e0ff !important; color: #27308a !important; }
#screen-soroban .sor-btn-sm        { height: 34px !important; padding: 0 12px !important; font-size: 12px !important; }

/* Quiz */
.sor-quiz-box {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 10px !important;
}
.sor-quiz-instruction { font-size: 14px !important; color: #80756d !important; margin: 0 !important; }
.sor-quiz-target {
  font-family: var(--font-display,'Bricolage Grotesque',sans-serif) !important;
  font-size: 44px !important;
  font-weight: 800 !important;
  color: #1d1b19 !important;
  letter-spacing: -.02em !important;
}
.sor-quiz-feedback { font-size: 14px !important; min-height: 20px !important; color: #4e453e !important; }
.sor-quiz-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  justify-content: center !important;
}

/* ── Rozmiar sorobanu ─────────────────────────────────────────────────────  */
.sor-size-bar {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  width: 100% !important;
}
.sor-size-label {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #80756d !important;
  letter-spacing: .05em !important;
  white-space: nowrap !important;
}
.sor-preset-group { display: flex !important; gap: 6px !important; flex-wrap: wrap !important; }
.sor-preset-btn {
  padding: 6px 14px !important;
  border-radius: 20px !important;
  border: 1.5px solid #d1c4ba !important;
  background: #fff !important;
  color: #80756d !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: all 120ms !important;
}
.sor-preset-btn:hover { border-color: #6f5a48 !important; color: #3a3028 !important; }
.sor-preset-btn.active {
  background: linear-gradient(to right,#fff8e7,#fff8e7) !important;
  border-color: #ddd0b0 !important;
  color: #27180a !important;
}
.sor-expert-row {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.sor-expert-label { font-size: 11px !important; color: #80756d !important; white-space: nowrap !important; }
.sor-expert-input {
  width: 60px !important;
  height: 32px !important;
  padding: 0 8px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 7px !important;
  color: #1d1b19 !important;
  font-size: 12px !important;
}
.sor-col-desc { font-size: 11px !important; color: #80756d !important; margin: 0 !important; }
.sor-stats-ghost { display: none !important; }

/* ══════════════════════════════════════════════════════════════════════
   GŁÓWNY SOROBAN — karta + rama + koraliki
   ══════════════════════════════════════════════════════════════════════ */

/* Karta zewnętrzna */
.sor-abacus-card {
  width: 100% !important;
  background: #f3ece9 !important;
  border-radius: 24px !important;
  border: 8px solid #d1c4ba !important;
  box-shadow: 0 10px 30px rgba(26,35,126,.06), 0 4px 12px rgba(0,0,0,.08) !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

/* Pojedynczy scroll-area: cyfry + koraliki w tym samym oknie przewijania */
.sor-abacus-card .sor-frame-wrap { width: 100% !important; }
.sor-abacus-card .sor-frame {
  background: #f3ece9 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}
.sor-abacus-card .sor-scroll-area {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  background: #f3ece9 !important;
  scrollbar-width: thin !important;
  scrollbar-color: #d1c4ba transparent !important;
  padding: 24px 24px 28px !important;
  box-sizing: border-box !important;
}
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar { height: 5px !important; }
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar-thumb { background: #d1c4ba !important; border-radius: 3px !important; }

/* ── Cyfry nad słupkami ──────────────────────────────────────────────────── */
.sor-digit-row {
  display: flex !important;
  align-items: flex-end !important;
  padding: 0 0 12px !important;
  margin: 0 !important;
  min-width: max-content !important;
}
.sor-digit-cell {
  width: 80px !important;
  flex-shrink: 0 !important;
  font-family: 'Space Grotesk','Bricolage Grotesque',sans-serif !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  color: #1A237E !important;
  text-align: center !important;
  line-height: 1 !important;
}
.sor-digit-cell.zero  { color: #d1c4ba !important; }
.sor-digit-cell.wrong { color: #ba1a1a !important; }
.sor-digit-row .sor-label-spacer {
  width: 4px !important;
  flex-shrink: 0 !important;
}

/* ── Wewnętrzny kontener koralików ──────────────────────────────────────── */
.sor-abacus-card .sor-abacus-inner {
  display: flex !important;
  align-items: flex-start !important;
  background: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
  min-width: max-content !important;
  position: relative !important;
}

/* ── Kolumna ─────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-column {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  position: relative !important;
  width: 80px !important;
  flex-shrink: 0 !important;
}

/* Separator kolumn */
.sor-abacus-card .sor-col-divider {
  width: 4px !important;
  align-self: stretch !important;
  background: rgba(0,0,0,0) !important;
  flex-shrink: 0 !important;
}

/* ── Pręt ────────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-rod {
  position: absolute !important;
  left: 50% !important;
  top: 0 !important;
  transform: translateX(-50%) !important;
  width: 8px !important;
  height: 100% !important;
  background: linear-gradient(to right,#835b32,#d1c4ba 50%,#835b32) !important;
  border-radius: 4px !important;
  z-index: 1 !important;
  box-shadow: none !important;
}

/* ── Górna sekcja (koralik górny — wartość 5) ────────────────────────────── */
.sor-abacus-card .sor-upper-area {
  width: 80px !important;
  height: 110px !important;
  position: relative !important;
  flex-shrink: 0 !important;
  background: transparent !important;
  border-bottom: none !important;
}

/* ── Belka ───────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-beam {
  width: 80px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
  background: linear-gradient(to bottom,#d1c4ba,#fff 50%,#d1c4ba) !important;
  border-top: 1px solid #80756d !important;
  border-bottom: 1px solid #80756d !important;
  box-shadow: 0 4px 8px rgba(0,0,0,.12) !important;
  position: relative !important;
  z-index: 10 !important;
}

/* ── Dolna sekcja (4 koraliki — wartość 1 każdy) ────────────────────────── */
.sor-abacus-card .sor-lower-area {
  width: 80px !important;
  height: 274px !important;
  position: relative !important;
  flex-shrink: 0 !important;
  background: transparent !important;
}

/* ── Koralik — kształt diamentu (rombu) ─────────────────────────────────── */
.sor-abacus-card .sor-bead {
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 64px !important;
  height: 32px !important;
  border-radius: 0 !important;
  clip-path: polygon(50% 0%,100% 50%,50% 100%,0% 50%) !important;
  cursor: pointer !important;
  z-index: 5 !important;
  transition: top .22s cubic-bezier(.175,.885,.32,1.275),
              bottom .22s cubic-bezier(.175,.885,.32,1.275) !important;
  box-shadow: none !important;
  border: none !important;
}
.sor-abacus-card .sor-bead:hover { filter: brightness(1.1) !important; }
.sor-abacus-card .sor-bead:active { filter: brightness(.9) !important; }

/* Górny koralik — koralowy/czerwono-pomarańczowy */
.sor-abacus-card .sor-bead-upper {
  background: linear-gradient(135deg,#ff7043,#d84315) !important;
  opacity: .45 !important;
}
.sor-abacus-card .sor-bead-upper.active {
  opacity: 1 !important;
  background: linear-gradient(135deg,#ff8a65,#e64a19) !important;
}

/* Dolne koraliki — złocisty żółty */
.sor-abacus-card .sor-bead-lower {
  background: linear-gradient(135deg,#ffca28,#f57f17) !important;
  opacity: .40 !important;
}
.sor-abacus-card .sor-bead-lower.active {
  opacity: 1 !important;
  background: linear-gradient(135deg,#ffd740,#ff8f00) !important;
}

/* Kolumna z błędem (tryb Zadanie) */
.sor-abacus-card .sor-column-wrong .sor-bead-lower,
.sor-abacus-card .sor-column-wrong .sor-bead-upper {
  outline: 2px solid #ba1a1a !important;
  outline-offset: -2px !important;
}

/* ── Przycisk Wstecz ──────────────────────────────────────────────────────  */
.sor-back-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  height: 48px !important;
  padding: 0 32px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 24px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #1d1b19 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.08) !important;
  transition: box-shadow 140ms, transform 140ms !important;
  margin-top: 8px !important;
}
.sor-back-btn:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,.14) !important;
  transform: translateY(-1px) !important;
  border-color: #6f5a48 !important;
}

/* ── Responsywność ────────────────────────────────────────────────────────  */
@media (max-width: 760px) {
  .sor-ctrl-bar {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .sor-tabs { justify-content: center !important; }
  .sor-actions { justify-content: center !important; }
  .sor-num-display { text-align: center !important; }
  .sor-size-bar { justify-content: center !important; }
  .sor-abacus-card .sor-column { width: 60px !important; }
  .sor-abacus-card .sor-bead  { width: 48px !important; height: 24px !important; }
  .sor-abacus-card .sor-upper-area { height: 80px !important; }
  .sor-abacus-card .sor-lower-area { height: 200px !important; }
  .sor-digit-cell { width: 60px !important; font-size: 24px !important; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-A — pełne kolory koralików (opacity:1), chipy #fff8e7
   ═══════════════════════════════════════════════════════════════════════════ */

/* Koraliki — pełny kolor (bez przezroczystości), nieaktywne = kremowy */
.sor-abacus-card .sor-bead-upper {
  background: linear-gradient(135deg, #e0cfc7, #bfaea5) !important;
  opacity: 1 !important;
}
.sor-abacus-card .sor-bead-upper.active {
  background: linear-gradient(135deg, #ff8a65, #e64a19) !important;
  opacity: 1 !important;
}
.sor-abacus-card .sor-bead-lower {
  background: linear-gradient(135deg, #e8ddd4, #c8bdb5) !important;
  opacity: 1 !important;
}
.sor-abacus-card .sor-bead-lower.active {
  background: linear-gradient(135deg, #ffd740, #ff8f00) !important;
  opacity: 1 !important;
}

/* Chipy opisu wartości — kolor #fff8e7, ciemny tekst */
#screen-soroban .sor-chip {
  background: #fff8e7 !important;
  color: #3a2e1a !important;
  border: 1px solid #e8d8b0 !important;
}
#screen-soroban .sor-chip-zero {
  background: #ede7e4 !important;
  color: #80756d !important;
  border: 1px solid #d1c4ba !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-B — zakładki, przyciski, panel "?", wyśrodkowanie słupków
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Zakładki trybów — wygląd jak w reference (pill container) ────────────  */
#screen-soroban .sor-tabs {
  display: flex !important;
  background: #ede7e4 !important;
  border-radius: 12px !important;
  padding: 4px !important;
  gap: 2px !important;
  border: 1px solid #d1c4ba !important;
  flex-shrink: 0 !important;
}
#screen-soroban .sor-mode-tab {
  padding: 10px 18px !important;
  border-radius: 9px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  background: transparent !important;
  color: #80756d !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: background 130ms, color 130ms, box-shadow 130ms !important;
  white-space: nowrap !important;
  letter-spacing: .01em !important;
}
#screen-soroban .sor-mode-tab.active {
  background: #ffffff !important;
  color: #1d1b19 !important;
  box-shadow: 0 1px 6px rgba(0,0,0,.13) !important;
}
#screen-soroban .sor-mode-tab:hover:not(.active) {
  background: rgba(255,255,255,.55) !important;
  color: #3a3028 !important;
}

/* ── Panel z chipami — bez dużej liczby ──────────────────────────────────── */
#screen-soroban .sor-num-display {
  flex: 1 !important;
  background: #f9f2ef !important;
  border-radius: 12px !important;
  padding: 10px 18px !important;
  border: 1px solid #e0d8d4 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 48px !important;
  min-width: 0 !important;
}
#screen-soroban .sor-num-display .sor-result-number {
  display: none !important;
}
#screen-soroban .sor-chips-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  justify-content: center !important;
  align-items: center !important;
}

/* ── Przycisk Wyczyść — obrysowy ─────────────────────────────────────────── */
#screen-soroban .sor-act-outline {
  background: #ffffff !important;
  border: 1.5px solid #6f5a48 !important;
  color: #6f5a48 !important;
  font-weight: 700 !important;
}
#screen-soroban .sor-act-outline:hover {
  background: #f9f2ef !important;
  border-color: #3a2e1a !important;
  color: #3a2e1a !important;
}

/* ── Przycisk Losowo — wypełniony gradientem ─────────────────────────────── */
#screen-soroban .sor-act-filled {
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  border: 1.5px solid #ddd0b0 !important;
  color: #27180a !important;
  font-weight: 700 !important;
  box-shadow: 0 2px 8px rgba(244,193,154,.35) !important;
}
#screen-soroban .sor-act-filled:hover {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  box-shadow: 0 3px 12px rgba(244,193,154,.5) !important;
  color: #ffffff !important;
  border: 1.5px solid #ddd0b0 !important;
}

/* ── Przycisk "?" — info ─────────────────────────────────────────────────── */
#screen-soroban .sor-act-info {
  width: 38px !important;
  height: 38px !important;
  padding: 0 !important;
  border-radius: 50% !important;
  background: #ffffff !important;
  border: 1.5px solid #d1c4ba !important;
  color: #6f5a48 !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
#screen-soroban .sor-act-info:hover,
#screen-soroban .sor-act-info.active {
  background: #6f5a48 !important;
  color: #ffffff !important;
  border-color: #6f5a48 !important;
}

/* ── Panel informacyjny "?" ──────────────────────────────────────────────── */
#sor-info-panel {
  display: none;
  flex-direction: column !important;
  gap: 10px !important;
  background: #fffbf6 !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 14px !important;
  padding: 18px 22px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.08) !important;
}
.sor-info-title {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #6f5a48 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  margin: 0 0 4px !important;
}
.sor-info-rows { display: flex !important; flex-direction: column !important; gap: 8px !important; }
.sor-info-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  font-size: 14px !important;
  color: #1d1b19 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
.sor-info-row-note {
  color: #4e453e !important;
  font-size: 13px !important;
  padding-top: 8px !important;
  border-top: 1px solid #e0d8d4 !important;
  line-height: 1.55 !important;
  align-items: flex-start !important;
}
.sor-info-row-note svg { flex-shrink: 0 !important; margin-top: 1px !important; color: #6f5a48 !important; }
/* Mini koraliki w panelu */
.sor-info-bead {
  display: inline-block !important;
  width: 32px !important;
  height: 16px !important;
  border-radius: 3px !important;
  clip-path: polygon(50% 0%,100% 50%,50% 100%,0% 50%) !important;
  flex-shrink: 0 !important;
}
.sor-info-bead-upper { background: linear-gradient(135deg,#ff8a65,#e64a19) !important; }
.sor-info-bead-lower { background: linear-gradient(135deg,#ffd740,#ff8f00) !important; }

/* ── Wyśrodkowanie sorobanu ──────────────────────────────────────────────── */
.sor-abacus-card .sor-scroll-area {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}
.sor-abacus-card .sor-digit-row,
.sor-abacus-card .sor-abacus-inner {
  width: max-content !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-C — panel Wpisz, panel Zadanie (poziomy), przyciski
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Panel Wpisz liczbę — mniejsze pole ─────────────────────────────────── */
#screen-soroban .sor-enter-card {
  background: #f9f2ef !important;
  border: 1px solid #e0d8d4 !important;
  border-radius: 14px !important;
  padding: 16px 20px !important;
}
#screen-soroban .sor-enter-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
}
#screen-soroban .sor-enter-input {
  width: 140px !important;
  min-width: 0 !important;
  flex: 0 0 140px !important;
  height: 38px !important;
  padding: 0 12px !important;
  font-size: 14px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 9px !important;
  color: #1d1b19 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
#screen-soroban .sor-enter-input:focus { border-color: #6f5a48 !important; outline: none !important; }

/* Przyciski w panelach — dopasowane do stylu strony */
#screen-soroban .sor-btn-primary {
  background: linear-gradient(to right,#fff8e7,#fff8e7) !important;
  border: 1.5px solid #ddd0b0 !important;
  color: #27180a !important;
  box-shadow: 0 2px 8px rgba(244,193,154,.30) !important;
}
#screen-soroban .sor-btn-primary:hover {
  background: linear-gradient(to right,#b8890a,#b8890a) !important;
    color: #ffffff !important;
}
#screen-soroban .sor-btn-secondary {
  background: #fff8e7 !important;
  border: 1.5px solid #ddd0b0 !important;
  color: #27180a !important;
}
#screen-soroban .sor-btn-secondary:hover {
  background: #b8890a !important;
  border-color: #ddd0b0 !important;
  color: #ffffff !important;
}
#screen-soroban .sor-btn-hint {
  background: #f0edff !important;
  border: 1.5px solid #c5bef8 !important;
  color: #27308a !important;
}
#screen-soroban .sor-btn-hint:hover {
  background: #e3deff !important;
}
#screen-soroban .sor-btn {
  height: 38px !important;
  padding: 0 14px !important;
  border-radius: 9px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: all 120ms !important;
  white-space: nowrap !important;
}

/* ── Panel Zadanie — wybór zakresu ───────────────────────────────────────── */
#screen-soroban .sor-quiz-card {
  background: #f9f2ef !important;
  border: 1px solid #e0d8d4 !important;
  border-radius: 14px !important;
  padding: 18px 20px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

/* Rząd zakresu */
.sor-quiz-levels {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}
.sor-quiz-levels-label {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #80756d !important;
  letter-spacing: .05em !important;
  white-space: nowrap !important;
}
.sor-level-btns {
  display: flex !important;
  gap: 6px !important;
  flex-wrap: wrap !important;
}
.sor-level-btn {
  padding: 5px 13px !important;
  border-radius: 20px !important;
  border: 1.5px solid #d1c4ba !important;
  background: #fff !important;
  color: #80756d !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: all 120ms !important;
  white-space: nowrap !important;
}
.sor-level-btn:hover { 
  background: linear-gradient(to right,#b8890a,#b8890a) !important;
  border-color: #ddd0b0 !important; 
  color: #ffffff !important; 
}
.sor-level-btn.active {
  background: linear-gradient(to right,#fff8e7,#fff8e7) !important;
  border-color: #ddd0b0 !important;
  color: #27180a !important;
}

/* Quiz box — cel, feedback, akcje */
#screen-soroban .sor-quiz-box {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 10px !important;
}
#screen-soroban .sor-quiz-instruction {
  font-size: 13px !important;
  color: #80756d !important;
  margin: 0 !important;
}
#screen-soroban .sor-quiz-target {
  font-family: var(--font-display,'Bricolage Grotesque',sans-serif) !important;
  font-size: 42px !important;
  font-weight: 800 !important;
  color: #1d1b19 !important;
  letter-spacing: -.02em !important;
  line-height: 1 !important;
}
#screen-soroban .sor-quiz-feedback {
  min-height: 22px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #4e453e !important;
  text-align: center !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  padding: 4px 10px !important;
  border-radius: 8px !important;
}
#screen-soroban .sor-quiz-feedback.correct {
  background: #e8f5e9 !important;
  color: #1b5e20 !important;
  border: 1px solid #a5d6a7 !important;
}
#screen-soroban .sor-quiz-feedback.wrong {
  background: #fce4ec !important;
  color: #880e4f !important;
  border: 1px solid #f48fb1 !important;
}
#screen-soroban .sor-quiz-feedback.hint1,
#screen-soroban .sor-quiz-feedback.hint2 {
  background: #fff8e7 !important;
  color: #5d4037 !important;
  border: 1px solid #ffe082 !important;
}
#screen-soroban .sor-quiz-feedback.hint3 {
  background: #e8eaf6 !important;
  color: #1a237e !important;
  border: 1px solid #9fa8da !important;
}
#screen-soroban .sor-quiz-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  justify-content: center !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-D — przycisk Zeruj przy belce, position:relative na card
   ═══════════════════════════════════════════════════════════════════════════ */

/* Karta sorobanu: potrzebujemy position:relative dla absolutnego Zeruj */
.sor-abacus-card {
  position: relative !important;
}

/* Przycisk Zeruj — przy belce środkowej, prawa strona karty */
.sor-abacus-clear-btn {
  position: absolute !important;
  right: 14px !important;
  /* scroll-area padding-top:24 + digit-row:44 + upper-area:110 + half-beam:8 = 186px */
  top: 186px !important;
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: #ffffff !important;
  border: 1.5px solid #d1c4ba !important;
  color: #80756d !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  z-index: 20 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.14) !important;
  transition: background 120ms, color 120ms, border-color 120ms !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  padding: 0 !important;
}
.sor-abacus-clear-btn:hover {
  background: #6f5a48 !important;
  color: #ffffff !important;
  border-color: #6f5a48 !important;
}
.sor-abacus-clear-btn:active {
  background: #4e3526 !important;
}


/* ══ pdf-cv4 — karty zakresów dla mnożenia/dzielenia ══ */
.pdf-cv4 {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
}
.pdf-cv4-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pdf-cv4-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--gold-3, #8a6a3e);
}
.pdf-cv4-row {
  display: flex;
  gap: 10px;
  width: 100%;
}
.pdf-cv4-row-cards {
  display: flex;
  gap: 10px;
}
/* Clickable variant — nadpisuje stały kursor z base */
.pdf-range-card-clickable {
  cursor: pointer !important;
  user-select: none;
}
.pdf-range-card-clickable:hover:not(.pdf-range-card-disabled) {
  border-color: #e0d4b8 !important;
  background: #faf5ea !important;
}
/* Disabled — dla dzielnika > dzielna */
.pdf-range-card-disabled {
  opacity: 0.32 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}
/* Neutralizuj nth-child kolory w cv4 (nie mylić z add/sub) */
.pdf-cv4 .pdf-range-card-name {
  color: var(--ink, #041627) !important;
}
.pdf-cv4 .pdf-range-card-desc {
  color: var(--ink-faint, #74777d) !important;
}
/* Hint "Dzielnik nie może być..." */
.pdf-cv4-hint {
  font-size: 11px;
  color: #b07840;
  font-style: italic;
  margin-top: -2px;
}
/* Summary "Wybrany wariant" */
.pdf-cv4-summary {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
}
.pdf-cv4-summary-label {
  font-size: 11px;
  color: var(--ink-faint, #74777d);
  font-weight: 500;
}
.pdf-cv4-summary-variant {
  font-size: 12px;
  font-weight: 700;
  color: var(--ink, #041627);
  letter-spacing: .04em;
}
/* Mobile: 2×2 */
@media (max-width: 500px) {
  .pdf-cv4-row,
  .pdf-cv4-row-cards {
    flex-wrap: wrap;
  }
  .pdf-cv4-row .pdf-range-card,
  .pdf-cv4-row .pdf-range-card-simple {
    flex: 1 1 calc(50% - 5px);
  }
}

/* ══ Krok 3 — titlerow z badge "Wariant" po prawej ══ */
.pdf-step3-titlerow {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 4px;
}
.pdf-step3-titlecol {
  flex: 1;
  min-width: 0;
}
.pdf-step3-badge {
  flex-shrink: 0;
  background: #1a1e2e;
  color: #fff;
  border-radius: 100px;
  padding: 7px 18px;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  letter-spacing: .02em;
  align-self: center;
}
.pdf-step3-badge strong {
  font-weight: 700;
  color: #fff;
  letter-spacing: .04em;
}
@media (max-width: 560px) {
  .pdf-step3-titlerow {
    flex-direction: column;
    gap: 8px;
  }
  .pdf-step3-badge {
    align-self: flex-start;
    font-size: 11px;
    padding: 5px 14px;
  }
}

/* ══ Aktywna karta podczas hover — pokazuj active od razu ══ */
.pdf-cv4 .pdf-range-card-clickable.active:hover,
.pdf-cv4 .pdf-range-card-clickable.pdf-range-card-simple.active:hover,
.pdf-cv4 .pdf-range-card-clickable.pdf-range-card-b-simple.active:hover {
  background: #fdefc8 !important;
  border-color: #b8890a !important;
  box-shadow: 0 0 0 2px rgba(184,137,10,.20) !important;
}

/* ══ Neutralizuj hover na kontenerze pdf-cv4 (nth-child zmienia tło rodzica) ══ */
.pdf-range-grid > .pdf-cv4:nth-child(1):hover,
.pdf-range-grid > .pdf-cv4:nth-child(2):hover,
.pdf-range-grid > .pdf-cv4:nth-child(3):hover,
.pdf-range-grid > .pdf-cv4:nth-child(4):hover {
  background: #e8f2e4 !important;
}

/* ══ Picker mnożników / dzielników ══ */
.pdf-mult-picker {
  margin-top: 16px;
  background: #fff;
  border: 1.5px solid #d9c07a;
  border-radius: 12px;
  padding: 14px 16px 12px;
}

.pdf-mult-picker-header {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  color: #7a6a3a;
  background: #f5edcf;
  border: 1px solid #d9c07a;
  border-radius: 20px;
  display: inline-block;
  padding: 3px 12px;
  margin-bottom: 12px;
}

.pdf-mult-picker-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px 12px;
}

.pdf-mult-col {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pdf-mult-cb-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
  color: #2d2d2d;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 6px;
  transition: background .12s;
  user-select: none;
}

.pdf-mult-cb-label:hover {
  background: #fdf6e3;
}

.pdf-mult-cb-label-dis {
  opacity: .38;
  cursor: not-allowed;
}

.pdf-mult-cb-label-dis:hover {
  background: transparent;
}

.pdf-mult-cb {
  width: 18px;
  height: 18px;
  accent-color: #b8890a;
  cursor: pointer;
  flex-shrink: 0;
}

.pdf-mult-cb-label-dis .pdf-mult-cb {
  cursor: not-allowed;
}

.pdf-mult-hint {
  margin-top: 10px;
  font-size: 11.5px;
  color: #888;
  line-height: 1.5;
  border-top: 1px solid #ede5c8;
  padding-top: 8px;
}

/* ══ Kolumny 6-8 — mniejsza czcionka żeby zmieścić w wierszu ══ */
.col-grid[style*="--col-cols: 6"] .col-card,
.col-grid[style*="--col-cols: 7"] .col-card,
.col-grid[style*="--col-cols: 8"] .col-card {
  padding: 10px 8px 12px;
  gap: 6px;
}
.col-grid[style*="--col-cols: 6"] .col-row,
.col-grid[style*="--col-cols: 7"] .col-row,
.col-grid[style*="--col-cols: 8"] .col-row {
  font-size: 28px;
  line-height: 1.1;
  padding: 0 4px;
}
.col-grid[style*="--col-cols: 6"] .col-input,
.col-grid[style*="--col-cols: 7"] .col-input,
.col-grid[style*="--col-cols: 8"] .col-input {
  font-size: 28px;
  line-height: 1.1;
  padding: 5px 8px;
}
.col-grid[style*="--col-cols: 6"] .col-check-btn,
.col-grid[style*="--col-cols: 7"] .col-check-btn,
.col-grid[style*="--col-cols: 8"] .col-check-btn {
  padding: 5px 8px;
  font-size: 11px;
}
.col-grid[style*="--col-cols: 6"] .col-timer,
.col-grid[style*="--col-cols: 7"] .col-timer,
.col-grid[style*="--col-cols: 8"] .col-timer {
  padding: 4px 8px;
  font-size: 10px;
  letter-spacing: 0.12em;
}
.col-grid[style*="--col-cols: 6"] .col-timer .value,
.col-grid[style*="--col-cols: 7"] .col-timer .value,
.col-grid[style*="--col-cols: 8"] .col-timer .value {
  font-size: 12px;
}
@media (max-width: 1280px) {
  .col-grid[style*="--col-cols: 7"] .col-row,
  .col-grid[style*="--col-cols: 7"] .col-input,
  .col-grid[style*="--col-cols: 8"] .col-row,
  .col-grid[style*="--col-cols: 8"] .col-input { font-size: clamp(16px, 2.2vw, 26px); }
}

/* ══ Kolumny > konfiguracja — 4 suwaki w jednym wierszu ══ */
#screen-config-col .slider-rail {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 16px;
  max-width: none;
}
#screen-config-col .slider-rig {
  height: 260px !important;
}
@media (max-width: 1000px) {
  #screen-config-col .slider-rail {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 560px) {
  #screen-config-col .slider-rail {
    grid-template-columns: 1fr !important;
  }
}

/* ══ Mobile — większy input i przycisk w FLASH/KOLUMNY i MUL/DIV ══ */
@media (max-width: 600px) {
  /* Pole na wynik — wyższe, większa czcionka */
  .col-input {
    font-size: 22px !important;
    padding: 10px 12px !important;
    min-height: 48px !important;
    border-radius: 8px !important;
    border-width: 2px !important;
  }

  /* Przycisk ✓ w kolumnach — wyraźnie większy obszar dotyku */
  .col-check-btn {
    width: 52px !important;
    height: 48px !important;
    font-size: 22px !important;
    padding: 0 !important;
    border-radius: 8px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-width: 2px !important;
  }

  /* Przycisk ✓ w mnożeniu/dzieleniu */
  .mul-check-btn {
    width: 52px !important;
    height: 48px !important;
    font-size: 24px !important;
    border-radius: 8px !important;
    border-width: 2px !important;
  }

  /* Rząd z inputem — trochę więcej oddechu */
  .col-answer {
    gap: 10px !important;
    margin-top: 8px !important;
  }
}

/* ══ Mobile — cyfry w kolumnach FLASH ══ */
@media (max-width: 600px) {
  .col-row {
    font-size: 22px !important;
    line-height: 1.2 !important;
    padding: 2px 6px !important;
  }
}

/* ══ Mobile — większe cyfry w mnożeniu/dzieleniu FLASH ══ */
@media (max-width: 600px) {
  .mul-problem-row {
    font-size: 28px !important;
    gap: 8px !important;
  }
  .mul-input {
    font-size: 26px !important;
    padding: 8px 10px !important;
    min-height: 48px !important;
    border-radius: 8px !important;
    border-width: 2px !important;
  }
}


/* ── Desktop: przycisk ✓ pod polem wpisywania w kolumnach ─────────────────── */
@media (min-width: 601px) {
  .col-answer {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .col-check-btn {
    width: 100% !important;
    height: 36px !important;
  }
}

/* ── Desktop: mniej przestrzeni pod kartami kolumn ──────────────────────────── */
@media (min-width: 601px) {
  .col-card {
    padding-bottom: 4px !important;
    gap: 6px !important;
  }
  .col-feedback {
    min-height: 0 !important;
    padding: 0 2px 2px !important;
    line-height: 1.2 !important;
  }
}

/* ── Karty kolumn: nie rozciągaj do wysokości sąsiada ────────────────────── */
.col-grid {
  align-items: start !important;
}


/* ── Karta sorobanu ─────────────────────────────────────────────────────── */
.sor-abacus-card {
  width: 100% !important;
  background: #ffffff !important;
  border-radius: 20px !important;
  padding: 0 !important;
  overflow: hidden !important;
  box-shadow: 0 8px 36px rgba(0,0,0,0.35) !important;
}

/* Zewnętrzna rama — krem/beż */
.sor-frame-wrap {
  width: 100% !important;
}
  background: #e8dfd0 !important;
  border-radius: 20px !important;
  padding: 20px 20px 0 !important;
  position: relative !important;
  box-shadow: inset 0 0 40px rgba(100,70,30,0.15) !important;
  /* Wkręty w rogach */
  --screw-size: 10px !important;
}
/* Wkręty w narożnikach ramy */
.sor-abacus-card .sor-frame::before,
.sor-abacus-card .sor-frame::after {
  content: '◎' !important;
  position: absolute !important;
  font-size: 12px !important;
  color: #c0b090 !important;
  line-height: 1 !important;
}
.sor-abacus-card .sor-frame::before { top: 7px; left: 10px !important; }
.sor-abacus-card .sor-frame::after  { top: 7px; right: 10px !important; }

/* Obszar przewijania (cyfry + koraliki w jednym) */
.sor-abacus-card .sor-scroll-area {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  background: transparent !important;
  scrollbar-width: thin !important;
  scrollbar-color: #c0b090 transparent !important;
  border-radius: 0 !important;
  padding-bottom: 0 !important;
}
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar { height: 4px !important; }
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar-thumb { background: #c0b090 !important; border-radius: 2px !important; }

/* ── Cyfry nad słupkami ─────────────────────────────────────────────────── */
.sor-digit-row {
  display: flex !important;
  align-items: center !important;
  padding: 0 !important;
  margin: 0 !important;
  min-width: max-content !important;
}
.sor-digit-cell {
  font-family: var(--font-display, 'Bricolage Grotesque', sans-serif) !important;
  font-size: 26px !important;
  font-weight: 800 !important;
  color: #2a2520 !important;
  text-align: center !important;
  line-height: 1 !important;
  padding: 12px 0 10px !important;
  /* width matched by JS flex, same as .sor-column */
  flex-shrink: 0 !important;
}
.sor-digit-cell.zero  { color: #bbb4a8 !important; }
.sor-digit-cell.wrong { color: #c0392b !important; font-weight: 900 !important; }

/* Spacer między cyframi = szerokość .sor-col-divider */
.sor-digit-row .sor-label-spacer {
  flex-shrink: 0 !important;
}

/* ── Koraliki ────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-abacus-inner {
  display: flex !important;
  align-items: stretch !important;
  background: #f5ede0 !important;
  border-radius: 10px 10px 0 0 !important;
  padding: 0 !important;
  min-width: max-content !important;
}

/* Kolumna */
.sor-abacus-card .sor-column {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  position: relative !important;
  flex-shrink: 0 !important;
}

/* Pręt – metaliczny złoto-brąz */
.sor-abacus-card .sor-rod {
  background: linear-gradient(to right, #9a7040 10%, #d4a450 50%, #9a7040 90%) !important;
  border-radius: 3px !important;
  box-shadow: none !important;
}

/* Belka środkowa */
.sor-abacus-card .sor-beam {
  background: #f5ede0 !important;
  border-top: 2px solid #d0c4a8 !important;
  border-bottom: 2px solid #d0c4a8 !important;
  box-shadow: none !important;
}

/* Górna sekcja (tło) */
.sor-abacus-card .sor-upper-area {
  background: #f0e8d8 !important;
  border-bottom: 3px solid #d8cdb8 !important;
}

/* Dolna sekcja (tło) */
.sor-abacus-card .sor-lower-area {
  background: #f5ede0 !important;
}

/* Górny koralik — koralowy/łososiowy */
.sor-abacus-card .sor-bead-upper {
  background: radial-gradient(circle at 38% 32%, #ffc8b0, #dd6040 55%, #b03020) !important;
  opacity: 0.42 !important;
  border: none !important;
  box-shadow: 0 2px 6px rgba(180,60,30,0.20) !important;
}
.sor-abacus-card .sor-bead-upper.active {
  background: radial-gradient(circle at 38% 32%, #ffd8c0, #ee7050 55%, #c84030) !important;
  opacity: 1 !important;
  box-shadow: 0 3px 12px rgba(200,60,30,0.45) !important;
}

/* Dolne koraliki — złocisty bursztyn */
.sor-abacus-card .sor-bead-lower {
  background: radial-gradient(circle at 38% 32%, #fff0a0, #e8b020 55%, #b07808) !important;
  opacity: 0.38 !important;
  border: none !important;
  box-shadow: 0 2px 5px rgba(160,110,10,0.18) !important;
}
.sor-abacus-card .sor-bead-lower.active {
  background: radial-gradient(circle at 38% 32%, #fff8b0, #f8c828 55%, #c89010) !important;
  opacity: 1 !important;
  box-shadow: 0 3px 10px rgba(190,140,10,0.45) !important;
}

/* Kolumna z błędem (tryb quiz) */
.sor-abacus-card .sor-column-wrong .sor-bead { outline: 2px solid #e05550 !important; }

/* Separator kolumn */
.sor-abacus-card .sor-col-divider {
  background: rgba(0,0,0,0.06) !important;
  flex-shrink: 0 !important;
}

/* ── Przycisk Wstecz ────────────────────────────────────────────────────── */
.sor-back-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  height: 46px !important;
  padding: 0 28px !important;
  background: #ffffff !important;
  border: none !important;
  border-radius: 23px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #1a1a18 !important;
  cursor: pointer !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.22) !important;
  transition: box-shadow 140ms, transform 140ms !important;
  margin-top: 10px !important;
}
.sor-back-btn:hover {
  box-shadow: 0 4px 22px rgba(0,0,0,0.35) !important;
  transform: translateY(-1px) !important;
}

/* ── Responsywność ──────────────────────────────────────────────────────── */
@media (max-width: 760px) {
  .sor-ctrl-bar {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .sor-tabs { justify-content: center !important; }
  .sor-actions { justify-content: center !important; }
  .sor-num-display { text-align: center !important; }
  .sor-size-bar { justify-content: center !important; }
  .sor-preset-group { flex-wrap: wrap !important; justify-content: center !important; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5 — pełna korekta (jasne tło, rozmby koraliki 64×32, cyfry nad)
   Nadpisuje V4. Bazuje na reference code.html (dobry_widok.zip).
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Tło sekcji — JASNE (nie ciemne) ────────────────────────────────────── */
#screen-soroban {
  background: #fff8f5 !important;
  padding: 0 !important;
  min-height: 100vh !important;
}

.sor-page {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 20px !important;
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 48px 28px 64px !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

/* ── Nagłówek ────────────────────────────────────────────────────────────── */
.sor-page-head { text-align: center !important; }
.sor-page-title {
  font-size: clamp(26px, 4vw, 38px) !important;
  font-weight: 700 !important;
  color: #1d1b19 !important;
  margin: 0 0 10px !important;
  letter-spacing: -0.02em !important;
  line-height: 1.2 !important;
}
.sor-page-desc {
  font-size: 16px !important;
  color: #4e453e !important;
  line-height: 1.65 !important;
  max-width: 520px !important;
  margin: 0 auto !important;
}

/* ── Pasek sterowania ─────────────────────────────────────────────────────  */
.sor-ctrl-bar {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  background: #ffffff !important;
  border-radius: 16px !important;
  padding: 14px 18px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  box-shadow: 0 4px 20px rgba(26,35,126,.07), 0 1px 4px rgba(0,0,0,.06) !important;
  border: 1px solid #e8e1de !important;
}

/* Zakładki */
.sor-tabs {
  display: flex !important;
  background: #f3ece9 !important;
  border-radius: 10px !important;
  padding: 4px !important;
  gap: 3px !important;
  flex-shrink: 0 !important;
}
.sor-mode-tab {
  padding: 9px 14px !important;
  border-radius: 7px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  background: transparent !important;
  color: #80756d !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: all 130ms !important;
  white-space: nowrap !important;
}
.sor-mode-tab.active {
  background: #fff !important;
  color: #1d1b19 !important;
  box-shadow: 0 1px 5px rgba(0,0,0,.11) !important;
}
.sor-mode-tab:hover:not(.active) {
  background: rgba(255,255,255,.6) !important;
  color: #3a3028 !important;
}

/* Wynik z chipami */
.sor-num-display {
  flex: 1 !important;
  background: #f9f2ef !important;
  border-radius: 12px !important;
  padding: 10px 18px 12px !important;
  text-align: center !important;
  border: 1px solid #e0d8d4 !important;
  min-width: 0 !important;
}
.sor-num-label {
  font-size: 9px !important;
  font-weight: 700 !important;
  color: #a09890 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  margin-bottom: 3px !important;
}
.sor-result-number {
  font-family: var(--font-display,'Bricolage Grotesque',sans-serif) !important;
  font-size: clamp(30px, 4vw, 46px) !important;
  font-weight: 800 !important;
  color: #1d1b19 !important;
  letter-spacing: -0.02em !important;
  line-height: 1 !important;
  margin-bottom: 8px !important;
}
.sor-result-number.sor-result-correct { color: #228b22 !important; }
.sor-result-number.sor-result-wrong   { color: #c0392b !important; }

/* Chipy */
.sor-chips-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 5px !important;
  justify-content: center !important;
  min-height: 20px !important;
}
.sor-chip {
  display: inline-block !important;
  padding: 3px 9px !important;
  border-radius: 20px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  color: #3a3028 !important;
  letter-spacing: .06em !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
.sor-chip-zero {
  background: #ede7e4 !important;
  color: #80756d !important;
}

/* Przyciski akcji */
.sor-actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
}
.sor-act-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  height: 38px !important;
  padding: 0 14px !important;
  background: #fff !important;
  border: 1.5px solid #d8d1cc !important;
  border-radius: 9px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  color: #4e453e !important;
  letter-spacing: .06em !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: background 120ms, border-color 120ms !important;
  white-space: nowrap !important;
}
.sor-act-btn:hover {
  background: #f9f2ef !important;
  border-color: #b8956a !important;
}
.sor-act-round {
  width: 38px !important;
  padding: 0 !important;
  justify-content: center !important;
  border-radius: 50% !important;
  font-size: 16px !important;
}

/* ── Panele trybów ────────────────────────────────────────────────────────  */
#screen-soroban .sor-mode-panel {
  display: none !important;
  width: 100% !important;
}
#screen-soroban .sor-mode-panel.active { display: block !important; }

.sor-enter-card, .sor-quiz-card {
  background: #f9f2ef !important;
  border: 1px solid #e0d8d4 !important;
  border-radius: 14px !important;
  padding: 18px 22px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.sor-enter-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
}
.sor-enter-input {
  flex: 1 !important;
  min-width: 180px !important;
  height: 42px !important;
  padding: 0 14px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 9px !important;
  font-size: 15px !important;
  color: #1d1b19 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  outline: none !important;
}
.sor-enter-input:focus { border-color: #6f5a48 !important; }
.sor-enter-msg {
  margin: 8px 0 0 !important;
  font-size: 13px !important;
  color: #80756d !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
.sor-enter-msg.ok    { color: #2e7d32 !important; }
.sor-enter-msg.error { color: #c62828 !important; }

/* Przyciski w panelach */
  height: 42px !important;
  padding: 0 16px !important;
  border-radius: 9px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: opacity 130ms, transform 100ms !important;
  white-space: nowrap !important;
}
#screen-soroban .sor-btn:hover  { opacity: .88 !important; }

/* Quiz */
.sor-quiz-box {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 10px !important;
}
.sor-quiz-instruction { font-size: 14px !important; color: #80756d !important; margin: 0 !important; }
.sor-quiz-target {
  font-family: var(--font-display,'Bricolage Grotesque',sans-serif) !important;
  font-size: 44px !important;
  font-weight: 800 !important;
  color: #1d1b19 !important;
  letter-spacing: -.02em !important;
}
.sor-quiz-feedback { font-size: 14px !important; min-height: 20px !important; color: #4e453e !important; }
.sor-quiz-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  justify-content: center !important;
}

/* ── Rozmiar sorobanu ─────────────────────────────────────────────────────  */
.sor-size-bar {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  width: 100% !important;
}
.sor-size-label {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #80756d !important;
  letter-spacing: .05em !important;
  white-space: nowrap !important;
}
.sor-preset-group { display: flex !important; gap: 6px !important; flex-wrap: wrap !important; }
}
.sor-expert-row {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.sor-expert-label { font-size: 11px !important; color: #80756d !important; white-space: nowrap !important; }
.sor-expert-input {
  width: 60px !important;
  height: 32px !important;
  padding: 0 8px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 7px !important;
  color: #1d1b19 !important;
  font-size: 12px !important;
}
.sor-col-desc { font-size: 11px !important; color: #80756d !important; margin: 0 !important; }
.sor-stats-ghost { display: none !important; }

/* ══════════════════════════════════════════════════════════════════════
   GŁÓWNY SOROBAN — karta + rama + koraliki
   ══════════════════════════════════════════════════════════════════════ */

/* Karta zewnętrzna */
.sor-abacus-card {
  width: 100% !important;
  background: #f3ece9 !important;
  border-radius: 24px !important;
  border: 8px solid #d1c4ba !important;
  box-shadow: 0 10px 30px rgba(26,35,126,.06), 0 4px 12px rgba(0,0,0,.08) !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

/* Pojedynczy scroll-area: cyfry + koraliki w tym samym oknie przewijania */
.sor-abacus-card .sor-frame-wrap { width: 100% !important; }
  background: #f3ece9 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}
.sor-abacus-card .sor-scroll-area {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  background: #f3ece9 !important;
  scrollbar-width: thin !important;
  scrollbar-color: #d1c4ba transparent !important;
  padding: 24px 24px 28px !important;
  box-sizing: border-box !important;
}
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar { height: 5px !important; }
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar-thumb { background: #d1c4ba !important; border-radius: 3px !important; }

/* ── Cyfry nad słupkami ──────────────────────────────────────────────────── */
.sor-digit-row {
  display: flex !important;
  align-items: flex-end !important;
  padding: 0 0 12px !important;
  margin: 0 !important;
  min-width: max-content !important;
}
.sor-digit-cell {
  width: 80px !important;
  flex-shrink: 0 !important;
  font-family: 'Space Grotesk','Bricolage Grotesque',sans-serif !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  color: #1A237E !important;
  text-align: center !important;
  line-height: 1 !important;
}
.sor-digit-cell.zero  { color: #d1c4ba !important; }
.sor-digit-cell.wrong { color: #ba1a1a !important; }
.sor-digit-row .sor-label-spacer {
  width: 4px !important;
  flex-shrink: 0 !important;
}

/* ── Wewnętrzny kontener koralików ──────────────────────────────────────── */
.sor-abacus-card .sor-abacus-inner {
  display: flex !important;
  align-items: flex-start !important;
  background: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
  min-width: max-content !important;
  position: relative !important;
}

/* ── Kolumna ─────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-column {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  position: relative !important;
  width: 80px !important;
  flex-shrink: 0 !important;
}

/* Separator kolumn */
.sor-abacus-card .sor-col-divider {
  width: 4px !important;
  align-self: stretch !important;
  background: rgba(0,0,0,0) !important;
  flex-shrink: 0 !important;
}

/* ── Pręt ────────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-rod {
  position: absolute !important;
  left: 50% !important;
  top: 0 !important;
  transform: translateX(-50%) !important;
  width: 8px !important;
  height: 100% !important;
  background: linear-gradient(to right,#835b32,#d1c4ba 50%,#835b32) !important;
  border-radius: 4px !important;
  z-index: 1 !important;
  box-shadow: none !important;
}

/* ── Górna sekcja (koralik górny — wartość 5) ────────────────────────────── */
.sor-abacus-card .sor-upper-area {
  width: 80px !important;
  height: 110px !important;
  position: relative !important;
  flex-shrink: 0 !important;
  background: transparent !important;
  border-bottom: none !important;
}

/* ── Belka ───────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-beam {
  width: 80px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
  background: linear-gradient(to bottom,#d1c4ba,#fff 50%,#d1c4ba) !important;
  border-top: 1px solid #80756d !important;
  border-bottom: 1px solid #80756d !important;
  box-shadow: 0 4px 8px rgba(0,0,0,.12) !important;
  position: relative !important;
  z-index: 10 !important;
}

/* ── Dolna sekcja (4 koraliki — wartość 1 każdy) ────────────────────────── */
.sor-abacus-card .sor-lower-area {
  width: 80px !important;
  height: 274px !important;
  position: relative !important;
  flex-shrink: 0 !important;
  background: transparent !important;
}

/* ── Koralik — kształt diamentu (rombu) ─────────────────────────────────── */
.sor-abacus-card .sor-bead {
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 64px !important;
  height: 32px !important;
  border-radius: 0 !important;
  clip-path: polygon(50% 0%,100% 50%,50% 100%,0% 50%) !important;
  cursor: pointer !important;
  z-index: 5 !important;
  transition: top .22s cubic-bezier(.175,.885,.32,1.275),
              bottom .22s cubic-bezier(.175,.885,.32,1.275) !important;
  box-shadow: none !important;
  border: none !important;
}
.sor-abacus-card .sor-bead:hover { filter: brightness(1.1) !important; }
.sor-abacus-card .sor-bead:active { filter: brightness(.9) !important; }

/* Górny koralik — koralowy/czerwono-pomarańczowy */
.sor-abacus-card .sor-bead-upper {
  background: linear-gradient(135deg,#ff7043,#d84315) !important;
  opacity: .45 !important;
}
.sor-abacus-card .sor-bead-upper.active {
  opacity: 1 !important;
  background: linear-gradient(135deg,#ff8a65,#e64a19) !important;
}

/* Dolne koraliki — złocisty żółty */
.sor-abacus-card .sor-bead-lower {
  background: linear-gradient(135deg,#ffca28,#f57f17) !important;
  opacity: .40 !important;
}
.sor-abacus-card .sor-bead-lower.active {
  opacity: 1 !important;
  background: linear-gradient(135deg,#ffd740,#ff8f00) !important;
}

/* Kolumna z błędem (tryb Zadanie) */
.sor-abacus-card .sor-column-wrong .sor-bead-lower,
.sor-abacus-card .sor-column-wrong .sor-bead-upper {
  outline: 2px solid #ba1a1a !important;
  outline-offset: -2px !important;
}

/* ── Przycisk Wstecz ──────────────────────────────────────────────────────  */
.sor-back-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  height: 48px !important;
  padding: 0 32px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 24px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #1d1b19 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.08) !important;
  transition: box-shadow 140ms, transform 140ms !important;
  margin-top: 8px !important;
}
.sor-back-btn:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,.14) !important;
  transform: translateY(-1px) !important;
  border-color: #6f5a48 !important;
}

/* ── Responsywność ────────────────────────────────────────────────────────  */
@media (max-width: 760px) {
  .sor-ctrl-bar {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .sor-tabs { justify-content: center !important; }
  .sor-actions { justify-content: center !important; }
  .sor-num-display { text-align: center !important; }
  .sor-size-bar { justify-content: center !important; }
  .sor-abacus-card .sor-column { width: 60px !important; }
  .sor-abacus-card .sor-bead  { width: 48px !important; height: 24px !important; }
  .sor-abacus-card .sor-upper-area { height: 80px !important; }
  .sor-abacus-card .sor-lower-area { height: 200px !important; }
  .sor-digit-cell { width: 60px !important; font-size: 24px !important; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-A — pełne kolory koralików (opacity:1), chipy #fff8e7
   ═══════════════════════════════════════════════════════════════════════════ */

/* Koraliki — pełny kolor (bez przezroczystości), nieaktywne = kremowy */
.sor-abacus-card .sor-bead-upper {
  background: linear-gradient(135deg, #e0cfc7, #bfaea5) !important;
  opacity: 1 !important;
}
.sor-abacus-card .sor-bead-upper.active {
  background: linear-gradient(135deg, #ff8a65, #e64a19) !important;
  opacity: 1 !important;
}
.sor-abacus-card .sor-bead-lower {
  background: linear-gradient(135deg, #e8ddd4, #c8bdb5) !important;
  opacity: 1 !important;
}
.sor-abacus-card .sor-bead-lower.active {
  background: linear-gradient(135deg, #ffd740, #ff8f00) !important;
  opacity: 1 !important;
}

/* Chipy opisu wartości — kolor #fff8e7, ciemny tekst */
#screen-soroban .sor-chip {
  background: #fff8e7 !important;
  color: #3a2e1a !important;
  border: 1px solid #e8d8b0 !important;
}
#screen-soroban .sor-chip-zero {
  background: #ede7e4 !important;
  color: #80756d !important;
  border: 1px solid #d1c4ba !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-B — zakładki, przyciski, panel "?", wyśrodkowanie słupków
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Zakładki trybów — wygląd jak w reference (pill container) ────────────  */
#screen-soroban .sor-tabs {
  display: flex !important;
  background: #ede7e4 !important;
  border-radius: 12px !important;
  padding: 4px !important;
  gap: 2px !important;
  border: 1px solid #d1c4ba !important;
  flex-shrink: 0 !important;
}
#screen-soroban .sor-mode-tab {
  padding: 10px 18px !important;
  border-radius: 9px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  background: transparent !important;
  color: #80756d !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: background 130ms, color 130ms, box-shadow 130ms !important;
  white-space: nowrap !important;
  letter-spacing: .01em !important;
}
#screen-soroban .sor-mode-tab.active {
  background: #ffffff !important;
  color: #1d1b19 !important;
  box-shadow: 0 1px 6px rgba(0,0,0,.13) !important;
}
#screen-soroban .sor-mode-tab:hover:not(.active) {
  background: rgba(255,255,255,.55) !important;
  color: #3a3028 !important;
}

/* ── Panel z chipami — bez dużej liczby ──────────────────────────────────── */
#screen-soroban .sor-num-display {
  flex: 1 !important;
  background: #f9f2ef !important;
  border-radius: 12px !important;
  padding: 10px 18px !important;
  border: 1px solid #e0d8d4 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 48px !important;
  min-width: 0 !important;
}
#screen-soroban .sor-num-display .sor-result-number {
  display: none !important;
}
#screen-soroban .sor-chips-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  justify-content: center !important;
  align-items: center !important;
}

/* ── Przycisk Wyczyść — obrysowy ─────────────────────────────────────────── */
#screen-soroban .sor-act-outline {
  background: #ffffff !important;
  border: 1.5px solid #6f5a48 !important;
  color: #6f5a48 !important;
  font-weight: 700 !important;
}
#screen-soroban .sor-act-outline:hover {
  background: #f9f2ef !important;
  border-color: #3a2e1a !important;
  color: #3a2e1a !important;
}

/* ── Przycisk Losowo — wypełniony gradientem ─────────────────────────────── */
#screen-soroban .sor-act-filled {
  background: linear-gradient(to right, #f9dcc4, #f4c19a) !important;
  border: 1.5px solid #e8b07a !important;
  color: #27180a !important;
  font-weight: 700 !important;
  box-shadow: 0 2px 8px rgba(244,193,154,.35) !important;
}
#screen-soroban .sor-act-filled:hover {
  background: linear-gradient(to right, #f4c19a, #eca870) !important;
  box-shadow: 0 3px 12px rgba(244,193,154,.5) !important;
}

/* ── Przycisk "?" — info ─────────────────────────────────────────────────── */
#screen-soroban .sor-act-info {
  width: 38px !important;
  height: 38px !important;
  padding: 0 !important;
  border-radius: 50% !important;
  background: #ffffff !important;
  border: 1.5px solid #d1c4ba !important;
  color: #6f5a48 !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
#screen-soroban .sor-act-info:hover,
#screen-soroban .sor-act-info.active {
  background: #6f5a48 !important;
  color: #ffffff !important;
  border-color: #6f5a48 !important;
}

/* ── Panel informacyjny "?" ──────────────────────────────────────────────── */
#sor-info-panel {
  display: none;
  flex-direction: column !important;
  gap: 10px !important;
  background: #fffbf6 !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 14px !important;
  padding: 18px 22px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.08) !important;
}
.sor-info-title {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #6f5a48 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  margin: 0 0 4px !important;
}
.sor-info-rows { display: flex !important; flex-direction: column !important; gap: 8px !important; }
.sor-info-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  font-size: 14px !important;
  color: #1d1b19 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
.sor-info-row-note {
  color: #4e453e !important;
  font-size: 13px !important;
  padding-top: 8px !important;
  border-top: 1px solid #e0d8d4 !important;
  line-height: 1.55 !important;
  align-items: flex-start !important;
}
.sor-info-row-note svg { flex-shrink: 0 !important; margin-top: 1px !important; color: #6f5a48 !important; }
/* Mini koraliki w panelu */
.sor-info-bead {
  display: inline-block !important;
  width: 32px !important;
  height: 16px !important;
  border-radius: 3px !important;
  clip-path: polygon(50% 0%,100% 50%,50% 100%,0% 50%) !important;
  flex-shrink: 0 !important;
}
.sor-info-bead-upper { background: linear-gradient(135deg,#ff8a65,#e64a19) !important; }
.sor-info-bead-lower { background: linear-gradient(135deg,#ffd740,#ff8f00) !important; }

/* ── Wyśrodkowanie sorobanu ──────────────────────────────────────────────── */
.sor-abacus-card .sor-scroll-area {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}
.sor-abacus-card .sor-digit-row,
.sor-abacus-card .sor-abacus-inner {
  width: max-content !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-C — panel Wpisz, panel Zadanie (poziomy), przyciski
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Panel Wpisz liczbę — mniejsze pole ─────────────────────────────────── */
#screen-soroban .sor-enter-card {
  background: #f9f2ef !important;
  border: 1px solid #e0d8d4 !important;
  border-radius: 14px !important;
  padding: 16px 20px !important;
}
#screen-soroban .sor-enter-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
}
#screen-soroban .sor-enter-input {
  width: 140px !important;
  min-width: 0 !important;
  flex: 0 0 140px !important;
  height: 38px !important;
  padding: 0 12px !important;
  font-size: 14px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 9px !important;
  color: #1d1b19 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
#screen-soroban .sor-enter-input:focus { border-color: #6f5a48 !important; outline: none !important; }

/* Przyciski w panelach — dopasowane do stylu strony */
  background: linear-gradient(to right,#f9dcc4,#f4c19a) !important;
  border: 1.5px solid #e8b07a !important;
  color: #27180a !important;
  box-shadow: 0 2px 8px rgba(244,193,154,.30) !important;
}
  background: linear-gradient(to right,#f4c19a,#eca870) !important;
}
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  color: #4e453e !important;
}
  background: #f9f2ef !important;
  border-color: #6f5a48 !important;
}
  background: #f0edff !important;
  border: 1.5px solid #c5bef8 !important;
  color: #27308a !important;
}
  background: #e3deff !important;
}
  height: 38px !important;
  padding: 0 14px !important;
  border-radius: 9px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: all 120ms !important;
  white-space: nowrap !important;
}

/* ── Panel Zadanie — wybór zakresu ───────────────────────────────────────── */
#screen-soroban .sor-quiz-card {
  background: #f9f2ef !important;
  border: 1px solid #e0d8d4 !important;
  border-radius: 14px !important;
  padding: 18px 20px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

/* Rząd zakresu */
.sor-quiz-levels {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}
.sor-quiz-levels-label {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #80756d !important;
  letter-spacing: .05em !important;
  white-space: nowrap !important;
}
.sor-level-btns {
  display: flex !important;
  gap: 6px !important;
  flex-wrap: wrap !important;
}
.sor-level-btn {
  padding: 5px 13px !important;
  border-radius: 20px !important;
  border: 1.5px solid #d1c4ba !important;
  background: #fff !important;
  color: #80756d !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: all 120ms !important;
  white-space: nowrap !important;
}
.sor-level-btn:hover { border-color: #6f5a48 !important; color: #3a3028 !important; }
.sor-level-btn.active {
  background: linear-gradient(to right,#f9dcc4,#f4c19a) !important;
  border-color: #d1a070 !important;
  color: #27180a !important;
}

/* Quiz box — cel, feedback, akcje */
#screen-soroban .sor-quiz-box {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 10px !important;
}
#screen-soroban .sor-quiz-instruction {
  font-size: 13px !important;
  color: #80756d !important;
  margin: 0 !important;
}
#screen-soroban .sor-quiz-target {
  font-family: var(--font-display,'Bricolage Grotesque',sans-serif) !important;
  font-size: 42px !important;
  font-weight: 800 !important;
  color: #1d1b19 !important;
  letter-spacing: -.02em !important;
  line-height: 1 !important;
}
#screen-soroban .sor-quiz-feedback {
  min-height: 22px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #4e453e !important;
  text-align: center !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  padding: 4px 10px !important;
  border-radius: 8px !important;
}
#screen-soroban .sor-quiz-feedback.correct {
  background: #e8f5e9 !important;
  color: #1b5e20 !important;
  border: 1px solid #a5d6a7 !important;
}
#screen-soroban .sor-quiz-feedback.wrong {
  background: #fce4ec !important;
  color: #880e4f !important;
  border: 1px solid #f48fb1 !important;
}
#screen-soroban .sor-quiz-feedback.hint1,
#screen-soroban .sor-quiz-feedback.hint2 {
  background: #fff8e7 !important;
  color: #5d4037 !important;
  border: 1px solid #ffe082 !important;
}
#screen-soroban .sor-quiz-feedback.hint3 {
  background: #e8eaf6 !important;
  color: #1a237e !important;
  border: 1px solid #9fa8da !important;
}
#screen-soroban .sor-quiz-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  justify-content: center !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-D — przycisk Zeruj przy belce, position:relative na card
   ═══════════════════════════════════════════════════════════════════════════ */

/* Karta sorobanu: potrzebujemy position:relative dla absolutnego Zeruj */
.sor-abacus-card {
  position: relative !important;
}

/* Przycisk Zeruj — przy belce środkowej, prawa strona karty */
.sor-abacus-clear-btn {
  position: absolute !important;
  right: 14px !important;
  /* scroll-area padding-top:24 + digit-row:44 + upper-area:110 + half-beam:8 = 186px */
  top: 186px !important;
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: #ffffff !important;
  border: 1.5px solid #d1c4ba !important;
  color: #80756d !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  z-index: 20 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.14) !important;
  transition: background 120ms, color 120ms, border-color 120ms !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  padding: 0 !important;
}
.sor-abacus-clear-btn:hover {
  background: #6f5a48 !important;
  color: #ffffff !important;
  border-color: #6f5a48 !important;
}
.sor-abacus-clear-btn:active {
  background: #4e3526 !important;
}


/* ── Błąd kolumny w trybie Zadanie — styl pdf-layout-warning (bez nakładania) ── */
/* box-shadow:inset zostaje wewnątrz elementu → brak overlap sąsiednich kolumn */
.sor-column-wrong {
  outline: none !important;
  box-shadow: inset 0 0 0 2px #f0a500 !important;
  background: rgba(255,243,205,0.40) !important;
  border-radius: 4px !important;
}
.sor-column-wrong > .sor-rod {
  background: #c87800 !important;
  box-shadow: 0 0 6px rgba(200,120,0,.40) !important;
}
/* Usuwamy outline na koralach (był 2px solid #ba1a1a / #e05550) */
.sor-abacus-card .sor-column-wrong .sor-bead { outline: none !important; }
.sor-abacus-card .sor-column-wrong .sor-bead-lower,
.sor-abacus-card .sor-column-wrong .sor-bead-upper {
  outline: none !important;
}

/* ══ Responsywny rozmiar sorobanu — 13 słupków jednocześnie ════════════════
   Skalowanie ~70%: kolumna 80→56 px, koralik 64×32→44×22 px
   13 col×56 + 12 div×3 = 764 px → mieści się przy ~900 px szerokości
   ═══════════════════════════════════════════════════════════════════════ */

.sor-abacus-card .sor-scroll-area {
  padding: 16px 16px 20px !important;
}

/* Cyfry nad słupkami */
.sor-digit-cell {
  width: 56px !important;
  font-size: 22px !important;
}
.sor-digit-row .sor-label-spacer {
  width: 3px !important;
}
.sor-digit-row {
  padding: 0 0 8px !important;
}

/* Kolumna */
.sor-abacus-card .sor-column {
  width: 56px !important;
}

/* Separator */
.sor-abacus-card .sor-col-divider {
  width: 3px !important;
}

/* Pręt */
.sor-abacus-card .sor-rod {
  width: 6px !important;
}

/* Górna sekcja */
.sor-abacus-card .sor-upper-area {
  width: 56px !important;
  height: 80px !important;
}

/* Belka */
.sor-abacus-card .sor-beam {
  width: 56px !important;
  height: 12px !important;
}

/* Dolna sekcja — B_H=22, B_GAP=2, B_PAD=7 → 7+4×24-2+7=174≈175 px */
.sor-abacus-card .sor-lower-area {
  width: 56px !important;
  height: 175px !important;
}

/* Koralik */
.sor-abacus-card .sor-bead {
  width: 44px !important;
  height: 22px !important;
}

/* Przycisk × — nowa pozycja: padding-top:16 + cyfry:30 + upper:80 + half-beam:6 = 132 px */
.sor-abacus-clear-btn {
  top: 132px !important;
  width: 28px !important;
  height: 28px !important;
  font-size: 15px !important;
  right: 10px !important;
}

/* ── Cyfry nad słupkami — kolor gold-3 ────────────────────────────────────── */
.sor-digit-cell {
  color: var(--gold-3) !important;
}

/* ══ Style przycisków sorobanu — spójne z ramką ════════════════════════════
   Dotyczy: Sprawdź, Wylosuj, Wyczyść, Następne, przyciski słupków
   ══════════════════════════════════════════════════════════════════════════ */
#screen-soroban .sor-btn,
.sor-preset-btn {
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  border: 1.5px solid #ddd0b0 !important;
  color: #27180a !important;
  font-weight: 700 !important;
}
#screen-soroban .sor-btn:hover,
.sor-preset-btn:hover,
.sor-preset-btn.active {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border: 1.5px solid #ddd0b0 !important;
}
#screen-soroban .sor-btn:disabled {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  color: #27180a !important;
}

/* ══ Soroban — zmieść w ramce, bez paska przewijania ═══════════════════════ */
.sor-abacus-card .sor-scroll-area {
  overflow-x: hidden !important;
}

/* ══ Tablet (max 1023px) — kolumna 46px
   13 col×46 + 12 div×3 = 634 + 36 = 670px + 2×16 = 702px
   ══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1023px) {
  .sor-digit-cell                       { width: 46px !important; font-size: 18px !important; }
  .sor-digit-row .sor-label-spacer      { width: 3px !important; }
  .sor-abacus-card .sor-column          { width: 46px !important; }
  .sor-abacus-card .sor-upper-area      { width: 46px !important; height: 70px !important; }
  .sor-abacus-card .sor-beam            { width: 46px !important; height: 10px !important; }
  .sor-abacus-card .sor-lower-area      { width: 46px !important; height: 155px !important; }
  .sor-abacus-card .sor-bead            { width: 36px !important; height: 20px !important; }
  /* Przycisk × — padding-top:16 + cyfry:26 + upper:70 + half-beam:5 = 117px */
  .sor-abacus-clear-btn                 { top: 117px !important; }
}

/* ══ Mobile (max 767px) — tylko 4 i 6 słupków, kolumna 46px ═══════════════ */
@media (max-width: 767px) {
  /* Ukryj opcje 9 i 13 słupków */
  .sor-preset-btn[data-cols="9"],
  .sor-preset-btn[data-cols="13"]       { display: none !important; }

  .sor-digit-cell                       { width: 46px !important; font-size: 18px !important; }
  .sor-digit-row .sor-label-spacer      { width: 3px !important; }
  .sor-abacus-card .sor-column          { width: 46px !important; }
  .sor-abacus-card .sor-upper-area      { width: 46px !important; height: 70px !important; }
  .sor-abacus-card .sor-beam            { width: 46px !important; height: 10px !important; }
  .sor-abacus-card .sor-lower-area      { width: 46px !important; height: 155px !important; }
  .sor-abacus-card .sor-bead            { width: 36px !important; height: 20px !important; }
  .sor-abacus-clear-btn                 { top: 117px !important; }
}

/* ══ Przycisk LOSOWO — spójny styl z przyciskami sorobanu ══════════════════ */
#sor-btn-random {
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  border: 1.5px solid #ddd0b0 !important;
  color: #27180a !important;
  font-weight: 700 !important;
}
#sor-btn-random:hover {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border: 1.5px solid #ddd0b0 !important;
}

/* ══ Jedności / Dziesiątki / Setki / Tysiące — spójny styl z sorobanem ═════ */
.sor-level-btn {
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  border: 1.5px solid #ddd0b0 !important;
  color: #27180a !important;
  font-weight: 700 !important;
}
.sor-level-btn:hover {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border: 1.5px solid #ddd0b0 !important;
}
.sor-level-btn.active {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border: 1.5px solid #ddd0b0 !important;
}

/* ══ pdf-cv4 — karty zakresów dla mnożenia/dzielenia ══ */
.pdf-cv4 {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
}
.pdf-cv4-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pdf-cv4-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--gold-3, #8a6a3e);
}
.pdf-cv4-row {
  display: flex;
  gap: 10px;
  width: 100%;
}
.pdf-cv4-row-cards {
  display: flex;
  gap: 10px;
}
/* Clickable variant — nadpisuje stały kursor z base */
.pdf-range-card-clickable {
  cursor: pointer !important;
  user-select: none;
}
.pdf-range-card-clickable:hover:not(.pdf-range-card-disabled) {
  border-color: #e0d4b8 !important;
  background: #faf5ea !important;
}
/* Disabled — dla dzielnika > dzielna */
.pdf-range-card-disabled {
  opacity: 0.32 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}
/* Neutralizuj nth-child kolory w cv4 (nie mylić z add/sub) */
.pdf-cv4 .pdf-range-card-name {
  color: var(--ink, #041627) !important;
}
.pdf-cv4 .pdf-range-card-desc {
  color: var(--ink-faint, #74777d) !important;
}
/* Hint "Dzielnik nie może być..." */
.pdf-cv4-hint {
  font-size: 11px;
  color: #b07840;
  font-style: italic;
  margin-top: -2px;
}
/* Summary "Wybrany wariant" */
.pdf-cv4-summary {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
}
.pdf-cv4-summary-label {
  font-size: 11px;
  color: var(--ink-faint, #74777d);
  font-weight: 500;
}
.pdf-cv4-summary-variant {
  font-size: 12px;
  font-weight: 700;
  color: var(--ink, #041627);
  letter-spacing: .04em;
}
/* Mobile: 2×2 */
@media (max-width: 500px) {
  .pdf-cv4-row,
  .pdf-cv4-row-cards {
    flex-wrap: wrap;
  }
  .pdf-cv4-row .pdf-range-card,
  .pdf-cv4-row .pdf-range-card-simple {
    flex: 1 1 calc(50% - 5px);
  }
}

/* ══ Krok 3 — titlerow z badge "Wariant" po prawej ══ */
.pdf-step3-titlerow {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 4px;
}
.pdf-step3-titlecol {
  flex: 1;
  min-width: 0;
}
.pdf-step3-badge {
  flex-shrink: 0;
  background: #1a1e2e;
  color: #fff;
  border-radius: 100px;
  padding: 7px 18px;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  letter-spacing: .02em;
  align-self: center;
}
.pdf-step3-badge strong {
  font-weight: 700;
  color: #fff;
  letter-spacing: .04em;
}
@media (max-width: 560px) {
  .pdf-step3-titlerow {
    flex-direction: column;
    gap: 8px;
  }
  .pdf-step3-badge {
    align-self: flex-start;
    font-size: 11px;
    padding: 5px 14px;
  }
}

/* ══ Aktywna karta podczas hover — pokazuj active od razu ══ */
.pdf-cv4 .pdf-range-card-clickable.active:hover,
.pdf-cv4 .pdf-range-card-clickable.pdf-range-card-simple.active:hover,
.pdf-cv4 .pdf-range-card-clickable.pdf-range-card-b-simple.active:hover {
  background: #fdefc8 !important;
  border-color: #b8890a !important;
  box-shadow: 0 0 0 2px rgba(184,137,10,.20) !important;
}

/* ══ Neutralizuj hover na kontenerze pdf-cv4 (nth-child zmienia tło rodzica) ══ */
.pdf-range-grid > .pdf-cv4:nth-child(1):hover,
.pdf-range-grid > .pdf-cv4:nth-child(2):hover,
.pdf-range-grid > .pdf-cv4:nth-child(3):hover,
.pdf-range-grid > .pdf-cv4:nth-child(4):hover {
  background: #e8f2e4 !important;
}

/* ══ Picker mnożników / dzielników ══ */
.pdf-mult-picker {
  margin-top: 16px;
  background: #fff;
  border: 1.5px solid #d9c07a;
  border-radius: 12px;
  padding: 14px 16px 12px;
}

.pdf-mult-picker-header {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  color: #7a6a3a;
  background: #f5edcf;
  border: 1px solid #d9c07a;
  border-radius: 20px;
  display: inline-block;
  padding: 3px 12px;
  margin-bottom: 12px;
}

.pdf-mult-picker-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px 12px;
}

.pdf-mult-col {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pdf-mult-cb-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
  color: #2d2d2d;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 6px;
  transition: background .12s;
  user-select: none;
}

.pdf-mult-cb-label:hover {
  background: #fdf6e3;
}

.pdf-mult-cb-label-dis {
  opacity: .38;
  cursor: not-allowed;
}

.pdf-mult-cb-label-dis:hover {
  background: transparent;
}

.pdf-mult-cb {
  width: 18px;
  height: 18px;
  accent-color: #b8890a;
  cursor: pointer;
  flex-shrink: 0;
}

.pdf-mult-cb-label-dis .pdf-mult-cb {
  cursor: not-allowed;
}

.pdf-mult-hint {
  margin-top: 10px;
  font-size: 11.5px;
  color: #888;
  line-height: 1.5;
  border-top: 1px solid #ede5c8;
  padding-top: 8px;
}

/* ══ Kolumny 6-8 — mniejsza czcionka żeby zmieścić w wierszu ══ */
.col-grid[style*="--col-cols: 6"] .col-card,
.col-grid[style*="--col-cols: 7"] .col-card,
.col-grid[style*="--col-cols: 8"] .col-card {
  padding: 10px 8px 12px;
  gap: 6px;
}
.col-grid[style*="--col-cols: 6"] .col-row,
.col-grid[style*="--col-cols: 7"] .col-row,
.col-grid[style*="--col-cols: 8"] .col-row {
  font-size: 28px;
  line-height: 1.1;
  padding: 0 4px;
}
.col-grid[style*="--col-cols: 6"] .col-input,
.col-grid[style*="--col-cols: 7"] .col-input,
.col-grid[style*="--col-cols: 8"] .col-input {
  font-size: 28px;
  line-height: 1.1;
  padding: 5px 8px;
}
.col-grid[style*="--col-cols: 6"] .col-check-btn,
.col-grid[style*="--col-cols: 7"] .col-check-btn,
.col-grid[style*="--col-cols: 8"] .col-check-btn {
  padding: 5px 8px;
  font-size: 11px;
}
.col-grid[style*="--col-cols: 6"] .col-timer,
.col-grid[style*="--col-cols: 7"] .col-timer,
.col-grid[style*="--col-cols: 8"] .col-timer {
  padding: 4px 8px;
  font-size: 10px;
  letter-spacing: 0.12em;
}
.col-grid[style*="--col-cols: 6"] .col-timer .value,
.col-grid[style*="--col-cols: 7"] .col-timer .value,
.col-grid[style*="--col-cols: 8"] .col-timer .value {
  font-size: 12px;
}
@media (max-width: 1280px) {
  .col-grid[style*="--col-cols: 7"] .col-row,
  .col-grid[style*="--col-cols: 7"] .col-input,
  .col-grid[style*="--col-cols: 8"] .col-row,
  .col-grid[style*="--col-cols: 8"] .col-input { font-size: clamp(16px, 2.2vw, 26px); }
}

/* ══ Kolumny > konfiguracja — 4 suwaki w jednym wierszu ══ */
#screen-config-col .slider-rail {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 16px;
  max-width: none;
}
#screen-config-col .slider-rig {
  height: 260px !important;
}
@media (max-width: 1000px) {
  #screen-config-col .slider-rail {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 560px) {
  #screen-config-col .slider-rail {
    grid-template-columns: 1fr !important;
  }
}

/* ══ Mobile — większy input i przycisk w FLASH/KOLUMNY i MUL/DIV ══ */
@media (max-width: 600px) {
  /* Pole na wynik — wyższe, większa czcionka */
  .col-input {
    font-size: 22px !important;
    padding: 10px 12px !important;
    min-height: 48px !important;
    border-radius: 8px !important;
    border-width: 2px !important;
  }

  /* Przycisk ✓ w kolumnach — wyraźnie większy obszar dotyku */
  .col-check-btn {
    width: 52px !important;
    height: 48px !important;
    font-size: 22px !important;
    padding: 0 !important;
    border-radius: 8px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-width: 2px !important;
  }

  /* Przycisk ✓ w mnożeniu/dzieleniu */
  .mul-check-btn {
    width: 52px !important;
    height: 48px !important;
    font-size: 24px !important;
    border-radius: 8px !important;
    border-width: 2px !important;
  }

  /* Rząd z inputem — trochę więcej oddechu */
  .col-answer {
    gap: 10px !important;
    margin-top: 8px !important;
  }
}

/* ══ Mobile — cyfry w kolumnach FLASH ══ */
@media (max-width: 600px) {
  .col-row {
    font-size: 22px !important;
    line-height: 1.2 !important;
    padding: 2px 6px !important;
  }
}

/* ══ Mobile — większe cyfry w mnożeniu/dzieleniu FLASH ══ */
@media (max-width: 600px) {
  .mul-problem-row {
    font-size: 28px !important;
    gap: 8px !important;
  }
  .mul-input {
    font-size: 26px !important;
    padding: 8px 10px !important;
    min-height: 48px !important;
    border-radius: 8px !important;
    border-width: 2px !important;
  }
}


/* ── Desktop: przycisk ✓ pod polem wpisywania w kolumnach ─────────────────── */
@media (min-width: 601px) {
  .col-answer {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .col-check-btn {
    width: 100% !important;
    height: 36px !important;
  }
}

/* ── Desktop: mniej przestrzeni pod kartami kolumn ──────────────────────────── */
@media (min-width: 601px) {
  .col-card {
    padding-bottom: 4px !important;
    gap: 6px !important;
  }
  .col-feedback {
    min-height: 0 !important;
    padding: 0 2px 2px !important;
    line-height: 1.2 !important;
  }
}

/* ── Karty kolumn: nie rozciągaj do wysokości sąsiada ────────────────────── */
.col-grid {
  align-items: start !important;
}


/* ── Karta sorobanu ─────────────────────────────────────────────────────── */
.sor-abacus-card {
  width: 100% !important;
  background: #ffffff !important;
  border-radius: 20px !important;
  padding: 0 !important;
  overflow: hidden !important;
  box-shadow: 0 8px 36px rgba(0,0,0,0.35) !important;
}

/* Zewnętrzna rama — krem/beż */
.sor-frame-wrap {
  width: 100% !important;
}
  background: #e8dfd0 !important;
  border-radius: 20px !important;
  padding: 20px 20px 0 !important;
  position: relative !important;
  box-shadow: inset 0 0 40px rgba(100,70,30,0.15) !important;
  /* Wkręty w rogach */
  --screw-size: 10px !important;
}
/* Wkręty w narożnikach ramy */
.sor-abacus-card .sor-frame::before,
.sor-abacus-card .sor-frame::after {
  content: '◎' !important;
  position: absolute !important;
  font-size: 12px !important;
  color: #c0b090 !important;
  line-height: 1 !important;
}
.sor-abacus-card .sor-frame::before { top: 7px; left: 10px !important; }
.sor-abacus-card .sor-frame::after  { top: 7px; right: 10px !important; }

/* Obszar przewijania (cyfry + koraliki w jednym) */
.sor-abacus-card .sor-scroll-area {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  background: transparent !important;
  scrollbar-width: thin !important;
  scrollbar-color: #c0b090 transparent !important;
  border-radius: 0 !important;
  padding-bottom: 0 !important;
}
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar { height: 4px !important; }
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar-thumb { background: #c0b090 !important; border-radius: 2px !important; }

/* ── Cyfry nad słupkami ─────────────────────────────────────────────────── */
.sor-digit-row {
  display: flex !important;
  align-items: center !important;
  padding: 0 !important;
  margin: 0 !important;
  min-width: max-content !important;
}
.sor-digit-cell {
  font-family: var(--font-display, 'Bricolage Grotesque', sans-serif) !important;
  font-size: 26px !important;
  font-weight: 800 !important;
  color: #2a2520 !important;
  text-align: center !important;
  line-height: 1 !important;
  padding: 12px 0 10px !important;
  /* width matched by JS flex, same as .sor-column */
  flex-shrink: 0 !important;
}
.sor-digit-cell.zero  { color: #bbb4a8 !important; }
.sor-digit-cell.wrong { color: #c0392b !important; font-weight: 900 !important; }

/* Spacer między cyframi = szerokość .sor-col-divider */
.sor-digit-row .sor-label-spacer {
  flex-shrink: 0 !important;
}

/* ── Koraliki ────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-abacus-inner {
  display: flex !important;
  align-items: stretch !important;
  background: #f5ede0 !important;
  border-radius: 10px 10px 0 0 !important;
  padding: 0 !important;
  min-width: max-content !important;
}

/* Kolumna */
.sor-abacus-card .sor-column {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  position: relative !important;
  flex-shrink: 0 !important;
}

/* Pręt – metaliczny złoto-brąz */
.sor-abacus-card .sor-rod {
  background: linear-gradient(to right, #9a7040 10%, #d4a450 50%, #9a7040 90%) !important;
  border-radius: 3px !important;
  box-shadow: none !important;
}

/* Belka środkowa */
.sor-abacus-card .sor-beam {
  background: #f5ede0 !important;
  border-top: 2px solid #d0c4a8 !important;
  border-bottom: 2px solid #d0c4a8 !important;
  box-shadow: none !important;
}

/* Górna sekcja (tło) */
.sor-abacus-card .sor-upper-area {
  background: #f0e8d8 !important;
  border-bottom: 3px solid #d8cdb8 !important;
}

/* Dolna sekcja (tło) */
.sor-abacus-card .sor-lower-area {
  background: #f5ede0 !important;
}

/* Górny koralik — koralowy/łososiowy */
.sor-abacus-card .sor-bead-upper {
  background: radial-gradient(circle at 38% 32%, #ffc8b0, #dd6040 55%, #b03020) !important;
  opacity: 0.42 !important;
  border: none !important;
  box-shadow: 0 2px 6px rgba(180,60,30,0.20) !important;
}
.sor-abacus-card .sor-bead-upper.active {
  background: radial-gradient(circle at 38% 32%, #ffd8c0, #ee7050 55%, #c84030) !important;
  opacity: 1 !important;
  box-shadow: 0 3px 12px rgba(200,60,30,0.45) !important;
}

/* Dolne koraliki — złocisty bursztyn */
.sor-abacus-card .sor-bead-lower {
  background: radial-gradient(circle at 38% 32%, #fff0a0, #e8b020 55%, #b07808) !important;
  opacity: 0.38 !important;
  border: none !important;
  box-shadow: 0 2px 5px rgba(160,110,10,0.18) !important;
}
.sor-abacus-card .sor-bead-lower.active {
  background: radial-gradient(circle at 38% 32%, #fff8b0, #f8c828 55%, #c89010) !important;
  opacity: 1 !important;
  box-shadow: 0 3px 10px rgba(190,140,10,0.45) !important;
}

/* Kolumna z błędem (tryb quiz) */
.sor-abacus-card .sor-column-wrong .sor-bead { outline: 2px solid #e05550 !important; }

/* Separator kolumn */
.sor-abacus-card .sor-col-divider {
  background: rgba(0,0,0,0.06) !important;
  flex-shrink: 0 !important;
}

/* ── Przycisk Wstecz ────────────────────────────────────────────────────── */
.sor-back-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  height: 46px !important;
  padding: 0 28px !important;
  background: #ffffff !important;
  border: none !important;
  border-radius: 23px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #1a1a18 !important;
  cursor: pointer !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.22) !important;
  transition: box-shadow 140ms, transform 140ms !important;
  margin-top: 10px !important;
}
.sor-back-btn:hover {
  box-shadow: 0 4px 22px rgba(0,0,0,0.35) !important;
  transform: translateY(-1px) !important;
}

/* ── Responsywność ──────────────────────────────────────────────────────── */
@media (max-width: 760px) {
  .sor-ctrl-bar {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .sor-tabs { justify-content: center !important; }
  .sor-actions { justify-content: center !important; }
  .sor-num-display { text-align: center !important; }
  .sor-size-bar { justify-content: center !important; }
  .sor-preset-group { flex-wrap: wrap !important; justify-content: center !important; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5 — pełna korekta (jasne tło, rozmby koraliki 64×32, cyfry nad)
   Nadpisuje V4. Bazuje na reference code.html (dobry_widok.zip).
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Tło sekcji — JASNE (nie ciemne) ────────────────────────────────────── */
#screen-soroban {
  background: #fff8f5 !important;
  padding: 0 !important;
  min-height: 100vh !important;
}

.sor-page {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 20px !important;
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 48px 28px 64px !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

/* ── Nagłówek ────────────────────────────────────────────────────────────── */
.sor-page-head { text-align: center !important; }
.sor-page-title {
  font-size: clamp(26px, 4vw, 38px) !important;
  font-weight: 700 !important;
  color: #1d1b19 !important;
  margin: 0 0 10px !important;
  letter-spacing: -0.02em !important;
  line-height: 1.2 !important;
}
.sor-page-desc {
  font-size: 16px !important;
  color: #4e453e !important;
  line-height: 1.65 !important;
  max-width: 520px !important;
  margin: 0 auto !important;
}

/* ── Pasek sterowania ─────────────────────────────────────────────────────  */
.sor-ctrl-bar {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  background: #ffffff !important;
  border-radius: 16px !important;
  padding: 14px 18px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  box-shadow: 0 4px 20px rgba(26,35,126,.07), 0 1px 4px rgba(0,0,0,.06) !important;
  border: 1px solid #e8e1de !important;
}

/* Zakładki */
.sor-tabs {
  display: flex !important;
  background: #f3ece9 !important;
  border-radius: 10px !important;
  padding: 4px !important;
  gap: 3px !important;
  flex-shrink: 0 !important;
}
.sor-mode-tab {
  padding: 9px 14px !important;
  border-radius: 7px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  background: transparent !important;
  color: #80756d !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: all 130ms !important;
  white-space: nowrap !important;
}
.sor-mode-tab.active {
  background: #fff !important;
  color: #1d1b19 !important;
  box-shadow: 0 1px 5px rgba(0,0,0,.11) !important;
}
.sor-mode-tab:hover:not(.active) {
  background: rgba(255,255,255,.6) !important;
  color: #3a3028 !important;
}

/* Wynik z chipami */
.sor-num-display {
  flex: 1 !important;
  background: #f9f2ef !important;
  border-radius: 12px !important;
  padding: 10px 18px 12px !important;
  text-align: center !important;
  border: 1px solid #e0d8d4 !important;
  min-width: 0 !important;
}
.sor-num-label {
  font-size: 9px !important;
  font-weight: 700 !important;
  color: #a09890 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  margin-bottom: 3px !important;
}
.sor-result-number {
  font-family: var(--font-display,'Bricolage Grotesque',sans-serif) !important;
  font-size: clamp(30px, 4vw, 46px) !important;
  font-weight: 800 !important;
  color: #1d1b19 !important;
  letter-spacing: -0.02em !important;
  line-height: 1 !important;
  margin-bottom: 8px !important;
}
.sor-result-number.sor-result-correct { color: #228b22 !important; }
.sor-result-number.sor-result-wrong   { color: #c0392b !important; }

/* Chipy */
.sor-chips-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 5px !important;
  justify-content: center !important;
  min-height: 20px !important;
}
.sor-chip {
  display: inline-block !important;
  padding: 3px 9px !important;
  border-radius: 20px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  color: #3a3028 !important;
  letter-spacing: .06em !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
.sor-chip-zero {
  background: #ede7e4 !important;
  color: #80756d !important;
}

/* Przyciski akcji */
.sor-actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
}
.sor-act-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  height: 38px !important;
  padding: 0 14px !important;
  background: #fff !important;
  border: 1.5px solid #d8d1cc !important;
  border-radius: 9px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  color: #4e453e !important;
  letter-spacing: .06em !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: background 120ms, border-color 120ms !important;
  white-space: nowrap !important;
}
.sor-act-btn:hover {
  background: #f9f2ef !important;
  border-color: #b8956a !important;
}
.sor-act-round {
  width: 38px !important;
  padding: 0 !important;
  justify-content: center !important;
  border-radius: 50% !important;
  font-size: 16px !important;
}

/* ── Panele trybów ────────────────────────────────────────────────────────  */
#screen-soroban .sor-mode-panel {
  display: none !important;
  width: 100% !important;
}
#screen-soroban .sor-mode-panel.active { display: block !important; }

.sor-enter-card, .sor-quiz-card {
  background: #f9f2ef !important;
  border: 1px solid #e0d8d4 !important;
  border-radius: 14px !important;
  padding: 18px 22px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.sor-enter-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
}
.sor-enter-input {
  flex: 1 !important;
  min-width: 180px !important;
  height: 42px !important;
  padding: 0 14px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 9px !important;
  font-size: 15px !important;
  color: #1d1b19 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  outline: none !important;
}
.sor-enter-input:focus { border-color: #6f5a48 !important; }
.sor-enter-msg {
  margin: 8px 0 0 !important;
  font-size: 13px !important;
  color: #80756d !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
.sor-enter-msg.ok    { color: #2e7d32 !important; }
.sor-enter-msg.error { color: #c62828 !important; }

/* Przyciski w panelach */
  height: 42px !important;
  padding: 0 16px !important;
  border-radius: 9px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: opacity 130ms, transform 100ms !important;
  white-space: nowrap !important;
}
#screen-soroban .sor-btn:hover  { opacity: .88 !important; }

/* Quiz */
.sor-quiz-box {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 10px !important;
}
.sor-quiz-instruction { font-size: 14px !important; color: #80756d !important; margin: 0 !important; }
.sor-quiz-target {
  font-family: var(--font-display,'Bricolage Grotesque',sans-serif) !important;
  font-size: 44px !important;
  font-weight: 800 !important;
  color: #1d1b19 !important;
  letter-spacing: -.02em !important;
}
.sor-quiz-feedback { font-size: 14px !important; min-height: 20px !important; color: #4e453e !important; }
.sor-quiz-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  justify-content: center !important;
}

/* ── Rozmiar sorobanu ─────────────────────────────────────────────────────  */
.sor-size-bar {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  width: 100% !important;
}
.sor-size-label {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #80756d !important;
  letter-spacing: .05em !important;
  white-space: nowrap !important;
}
.sor-preset-group { display: flex !important; gap: 6px !important; flex-wrap: wrap !important; }
}
.sor-expert-row {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.sor-expert-label { font-size: 11px !important; color: #80756d !important; white-space: nowrap !important; }
.sor-expert-input {
  width: 60px !important;
  height: 32px !important;
  padding: 0 8px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 7px !important;
  color: #1d1b19 !important;
  font-size: 12px !important;
}
.sor-col-desc { font-size: 11px !important; color: #80756d !important; margin: 0 !important; }
.sor-stats-ghost { display: none !important; }

/* ══════════════════════════════════════════════════════════════════════
   GŁÓWNY SOROBAN — karta + rama + koraliki
   ══════════════════════════════════════════════════════════════════════ */

/* Karta zewnętrzna */
.sor-abacus-card {
  width: 100% !important;
  background: #f3ece9 !important;
  border-radius: 24px !important;
  border: 8px solid #d1c4ba !important;
  box-shadow: 0 10px 30px rgba(26,35,126,.06), 0 4px 12px rgba(0,0,0,.08) !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

/* Pojedynczy scroll-area: cyfry + koraliki w tym samym oknie przewijania */
.sor-abacus-card .sor-frame-wrap { width: 100% !important; }
  background: #f3ece9 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}
.sor-abacus-card .sor-scroll-area {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  background: #f3ece9 !important;
  scrollbar-width: thin !important;
  scrollbar-color: #d1c4ba transparent !important;
  padding: 24px 24px 28px !important;
  box-sizing: border-box !important;
}
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar { height: 5px !important; }
.sor-abacus-card .sor-scroll-area::-webkit-scrollbar-thumb { background: #d1c4ba !important; border-radius: 3px !important; }

/* ── Cyfry nad słupkami ──────────────────────────────────────────────────── */
.sor-digit-row {
  display: flex !important;
  align-items: flex-end !important;
  padding: 0 0 12px !important;
  margin: 0 !important;
  min-width: max-content !important;
}
.sor-digit-cell {
  width: 80px !important;
  flex-shrink: 0 !important;
  font-family: 'Space Grotesk','Bricolage Grotesque',sans-serif !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  color: #1A237E !important;
  text-align: center !important;
  line-height: 1 !important;
}
.sor-digit-cell.zero  { color: #d1c4ba !important; }
.sor-digit-cell.wrong { color: #ba1a1a !important; }
.sor-digit-row .sor-label-spacer {
  width: 4px !important;
  flex-shrink: 0 !important;
}

/* ── Wewnętrzny kontener koralików ──────────────────────────────────────── */
.sor-abacus-card .sor-abacus-inner {
  display: flex !important;
  align-items: flex-start !important;
  background: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
  min-width: max-content !important;
  position: relative !important;
}

/* ── Kolumna ─────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-column {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  position: relative !important;
  width: 80px !important;
  flex-shrink: 0 !important;
}

/* Separator kolumn */
.sor-abacus-card .sor-col-divider {
  width: 4px !important;
  align-self: stretch !important;
  background: rgba(0,0,0,0) !important;
  flex-shrink: 0 !important;
}

/* ── Pręt ────────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-rod {
  position: absolute !important;
  left: 50% !important;
  top: 0 !important;
  transform: translateX(-50%) !important;
  width: 8px !important;
  height: 100% !important;
  background: linear-gradient(to right,#835b32,#d1c4ba 50%,#835b32) !important;
  border-radius: 4px !important;
  z-index: 1 !important;
  box-shadow: none !important;
}

/* ── Górna sekcja (koralik górny — wartość 5) ────────────────────────────── */
.sor-abacus-card .sor-upper-area {
  width: 80px !important;
  height: 110px !important;
  position: relative !important;
  flex-shrink: 0 !important;
  background: transparent !important;
  border-bottom: none !important;
}

/* ── Belka ───────────────────────────────────────────────────────────────── */
.sor-abacus-card .sor-beam {
  width: 80px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
  background: linear-gradient(to bottom,#d1c4ba,#fff 50%,#d1c4ba) !important;
  border-top: 1px solid #80756d !important;
  border-bottom: 1px solid #80756d !important;
  box-shadow: 0 4px 8px rgba(0,0,0,.12) !important;
  position: relative !important;
  z-index: 10 !important;
}

/* ── Dolna sekcja (4 koraliki — wartość 1 każdy) ────────────────────────── */
.sor-abacus-card .sor-lower-area {
  width: 80px !important;
  height: 274px !important;
  position: relative !important;
  flex-shrink: 0 !important;
  background: transparent !important;
}

/* ── Koralik — kształt diamentu (rombu) ─────────────────────────────────── */
.sor-abacus-card .sor-bead {
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 64px !important;
  height: 32px !important;
  border-radius: 0 !important;
  clip-path: polygon(50% 0%,100% 50%,50% 100%,0% 50%) !important;
  cursor: pointer !important;
  z-index: 5 !important;
  transition: top .22s cubic-bezier(.175,.885,.32,1.275),
              bottom .22s cubic-bezier(.175,.885,.32,1.275) !important;
  box-shadow: none !important;
  border: none !important;
}
.sor-abacus-card .sor-bead:hover { filter: brightness(1.1) !important; }
.sor-abacus-card .sor-bead:active { filter: brightness(.9) !important; }

/* Górny koralik — koralowy/czerwono-pomarańczowy */
.sor-abacus-card .sor-bead-upper {
  background: linear-gradient(135deg,#ff7043,#d84315) !important;
  opacity: .45 !important;
}
.sor-abacus-card .sor-bead-upper.active {
  opacity: 1 !important;
  background: linear-gradient(135deg,#ff8a65,#e64a19) !important;
}

/* Dolne koraliki — złocisty żółty */
.sor-abacus-card .sor-bead-lower {
  background: linear-gradient(135deg,#ffca28,#f57f17) !important;
  opacity: .40 !important;
}
.sor-abacus-card .sor-bead-lower.active {
  opacity: 1 !important;
  background: linear-gradient(135deg,#ffd740,#ff8f00) !important;
}

/* Kolumna z błędem (tryb Zadanie) */
.sor-abacus-card .sor-column-wrong .sor-bead-lower,
.sor-abacus-card .sor-column-wrong .sor-bead-upper {
  outline: 2px solid #ba1a1a !important;
  outline-offset: -2px !important;
}

/* ── Przycisk Wstecz ──────────────────────────────────────────────────────  */
.sor-back-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  height: 48px !important;
  padding: 0 32px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 24px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #1d1b19 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.08) !important;
  transition: box-shadow 140ms, transform 140ms !important;
  margin-top: 8px !important;
}
.sor-back-btn:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,.14) !important;
  transform: translateY(-1px) !important;
  border-color: #6f5a48 !important;
}

/* ── Responsywność ────────────────────────────────────────────────────────  */
@media (max-width: 760px) {
  .sor-ctrl-bar {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .sor-tabs { justify-content: center !important; }
  .sor-actions { justify-content: center !important; }
  .sor-num-display { text-align: center !important; }
  .sor-size-bar { justify-content: center !important; }
  .sor-abacus-card .sor-column { width: 60px !important; }
  .sor-abacus-card .sor-bead  { width: 48px !important; height: 24px !important; }
  .sor-abacus-card .sor-upper-area { height: 80px !important; }
  .sor-abacus-card .sor-lower-area { height: 200px !important; }
  .sor-digit-cell { width: 60px !important; font-size: 24px !important; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-A — pełne kolory koralików (opacity:1), chipy #fff8e7
   ═══════════════════════════════════════════════════════════════════════════ */

/* Koraliki — pełny kolor (bez przezroczystości), nieaktywne = kremowy */
.sor-abacus-card .sor-bead-upper {
  background: linear-gradient(135deg, #e0cfc7, #bfaea5) !important;
  opacity: 1 !important;
}
.sor-abacus-card .sor-bead-upper.active {
  background: linear-gradient(135deg, #ff8a65, #e64a19) !important;
  opacity: 1 !important;
}
.sor-abacus-card .sor-bead-lower {
  background: linear-gradient(135deg, #e8ddd4, #c8bdb5) !important;
  opacity: 1 !important;
}
.sor-abacus-card .sor-bead-lower.active {
  background: linear-gradient(135deg, #ffd740, #ff8f00) !important;
  opacity: 1 !important;
}

/* Chipy opisu wartości — kolor #fff8e7, ciemny tekst */
#screen-soroban .sor-chip {
  background: #fff8e7 !important;
  color: #3a2e1a !important;
  border: 1px solid #e8d8b0 !important;
}
#screen-soroban .sor-chip-zero {
  background: #ede7e4 !important;
  color: #80756d !important;
  border: 1px solid #d1c4ba !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-B — zakładki, przyciski, panel "?", wyśrodkowanie słupków
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Zakładki trybów — wygląd jak w reference (pill container) ────────────  */
#screen-soroban .sor-tabs {
  display: flex !important;
  background: #ede7e4 !important;
  border-radius: 12px !important;
  padding: 4px !important;
  gap: 2px !important;
  border: 1px solid #d1c4ba !important;
  flex-shrink: 0 !important;
}
#screen-soroban .sor-mode-tab {
  padding: 10px 18px !important;
  border-radius: 9px !important;
  border: none !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  background: transparent !important;
  color: #80756d !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: background 130ms, color 130ms, box-shadow 130ms !important;
  white-space: nowrap !important;
  letter-spacing: .01em !important;
}
#screen-soroban .sor-mode-tab.active {
  background: #ffffff !important;
  color: #1d1b19 !important;
  box-shadow: 0 1px 6px rgba(0,0,0,.13) !important;
}
#screen-soroban .sor-mode-tab:hover:not(.active) {
  background: rgba(255,255,255,.55) !important;
  color: #3a3028 !important;
}

/* ── Panel z chipami — bez dużej liczby ──────────────────────────────────── */
#screen-soroban .sor-num-display {
  flex: 1 !important;
  background: #f9f2ef !important;
  border-radius: 12px !important;
  padding: 10px 18px !important;
  border: 1px solid #e0d8d4 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 48px !important;
  min-width: 0 !important;
}
#screen-soroban .sor-num-display .sor-result-number {
  display: none !important;
}
#screen-soroban .sor-chips-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  justify-content: center !important;
  align-items: center !important;
}

/* ── Przycisk Wyczyść — obrysowy ─────────────────────────────────────────── */
#screen-soroban .sor-act-outline {
  background: #ffffff !important;
  border: 1.5px solid #6f5a48 !important;
  color: #6f5a48 !important;
  font-weight: 700 !important;
}
#screen-soroban .sor-act-outline:hover {
  background: #f9f2ef !important;
  border-color: #3a2e1a !important;
  color: #3a2e1a !important;
}

/* ── Przycisk Losowo — wypełniony gradientem ─────────────────────────────── */
#screen-soroban .sor-act-filled {
  background: linear-gradient(to right, #f9dcc4, #f4c19a) !important;
  border: 1.5px solid #e8b07a !important;
  color: #27180a !important;
  font-weight: 700 !important;
  box-shadow: 0 2px 8px rgba(244,193,154,.35) !important;
}
#screen-soroban .sor-act-filled:hover {
  background: linear-gradient(to right, #f4c19a, #eca870) !important;
  box-shadow: 0 3px 12px rgba(244,193,154,.5) !important;
}

/* ── Przycisk "?" — info ─────────────────────────────────────────────────── */
#screen-soroban .sor-act-info {
  width: 38px !important;
  height: 38px !important;
  padding: 0 !important;
  border-radius: 50% !important;
  background: #ffffff !important;
  border: 1.5px solid #d1c4ba !important;
  color: #6f5a48 !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
#screen-soroban .sor-act-info:hover,
#screen-soroban .sor-act-info.active {
  background: #6f5a48 !important;
  color: #ffffff !important;
  border-color: #6f5a48 !important;
}

/* ── Panel informacyjny "?" ──────────────────────────────────────────────── */
#sor-info-panel {
  display: none;
  flex-direction: column !important;
  gap: 10px !important;
  background: #fffbf6 !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 14px !important;
  padding: 18px 22px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.08) !important;
}
.sor-info-title {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #6f5a48 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  margin: 0 0 4px !important;
}
.sor-info-rows { display: flex !important; flex-direction: column !important; gap: 8px !important; }
.sor-info-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  font-size: 14px !important;
  color: #1d1b19 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
.sor-info-row-note {
  color: #4e453e !important;
  font-size: 13px !important;
  padding-top: 8px !important;
  border-top: 1px solid #e0d8d4 !important;
  line-height: 1.55 !important;
  align-items: flex-start !important;
}
.sor-info-row-note svg { flex-shrink: 0 !important; margin-top: 1px !important; color: #6f5a48 !important; }
/* Mini koraliki w panelu */
.sor-info-bead {
  display: inline-block !important;
  width: 32px !important;
  height: 16px !important;
  border-radius: 3px !important;
  clip-path: polygon(50% 0%,100% 50%,50% 100%,0% 50%) !important;
  flex-shrink: 0 !important;
}
.sor-info-bead-upper { background: linear-gradient(135deg,#ff8a65,#e64a19) !important; }
.sor-info-bead-lower { background: linear-gradient(135deg,#ffd740,#ff8f00) !important; }

/* ── Wyśrodkowanie sorobanu ──────────────────────────────────────────────── */
.sor-abacus-card .sor-scroll-area {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}
.sor-abacus-card .sor-digit-row,
.sor-abacus-card .sor-abacus-inner {
  width: max-content !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-C — panel Wpisz, panel Zadanie (poziomy), przyciski
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Panel Wpisz liczbę — mniejsze pole ─────────────────────────────────── */
#screen-soroban .sor-enter-card {
  background: #f9f2ef !important;
  border: 1px solid #e0d8d4 !important;
  border-radius: 14px !important;
  padding: 16px 20px !important;
}
#screen-soroban .sor-enter-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
}
#screen-soroban .sor-enter-input {
  width: 140px !important;
  min-width: 0 !important;
  flex: 0 0 140px !important;
  height: 38px !important;
  padding: 0 12px !important;
  font-size: 14px !important;
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  border-radius: 9px !important;
  color: #1d1b19 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
}
#screen-soroban .sor-enter-input:focus { border-color: #6f5a48 !important; outline: none !important; }

/* Przyciski w panelach — dopasowane do stylu strony */
  background: linear-gradient(to right,#f9dcc4,#f4c19a) !important;
  border: 1.5px solid #e8b07a !important;
  color: #27180a !important;
  box-shadow: 0 2px 8px rgba(244,193,154,.30) !important;
}
  background: linear-gradient(to right,#f4c19a,#eca870) !important;
}
  background: #fff !important;
  border: 1.5px solid #d1c4ba !important;
  color: #4e453e !important;
}
  background: #f9f2ef !important;
  border-color: #6f5a48 !important;
}
  background: #f0edff !important;
  border: 1.5px solid #c5bef8 !important;
  color: #27308a !important;
}
  background: #e3deff !important;
}
  height: 38px !important;
  padding: 0 14px !important;
  border-radius: 9px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: all 120ms !important;
  white-space: nowrap !important;
}

/* ── Panel Zadanie — wybór zakresu ───────────────────────────────────────── */
#screen-soroban .sor-quiz-card {
  background: #f9f2ef !important;
  border: 1px solid #e0d8d4 !important;
  border-radius: 14px !important;
  padding: 18px 20px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

/* Rząd zakresu */
.sor-quiz-levels {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}
.sor-quiz-levels-label {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #80756d !important;
  letter-spacing: .05em !important;
  white-space: nowrap !important;
}
.sor-level-btns {
  display: flex !important;
  gap: 6px !important;
  flex-wrap: wrap !important;
}
.sor-level-btn {
  padding: 5px 13px !important;
  border-radius: 20px !important;
  border: 1.5px solid #d1c4ba !important;
  background: #fff !important;
  color: #80756d !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: all 120ms !important;
  white-space: nowrap !important;
}
.sor-level-btn:hover { border-color: #6f5a48 !important; color: #3a3028 !important; }
.sor-level-btn.active {
  background: linear-gradient(to right,#f9dcc4,#f4c19a) !important;
  border-color: #d1a070 !important;
  color: #27180a !important;
}

/* Quiz box — cel, feedback, akcje */
#screen-soroban .sor-quiz-box {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 10px !important;
}
#screen-soroban .sor-quiz-instruction {
  font-size: 13px !important;
  color: #80756d !important;
  margin: 0 !important;
}
#screen-soroban .sor-quiz-target {
  font-family: var(--font-display,'Bricolage Grotesque',sans-serif) !important;
  font-size: 42px !important;
  font-weight: 800 !important;
  color: #1d1b19 !important;
  letter-spacing: -.02em !important;
  line-height: 1 !important;
}
#screen-soroban .sor-quiz-feedback {
  min-height: 22px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #4e453e !important;
  text-align: center !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  padding: 4px 10px !important;
  border-radius: 8px !important;
}
#screen-soroban .sor-quiz-feedback.correct {
  background: #e8f5e9 !important;
  color: #1b5e20 !important;
  border: 1px solid #a5d6a7 !important;
}
#screen-soroban .sor-quiz-feedback.wrong {
  background: #fce4ec !important;
  color: #880e4f !important;
  border: 1px solid #f48fb1 !important;
}
#screen-soroban .sor-quiz-feedback.hint1,
#screen-soroban .sor-quiz-feedback.hint2 {
  background: #fff8e7 !important;
  color: #5d4037 !important;
  border: 1px solid #ffe082 !important;
}
#screen-soroban .sor-quiz-feedback.hint3 {
  background: #e8eaf6 !important;
  color: #1a237e !important;
  border: 1px solid #9fa8da !important;
}
#screen-soroban .sor-quiz-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  justify-content: center !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SOROBAN V5-PATCH-D — przycisk Zeruj przy belce, position:relative na card
   ═══════════════════════════════════════════════════════════════════════════ */

/* Karta sorobanu: potrzebujemy position:relative dla absolutnego Zeruj */
.sor-abacus-card {
  position: relative !important;
}

/* Przycisk Zeruj — przy belce środkowej, prawa strona karty */
.sor-abacus-clear-btn {
  position: absolute !important;
  right: 14px !important;
  /* scroll-area padding-top:24 + digit-row:44 + upper-area:110 + half-beam:8 = 186px */
  top: 186px !important;
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: #ffffff !important;
  border: 1.5px solid #d1c4ba !important;
  color: #80756d !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  z-index: 20 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.14) !important;
  transition: background 120ms, color 120ms, border-color 120ms !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  padding: 0 !important;
}
.sor-abacus-clear-btn:hover {
  background: #6f5a48 !important;
  color: #ffffff !important;
  border-color: #6f5a48 !important;
}
.sor-abacus-clear-btn:active {
  background: #4e3526 !important;
}


/* ── Błąd kolumny w trybie Zadanie — styl pdf-layout-warning (bez nakładania) ── */
/* box-shadow:inset zostaje wewnątrz elementu → brak overlap sąsiednich kolumn */
.sor-column-wrong {
  outline: none !important;
  box-shadow: inset 0 0 0 2px #f0a500 !important;
  background: rgba(255,243,205,0.40) !important;
  border-radius: 4px !important;
}
.sor-column-wrong > .sor-rod {
  background: #c87800 !important;
  box-shadow: 0 0 6px rgba(200,120,0,.40) !important;
}
/* Usuwamy outline na koralach (był 2px solid #ba1a1a / #e05550) */
.sor-abacus-card .sor-column-wrong .sor-bead { outline: none !important; }
.sor-abacus-card .sor-column-wrong .sor-bead-lower,
.sor-abacus-card .sor-column-wrong .sor-bead-upper {
  outline: none !important;
}

/* ══ Responsywny rozmiar sorobanu — 13 słupków jednocześnie ════════════════
   Skalowanie ~70%: kolumna 80→56 px, koralik 64×32→44×22 px
   13 col×56 + 12 div×3 = 764 px → mieści się przy ~900 px szerokości
   ═══════════════════════════════════════════════════════════════════════ */

.sor-abacus-card .sor-scroll-area {
  padding: 16px 16px 20px !important;
}

/* Cyfry nad słupkami */
.sor-digit-cell {
  width: 56px !important;
  font-size: 22px !important;
}
.sor-digit-row .sor-label-spacer {
  width: 3px !important;
}
.sor-digit-row {
  padding: 0 0 8px !important;
}

/* Kolumna */
.sor-abacus-card .sor-column {
  width: 56px !important;
}

/* Separator */
.sor-abacus-card .sor-col-divider {
  width: 3px !important;
}

/* Pręt */
.sor-abacus-card .sor-rod {
  width: 6px !important;
}

/* Górna sekcja */
.sor-abacus-card .sor-upper-area {
  width: 56px !important;
  height: 80px !important;
}

/* Belka */
.sor-abacus-card .sor-beam {
  width: 56px !important;
  height: 12px !important;
}

/* Dolna sekcja — B_H=22, B_GAP=2, B_PAD=7 → 7+4×24-2+7=174≈175 px */
.sor-abacus-card .sor-lower-area {
  width: 56px !important;
  height: 175px !important;
}

/* Koralik */
.sor-abacus-card .sor-bead {
  width: 44px !important;
  height: 22px !important;
}

/* Przycisk × — nowa pozycja: padding-top:16 + cyfry:30 + upper:80 + half-beam:6 = 132 px */
.sor-abacus-clear-btn {
  top: 132px !important;
  width: 28px !important;
  height: 28px !important;
  font-size: 15px !important;
  right: 10px !important;
}

/* ── Cyfry nad słupkami — kolor gold-3 ────────────────────────────────────── */
.sor-digit-cell {
  color: var(--gold-3) !important;
}

/* ══ Style przycisków sorobanu — spójne z ramką ════════════════════════════
   Dotyczy: Sprawdź, Wylosuj, Wyczyść, Następne, przyciski słupków
   ══════════════════════════════════════════════════════════════════════════ */
#screen-soroban .sor-btn,
.sor-preset-btn {
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  border: 1.5px solid #ddd0b0 !important;
  color: #27180a !important;
  font-weight: 700 !important;
}
#screen-soroban .sor-btn:hover,
.sor-preset-btn:hover,
.sor-preset-btn.active {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border: 1.5px solid #ddd0b0 !important;
}
#screen-soroban .sor-btn:disabled {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  color: #27180a !important;
}

/* ══ Soroban — zmieść w ramce, bez paska przewijania ═══════════════════════ */
.sor-abacus-card .sor-scroll-area {
  overflow-x: hidden !important;
}

/* ══ Tablet (max 1023px) — kolumna 46px
   13 col×46 + 12 div×3 = 634 + 36 = 670px + 2×16 = 702px
   ══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1023px) {
  .sor-digit-cell                       { width: 46px !important; font-size: 18px !important; }
  .sor-digit-row .sor-label-spacer      { width: 3px !important; }
  .sor-abacus-card .sor-column          { width: 46px !important; }
  .sor-abacus-card .sor-upper-area      { width: 46px !important; height: 70px !important; }
  .sor-abacus-card .sor-beam            { width: 46px !important; height: 10px !important; }
  .sor-abacus-card .sor-lower-area      { width: 46px !important; height: 155px !important; }
  .sor-abacus-card .sor-bead            { width: 36px !important; height: 20px !important; }
  /* Przycisk × — padding-top:16 + cyfry:26 + upper:70 + half-beam:5 = 117px */
  .sor-abacus-clear-btn                 { top: 117px !important; }
}

/* ══ Mobile (max 767px) — tylko 4 i 6 słupków, kolumna 46px ═══════════════ */
@media (max-width: 767px) {
  /* Ukryj opcje 9 i 13 słupków */
  .sor-preset-btn[data-cols="9"],
  .sor-preset-btn[data-cols="13"]       { display: none !important; }

  .sor-digit-cell                       { width: 46px !important; font-size: 18px !important; }
  .sor-digit-row .sor-label-spacer      { width: 3px !important; }
  .sor-abacus-card .sor-column          { width: 46px !important; }
  .sor-abacus-card .sor-upper-area      { width: 46px !important; height: 70px !important; }
  .sor-abacus-card .sor-beam            { width: 46px !important; height: 10px !important; }
  .sor-abacus-card .sor-lower-area      { width: 46px !important; height: 155px !important; }
  .sor-abacus-card .sor-bead            { width: 36px !important; height: 20px !important; }
  .sor-abacus-clear-btn                 { top: 117px !important; }
}

/* ══ Przycisk LOSOWO — spójny styl z przyciskami sorobanu ══════════════════ */
#sor-btn-random {
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  border: 1.5px solid #ddd0b0 !important;
  color: #27180a !important;
  font-weight: 700 !important;
}
#sor-btn-random:hover {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border: 1.5px solid #ddd0b0 !important;
}

/* ══ Jedności / Dziesiątki / Setki / Tysiące — spójny styl z sorobanem ═════ */
.sor-level-btn {
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  border: 1.5px solid #ddd0b0 !important;
  color: #27180a !important;
  font-weight: 700 !important;
}
.sor-level-btn:hover {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border: 1.5px solid #ddd0b0 !important;
}
.sor-level-btn.active {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border: 1.5px solid #ddd0b0 !important;
}

/* ══ sor-abacus-card — border-radius 21px + pełne rozciągnięcie w ramce ════ */
.sor-abacus-card {
  border-radius: 21px !important;
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
}
.sor-abacus-card .sor-frame-wrap {
  width: 100% !important;
  flex: 1 1 auto !important;
}
.sor-abacus-card .sor-frame {
  width: 100% !important;
  border-radius: 17px !important;
  box-sizing: border-box !important;
}
.sor-abacus-card .sor-scroll-area {
  width: 100% !important;
  box-sizing: border-box !important;
  overflow-x: hidden !important;
}
/* Kolumny rozkładaj równomiernie na pełną szerokość */
.sor-abacus-card .sor-digit-row,
.sor-abacus-card .sor-abacus-inner {
  width: 100% !important;
  justify-content: space-around !important;
}

/* ══ Tryb Zadanie — ukryj cyfry nad słupkami sorobanu ══════════════════════ */
.sor-abacus-card.sor-mode-quiz #sor-labels {
  display: none !important;
}

/* ══ Soroban WIĘKSZY w ramce — kolumna 64px, koraliki 52×24px ══════════════
   lower=215px (≥ 2*(B_PAD+4*B_H+3*B_GAP)=202px), upper=92px
   ═══════════════════════════════════════════════════════════════════════════ */
.sor-abacus-card .sor-scroll-area {
  padding: 10px 14px 14px !important;
  overflow-x: hidden !important;
}
.sor-digit-cell {
  width: 64px !important;
  font-size: 24px !important;
}
.sor-digit-row .sor-label-spacer {
  width: 4px !important;
}
.sor-abacus-card .sor-column {
  width: 64px !important;
}
.sor-abacus-card .sor-col-divider {
  width: 4px !important;
}
.sor-abacus-card .sor-rod {
  width: 7px !important;
}
.sor-abacus-card .sor-upper-area {
  width: 64px !important;
  height: 92px !important;
}
.sor-abacus-card .sor-beam {
  width: 64px !important;
  height: 13px !important;
}
.sor-abacus-card .sor-lower-area {
  width: 64px !important;
  height: 215px !important;
}
.sor-abacus-card .sor-bead {
  width: 52px !important;
  height: 24px !important;
}
/* Przycisk × — 10+26+92+6 = 134px */
.sor-abacus-clear-btn {
  top: 134px !important;
  width: 28px !important;
  height: 28px !important;
  font-size: 15px !important;
  right: 10px !important;
}

/* ── Tablet (max 1023px) — kolumna 50px ─────────────────────────────────── */
@media (max-width: 1023px) {
  .sor-digit-cell                       { width: 50px !important; font-size: 19px !important; }
  .sor-digit-row .sor-label-spacer      { width: 3px !important; }
  .sor-abacus-card .sor-column          { width: 50px !important; }
  .sor-abacus-card .sor-col-divider     { width: 3px !important; }
  .sor-abacus-card .sor-upper-area      { width: 50px !important; height: 80px !important; }
  .sor-abacus-card .sor-beam            { width: 50px !important; height: 12px !important; }
  .sor-abacus-card .sor-lower-area      { width: 50px !important; height: 190px !important; }
  .sor-abacus-card .sor-bead            { width: 40px !important; height: 22px !important; }
  .sor-abacus-clear-btn                 { top: 120px !important; }
}

/* ── Mobile (max 767px) — tylko 4 i 6 słupków, kolumna 50px ─────────────── */
@media (max-width: 767px) {
  .sor-preset-btn[data-cols="9"],
  .sor-preset-btn[data-cols="13"]       { display: none !important; }
  .sor-digit-cell                       { width: 50px !important; font-size: 19px !important; }
  .sor-digit-row .sor-label-spacer      { width: 3px !important; }
  .sor-abacus-card .sor-column          { width: 50px !important; }
  .sor-abacus-card .sor-upper-area      { width: 50px !important; height: 80px !important; }
  .sor-abacus-card .sor-beam            { width: 50px !important; height: 12px !important; }
  .sor-abacus-card .sor-lower-area      { width: 50px !important; height: 190px !important; }
  .sor-abacus-card .sor-bead            { width: 40px !important; height: 22px !important; }
  .sor-abacus-clear-btn                 { top: 120px !important; }
}

/* ══ KOREKTA — cofnięcie space-around, przywrócenie flex-start ═════════════ */
.sor-abacus-card .sor-digit-row,
.sor-abacus-card .sor-abacus-inner {
  width: auto !important;
  justify-content: flex-start !important;
}

/* ══ Etykiety pozycji liczbowych pod słupkami sorobanu ═════════════════════ */
.sor-position-row {
  display: flex;
  align-items: flex-start;
  padding: 5px 0 2px;
}
.sor-position-cell {
  width: 64px;
  text-align: center;
  font-size: 10px;
  font-weight: 700;
  color: var(--gold-3, #8a6a3e);
  font-family: var(--font-body, 'Manrope', sans-serif);
  letter-spacing: 0.01em;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  opacity: 0.75;
}
@media (max-width: 1023px) {
  .sor-position-cell { width: 50px; font-size: 9px; }
}
@media (max-width: 767px) {
  .sor-position-cell { width: 50px; font-size: 9px; }
}

/* ══ TABY — segment control, wzór ze screenshota ═══════════════════════════ */
#screen-soroban .sor-tabs {
  display: inline-flex !important;
  background: #ece6e1 !important;
  border-radius: 14px !important;
  padding: 5px !important;
  gap: 2px !important;
  border: none !important;
  box-shadow: inset 0 1px 3px rgba(0,0,0,.08) !important;
  align-self: center !important;
}
#screen-soroban .sor-mode-tab {
  padding: 10px 22px !important;
  border-radius: 10px !important;
  border: none !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  background: transparent !important;
  color: #8a7d74 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  transition: background 140ms, color 140ms, box-shadow 140ms !important;
  white-space: nowrap !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
}
#screen-soroban .sor-mode-tab.active {
  background: #ffffff !important;
  color: #1d1b19 !important;
  font-weight: 700 !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.12), 0 2px 8px rgba(0,0,0,.06) !important;
}
#screen-soroban .sor-mode-tab:hover:not(.active) {
  background: rgba(255,255,255,.45) !important;
  color: #3a3028 !important;
}

/* ══ LOSOWO — identyczny styl jak preset-btn i inne przyciski sorobanu ══════
   Wyższy priorytet niż #screen-soroban .sor-act-filled                      */
#screen-soroban #sor-btn-random,
#sor-btn-random {
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  border: 1.5px solid #ddd0b0 !important;
  color: #27180a !important;
  font-weight: 700 !important;
  box-shadow: none !important;
}
#screen-soroban #sor-btn-random:hover,
#sor-btn-random:hover {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border: 1.5px solid #ddd0b0 !important;
  box-shadow: none !important;
}

/* ══ Panel "Wpisz liczbę" — wyśrodkowany ═══════════════════════════════════ */
#screen-soroban .sor-mode-panel[data-mode="enter"].active {
  display: flex !important;
  justify-content: center !important;
  align-items: flex-start !important;
}
#screen-soroban .sor-enter-card {
  align-items: center !important;
  width: 100% !important;
  max-width: 520px !important;
}
#screen-soroban .sor-enter-row {
  justify-content: center !important;
  flex-wrap: wrap !important;
}
#screen-soroban .sor-enter-msg {
  text-align: center !important;
}

/* ══ Aktywny tab — kolor jak aktywne przyciski (amber/gold) ════════════════ */
#screen-soroban .sor-mode-tab.active {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  font-weight: 700 !important;
  box-shadow: 0 1px 4px rgba(184,137,10,.35) !important;
}
#screen-soroban .sor-mode-tab:hover:not(.active) {
  background: rgba(255,255,255,.5) !important;
  color: #27180a !important;
}

/* ══ Toggle dźwięku koralika ════════════════════════════════════════════════ */
.sor-sound-toggle {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  cursor: pointer !important;
  padding: 5px 13px !important;
  border-radius: 20px !important;
  border: 1.5px solid #ddd0b0 !important;
  background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
  color: #27180a !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  user-select: none !important;
  transition: background 140ms, border-color 140ms !important;
  white-space: nowrap !important;
  margin-left: 6px !important;
}
.sor-sound-toggle:hover {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
}
.sor-sound-toggle input[type="checkbox"] {
  display: none !important;
}
.sor-sound-toggle .sor-sound-icon {
  font-size: 13px !important;
  line-height: 1 !important;
  opacity: 0.5 !important;
  transition: opacity 140ms !important;
}
.sor-sound-toggle:has(input:checked) {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border-color: #ddd0b0 !important;
}
.sor-sound-toggle:has(input:checked) .sor-sound-icon {
  opacity: 1 !important;
}

/* ══ Wskazówka o desktopie — domyślnie ukryta (widoczna tylko na mobile) ══ */
.sor-desktop-hint {
  display: none;
  width: 100%;
  margin: 6px 0 0 0;
  padding: 0;
  font-size: 11px;
  color: #8a6a3e;
  text-align: center;
  font-style: italic;
  line-height: 1.5;
}

/* ══ MOBILE — 4 i 6 słupków, taby pełna szerokość, info panel ════════════ */
@media (max-width: 767px) {
  /* Na mobile dostępne tylko 4 i 6 słupków */
  .sor-preset-btn[data-cols="9"],
  .sor-preset-btn[data-cols="13"] { display: none !important; }

  /* Wskazówka o desktopie — widoczna tylko na mobile */
  .sor-desktop-hint { display: block !important; }

  /* Taby — rozciągnij na całą szerokość, mniejsza czcionka */
  #screen-soroban .sor-tabs {
    display: flex !important;
    width: 100% !important;
    box-sizing: border-box !important;
    align-self: stretch !important;
  }
  #screen-soroban .sor-mode-tab {
    flex: 1 1 0 !important;
    padding: 9px 6px !important;
    font-size: 12px !important;
    text-align: center !important;
    white-space: nowrap !important;
  }

  /* Panel "?" — czytelny na wąskim ekranie */
  #sor-info-panel {
    padding: 14px 14px !important;
  }
  .sor-info-row {
    font-size: 13px !important;
    gap: 10px !important;
  }
  .sor-info-row-note {
    font-size: 12px !important;
    line-height: 1.6 !important;
    display: block !important;
  }
  .sor-info-row-note svg {
    display: inline !important;
    vertical-align: middle !important;
    margin-right: 4px !important;
  }
}

/* ══ TABY — oddzielne przyciski z separatorem (v2.2) ══════════════════════ */
#screen-soroban .sor-tabs {
  display: inline-flex !important;
  gap: 0 !important;
  background: #ece6e0 !important;
  border-radius: 14px !important;
  padding: 5px !important;
  box-shadow: inset 0 1px 4px rgba(0,0,0,.10) !important;
}
#screen-soroban .sor-mode-tab {
  flex: 1 1 0 !important;
  padding: 9px 18px !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  border-radius: 9px !important;
  border: 1.5px solid transparent !important;
  background: transparent !important;
  color: #6b5c50 !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: background 130ms, color 130ms, border-color 130ms, box-shadow 130ms !important;
  position: relative !important;
}
/* Separator między przyciskami (kreska po środku kontenera) */
#screen-soroban .sor-mode-tab + .sor-mode-tab::before {
  content: '' !important;
  position: absolute !important;
  left: -1px !important;
  top: 20% !important;
  height: 60% !important;
  width: 1px !important;
  background: #cdc4bc !important;
  border-radius: 1px !important;
  transition: opacity 130ms !important;
}
/* Ukryj separator gdy poprzedni lub bieżący tab jest active */
#screen-soroban .sor-mode-tab.active + .sor-mode-tab::before,
#screen-soroban .sor-mode-tab.active::before {
  opacity: 0 !important;
}
/* Inactive — subtelne tło "przycisku" */
#screen-soroban .sor-mode-tab:not(.active) {
  background: rgba(255,255,255,.35) !important;
  border-color: transparent !important;
  color: #6b5c50 !important;
}
#screen-soroban .sor-mode-tab:hover:not(.active) {
  background: rgba(255,255,255,.65) !important;
  color: #27180a !important;
  border-color: rgba(184,137,10,.18) !important;
}
/* Active — złoty */
#screen-soroban .sor-mode-tab.active {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #fff !important;
  font-weight: 700 !important;
  border-color: #b8890a !important;
  box-shadow: 0 1px 5px rgba(184,137,10,.35) !important;
}

/* Mobile — dopasuj rozmiar */
@media (max-width: 767px) {
  #screen-soroban .sor-tabs {
    display: flex !important;
    width: 100% !important;
    box-sizing: border-box !important;
    align-self: stretch !important;
  }
  #screen-soroban .sor-mode-tab {
    padding: 9px 6px !important;
    font-size: 11.5px !important;
  }
}

/* ══ Dźwięk — button z klasą .active zamiast checkbox (fix mobile) ════════ */
.sor-sound-toggle.active {
  background: linear-gradient(to right, #b8890a, #b8890a) !important;
  color: #ffffff !important;
  border-color: #ddd0b0 !important;
}
.sor-sound-toggle.active .sor-sound-icon {
  opacity: 1 !important;
}

/* ══ Dźwięk — brak efektu hover na touch (fix: przycisk "wisi" po tapnięciu) */
@media (hover: none) {
  .sor-sound-toggle:hover {
    background: linear-gradient(to right, #fff8e7, #fff8e7) !important;
    color: #27180a !important;
  }
  .sor-sound-toggle.active:hover {
    background: linear-gradient(to right, #b8890a, #b8890a) !important;
    color: #ffffff !important;
  }
}
.sor-sound-toggle:focus { outline: none !important; }


/* ═══════════════════════════════════════════════════════════════════════════
   ANIMAL LEVEL — Ścieżka arytmetyki mentalnej (Task #4)
   ═══════════════════════════════════════════════════════════════════════════ */


/* ═══════════════════════════════════════════════════════
   ANIMAL LEVEL SECTION — v2.6
   Kafle w stylu serwisu (CSS vars: --ink, --gold-*, --line, --r-lg)
   Gwarantowane 4 kafle w rzędzie (flex nowrap)
   ═══════════════════════════════════════════════════════ */

/* ── ROZMIARY SEKCJI ZWIERZĄT ──────────────────────────────────────────────
   max-width        → szerokość całej sekcji (zmień żeby kafle były szersze/węższe)
   margin-bottom    → odstęp poniżej sekcji
   ────────────────────────────────────────────────────────────────────────── */
.animal-level-section {
  width: 100%;
  margin: 0 auto 14px;
  max-width: 600px;   /* ← GŁÓWNY ROZMIAR: zwiększ/zmniejsz żeby kafle były większe/mniejsze */
}

.animal-level-header {
  text-align: center;
  margin-bottom: 10px;
}

/* font-size → rozmiar napisu "ŚCIEŻKA ARYTMETYKI MENTALNEJ" */
.animal-level-title {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.animal-level-subtitle {
  font-size: 11px;
  color: var(--ink-faint);
  margin-top: 2px;
}

/* ── SIATKA KAFLI ──────────────────────────────────────────────────────────
   grid-template-columns → liczba kolumn (repeat(4,1fr) = 4 równe kolumny)
   gap                   → odstęp między kaflami
   ────────────────────────────────────────────────────────────────────────── */
.animal-level-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);  /* ← 4 kolumny na desktopie */
  gap: 10px;                               /* ← odstęp między kaflami */
  width: 100%;
}

/* Tablet: przeskakuje na 2 kolumny poniżej 480px */
@media (max-width: 480px) {
  .animal-level-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
}

/* Bardzo mały ekran */
@media (max-width: 320px) {
  .animal-level-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
  }
}

/* ── POJEDYNCZY KAFELEK ────────────────────────────────────────────────────
   gap → odstęp między kwadratem karty a nazwą pod spodem
   ────────────────────────────────────────────────────────────────────────── */
.animal-tile {
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;           /* ← odstęp karta ↔ nazwa */
  cursor: pointer;
  user-select: none;
  background: transparent;
  border: none;
  padding: 0;
}

/* ── KARTA (kwadrat z obrazkiem) ───────────────────────────────────────────
   padding    → wewnętrzny margines wokół obrazka (większy = obrazek mniejszy)
   border-radius → zaokrąglenie rogów karty
   ────────────────────────────────────────────────────────────────────────── */
.animal-tile__card {
  width: 100%;
  aspect-ratio: 1 / 1;
  background: var(--surface);
  border-radius: var(--r-lg);  /* ← zaokrąglenie rogu */
  border: 2px solid var(--line);
  padding: 6px;                 /* ← margines wokół obrazka */
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  overflow: hidden;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.12s ease;
  box-shadow: 0 1px 3px rgba(0,0,0,0.07);
}

/* Hover: złota ramka jak focus w projekcie */
.animal-tile:hover .animal-tile__card {
  border-color: var(--gold-1);
  box-shadow:
    0 0 0 3px rgba(217, 185, 133, 0.25),
    0 4px 12px rgba(138, 106, 62, 0.18);
}

/* Klik */
.animal-tile:active .animal-tile__card {
  transform: scale(0.96);
}

/* ── Wybrany: --ink border (ciemna granatowa) + złoty ring ──
   Identyczny język wizualny co fokus inputów w projekcie */
.animal-tile.selected .animal-tile__card {
  border: 1.5px solid #b8890a;
  background: #fdf6e3;
  box-shadow:
    0 0 0 3px rgba(184, 137, 10, 0.22),
    0 4px 14px rgba(0, 0, 0, 0.12);
}

/* Obrazek — wypełnia kartę, biały bg obrazka zlewa się z --surface */
.animal-tile__avatar {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.animal-tile__emoji {
  font-size: 42px;   /* ← rozmiar emoji-fallbacka gdy brak obrazka */
  line-height: 1;
}

/* ── NAZWA pod kartą ───────────────────────────────────────────────────────
   font-size → rozmiar etykiety np. „Mądry Żółw"
   ────────────────────────────────────────────────────────────────────────── */
.animal-tile__name {
  font-family: var(--font-display);
  font-size: 12px;   /* ← rozmiar nazwy zwierzaka */
  font-weight: 700;
  color: var(--ink-soft);
  text-align: center;
  line-height: 1.2;
  transition: color 0.15s;
}

.animal-tile.selected .animal-tile__name {
  color: var(--ink);
}

.animal-tile:hover .animal-tile__name {
  color: var(--ink);
}

/* Status pod siatką */
.animal-level-status {
  text-align: center;
  font-size: 12px;
  color: var(--ink-faint);
  margin-top: 10px;
  min-height: 16px;
}

/* ── Result badge ── */
.animal-level-result {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: var(--r-md);
  padding: 6px 12px;
  margin: 8px auto 0;
  width: fit-content;
  max-width: 100%;
}

.animal-result__emoji {
  font-size: 20px;
  line-height: 1;
}

.animal-result__text {
  font-size: 13px;
  color: var(--ink);
}

/* ══ SEKCJE SEO — soroban, abakus, arytmetyka mentalna ════════════════════ */
.seo-section {
  max-width: 820px !important;
  margin: 0 auto 48px auto !important;
  padding: 36px 32px !important;
  background: var(--bg-card, #fffdf8) !important;
  border: 1.5px solid var(--line, #d8d4cf) !important;
  border-radius: var(--r-lg, 14px) !important;
  color: var(--ink, #041627) !important;
  font-family: var(--font-body,'Manrope',sans-serif) !important;
  line-height: 1.75 !important;
}
.seo-section h2 {
  font-size: 1.35rem !important;
  font-weight: 700 !important;
  margin: 0 0 16px 0 !important;
  color: var(--ink, #041627) !important;
  font-family: var(--font-head,'Bricolage Grotesque',sans-serif) !important;
  line-height: 1.3 !important;
}
.seo-section h3 {
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  margin: 24px 0 8px 0 !important;
  color: var(--gold-3, #8a6a3e) !important;
  font-family: var(--font-head,'Bricolage Grotesque',sans-serif) !important;
}
.seo-section p {
  font-size: 0.95rem !important;
  margin: 0 0 12px 0 !important;
  color: #2e3b4a !important;
}
.seo-section article {
  margin-bottom: 28px !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid var(--line, #d8d4cf) !important;
}
.seo-section article:last-child {
  border-bottom: none !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* ── FAQ accordion ── */
.faq-section details {
  border-bottom: 1px solid var(--line, #d8d4cf) !important;
  padding: 10px 0 !important;
}
.faq-section details:last-child {
  border-bottom: none !important;
}
.faq-section summary {
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  cursor: pointer !important;
  list-style: none !important;
  padding: 4px 0 !important;
  color: var(--ink, #041627) !important;
  position: relative !important;
  padding-right: 24px !important;
}
.faq-section summary::after {
  content: '+' !important;
  position: absolute !important;
  right: 0 !important;
  top: 4px !important;
  font-size: 1.1rem !important;
  color: var(--gold-2, #b8956a) !important;
  transition: transform 200ms !important;
}
.faq-section details[open] summary::after {
  content: '−' !important;
}
.faq-section details p {
  margin: 8px 0 4px 0 !important;
  font-size: 0.9rem !important;
  color: #3a4a5a !important;
}
/* ══ Wrapper na wszystkie sekcje SEO ═══════════════════════════════════════ */
#seo-content-block {
  padding: 40px 20px 0 20px !important;
}
@media (max-width: 767px) {
  .seo-section {
    padding: 24px 18px !important;
    margin-bottom: 28px !important;
  }
  .seo-section h2 { font-size: 1.1rem !important; }
  .seo-section h3 { font-size: 0.95rem !important; }
  .seo-section p  { font-size: 0.88rem !important; }
}

/* ═══════════════════════════════════════════════════════════
   SCREEN WIEDZA — menu wewnętrzne, przykłady poziomów, CTA
   v2026-05-24
   ═══════════════════════════════════════════════════════════ */

/* --- Anchor navigation (kapsułki) --- */
#screen-wiedza .knowledge-subnav {
  display: flex !important;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  align-items: center;
  padding: 0 16px;
  margin: 28px auto 56px !important;
  max-width: 600px;
}
#screen-wiedza .knowledge-subnav a {
  display: inline-flex !important;
  align-items: center;
  padding: 7px 20px !important;
  border-radius: 999px !important;
  border: 1.5px solid var(--gold-2, #b8956a) !important;
  background: var(--surface, #fff) !important;
  color: var(--gold-3, #7a5c3a) !important;
  font-size: 0.83rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  letter-spacing: 0.03em;
  line-height: 1;
  white-space: nowrap;
  box-shadow: 0 1px 3px rgba(184,149,106,0.10);
  transition: background 0.18s, border-color 0.18s, color 0.18s, box-shadow 0.18s;
}
#screen-wiedza .knowledge-subnav a:hover,
#screen-wiedza .knowledge-subnav a:focus-visible {
  background: var(--gold-2, #b8956a) !important;
  border-color: var(--gold-2, #b8956a) !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(184,149,106,0.28);
  outline: none;
}

/* Mobile: scroll poziomy jeśli za dużo kapsułek */
@media (max-width: 480px) {
  #screen-wiedza .knowledge-subnav {
    flex-wrap: nowrap;
    overflow-x: auto;
    justify-content: flex-start;
    padding-left: 20px;
    padding-right: 20px;
    scrollbar-width: none;
  }
  #screen-wiedza .knowledge-subnav::-webkit-scrollbar { display: none; }
}

/* --- Przykłady liczbowe przy poziomach --- */
.level-example {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin: 6px 0 0;
  padding: 8px 14px;
  background: #fdf6ee;
  border-left: 3px solid #b8956a;
  border-radius: 0 6px 6px 0;
  font-size: 0.88rem;
  color: #5a4028;
  line-height: 1.4;
}
.example-label {
  flex-shrink: 0;
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  background: #b8956a;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* --- Intro text w sekcji poziomów --- */
.levels-intro {
  font-size: 0.92rem;
  color: #6b5740;
  margin-bottom: 16px;
  font-style: italic;
}

/* --- CTA na dole Wiedzy --- */
.wiedza-cta {
  text-align: center;
  padding: 36px 20px 52px;
}
.wiedza-cta-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-bottom: 14px;
}
.wiedza-cta-sub {
  font-size: 0.82rem;
  color: #8a7060;
  margin: 0 auto;
  max-width: 420px;
  line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════
   SCREEN WIEDZA — poprawki wizualne v2026-05-24b
   ═══════════════════════════════════════════════════════════ */

/* Nagłówek strony Wiedza: więcej oddechu pod tytułem, subtelna linia */
#screen-wiedza .screen-head {
  padding-bottom: 28px;
  border-bottom: 1px solid var(--line-soft, #e9e5e0);
  margin-bottom: 0;
}

/* Podtytuł — trochę większy i łagodniejszy kolor */
#screen-wiedza .screen-sub {
  font-size: 1rem !important;
  color: var(--ink-faint, #74777d) !important;
  margin-top: 6px;
}

/* Przestrzeń między subnav a blokiem treści */
#screen-wiedza #seo-content-block {
  padding-top: 32px !important;
}

/* Sekcje treści — jednolite karty z delikatnym cieniem */
#screen-wiedza .seo-section {
  background: var(--surface, #fff);
  border: 1px solid var(--line-soft, #e9e5e0);
  border-radius: 14px;
  padding: 28px 32px;
  margin-bottom: 20px;
  box-shadow: 0 1px 4px rgba(4,22,39,0.04);
}
#screen-wiedza .seo-section:last-child { margin-bottom: 0; }

/* H2 w sekcjach — lekko mniejszy, wyraźna waga */
#screen-wiedza .seo-section h2 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ink, #041627);
  margin-top: 0;
  margin-bottom: 12px;
}
#screen-wiedza .seo-section h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink, #041627);
  margin-bottom: 8px;
}
#screen-wiedza .seo-section p {
  color: var(--ink-soft, #44474c);
  line-height: 1.65;
  margin-bottom: 10px;
}
#screen-wiedza .seo-section p:last-child { margin-bottom: 0; }

/* FAQ sekcja: details/summary styl */
#screen-wiedza .faq-section details {
  border-bottom: 1px solid var(--line-soft, #e9e5e0);
}
#screen-wiedza .faq-section details:last-child { border-bottom: none; }
#screen-wiedza .faq-section summary {
  font-weight: 600;
  color: var(--ink, #041627);
  padding: 13px 4px;
  cursor: pointer;
}
#screen-wiedza .faq-section details p {
  padding: 0 4px 12px;
  font-size: 0.9rem;
}

/* Sekcja animal-levels — article spacing */
#screen-wiedza .animal-levels-seo article {
  border-bottom: 1px solid var(--line-soft, #e9e5e0);
  padding-bottom: 16px;
  margin-bottom: 16px;
}
#screen-wiedza .animal-levels-seo article:last-child {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}

/* Mobile adjustments */
@media (max-width: 640px) {
  #screen-wiedza .seo-section {
    padding: 20px 18px;
    border-radius: 10px;
  }
  #screen-wiedza .seo-section h2 { font-size: 1.05rem; }
}

/* ═══════════════════════════════════════════════════════════
   SCREEN WIEDZA — spacing subnav + anchor scroll v2026-05-24c
   ═══════════════════════════════════════════════════════════ */

/* Płynne przewijanie dla całej strony */
html {
  scroll-behavior: smooth;
}

/* Offset przewijania — nagłówek sekcji nie chowa się pod sticky header
   (~80-90px header + 20px oddechu = 110px) */
#soroban,
#abakus,
#poziomy,
#generator,
#poziomy-nie-trudnosc,
#faq {
  scroll-margin-top: 110px;
}

/* ═══════════════════════════════════════════════════════════
   SCREEN WIEDZA — miniatury zwierząt przy poziomach v2026-05-24d
   ═══════════════════════════════════════════════════════════ */

/* Nagłówek artykułu: obrazek + h3 obok siebie */
.level-article-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 10px;
}

/* Miniatura zwierzęcia */
.level-animal-thumb {
  width: 72px;
  height: 72px;
  object-fit: contain;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--surface-alt, #f7f4f0);
  padding: 6px;
  box-shadow: 0 2px 8px rgba(184,149,106,0.15);
}

.level-article-header h3 {
  margin: 0;
}

/* Mobile: nieco mniejsza miniatura */
@media (max-width: 480px) {
  .level-animal-thumb {
    width: 56px;
    height: 56px;
    padding: 4px;
  }
  .level-article-header {
    gap: 10px;
  }
}

/* ── Animal level badge: więcej przestrzeni po statystykach ─────────────── */
.animal-level-result {
  margin-top: 20px;
}

/* ── Animal level — link "Przeczytaj czym są poziomy" ──────────────────── */
.animal-level-readmore {
  margin: 10px 0 0 0;
  text-align: center;
  font-size: 0.82rem;
  color: var(--text-muted, #888);
  line-height: 1.4;
}
.animal-level-readmore__link {
  color: #b8956a;
  text-decoration: none;
  font-weight: 600;
  white-space: nowrap;
  transition: color 0.2s ease;
}
.animal-level-readmore__link:hover,
.animal-level-readmore__link:focus-visible {
  color: #96744f;
  text-decoration: underline;
}

/* ── ach-hero-v3: padding-top reset ────────────────────────────────────── */
.ach-hero-v3 {
  padding-top: 0px !important;
}

/* ── screen-contact: padding hero/sections ─────────────────────────────── */
#screen-contact .home-hero,
#screen-contact .home-section,
#screen-contact .home-cta-section {
  padding-top: 18px !important;
  padding-bottom: 0px !important;
}

/* ── ach-hero-v3 mobile: ROK nad opisem (≤760px) ───────────────────────── */
@media (max-width: 760px) {
  .ach-hero-v3 .ach-year-card {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .ach-hero-v3 .ach-year {
    width: max-content;
    padding: 0 18px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   ANIMAL REACTION ANIMATIONS
   ═══════════════════════════════════════════════════════════════════════════ */

.animal-reaction {
  position: fixed;
  right: 24px;
  bottom: 24px;
  width: 180px;
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  transform: translateY(16px) scale(0.92);
  transition: opacity 280ms ease, transform 280ms cubic-bezier(0.34, 1.56, 0.64, 1);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(4, 22, 39, 0.22);
}

.animal-reaction.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.animal-reaction__video {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 16px;
}

@media (max-width: 600px) {
  .animal-reaction {
    width: 130px;
    right: 14px;
    bottom: 14px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .animal-reaction,
  .animal-reaction.is-visible {
    transition: none;
  }
}

/* ══ Mix-range toggle buttons — FLASH "Rodzaj liczb" ══ */
.mix-range-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  padding: 10px 0 4px;
  width: 100%;
}
.mix-range-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 10px 4px;
  border: 2px solid var(--line-soft);
  border-radius: 10px;
  background: var(--surface);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, color 0.15s;
  min-width: 0;
  font-family: inherit;
}
.mix-range-btn:hover {
  border-color: var(--accent);
}
.mix-range-btn.is-active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
}
.mix-range-name {
  font-family: var(--font-ui, var(--font-display));
  font-weight: 700;
  font-size: 12px;
  color: var(--ink);
  white-space: nowrap;
}
.mix-range-btn.is-active .mix-range-name {
  color: var(--accent);
}
.mix-range-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-soft);
  white-space: nowrap;
}
.mix-range-btn.is-active .mix-range-sub {
  color: var(--accent);
  opacity: 0.75;
}
.mix-range-status {
  text-align: center;
  font-size: 11px;
  color: var(--ink-soft);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  padding: 6px 0 0;
  min-height: 20px;
}
@media (max-width: 400px) {
  .mix-range-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ══ Mobile — większe cyfry FLASH dla jedności i dziesiątek ══
   data-range="0" = jedności (1 cyfra)  → max czcionka
   data-range="1" = dziesiątki (2 cyfry) → nieco mniejsza                  */
@media (max-width: 600px) {
  #screen-play[data-range="0"] .number-display {
    font-size: clamp(200px, 42vw, 280px);
  }
  #screen-play[data-range="1"] .number-display {
    font-size: clamp(160px, 34vw, 280px);
  }
}

/* ══ Mix-range toggle buttons — FLASH "Rodzaj liczb" ══ */
.mix-range-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  padding: 8px 0 4px;
  width: 100%;
}
.mix-range-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 10px 4px;
  border: 2px solid var(--line-soft);
  border-radius: 10px;
  background: var(--surface);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  min-width: 0;
  font-family: inherit;
}
.mix-range-btn:hover {
  border-color: var(--accent);
}
.mix-range-btn.is-active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
}
.mix-range-name {
  font-family: var(--font-ui, var(--font-display));
  font-weight: 700;
  font-size: 12px;
  color: var(--ink);
  white-space: nowrap;
}
.mix-range-btn.is-active .mix-range-name {
  color: var(--accent);
}
.mix-range-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-soft);
  white-space: nowrap;
}
.mix-range-btn.is-active .mix-range-sub {
  color: var(--accent);
  opacity: 0.75;
}
.mix-range-status {
  text-align: center;
  font-size: 11px;
  color: var(--ink-soft);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  padding: 6px 0 0;
  min-height: 18px;
}
@media (max-width: 400px) {
  .mix-range-grid { grid-template-columns: repeat(2, 1fr); }
}


/* ══ Tryb mieszany — sekcja pod poziomami zwierząt ══ */
.mixed-mode-section {
  padding: 6px 0 4px;
  width: 100%;
  margin-bottom: 14px;
}

/* ── Kafelki zakresów — kompaktowe, border+podświetlenie jak animal-tile ── */
.mix-tiles-wrap {
  margin-top: 12px;
}
.mix-tiles-hint {
  font-size: 11px;
  color: var(--ink-soft);
  margin-bottom: 8px;
  font-family: var(--font-mono);
  letter-spacing: 0.03em;
}
.mix-tiles-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.mix-tile-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 10px 8px;
  background: var(--surface);
  border: 2px solid var(--line);
  border-radius: var(--r-lg);
  cursor: pointer;
  user-select: none;
  font-family: inherit;
  min-width: 0;
  box-shadow: 0 1px 3px rgba(0,0,0,0.07);
  transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, transform 0.12s ease;
}
.mix-tile-btn:hover {
  border-color: var(--gold-1);
  box-shadow:
    0 0 0 3px rgba(217,185,133,0.25),
    0 4px 12px rgba(138,106,62,0.18);
}
.mix-tile-btn:active {
  transform: scale(0.96);
}
.mix-tile-btn.is-active {
  border: 1.5px solid #b8890a;
  background: #fdf6e3;
  box-shadow:
    0 0 0 3px rgba(184,137,10,0.22),
    0 4px 14px rgba(0,0,0,0.12);
}
.mix-tile-name {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 700;
  color: var(--ink-soft);
  text-align: center;
  line-height: 1.2;
  transition: color 0.15s;
}
.mix-tile-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-faint);
  text-align: center;
  white-space: nowrap;
  transition: color 0.15s;
}
.mix-tile-btn.is-active .mix-tile-name,
.mix-tile-btn:hover .mix-tile-name { color: var(--ink); }
.mix-tile-btn.is-active .mix-tile-sub { color: #b8890a; }
.mix-tile-btn:hover .mix-tile-sub { color: var(--ink-soft); }
.mix-tiles-status {
  text-align: center;
  font-size: 11px;
  color: var(--ink-soft);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  padding: 6px 0 0;
  min-height: 18px;
}
/* Suwak "Rodzaj liczb" wyszarzony gdy tryb mieszany aktywny */
.slider-card.is-disabled {
  opacity: 0.38;
  pointer-events: none;
  user-select: none;
}
@media (max-width: 400px) {
  .mix-tiles-grid { grid-template-columns: repeat(2, 1fr); }
}


/* === PIRAMIDA === */

/* ── Siatka kafli (4 kolumny) ───────────────────────────────────────────── */
.card-grid.four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-width: 1080px;
}
@media (max-width: 860px) {
  .card-grid.four { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .card-grid.four { grid-template-columns: 1fr 1fr; gap: 12px; }
  .card-grid.four .opt-card { padding: 14px 10px; }
  .card-grid.four .opt-title { font-size: 15px; }
}

/* ── Ekran konfiguracji ─────────────────────────────────────────────────── */
.pyr-config-grid {
  display: flex;
  flex-direction: column;
  gap: 28px;
  max-width: 640px;
  margin: 0 auto 32px;
}
.pyr-config-group {}
.pyr-config-label {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 12px;
}
.pyr-btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.pyr-btn-row--col { flex-direction: column; gap: 8px; }

.pyr-level-btn,
.pyr-diff-btn {
  padding: 10px 22px;
  border-radius: var(--r-md);
  border: 1px solid var(--line-soft);
  background: var(--surface);
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 600;
  color: var(--ink-soft);
  cursor: pointer;
  transition: border-color 180ms, background 180ms, color 180ms;
}
.pyr-level-btn:hover,
.pyr-diff-btn:hover {
  border-color: var(--gold-2);
  color: var(--ink);
}
.pyr-level-btn.selected,
.pyr-diff-btn.selected {
  background: var(--ink);
  color: var(--gold-1);
  border-color: var(--ink);
}

.pyr-gamemode-btn {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border-radius: var(--r-md);
  border: 1px solid var(--line-soft);
  background: var(--surface);
  cursor: pointer;
  text-align: left;
  transition: border-color 180ms, background 180ms, box-shadow 180ms;
}
.pyr-gamemode-btn:hover {
  border-color: var(--gold-2);
  box-shadow: var(--shadow-soft);
}
.pyr-gamemode-btn.selected {
  border-color: var(--gold-2);
  background: linear-gradient(180deg, #fffdf9 0%, #fff 100%);
  box-shadow: 0 0 0 2px var(--gold-glow);
}
.pyr-gm-icon { font-size: 22px; line-height: 1; flex-shrink: 0; }
.pyr-gm-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 15px;
  color: var(--ink);
  display: block;
  margin-bottom: 2px;
}
.pyr-gm-desc {
  font-size: 13px;
  color: var(--ink-soft);
  display: block;
}

/* ── Układ ekranu gry ────────────────────────────────────────────────────── */
.pyr-game-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 28px;
  align-items: start;
  max-width: 1060px;
  margin: 0 auto;
  padding: 20px 0 40px;
}
@media (max-width: 800px) {
  .pyr-game-layout { grid-template-columns: 1fr; }
  .pyr-game-right  { order: -1; }
}

/* ── Pasek podsumowania ────────────────────────────────────────────────── */
.pyr-summary-bar-wrap { text-align: center; margin-bottom: 16px; }
.pyr-summary-bar {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  background: var(--surface-2);
  border: 1px solid var(--line-soft);
  border-radius: 20px;
  padding: 5px 16px;
}

/* ── Plansza piramidy ────────────────────────────────────────────────────── */
.pyr-board {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 20px 10px 30px;
  background: linear-gradient(180deg, #fffdf7 0%, #fbf6ec 100%);
  border: 1px solid var(--gold-1);
  border-radius: var(--r-lg);
  box-shadow: 0 6px 28px rgba(184,149,106,0.10);
  min-height: 280px;
}
.pyr-trophy {
  font-size: 26px;
  margin-bottom: 2px;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.12));
}
.pyr-row {
  display: flex;
  gap: 10px;
  justify-content: center;
}

/* ── Cegiełka ────────────────────────────────────────────────────────────── */
.pyr-cell {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-md);
  border: 2px solid var(--line);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 18px;
  color: var(--ink);
  background: var(--surface);
  cursor: pointer;
  transition: border-color 180ms, background 180ms, box-shadow 180ms, transform 120ms;
  user-select: none;
  position: relative;
}
@media (max-width: 480px) {
  .pyr-cell { width: 52px; height: 52px; font-size: 15px; }
  .pyr-row  { gap: 6px; }
  .pyr-board { gap: 6px; }
}
.pyr-cell.pyr-given {
  background: var(--surface-2);
  color: var(--ink-soft);
  cursor: default;
  font-size: 17px;
}
.pyr-cell.pyr-empty {
  border-style: dashed;
  color: transparent;
}
.pyr-cell.pyr-empty::after {
  content: "";
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 2px dashed var(--line);
  display: block;
}
.pyr-cell.pyr-active {
  border-color: var(--gold-2);
  border-style: solid;
  box-shadow: 0 0 0 3px var(--gold-glow), 0 4px 14px rgba(184,149,106,.18);
  background: #fffdf5;
  transform: scale(1.07);
  z-index: 2;
}
.pyr-cell.pyr-active::after { display: none; }
.pyr-cell.pyr-related {
  border-color: var(--amber);
  background: var(--amber-soft);
}
.pyr-cell.pyr-related.pyr-given { background: var(--amber-soft); }
.pyr-cell.pyr-correct {
  border-color: var(--success);
  border-style: solid;
  background: var(--success-soft);
  color: var(--success);
  cursor: default;
}
@keyframes pyrPop {
  0%   { transform: scale(1.18); }
  60%  { transform: scale(0.95); }
  100% { transform: scale(1); }
}
.pyr-cell.pyr-pop { animation: pyrPop 420ms cubic-bezier(.36,.07,.19,.97) both; }

@keyframes pyrShake {
  0%,100% { transform: translateX(0); }
  20%     { transform: translateX(-5px); }
  40%     { transform: translateX(5px); }
  60%     { transform: translateX(-4px); }
  80%     { transform: translateX(4px); }
}
.pyr-cell.pyr-error {
  border-color: var(--error);
  background: var(--error-soft);
  animation: pyrShake 0.45s ease-in-out;
}

/* ── Prawy panel ────────────────────────────────────────────────────────── */
.pyr-stats-panel {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 16px;
  background: var(--surface);
  border: 1px solid var(--line-soft);
  border-radius: var(--r-md);
  margin-bottom: 16px;
  box-shadow: var(--shadow-soft);
}
.pyr-stat-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 10px 12px;
  background: var(--surface-2);
  border-radius: var(--r-sm);
}
.pyr-stat-label {
  font-size: 11px;
  color: var(--ink-soft);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
}
.pyr-stat-val {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.01em;
}

/* ── Panel aktywnego działania ──────────────────────────────────────────── */
.pyr-action-panel {
  background: linear-gradient(180deg, #fffdf7 0%, #fbf6ec 100%);
  border: 1px solid var(--gold-1);
  border-radius: var(--r-md);
  padding: 18px 20px;
  margin-bottom: 16px;
  box-shadow: 0 4px 14px rgba(184,149,106,.10);
  min-height: 90px;
}
.pyr-action-title {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold-3);
  margin-bottom: 10px;
}
.pyr-eq-text {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}
.pyr-eq-unknown {
  color: var(--gold-3);
  font-size: 28px;
}
.pyr-eq-secondary { color: var(--ink-faint); }
.pyr-eq-hint {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.5;
  min-height: 20px;
  transition: color 200ms;
}
@keyframes pyrHintFlash {
  0%,100% { color: var(--ink-soft); }
  40%     { color: var(--gold-3); font-weight: 700; }
}
.pyr-eq-hint.pyr-hint-flash { animation: pyrHintFlash 0.7s ease; }

/* ── Input i przycisk Sprawdz ───────────────────────────────────────────── */
.pyr-input-row {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
}
.pyr-input {
  flex: 1;
  padding: 12px 16px;
  border-radius: var(--r-md);
  border: 1px solid var(--line-soft);
  background: var(--surface);
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  color: var(--ink);
  outline: none;
  transition: border-color 180ms, box-shadow 180ms;
  text-align: center;
}
.pyr-input:focus {
  border-color: var(--gold-2);
  box-shadow: 0 0 0 3px var(--gold-glow);
}
.pyr-check-btn { white-space: nowrap; }

/* ── Feedback ────────────────────────────────────────────────────────────── */
.pyr-feedback {
  font-size: 13px;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: var(--r-sm);
  min-height: 32px;
  opacity: 0;
  transition: opacity 220ms;
  margin-bottom: 12px;
}
.pyr-feedback.show { opacity: 1; }
.pyr-feedback--error  { color: var(--error);   background: var(--error-soft); }
.pyr-feedback--neutral { color: var(--ink-soft); background: var(--surface-2); }

/* ── Przyciski boczne ───────────────────────────────────────────────────── */
.pyr-side-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pyr-side-actions .btn { width: 100%; justify-content: center; }
.pyr-hint-btn { font-weight: 600; }

/* ── Modal sukcesu ──────────────────────────────────────────────────────── */
.pyr-success-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 200;
  align-items: center;
  justify-content: center;
  background: rgba(4,22,39,.45);
  backdrop-filter: blur(3px);
  padding: 20px;
}
.pyr-success-modal.show { display: flex; animation: navFade 220ms ease-out; }
.pyr-success-inner {
  background: var(--surface);
  border: 1px solid var(--gold-1);
  border-radius: var(--r-lg);
  box-shadow: 0 28px 70px rgba(4,22,39,.28);
  padding: 36px 40px;
  max-width: 480px;
  width: 100%;
  text-align: center;
  animation: navPop 240ms ease-out;
}
.pyr-success-badge {
  display: inline-block;
  background: linear-gradient(135deg, #ffd78a 0%, #c49032 100%);
  color: #41280a;
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.08em;
  padding: 7px 20px;
  border-radius: 30px;
  margin-bottom: 18px;
  box-shadow: 0 4px 14px rgba(184,149,106,.25);
}
.pyr-success-title {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 800;
  color: var(--ink);
  margin: 0 0 6px;
  letter-spacing: -0.02em;
}
.pyr-success-sub {
  color: var(--ink-soft);
  font-size: 15px;
  margin: 0 0 24px;
}
.pyr-success-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 28px;
}
@media (max-width: 440px) { .pyr-success-stats { grid-template-columns: repeat(2,1fr); } }
.pyr-sstat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: var(--surface-2);
  border-radius: var(--r-sm);
  padding: 12px 8px;
}
.pyr-sstat-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: var(--ink-faint);
  text-transform: uppercase;
}
.pyr-sstat-val {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
  color: var(--ink);
}
.pyr-success-btns {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ═══════════════════════════════════════════════════════════════════════════
   === PIRAMIDA CONFIG REDESIGN (v2) — dodane do bazy ===
   ═══════════════════════════════════════════════════════════════════════════ */

/* Sekcje konfiguracji */
.pyr-cfg-section {
  margin-bottom: 24px;
}
.pyr-cfg-label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ink-soft);
  margin-bottom: 10px;
}

/* Siatka trybow gry — mniejsze opt-card */
.pyr-mode-grid.card-grid.three {
  gap: 10px;
  margin-bottom: 0;
}
.pyr-mode-grid .opt-card {
  padding: 14px 10px;
  min-height: 100px;
}
.pyr-mode-grid .opt-card .opt-icon {
  font-size: 22px;
  margin-bottom: 6px;
}
.pyr-mode-grid .opt-card .opt-title {
  font-size: 13px;
}
.pyr-mode-grid .opt-card .opt-desc {
  font-size: 11px;
  line-height: 1.4;
}

/* Poziomy i trudnosc — mix-tile-btn */
.pyr-levels-grid,
.pyr-diff-grid {
  gap: 8px;
  margin-bottom: 10px;
}

/* Expert toggle przycisk */
.pyr-expert-toggle {
  background: none;
  border: 1px dashed var(--gold-2);
  border-radius: var(--r-sm);
  color: var(--gold-3);
  font-size: 12px;
  font-weight: 600;
  padding: 6px 14px;
  cursor: pointer;
  margin-top: 8px;
  transition: background 160ms;
}
.pyr-expert-toggle:hover { background: var(--gold-glow); }

/* Expert section */
.pyr-expert-section {
  margin-top: 10px;
  padding: 12px;
  background: var(--surface-2);
  border-radius: var(--r-md);
  border-left: 3px solid var(--gold-2);
}
.pyr-expert-warn {
  font-size: 12px;
  color: var(--ink-soft);
  margin: 0 0 10px;
  line-height: 1.5;
}

/* Sekcja mieszana — identyczna z FLASH */
.pyr-mixed-section {
  margin-top: 4px;
  padding: 14px 16px;
  border: 1px solid var(--line-soft);
  border-radius: var(--r-md);
  background: var(--surface-2);
}
.pyr-mixed-section .mix-tiles-wrap { margin-top: 12px; }

/* Poprawka input-row: input mniejszy, przycisk SPRAWDZ pelna szerokosc sekcji */
.pyr-input-row {
  display: flex;
  gap: 8px;
  align-items: stretch;
  margin-bottom: 10px;
}
.pyr-input {
  flex: 1;
  min-width: 0;
  max-width: 100px;
  padding: 10px 12px;
  font-size: 18px;
}
.pyr-check-btn {
  flex: 1;
  white-space: nowrap;
}

/* card-grid.one — jedna kolumna (dla screen-zabawy) */
.card-grid.one {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  max-width: 340px;
  margin: 0 auto 24px;
}

/* Responsywnosc config piramidy */
@media (max-width: 560px) {
  .pyr-mode-grid.card-grid.three {
    grid-template-columns: 1fr;
  }
  .pyr-mode-grid .opt-card { min-height: unset; }
  .pyr-levels-grid,
  .pyr-diff-grid { grid-template-columns: repeat(2, 1fr); }
  .pyr-input { max-width: 80px; font-size: 16px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   === PIRAMIDA MOBILE (v2) — Wstecz pod planszą, max 5 poziomów ===
   ═══════════════════════════════════════════════════════════════════════════ */

/* Mobilny przycisk Wstecz (widoczny tylko na mobile) */
.pyr-mobile-back-wrap {
  display: none;
  margin-top: 14px;
}
@media (max-width: 800px) {
  .pyr-mobile-back-wrap {
    display: block;
  }
  /* Ukryj oryginalny Wstecz z panelu bocznego na mobile */
  #pyr-back-btn {
    display: none;
  }
  /* Ukryj poziom 6, 8, 10 w konfiguracji na mobile */
  .pyr-levels-tile[data-levels="6"],
  .pyr-levels-tile[data-levels="8"],
  .pyr-levels-tile[data-levels="10"] {
    display: none;
  }
  /* Ukryj caly blok wyzwan mistrzowskich na mobile */
  #pyrExpertToggle,
  #pyrExpertSection {
    display: none;
  }
}

/* ── Piramida tryb gry: ikony bez tła, selected = podswietlony kafel ───── */
.pyr-mode-grid .opt-card .opt-icon {
  background: none;
  border: none;
  font-size: 28px;
  width: auto;
  height: auto;
  margin-bottom: 8px;
}
.pyr-mode-grid .opt-card.selected .opt-icon {
  background: none;
  border: none;
  color: inherit;
}
.pyr-mode-grid .opt-card.selected {
  border: 1.5px solid #b8890a;
  background: #fdf6e3;
  box-shadow: 0 0 0 3px rgba(184,137,10,0.22), 0 4px 14px rgba(0,0,0,0.10);
}

/* ── Piramida: kafle poziomow i trudnosci — szerokosc dopasowana do tekstu */
.pyr-levels-grid,
.pyr-diff-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-start;
}
.pyr-levels-grid .mix-tile-btn,
.pyr-diff-grid   .mix-tile-btn {
  width: auto;
  min-width: 52px;
  padding: 10px 22px;
  flex: 0 0 auto;
}

/* ── Piramida: pulsowanie pola input po kliknieciu cegiełki ─────────────── */
@keyframes pyrInputPulse {
  0%   { border-color: var(--gold-2); box-shadow: 0 0 0 4px rgba(184,137,10,0.35); }
  60%  { border-color: var(--gold-2); box-shadow: 0 0 0 8px rgba(184,137,10,0.10); }
  100% { border-color: var(--line-soft); box-shadow: none; }
}
.pyr-input-row.pyr-input-pulse .pyr-input {
  animation: pyrInputPulse 0.65s ease forwards;
}

/* Piramida: tryby gry — dwa kafle (po usunięciu Znajdź podstawę) */
.card-grid.two.pyr-mode-grid {
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 480px) {
  .card-grid.two.pyr-mode-grid { grid-template-columns: 1fr; }
}

/* ── Oblicz cegiełkę — input i feedback wewnątrz panelu ────────────────── */
.pyr-panel-divider {
  height: 1px;
  background: var(--gold-1);
  margin: 14px 0 14px;
  opacity: 0.7;
}
/* Input wewnatrz panelu: brak zewnetrznego marginesu */
.pyr-action-panel .pyr-input-row {
  margin-bottom: 6px;
}
/* Feedback wewnatrz panelu: mniejszy padding */
.pyr-action-panel .pyr-feedback {
  margin-bottom: 0;
  min-height: 24px;
  padding: 6px 10px;
}
/* Panel bez sztywnej min-height (teraz zawiera input) */
.pyr-action-panel {
  min-height: unset;
}

/* ── Piramida: złota ikona ▲ na kaflu ZABAWY ───────────────────────────── */
.pyr-card-icon {
  color: #c9920c;
  text-shadow: 0 1px 4px rgba(184,137,10,0.35);
  font-size: 32px !important;
  font-weight: 900;
  line-height: 1;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PIRAMIDA CONFIG — dopracowane sekcje (WYSOKOSC, POZIOM TRUDNOSCI)
   ═══════════════════════════════════════════════════════════════════════════ */

/* Opis pod etykieta sekcji */
.pyr-cfg-desc {
  font-size: 13px;
  color: #74777d;
  margin: -4px 0 12px;
  line-height: 1.5;
}

/* Wiekszy odstep miedzy sekcjami */
#screen-piramida-config .pyr-cfg-section {
  margin-bottom: 32px;
}

/* Kafle poziomow — liczba duza i czytelna */
.pyr-levels-grid .mix-tile-btn {
  min-width: 60px;
  padding: 12px 18px;
}
.pyr-levels-grid .mix-tile-name {
  font-size: 22px;
  font-weight: 800;
  color: #041627;
}
.pyr-levels-grid .mix-tile-sub {
  font-size: 10px;
  color: #74777d;
  margin-top: 2px;
}

/* Kafle trudnosci — nazwa + zakres */
.pyr-diff-grid .mix-tile-btn {
  min-width: 68px;
  padding: 11px 14px;
}
.pyr-diff-grid .mix-tile-name {
  font-size: 13px;
  font-weight: 700;
  color: #041627;
}
.pyr-diff-grid .mix-tile-sub {
  font-size: 11px;
  color: #74777d;
  font-family: var(--font-mono);
}

/* Aktywny kafel piramidy — ciepłe złoto wg specyfikacji */
#screen-piramida-config .mix-tile-btn {
  border: 2px solid #d8d4cf;
  background: #ffffff;
}
#screen-piramida-config .mix-tile-btn.is-active {
  background: #fff8e8;
  border: 2px solid #b8956a;
  box-shadow: 0 0 0 3px rgba(184,149,106,0.18), 0 3px 10px rgba(0,0,0,0.09);
}
#screen-piramida-config .mix-tile-btn.is-active .mix-tile-name {
  color: #041627;
  font-weight: 800;
}
#screen-piramida-config .mix-tile-btn.is-active .mix-tile-sub {
  color: #b8956a;
}
#screen-piramida-config .mix-tile-btn:hover {
  border-color: #b8956a;
  background: #fffdf7;
}

/* Opis wybranego poziomu trudnosci */
.pyr-diff-desc {
  font-size: 13px;
  color: #74777d;
  margin: 8px 0 0;
  line-height: 1.5;
  min-height: 20px;
  transition: opacity 200ms;
}

/* Sekcja expert — kafle na gorze, opis pod */
.pyr-expert-section {
  margin-top: 12px;
  padding: 14px 14px 10px;
}
.pyr-expert-warn {
  font-size: 12px;
  color: #74777d;
  margin: 10px 0 0;
  line-height: 1.55;
}

/* Expert toggle — wiekszy odstep od kafli */
.pyr-expert-toggle {
  margin-top: 12px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PIRAMIDA CONFIG — centralna karta konfiguracji
   ═══════════════════════════════════════════════════════════════════════════ */
.pyr-cfg-card {
  max-width: 1060px;
  margin: 0 auto 32px;
  background: #ffffff;
  border: 1px solid #d8d4cf;
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(4,22,39,0.07), 0 1px 4px rgba(4,22,39,0.04);
  padding: 32px 40px 24px;
}
@media (max-width: 700px) {
  .pyr-cfg-card { padding: 20px 16px 16px; border-radius: 12px; }
}

/* Tryb gry — kafle nie rozjezdzaja sie na cala szerokosc */
.pyr-mode-grid.card-grid.two {
  max-width: 560px;
}

/* Przyciski Wstecz/Dalej — wycentrowane pod karta */
.pyr-cfg-card .actions,
.pyr-cfg-actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 8px;
  padding-top: 20px;
  border-top: 1px solid #ece9e4;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PIRAMIDA CONFIG — poprawki layoutu i mobilki
   ═══════════════════════════════════════════════════════════════════════════ */

/* Zwez karte — tresc nie zostaje w lewej polowie */
.pyr-cfg-card {
  max-width: 840px;
}

/* Wycentruj zawartosc sekcji trybu gry */
#screen-piramida-config .pyr-cfg-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
#screen-piramida-config .pyr-cfg-label,
#screen-piramida-config .pyr-cfg-desc,
#screen-piramida-config .pyr-diff-desc,
#screen-piramida-config .pyr-expert-warn {
  align-self: flex-start;
  text-align: left;
}

/* Desktop: poziomy + trudnosc obok siebie */
@media (min-width: 640px) {
  #screen-piramida-config .pyr-cfg-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    width: 100%;
    align-items: start;
  }
}

/* Kafle troche wieksze i czytelniejsze */
#screen-piramida-config .pyr-levels-grid .mix-tile-btn {
  min-width: 72px;
  padding: 14px 20px;
}
#screen-piramida-config .pyr-diff-grid .mix-tile-btn {
  min-width: 80px;
  padding: 13px 16px;
}
#screen-piramida-config .pyr-diff-grid .mix-tile-name {
  font-size: 14px;
}

/* MOBILKA: przyciski Wstecz/Dalej wycentrowane, stack na bardzo malem ekranie */
@media (max-width: 480px) {
  .pyr-cfg-actions,
  .pyr-cfg-card .actions {
    flex-direction: column-reverse;
    align-items: center;
    gap: 10px;
  }
  .pyr-cfg-actions .btn,
  .pyr-cfg-card .actions .btn {
    width: 100%;
    max-width: 320px;
    text-align: center;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILNY UKŁAD GRY — piramida pierwsza, statystyki na dole
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 800px) {
  /* 1. Usuń order:-1 — piramida (left) naturalne pierwsze */
  .pyr-game-right { order: 0 !important; display: flex; flex-direction: column; }

  /* 2. Statystyki na sam dół */
  .pyr-stats-panel { order: 20; margin-bottom: 0; margin-top: 12px; }
  .pyr-action-panel { order: 1; }
  .pyr-side-actions  { order: 10; }

  /* 3. Kompaktowy pasek statystyk — jeden rząd */
  .pyr-stats-panel {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 6px 18px;
    padding: 10px 14px;
    background: var(--surface-2);
    border: 1px solid var(--line-soft);
    border-radius: var(--r-md);
    box-shadow: none;
  }
  .pyr-stat-item {
    flex-direction: row;
    align-items: center;
    gap: 5px;
    padding: 0;
    background: none;
    border-radius: 0;
  }
  .pyr-stat-label { font-size: 12px; white-space: nowrap; }
  .pyr-stat-val   { font-size: 15px; font-weight: 800; }

  /* 4. Input + Sprawdź — jeden pod drugim, pełna szerokość */
  .pyr-input-row { flex-direction: column; }
  .pyr-check-btn { width: 100%; justify-content: center; }
  .pyr-input     { text-align: left; }

  /* 5. Przyciski drugorzędne — dwa obok siebie, Wstecz na dole */
  .pyr-side-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  #pyr-back-btn { grid-column: 1 / -1; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   CONFIG: siatka 2×2 dla poziomów i trudności (zawsze, nie tylko mobile)
   ═══════════════════════════════════════════════════════════════════════════ */

/* Siatka 2×2 */
#screen-piramida-config .pyr-levels-grid,
#screen-piramida-config .pyr-diff-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  width: 100%;
}

/* Kafle równej wysokości i szerokości */
#screen-piramida-config .pyr-levels-grid .mix-tile-btn,
#screen-piramida-config .pyr-diff-grid   .mix-tile-btn {
  width: 100%;
  min-width: unset;
  padding: 14px 12px;
}

/* Wyrównanie sekcji w two-col — do lewej, nie do centrum */
#screen-piramida-config .pyr-cfg-two-col .pyr-cfg-section {
  align-items: flex-start;
  text-align: left;
}
#screen-piramida-config .pyr-cfg-two-col .pyr-cfg-label,
#screen-piramida-config .pyr-cfg-two-col .pyr-cfg-desc {
  text-align: left;
}

/* Expert toggle — wyrównany do lewej */
.pyr-expert-toggle {
  align-self: flex-start;
  margin-top: 10px;
}

/* Sekcja trybu gry — kafle wyśrodkowane, nie rozciągają się */
#screen-piramida-config > .pyr-cfg-card > .pyr-cfg-section:first-child {
  align-items: center;
}
.pyr-mode-grid.card-grid.two {
  max-width: 520px;
  margin: 0 auto;
}

/* Więcej oddechu między TRYB GRY a kolumnami */
#screen-piramida-config .pyr-cfg-section:first-child {
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid #ece9e4;
}

/* Two-col: więcej oddechu */
.pyr-cfg-two-col {
  gap: 28px;
  width: 100%;
}
@media (max-width: 639px) {
  .pyr-cfg-two-col { display: flex; flex-direction: column; gap: 20px; }
}

/* ── Modal końcowy piramidy: kolorowe statystyki ───────────────────────── */
.pyr-modal-correct {
  color: #1a7a3f !important;
}
.pyr-sstat:has(.pyr-modal-correct) {
  background: #e8f7ee;
  border: 1px solid #a8ddb8;
}
.pyr-modal-errors {
  color: #c0392b !important;
}
.pyr-sstat:has(.pyr-modal-errors) {
  background: #fdf0ee;
  border: 1px solid #f0b8b1;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CONFIG: expert sekcja — kafle inline (nie osobny box)
   ═══════════════════════════════════════════════════════════════════════════ */
.pyr-expert-section {
  background: none !important;
  border: none !important;
  border-left: none !important;
  padding: 0 !important;
  margin-top: 0 !important;
  display: contents; /* dzieci stają się dziećmi rodzica — kafle wpadają do gridu */
}
/* Kafle 8/10 wpadają w tę samą siatkę co 3/4/5/6 */
#screen-piramida-config .pyr-levels-grid,
#screen-piramida-config .pyr-levels-grid ~ .pyr-expert-section {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  width: 100%;
}
/* Zmień display:contents na grid gdy sekcja jest widoczna */
.pyr-expert-section:not([hidden]) {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-top: 10px !important;
}
.pyr-expert-warn {
  grid-column: 1 / -1;
  font-size: 12px;
  color: #74777d;
  margin: 4px 0 0;
  line-height: 1.5;
}
/* Expert toggle — do lewej, mały */
.pyr-cfg-two-col .pyr-expert-toggle,
#screen-piramida-config .pyr-expert-toggle {
  align-self: flex-start;
  margin-top: 10px;
  font-size: 12px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILNY: Wstecz na samym dole (pyr-bottom-back)
   ═══════════════════════════════════════════════════════════════════════════ */
/* Desktop: pyr-bottom-back schowany, normalny back-btn widoczny */
.pyr-bottom-back { display: none; }

@media (max-width: 800px) {
  /* Wstecz na samym dole mobile */
  .pyr-bottom-back {
    display: block;
    order: 30;
    margin-top: 12px;
  }
  .pyr-bottom-back .btn {
    width: 100%;
    text-align: center;
    justify-content: center;
    font-size: 14px;
    padding: 10px;
    opacity: 0.8;
  }
  /* Ukryj stary mobilny przycisk pod planszą */
  .pyr-mobile-back-wrap { display: none !important; }
  /* side-actions: tylko Podpowiedź + Nowa piramida (2 przyciski, 2 kolumny) */
  .pyr-side-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
}

/* ── Fix: hidden na sekcji expert musi działać mimo display:contents ─────── */
#pyrExpertSection[hidden] { display: none !important; }

/* ── Fix: przycisk Wstecz widoczny na desktop i mobile ───────────────────── */
.pyr-bottom-back { display: block; }
@media (max-width: 800px) {
  .pyr-bottom-back { order: 30; margin-top: 12px; }
  .pyr-bottom-back .btn { width: 100%; justify-content: center; }
}

/* ── Przycisk Wstecz — mniejszy, pasujący do reszty ─────────────────────── */
.pyr-bottom-back {
  display: flex;
  justify-content: center;
  margin-top: 8px;
}
.pyr-bottom-back .btn {
  width: auto !important;
  min-width: 140px;
  max-width: 220px;
  font-size: 13px;
  padding: 9px 24px;
  opacity: 0.75;
  justify-content: center;
}
.pyr-bottom-back .btn:hover { opacity: 1; }

@media (max-width: 800px) {
  .pyr-bottom-back {
    justify-content: center;
    margin-top: 16px;
    padding-bottom: 8px;
  }
  .pyr-bottom-back .btn {
    width: auto !important;
    min-width: 160px;
  }
}

/* ── Wstecz: identyczny styl jak inne przyciski w grze ──────────────────── */
.pyr-bottom-back {
  display: block;
  margin-top: 0;
  padding-bottom: 0;
}
.pyr-bottom-back .btn {
  width: 100% !important;
  max-width: unset !important;
  min-width: unset !important;
  font-size: inherit !important;
  padding: inherit !important;
  opacity: 1 !important;
  justify-content: center;
}
/* Mobile: identyczne jak Podpowiedź i Nowa piramida */
@media (max-width: 800px) {
  .pyr-bottom-back { margin-top: 8px; justify-content: unset; }
  .pyr-bottom-back .btn { width: 100% !important; text-align: center; }
  /* Podpowiedź i Nowa piramida: jedna kolumna jak Wstecz */
  .pyr-side-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   GRA PIRAMIDA — spójne przyciski prawego panelu
   ═══════════════════════════════════════════════════════════════════════════ */

/* Kontener akcji — siatka 2 kolumny + Wstecz pod spodem */
.pyr-side-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 16px;
}

/* Wstecz — cała szerokość */
.pyr-bottom-back {
  display: block !important;
  margin-top: 10px;
}
.pyr-bottom-back .btn,
.pyr-side-actions .btn,
#pyr-hint-btn,
#pyr-new-btn {
  width: 100% !important;
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  border-radius: var(--r-md);
  padding: 0 16px;
  box-sizing: border-box;
  max-width: unset !important;
  min-width: unset !important;
  opacity: 1 !important;
}

/* Podpowiedź — złoto-bursztynowe */
#pyr-hint-btn {
  background: #fef3d8;
  border: 1px solid #d9b985;
  color: #5a3e00;
}
#pyr-hint-btn:hover { background: #fde8b0; }

/* Nowa piramida — neutralne */
#pyr-new-btn {
  background: var(--surface);
  border: 1px solid var(--line);
  color: var(--ink);
}
#pyr-new-btn:hover { background: var(--surface-2); }

/* Wstecz — białe, delikatne */
#pyr-back-btn {
  background: #ffffff;
  border: 1px solid #d8d4cf;
  color: var(--ink);
}
#pyr-back-btn:hover { background: var(--surface-2); }

/* Mobile: Podpowiedź + Nowa piramida obok siebie, Wstecz pod spodem */
@media (max-width: 800px) {
  .pyr-side-actions {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px;
  }
  .pyr-bottom-back { margin-top: 10px; }
  .pyr-bottom-back .btn,
  .pyr-side-actions .btn,
  #pyr-hint-btn,
  #pyr-new-btn {
    min-height: 56px;
    font-size: 14px;
  }
}

/* ── WAŻNE: expert section domyślnie ukryta — nadpisuje display:contents/grid */
#pyrExpertSection[hidden],
.pyr-expert-section[hidden] {
  display: none !important;
  visibility: hidden !important;
}
#pyrExpertSection:not([hidden]),
.pyr-expert-section:not([hidden]) {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-top: 10px;
  background: none;
  border: none;
  padding: 0;
}

/* ── Mobile: WSTECZ na samym dole ekranu gry ─────────────────────────────── */
@media (max-width: 800px) {
  .pyr-game-right { display: flex !important; flex-direction: column; }
  .pyr-bottom-back {
    display: block !important;
    order: 30;
    margin-top: 12px;
  }
  .pyr-bottom-back #pyr-back-btn {
    display: flex !important;
    width: 100%;
    min-height: 54px;
    align-items: center;
    justify-content: center;
  }
}

/* ── Mobile: statystyki piramidy — układ 2×2 ─────────────────────────────── */
@media (max-width: 800px) {
  .pyr-stats-panel {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    flex-direction: unset;
    flex-wrap: unset;
    padding: 0;
    background: none;
    border: none;
    box-shadow: none;
  }
  .pyr-stat-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start;
    gap: 4px;
    padding: 10px 14px;
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: var(--r-md);
    box-shadow: 0 1px 4px rgba(0,0,0,0.05);
  }
  .pyr-stat-label {
    font-size: 10px;
    color: var(--ink-soft);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
  }
  .pyr-stat-val {
    font-size: 20px;
    font-weight: 800;
    color: var(--ink);
    line-height: 1;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   PIRAMIDA MOBILE — statystyki oddzielone od przycisków akcji
   ═══════════════════════════════════════════════════════════════════════════ */

/* Wrapper statystyk — dodatkowy odstęp od przycisków akcji */
.pyr-stats-wrap {
  order: 20;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--line-soft);
}

/* Nagłówek "Twoje wyniki" */
.pyr-stats-heading {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 10px;
}

/* Statystyki — spokojniejsze, nie wyglądają jak przyciski */
@media (max-width: 800px) {
  .pyr-stats-wrap { display: block; order: 20; }

  .pyr-stats-panel {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 0;
    background: none;
    border: none;
    box-shadow: none;
  }
  .pyr-stat-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start;
    gap: 3px;
    padding: 10px 12px;
    background: #f6f4f0;
    border: 1px solid #e8e4de;
    border-radius: var(--r-sm);
    box-shadow: none;
    cursor: default;
  }
  .pyr-stat-label {
    font-size: 10px;
    color: #74777d;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    white-space: nowrap;
  }
  .pyr-stat-val {
    font-size: 22px;
    font-weight: 800;
    color: #041627;
    line-height: 1;
  }

  /* Wstecz — większy odstęp od statystyk */
  .pyr-bottom-back {
    margin-top: 20px !important;
    padding-top: 4px;
    border-top: 1px solid var(--line-soft);
  }
}

/* ── Mobile: większy input i Sprawdź pod spodem ─────────────────────────── */
@media (max-width: 800px) {
  .pyr-input-row {
    flex-direction: column !important;
    gap: 10px;
  }
  .pyr-input {
    width: 100% !important;
    height: 60px;
    font-size: 26px !important;
    padding: 14px 18px !important;
    text-align: left;
    border-radius: var(--r-md);
  }
  .pyr-input::placeholder {
    font-size: 16px;
    color: var(--ink-faint);
    font-weight: 400;
  }
  .pyr-check-btn {
    width: 100% !important;
    height: 54px;
    font-size: 16px !important;
    justify-content: center;
  }
}

/* ── Mobile: input odpowiedzi — pełna szerokość, duży, wygodny ──────────── */
@media (max-width: 800px) {
  .pyr-action-panel .pyr-input-row {
    flex-direction: column !important;
    gap: 10px !important;
  }
  .pyr-action-panel .pyr-input {
    width: 100% !important;
    height: 62px !important;
    min-height: 62px !important;
    font-size: 26px !important;
    font-weight: 700 !important;
    padding: 0 20px !important;
    text-align: center !important;
    box-sizing: border-box !important;
  }
  .pyr-action-panel .pyr-check-btn {
    width: 100% !important;
    height: 54px !important;
    font-size: 16px !important;
    justify-content: center !important;
    box-sizing: border-box !important;
  }
}

/* ── Input odpowiedzi — obsługa długich liczb, flex, nie ucina cyfr ─────── */
.pyr-input-row {
  display: flex;
  gap: 10px;
  align-items: stretch;
}
.pyr-input {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: hidden;
  text-overflow: clip;
  white-space: nowrap;
  text-align: center;
}
.pyr-input::placeholder {
  font-size: 15px;
  font-weight: 400;
  color: var(--ink-faint);
  letter-spacing: 0;
}

/* Desktop: input + Sprawdź w jednym rzędzie, input nie za mały */
@media (min-width: 801px) {
  .pyr-action-panel .pyr-input-row { flex-direction: row; }
  .pyr-action-panel .pyr-input { min-width: 120px; font-size: 20px; }
  .pyr-action-panel .pyr-check-btn { flex-shrink: 0; }
}

/* Mobile: input nad Sprawdź, pełna szerokość */
@media (max-width: 800px) {
  .pyr-action-panel .pyr-input-row {
    flex-direction: column !important;
    gap: 10px !important;
  }
  .pyr-action-panel .pyr-input {
    width: 100% !important;
    height: 62px !important;
    font-size: 28px !important;
    padding: 0 16px !important;
    text-align: center !important;
  }
  .pyr-action-panel .pyr-check-btn {
    width: 100% !important;
    height: 54px !important;
    font-size: 16px !important;
    flex-shrink: 0;
  }
}

/* ── KLUCZOWE: input flex:1 min-width:0 — bez tego jest ściskany w flexie ── */
#pyr-input.pyr-input {
  flex: 1 1 0% !important;
  min-width: 0 !important;
  width: auto !important;
  box-sizing: border-box !important;
}
#pyr-check-btn.pyr-check-btn {
  flex: 0 0 auto !important;
  white-space: nowrap;
}

/* Mobile: kolumna — input nad Sprawdź, oba 100% */
@media (max-width: 800px) {
  #pyr-input.pyr-input {
    flex: none !important;
    width: 100% !important;
    height: 62px !important;
    font-size: 28px !important;
    padding: 0 20px !important;
    text-align: center !important;
  }
  #pyr-check-btn.pyr-check-btn {
    flex: none !important;
    width: 100% !important;
    height: 54px !important;
    font-size: 16px !important;
  }
  .pyr-action-panel .pyr-input-row,
  .pyr-input-row {
    flex-direction: column !important;
    gap: 10px !important;
    align-items: stretch !important;
  }
}

/* ── DESKTOP fix: input rośnie, Sprawdź tylko tyle ile potrzebuje ─────────── */
@media (min-width: 801px) {
  .pyr-action-panel .pyr-input-row {
    flex-direction: row !important;
    align-items: stretch;
  }
  .pyr-action-panel #pyr-input {
    flex: 1 1 0% !important;
    min-width: 0 !important;
    width: auto !important;
  }
  .pyr-action-panel #pyr-check-btn {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: 110px;
    padding-left: 20px;
    padding-right: 20px;
  }
}

/* ── NOWA PIRAMIDA — ikona SVG odświeżenia ─────────────────────────────── */
.pyr-new-icon {
  width: 17px;
  height: 17px;
  display: inline-block;
  vertical-align: middle;
  margin-right: 4px;
  margin-top: -2px;
  flex-shrink: 0;
}
#pyr-new-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

/* === home-feature: emoji/ikona obok nagłówka na mobile === */
@media (max-width: 767px) {
  .home-feature {
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: 14px;
    align-items: start;
  }
  .home-feature-icon {
    grid-column: 1;
    grid-row: 1;
    margin-bottom: 0;
    align-self: center;
  }
  .home-feature h3 {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    margin-bottom: 6px;
  }
  .home-feature p {
    grid-column: 2;
    grid-row: 2;
  }
  /* nail-tl / nail-tr zajmują grid-row: 1, col: 1 — resetujemy */
  .home-feature .nail-tl,
  .home-feature .nail-tr {
    display: none;
  }
  /* ach-year-card: rok obok tytułu */
  .ach-year-card,
  .ach-hero-v3 .ach-year-card {
    grid-template-columns: auto 1fr !important;
    gap: 10px 14px !important;
    align-items: center !important;
  }
  .ach-year,
  .ach-hero-v3 .ach-year {
    width: max-content !important;
    padding: 0 14px !important;
  }
}

/* === home-step: cyfra i tytuł w jednej linii na mobile === */
@media (max-width: 767px) {
  .home-step {
    display: grid;
    grid-template-columns: 52px 1fr;
    grid-template-rows: auto auto;
    column-gap: 14px;
    align-items: start;
  }
  .home-step-num {
    grid-column: 1;
    grid-row: 1;
    margin-bottom: 0;
    width: 48px;
    height: 48px;
    font-size: 22px;
  }
  .home-step h3 {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    margin-bottom: 6px;
  }
  .home-step p {
    grid-column: 2;
    grid-row: 2;
  }
}

/* === Flaga języka w headerze mobile — obok burgera === */
.topbar-actions {
  display: none;
}
@media (max-width: 767px) {
  .topbar-actions {
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .topbar-lang-mobile {
    display: inline-flex;
    align-items: center;
    font-size: 1.5rem;
    line-height: 1;
    text-decoration: none;
    flex-shrink: 0;
  }
}
