:root{
  --bg:#fbfaf7; --panel:#ffffff; --ink:#23201b; --muted:#6c645a;
  --line:#e7e1d6; --accent:#7a5b34; --accent2:#9a7a4a; --soft:#f1ece2;
  --link:#8a5a2b;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--ink);
  font:16px/1.65 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  display:flex;
}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- nawigacja ---- */
#nav{
  width:300px; min-width:300px; height:100vh; overflow-y:auto; position:sticky; top:0;
  background:var(--panel); border-right:1px solid var(--line); padding:14px 12px 60px;
}
#nav .home{display:block;font-weight:700;padding:8px 10px;border-radius:8px;color:var(--ink)}
#nav .home.active{background:var(--soft)}
.subj{margin-top:14px}
.subj-h{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--accent);
  font-weight:700;margin:6px 10px 4px}
#nav a{display:block;padding:4px 10px;border-radius:7px;color:var(--ink);font-size:14.5px}
#nav a.ix{color:var(--muted);font-weight:600}
#nav a:hover{background:var(--soft);text-decoration:none}
#nav a.active{background:var(--accent);color:#fff}
#nav a.active.ix{background:var(--accent2);color:#fff}

/* ---- szukajka ---- */
.search{position:relative;margin-bottom:8px}
#q{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;
  background:var(--bg);font-size:14px}
#q:focus{outline:none;border-color:var(--accent2)}
#results{position:absolute;z-index:20;left:0;right:0;top:42px;background:var(--panel);
  border:1px solid var(--line);border-radius:9px;box-shadow:0 8px 24px #0002;
  max-height:60vh;overflow-y:auto;display:none}
#results.show{display:block}
#results a{display:block;padding:8px 11px;border-bottom:1px solid var(--line)}
#results a:last-child{border-bottom:none}
#results .rt{font-weight:600;font-size:14px}
#results .rs{font-size:12px;color:var(--accent)}
#results .rx{font-size:12px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden}
#results .empty{padding:10px 12px;color:var(--muted);font-size:13px}

/* ---- treść ---- */
main{flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}
.md{max-width:820px;margin:0 auto;padding:34px 40px 60px;width:100%}
.md h1{font-size:30px;line-height:1.2;margin:.2em 0 .6em;color:#1c180f;
  border-bottom:3px solid var(--accent);padding-bottom:.25em}
