/* path: public/css/matemaks.css */
/* ================================
   MatmaPlusPlus — nowoczesny „Matemaks”
   ================================ */
   :root{
    --bg:#f4efe4;          /* beż tła */
    --paper:#ffffff;       /* kartka */
    --ink:#111;            /* tekst */
    --muted:#3b3b3b;       /* subtelny */
    --link:#275789;        /* linki */
    --tab:#efede7;         /* pasek nawigacji */
    --tab-border:#c9c4b8;
    --line:#b9d7ac;        /* zieleń */
    --line-strong:#9dc48e;
    --greenbox:#f8fff2;
    --shadow:0 6px 24px rgba(0,0,0,.06);
    --radius:8px;
  }
  
  *{box-sizing:border-box}
  html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font:18px/1.6 "Georgia","Times New Roman",serif}
  a{color:var(--link);text-decoration:none}
  a:hover{text-decoration:underline}
  
  /* Layout główny (>=1700px) */
  .wrap{max-width:1720px;margin:0 auto;padding:18px}
  .bg{background:var(--bg)}
  
  /* Pasek progresu scrolla (alias dla id i klasy) */
  .scroll-progress,
  #scrollProgress{position:fixed;inset:0 0 auto 0;height:3px;background:rgba(0,0,0,.04);z-index:999}
  .scroll-progress i,
  #scrollProgress i{display:block;height:100%;width:0;background:linear-gradient(90deg,#9cb1ff,#667fe0)}
  
  /* Brand (logo z 3 kółek) */
  .brand{display:flex;align-items:center;gap:18px;margin:8px 0 12px}
  .brand__logo{position:relative;width:150px;height:90px}
  .c{position:absolute;border:3px solid #000;border-radius:50%;background:#fff}
  .c--big{width:104px;height:104px;left:0;top:-10px}
  .c--mid{width:70px;height:70px;left:84px;top:8px}
  .c--small{width:36px;height:36px;left:126px;top:34px}
  .brand__title h1{font-size:46px;line-height:1;margin:0 0 6px;text-rendering:optimizeLegibility}
  .brand__title p{margin:0;color:#555;font-size:18px}
  
  /* Top nav — kafelki */
  .nav{display:flex;gap:8px;flex-wrap:wrap;background:var(--tab);border:1px solid var(--tab-border);border-radius:6px;padding:6px;box-shadow:var(--shadow)}
  .nav__item{padding:10px 14px;border:1px solid var(--tab-border);background:#fff;border-radius:6px;color:#222;transition:transform .12s ease, box-shadow .12s ease}
  .nav__item:hover{transform:translateY(-1px);box-shadow:0 6px 12px rgba(0,0,0,.06)}
  .nav__item.is-active{box-shadow:inset 0 1px 0 #fff, 0 0 0 1px #ddd}
  
  /* Sub nav */
  .subnav{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;border:1px solid #d0d0cc;background:#fff;border-radius:6px;padding:10px}
  .subnav__topic{font-weight:bold}
  .subnav__link{color:#7b5c2f}
  .subnav__print{padding:6px 12px;border:1px solid #bbb;background:#f7f7f7;border-radius:6px;cursor:pointer}
  
  /* Kartka */
  .paper{
    background:var(--paper);
    border:2px solid var(--line);
    border-radius:8px;
    box-shadow:var(--shadow);
    margin-top:16px;
    overflow:hidden;               /* zachowaj clipping rogów */
    padding:clamp(12px, 2.4vw, 24px); /* ochrona przed „klejeniem się” do krawędzi na każdej szerokości */
  }
  
  /* Tytuły */
  .title{text-align:center;border-bottom:1px solid var(--line-strong);padding:16px 12px}
  .title h2{margin:0 0 4px;font-size:28px}
  .title h3{margin:0 0 6px;font-size:24px}
  .title__sub{display:inline-block;background:#edf7e8;border:1px solid var(--line);border-radius:6px;padding:4px 10px;color:#2f4d2b;font-size:14px}
  .title--section{background:#fafcf8}
  
  /* Zielone „pudełka” treści */
  .box{border:1px solid var(--line);background:var(--greenbox);margin:16px;border-radius:8px;padding:12px}
  .box--ex{background:#f6fff0}
  .box__title{font-weight:bold;margin-bottom:6px}
  .ol{margin:8px 0 8px 20px}
  .ul{margin:8px 0 8px 20px;list-style:disc}
  
  /* Lista tematów */
  .topiclist{margin:16px;border:1px solid var(--tab-border);border-radius:8px;overflow:hidden;background:#fff}
  .topiclist__row{display:grid;grid-template-columns:60px 1fr 60px;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid #e6e2d9}
  .topiclist__row:last-child{border-bottom:none}
  .topiclist__row:hover{background:#faf8f2}
  .topiclist__head{background:#f4efe7;font-weight:600}
  .topiclist__idx{text-align:center;color:#6b6b6b}
  .topiclist__name{color:#1a1a1a}
  .topiclist__ctrl{text-align:center;color:#8b8b8b}
  .topiclist__sort{text-align:center;color:#8b8b8b}
  
  /* Sub-bar pod listą tematów */
  .subbar{display:grid;grid-template-columns:1fr 1fr auto;align-items:center;margin:0 16px}
  .subbar__left{color:#3c3c3c}
  .subbar__right{justify-self:end;color:#7b5c2f}
  .subbar__print{margin-left:8px;padding:6px 12px;border:1px solid #bbb;background:#f7f7f7;border-radius:6px;cursor:pointer}
  
  /* „Tabela” sekcji w ramach działu */
  .tablebox{margin:16px;border:1px solid #e0ded7;border-radius:8px;background:#fff;overflow:hidden}
  .tablebox__row{display:grid;grid-template-columns:80px 1fr;gap:10px;padding:10px 12px;border-bottom:1px solid #eae6dc}
  .tablebox__row:last-child{border-bottom:none}
  .tablebox__row:hover{background:#faf8f2}
  .tablebox__idx{text-align:right;color:#6b6b6b}
  
  /* Uploader */
  .upload .btn{border:1px solid #bfbfbf;background:#fff;border-radius:6px;padding:9px 14px;cursor:pointer;margin-right:6px;transition:transform .12s ease, box-shadow .12s ease}
  .upload .btn:hover{transform:translateY(-1px);box-shadow:0 6px 12px rgba(0,0,0,.06)}
  .upload .btn.btn--pri{border-color:#657ac6;background:#e8eeff}
  .upload .note{margin-top:10px;display:grid;gap:6px}
  .upload textarea{width:100%;min-height:96px;border:1px solid #cbd5e1;border-radius:8px;padding:10px;font:16px/1.4 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}
  .preview{margin-top:10px;border:1px dashed #bcd;border-radius:8px;min-height:160px;display:grid;place-items:center;overflow:hidden;background:#fff}
  .preview img{width:100%;height:auto;display:block}
  .preview.is-empty{color:#8aa}
  .bar{height:6px;background:#eef3ff;border-radius:999px;margin-top:10px;overflow:hidden;opacity:0;transition:opacity .25s}
  .bar[aria-hidden="false"]{opacity:1}
  .bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,#9cb1ff,#667fe0)}
  
  /* Karty + skeleton */
  .card{background:#fff;border:1px solid #e5e5e5;border-radius:8px;padding:10px}
  .skeleton{position:relative;overflow:hidden}
  .skeleton::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,0),rgba(0,0,0,.06),rgba(0,0,0,0));animation:shimmer 1.3s infinite}
  @keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
  
  /* Zakładki */
  .tab{display:none}
  .tab.is-visible{display:block}
  
  /* ──────────────────────────────────────────────────────────────
     PREMIUM — overlay na środku ZABLOKOWANEJ SEKCJI (nie całej strony)
     ────────────────────────────────────────────────────────────── */
  .premium{
    position:relative;
    isolation:isolate; /* gwarantuje, że overlay zawsze nad treścią tej sekcji */
  }
  .premium.is-locked .premium__content{
    filter:blur(3px);
    pointer-events:none;
    user-select:none;
  }
  
  /* overlay jest częścią sekcji, a nie całego viewportu */
  .premium__overlay{
    display:none;
    position:absolute;     /* <— względem sekcji .premium */
    inset:0;
    padding:clamp(16px, 3vw, 32px);
    z-index:5;
    align-items:center;
    justify-content:center;
    background:color-mix(in srgb, #0b1b2b 12%, transparent);
    -webkit-backdrop-filter:blur(8px) saturate(120%);
    backdrop-filter:blur(8px) saturate(120%);
    pointer-events:all;
  }
  
  /* pokaż overlay tylko, gdy sekcja jest zablokowana */
  .premium.is-locked .premium__overlay{ display:flex }
  
  /* na nieaktywnej karcie nie pokazuj overlayów */
  .tab:not(.is-visible) .premium__overlay{ display:none !important }
  
  /* panel w overlayu */
  .premium__panel{
    position:relative;
    width:min(720px,92%);
    border-radius:16px;
    background:var(--paper);
    border:1px solid var(--line);
    box-shadow:var(--shadow), 0 16px 48px rgba(0,0,0,.18);
    padding:clamp(16px, 2.4vw, 24px);
    text-align:center;
    animation:premium-pop .22s cubic-bezier(.2,.8,.2,1);
  }
  @keyframes premium-pop{
    from{ transform:translateY(8px) scale(.97); opacity:0 }
    to  { transform:none; opacity:1 }
  }
  
  .premium__form{display:grid;grid-template-columns:1fr auto;gap:10px;margin-top:12px}
  .premium__input{border:1px solid #cbd5e1;border-radius:10px;padding:12px 14px;min-width:220px;font:16px/1.3 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}
  .premium__btn{border:1px solid #657ac6;background:#e8eeff;border-radius:10px;padding:12px 16px;cursor:pointer}
  .premium__msg{margin-top:8px;color:#275789;min-height:1.2em}
  
  /* Grids do poradników */
  .statgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
  .statcard{background:#fff;border:1px solid #e8e8e8;border-radius:10px;padding:10px}
  
  /* Reveal animation classes */
  .reveal{opacity:.001;transform:translateY(6px)}
  .is-revealed{opacity:1 !important;transform:none !important;transition:opacity .45s ease, transform .45s ease}
  
  /* Stopka */
  .foot{padding:18px;text-align:center;color:#666}
  
  /* Responsive */
  @media (max-width: 780px){
    html,body{font-size:16px}
    .brand__title h1{font-size:36px}
    .subnav{grid-template-columns:1fr;gap:8px}
    .topiclist__row{grid-template-columns:48px 1fr 48px}
    .tablebox__row{grid-template-columns:60px 1fr}
  }
  
  /* ──────────────────────────────────────────────────────────────
     SAFEGUARDS: matematyka / tabele / preformatowane — nigdy poza ekran
     ────────────────────────────────────────────────────────────── */
  
  /* Obrazki i media nigdy nie wychodzą poza kontener */
  img, svg, canvas, video{max-width:100%;height:auto}
  
  /* Domyślne „poduszki” w sekcjach i kartach wewnątrz kartki */
  .paper :where(section,.box,.tablebox,.card,.statcard){margin-inline:auto;max-width:100%}
  .paper :where(section){padding-inline:clamp(8px,2.5vw,20px)}
  
  /* Długie słowa/ciągi znaków nie łamią layoutu (np. długie zmienne) */
  .paper :where(p,li,td,th,span){overflow-wrap:anywhere}
  
  /* Tabele: przewijak poziomy, centrowanie i brak wycieku na boki */
  .paper table{
    display:block;                 /* umożliwia overflow-x */
    width:100%;
    border-collapse:collapse;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    margin:12px auto;              /* centrowanie w obrębie sekcji */
  }
  .paper thead th{white-space:nowrap}
  .paper th,.paper td{padding:8px 10px;border-bottom:1px solid #e9e6de}
  .paper tr:nth-child(even){background:#fbfaf6}
  
  /* Pre/code: przewijak poziomy jeśli za długie, miękkie krawędzie */
  .paper pre,
  .paper .code,
  .paper code:not(pre > code){
    display:block;
    max-width:100%;
    overflow-x:auto;
    white-space:pre;               /* nie łam — użyj scrolla */
    padding:10px 12px;
    background:#fafafc;
    border:1px solid #e5e7eb;
    border-radius:8px;
  }
  
  /* KaTeX (inline i display) oraz MathJax — bez wyciekania poza ekran */
  .katex{overflow-wrap:anywhere}
  .katex-display{
    overflow-x:auto;
    overflow-y:hidden;
    max-width:100%;
    text-align:center;
    padding:6px 4px;
    margin:10px auto;
  }
  
  /* MathJax v2 */
  .MathJax_Display{
    overflow-x:auto !important;
    overflow-y:hidden !important;
    max-width:100%;
    text-align:center;
    padding:6px 4px;
    margin:10px auto !important;
  }
  
  /* MathJax v3 */
  .mjx-container{
    display:block;
    max-width:100%;
    overflow-x:auto;
    overflow-y:hidden;
    justify-content:center;
    padding:6px 4px;
    margin:10px auto;
  }
  
  /* Sekcje wyników (np. #s0, #s1, #s2...) trzymają bezpieczną szerokość i centrowanie */
  .paper [id^="s"]{
    margin-inline:auto;
    max-width:min(100%, 1200px);   /* szeroko, ale z limitem dla dużych ekranów */
  }
  
  /* Dodatkowe bezpieczeństwo dla długich równań wewnątrz komórek tabeli */
  .paper td :is(.katex,.mjx-container,.MathJax_Display){display:block}
  
  /* Małe paski przewijania – dyskretne (opcjonalnie) */
  .paper :is(table,pre,.code,.katex-display,.MathJax_Display,.mjx-container){scrollbar-width:thin}
  .paper :is(table,pre,.code,.katex-display,.MathJax_Display,.mjx-container)::-webkit-scrollbar{height:8px}
  .paper :is(table,pre,.code,.katex-display,.MathJax_Display,.mjx-container)::-webkit-scrollbar-thumb{
    background:rgba(0,0,0,.2);
    border-radius:999px;
  }
  .paper :is(table,pre,.code,.katex-display,.MathJax_Display,.mjx-container)::-webkit-scrollbar-track{
    background:rgba(0,0,0,.06);
  }
  
  /* Gęstsze marginesy na bardzo wąskich ekranach */
  @media (max-width: 480px){
    .paper{padding:14px}
    .paper :where(section){padding-inline:12px}
  }
  