.md h2{font-size:22px;margin:1.5em 0 .5em;color:var(--accent)}
.md h3{font-size:18px;margin:1.3em 0 .3em;color:#3c352a}
.md blockquote{border-left:4px solid var(--accent2);margin:1em 0;padding:.4em 1em;
  background:var(--soft);color:var(--muted);border-radius:0 8px 8px 0}
.md code{background:var(--soft);padding:.1em .35em;border-radius:5px;font-size:.9em}
.md ul{padding-left:1.3em}
.md li{margin:.25em 0}
.md li::marker{color:var(--accent2)}
.md strong{color:#2c2620}
.md hr{border:none;border-top:1px solid var(--line);margin:1.6em 0}
footer{margin-top:auto;padding:18px 40px;color:var(--muted);font-size:12px;
  border-top:1px solid var(--line);text-align:center}

/* fiszki: odpowiedź jako spoiler */
.md li:has(> br){}
#navtoggle{display:none}

/* ---- mobile ---- */
@media(max-width:860px){
  body{flex-direction:column}
  #nav{position:fixed;left:-320px;top:0;z-index:50;transition:left .2s;box-shadow:0 0 30px #0003}
  #nav.open{left:0}
  #navtoggle{display:block;position:fixed;top:10px;left:10px;z-index:60;
    background:var(--accent);color:#fff;border:none;border-radius:8px;
    width:42px;height:42px;font-size:20px;cursor:pointer}
  .md{padding:64px 20px 50px}
}

/* ===== strona grafu ===== */
.graphpage main{height:100vh;overflow:hidden}
.ghead{padding:12px 20px 10px;border-bottom:1px solid var(--line);flex:none}
.ghead h1{font-size:20px;margin:0 0 8px;border:none;padding:0;color:#1c180f}
.gtop{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.gsearch{position:relative;width:260px}
#gsearch{width:100%;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--bg);font-size:14px}
#gsearch:focus{outline:none;border-color:var(--accent2)}
#gsres{position:absolute;z-index:30;left:0;right:0;top:38px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 8px 24px #0002;display:none;max-height:50vh;overflow:auto}
#gsres.show{display:block}
#gsres a{display:block;padding:7px 10px;cursor:pointer;border-bottom:1px solid var(--line);font-size:14px}
#gsres a:last-child{border-bottom:none}
#gsres a:hover{background:var(--soft)}
#gfit{padding:7px 12px;border:1px solid var(--line);background:var(--panel);border-radius:8px;cursor:pointer;font-size:13px}
#gfit:hover{background:var(--soft)}
.gcount{color:var(--muted);font-size:13px}
.gmain{position:relative;flex:1;min-height:0}
#graph{position:absolute;inset:0;background:
  radial-gradient(circle at 1px 1px,#00000008 1px,transparent 0) 0 0/22px 22px,var(--bg)}
.glegend{position:absolute;top:12px;left:12px;background:#fffffff5;border:1px solid var(--line);
  border-radius:10px;padding:8px 11px;font-size:12.5px;max-width:240px;box-shadow:0 4px 14px #0001;z-index:5}
.lg-h{font-weight:700;color:var(--accent);margin-bottom:5px;font-size:11px;text-transform:uppercase;letter-spacing:.03em}
.lg-i{display:flex;align-items:center;gap:6px;cursor:pointer;padding:2px 0}
.lg-i input{margin:0}
.lg-line{width:18px;height:3px;border-radius:2px;display:inline-block;flex:none}
.lg-i i{color:var(--muted);font-style:normal}
.gpanel{position:absolute;top:12px;right:12px;width:300px;max-height:calc(100% - 24px);overflow:auto;
  background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;
  box-shadow:0 8px 30px #0002;display:none;z-index:6}
.gpanel.open{display:block}
.gpanel h3{margin:.1em 0 .4em;font-size:17px;color:#1c180f;border:none;padding:0}
.gpanel .gdef{font-size:13.5px;color:#3c352a;margin:.2em 0 .6em;line-height:1.5}
#gclose{float:right;border:none;background:none;font-size:22px;line-height:1;cursor:pointer;color:var(--muted)}
.grel{margin:.5em 0}
.grel>b{font-size:13px}
.grel .dot,.mod-i .dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:5px;vertical-align:middle;flex:none}
.grel ul{margin:.2em 0;padding-left:18px}
.grel li{margin:.1em 0;font-size:13px}
.gmod{position:absolute;bottom:10px;left:12px;background:#fffffff5;border:1px solid var(--line);
  border-radius:10px;padding:6px 10px;font-size:11.5px;max-width:62%;display:flex;flex-wrap:wrap;gap:3px 10px;z-index:5}
.mod-i{display:inline-flex;align-items:center;white-space:nowrap;color:var(--muted)}
@media(max-width:860px){
  .graphpage main{height:auto;min-height:100vh}
  .gpanel{width:auto;left:12px;right:12px;top:auto;bottom:12px;max-height:50%}
  .gmain{height:70vh}
  .gmod{max-width:50%}
}

/* ===== zwijana lista wykładów w nawigacji ===== */
#nav details.lecs{margin:2px 0 2px}
#nav details.lecs>summary{list-style:none;cursor:pointer;padding:4px 10px;border-radius:7px;
  font-size:14px;color:var(--muted);font-weight:600;user-select:none}
#nav details.lecs>summary::-webkit-details-marker{display:none}
#nav details.lecs>summary::before{content:"▸";color:var(--accent2);display:inline-block;
  width:1em;transition:transform .15s}
#nav details.lecs[open]>summary::before{transform:rotate(90deg)}
#nav details.lecs>summary:hover{background:var(--soft)}
#nav details.lecs>a{padding-left:24px;font-size:14px}

/* ===== trener powtórek (fiszki) ===== */
.trainwrap{max-width:720px;margin:0 auto;padding:30px 30px 60px}
.trainwrap h1{font-size:26px;margin:0 0 .6em;border-bottom:3px solid var(--accent);padding-bottom:.25em;color:#1c180f}
.ttop{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:18px;font-size:14px}
#tfilter{padding:6px 9px;border:1px solid var(--line);border-radius:8px;background:var(--bg);font-size:14px;max-width:260px}
.tdue{display:flex;align-items:center;gap:5px;color:var(--muted);cursor:pointer}
.tprog{margin-left:auto;color:var(--ink)}
.tlink{background:none;border:none;color:var(--link);cursor:pointer;font-size:13px;text-decoration:underline}
.tempty{padding:40px 20px;text-align:center;color:var(--muted);font-size:16px;
  background:var(--panel);border:1px solid var(--line);border-radius:14px}
.tcard{background:var(--panel);border:1px solid var(--line);border-radius:16px;
  padding:26px 28px;box-shadow:0 6px 22px #0001;min-height:180px}
.tlec{font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--accent);font-weight:700;margin-bottom:10px}
.tq{font-size:20px;line-height:1.5;color:#23201b;font-weight:600}
.ta{margin-top:16px;padding-top:16px;border-top:1px dashed var(--line);font-size:16.5px;line-height:1.6;color:#3c352a}
.tbtns{margin:18px 0 22px;display:flex;justify-content:center}
.tbig{padding:13px 26px;border:none;border-radius:10px;background:var(--accent);color:#fff;
  font-size:16px;cursor:pointer;font-weight:600}
.tbig:hover{background:#634726}
.tgrade{display:flex;gap:12px}
.tgrade button{padding:13px 30px;border:1px solid var(--line);border-radius:10px;font-size:16px;
  cursor:pointer;font-weight:600;background:var(--panel)}
.tgrade .bad{color:#b03a2e;border-color:#e6b8b2}
.tgrade .bad:hover{background:#fceae8}
.tgrade .good{color:#1e7a47;border-color:#aedcbf}
.tgrade .good:hover{background:#e8f7ee}
.tgrade kbd,.tbig kbd{font-size:11px;opacity:.7;border:1px solid currentColor;border-radius:4px;padding:0 4px;margin-left:5px}
.tboxes{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.tbox{font-size:12px}
.tbl{color:var(--muted)}
.tbar{height:7px;background:var(--soft);border-radius:4px;overflow:hidden;margin-top:2px}
.tbar>div{height:100%;border-radius:4px}
.tbox.b1 .tbar>div{background:#c0392b}
.tbox.b2 .tbar>div{background:#e67e22}
.tbox.b3 .tbar>div{background:#e0b000}
.tbox.b4 .tbar>div{background:#7faa4a}
.tbox.b5 .tbar>div{background:#27ae60}
@media(max-width:860px){.trainwrap{padding:64px 16px 50px}.tprog{margin-left:0;width:100%}}

/* ===== przełącznik Basic / Pro ===== */
.modesw{display:flex;gap:4px;margin:2px 4px 12px;background:var(--soft);padding:3px;border-radius:10px}
.modesw button{flex:1;border:none;background:none;padding:6px 6px;border-radius:8px;cursor:pointer;
  font-size:13px;font-weight:700;color:var(--muted);line-height:1.15}
.modesw button i{display:block;font-style:normal;font-size:8.5px;font-weight:500;opacity:.75;letter-spacing:.02em}
html[data-mode="pro"] .modesw .mp{background:var(--accent);color:#fff}
html:not([data-mode="pro"]) .modesw .mb{background:#fff;color:var(--ink);box-shadow:0 1px 3px #0001}
/* w trybie Basic ukryj pozycje Pro */
html:not([data-mode="pro"]) .pronav{display:none !important}
/* plakietka PRO na stronach eksperymentalnych */
body[data-pro="1"] h1::after{content:"PRO · eksperymentalne";display:inline-block;margin-left:10px;
  font-size:11px;vertical-align:middle;background:var(--accent2);color:#fff;padding:2px 9px;
  border-radius:20px;font-weight:600;letter-spacing:.02em;white-space:nowrap}

/* ===== komparator różnicowy ===== */
.kwrap{max-width:980px;margin:0 auto;padding:30px 30px 60px}
.kwrap h1{font-size:26px;margin:0 0 .3em;border-bottom:3px solid var(--accent);padding-bottom:.25em;color:#1c180f}
.klead{color:var(--muted);margin:.2em 0 1em}
.ktop{display:flex;gap:12px;align-items:center;margin-bottom:18px}
#kq{flex:1;max-width:360px;padding:8px 12px;border:1px solid var(--line);border-radius:9px;background:var(--bg);font-size:14px}
#kq:focus{outline:none;border-color:var(--accent2)}
.kcount{color:var(--muted);font-size:13px}
.kgroup{margin:0 0 26px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px 18px 6px;box-shadow:0 4px 16px #0001}
.kgroup h3{margin:0 0 .2em;font-size:18px;color:var(--accent)}
.knote{margin:.1em 0 .8em;color:var(--muted);font-size:13.5px}
.ktab-wrap{overflow-x:auto}
.ktab{border-collapse:collapse;width:100%;font-size:14px}
.ktab th,.ktab td{border:1px solid var(--line);padding:9px 11px;vertical-align:top;text-align:left}
.ktab thead th{background:var(--soft);color:#1c180f;font-size:14.5px}
.ktab th.kdim{background:var(--soft);color:var(--accent);font-weight:700;white-space:nowrap;font-size:12px;
  text-transform:uppercase;letter-spacing:.02em;width:1%}
.ktab .kr-roznica td{background:#fbf6ee;font-weight:500}
.ktab .kr-pulapka td{color:#8a4b2b;font-size:13.5px}
.kempty{color:var(--muted);padding:30px;text-align:center}
@media(max-width:860px){.kwrap{padding:64px 14px 50px}.ktab{font-size:13px}}

/* ===== quiz różnicujący ===== */
.qwrap{max-width:720px;margin:0 auto;padding:30px 30px 60px}
.qwrap h1{font-size:26px;margin:0 0 .3em;border-bottom:3px solid var(--accent);padding-bottom:.25em;color:#1c180f}
.qtop{margin:6px 0 14px;color:var(--muted);font-size:14px}
.qcard2{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px 24px;box-shadow:0 6px 22px #0001}
.qoset{font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--accent);font-weight:700;margin-bottom:10px}
.qclue{font-size:18px;line-height:1.5;color:#23201b}
.qhint{margin-top:12px;color:var(--muted);font-size:14px}
.qopts{display:flex;flex-direction:column;gap:10px;margin:18px 0}
.qopt{text-align:left;padding:12px 16px;border:1px solid var(--line);border-radius:10px;background:var(--panel);
  font-size:15.5px;cursor:pointer;color:var(--ink)}
.qopt:hover:not(:disabled){background:var(--soft)}
.qopt kbd{font-size:11px;opacity:.6;border:1px solid currentColor;border-radius:4px;padding:0 5px;margin-right:6px}
.qopt.ok{background:#e8f7ee;border-color:#27ae60;color:#1e7a47;font-weight:600}
.qopt.bad{background:#fceae8;border-color:#c0392b;color:#b03a2e}
.qopt:disabled{cursor:default}
.qres{font-size:16px;font-weight:700;margin:6px 0 8px}
.qres.good{color:#1e7a47}.qres.bad{color:#b03a2e}
.qexpl{background:var(--soft);border-radius:10px;padding:11px 14px;font-size:14px;color:#3c352a;margin-bottom:14px}
.qnext{padding:11px 22px;border:none;border-radius:10px;background:var(--accent);color:#fff;font-size:15px;cursor:pointer;font-weight:600}
.qnext:hover{background:#634726}.qnext.alt{background:var(--accent2)}
.qsum{font-size:20px;font-weight:700;text-align:center;padding:20px;color:#1c180f}
@media(max-width:860px){.qwrap{padding:64px 16px 50px}}

/* ===== karty teoretyków ===== */
.kfwrap{max-width:980px;margin:0 auto;padding:30px 30px 60px}
.kfwrap h1{font-size:26px;margin:0 0 .3em;border-bottom:3px solid var(--accent);padding-bottom:.25em;color:#1c180f}
#kfq{flex:1;max-width:360px;padding:8px 12px;border:1px solid var(--line);border-radius:9px;background:var(--bg);font-size:14px}
#kfq:focus{outline:none;border-color:var(--accent2)}
.karty{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:8px}
.kcard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:0 3px 12px #0001}
.kname{font-size:17px;font-weight:700;color:var(--accent);margin-bottom:6px}
.kcontrib{font-size:14px;line-height:1.55;color:#3c352a}
.kchips{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}
.kchip{font-size:12px;background:var(--soft);color:var(--ink);padding:3px 9px;border-radius:20px;text-decoration:none}
.kchip:hover{background:var(--accent2);color:#fff;text-decoration:none}
.klec{margin-top:10px;font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.02em}
@media(max-width:860px){.kfwrap{padding:64px 14px 50px}}

/* ===== strony logowania / rejestracji / admin ===== */
body.authpage{display:block;background:var(--bg)}
.authwrap{max-width:440px;margin:8vh auto;padding:30px 28px;background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:0 8px 30px #0001}
.authwrap.wide{max-width:760px}
.authwrap h1{font-size:24px;margin:0 0 .4em;border:none;padding:0;color:#1c180f}
.authwrap h2{font-size:16px;color:var(--accent);margin:1.4em 0 .5em}
.authlead{color:var(--muted);font-size:14.5px;line-height:1.55;margin-bottom:1.2em}
.authwrap form{display:flex;flex-direction:column;gap:12px}
.authwrap label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted);font-weight:600}
.authwrap input{padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:15px;background:var(--bg)}
.authwrap input:focus{outline:none;border-color:var(--accent2)}
.authwrap button[type=submit]{padding:11px;border:none;border-radius:9px;background:var(--accent);color:#fff;font-size:15px;font-weight:600;cursor:pointer}
.authwrap button[type=submit]:hover{background:#634726}
.authwrap button:disabled{opacity:.6;cursor:default}
.authmsg{margin-top:14px;padding:11px 14px;border-radius:9px;font-size:14px;background:var(--soft);color:#3c352a}
.authmsg.ok{background:#e8f7ee;color:#1e7a47}
.authmsg.err{background:#fceae8;color:#b03a2e}
.authalt{margin-top:16px;font-size:13.5px;color:var(--muted)}
.adminbar{font-size:13px;color:var(--muted);margin-bottom:10px}
.atab{border-collapse:collapse;width:100%;font-size:13.5px;margin-bottom:10px}
.atab th,.atab td{border-bottom:1px solid var(--line);padding:8px 9px;text-align:left;vertical-align:middle}
.atab th{color:var(--accent);font-size:12px;text-transform:uppercase;letter-spacing:.02em}
.st{font-size:12px;padding:2px 8px;border-radius:20px}
.s-pending{background:#fdf0d8;color:#8a5a1a}.s-approved{background:#e8f7ee;color:#1e7a47}.s-rejected{background:#f0e8e6;color:#8a4b3a}
.acts{white-space:nowrap}
.ba{font-size:12px;padding:4px 9px;margin-left:4px;border:1px solid var(--line);border-radius:7px;background:var(--panel);cursor:pointer}
.ba.ok{border-color:#aedcbf;color:#1e7a47}.ba.del{border-color:#e6b8b2;color:#b03a2e}
.ba:hover{background:var(--soft)}
/* widżet konta w nawigacji */
#nav .acct{font-size:12.5px;color:var(--muted);background:var(--soft);border-radius:8px;padding:6px 10px;margin:0 4px 8px}
#nav .acct a{color:var(--link)}
#nav .acct span{font-weight:600;color:var(--ink)}
