/* ============ TOKENS — emerald + amber palette ============ */
:root{
  --primary:#0f5132; --primary-light:#157347; --accent:#d97706; --accent-2:#f59e0b;
  --bg:#faf9f6; --surface:#ffffff; --surface-2:#f5f4ef;
  --text:#1c1917; --muted:#78716c; --subtle:#a8a29e;
  --border:#e7e5e4; --border-soft:#efedea;
  --green:#15803d; --green-soft:#dcfce7;
  --red:#b91c1c; --red-soft:#fee2e2;
  --yellow:#ca8a04; --yellow-soft:#fef9c3;
  --shadow-sm:0 1px 2px rgba(28,25,23,.04), 0 1px 3px rgba(28,25,23,.06);
  --shadow-md:0 4px 10px rgba(28,25,23,.06), 0 2px 4px rgba(28,25,23,.04);
  --shadow-lg:0 12px 32px rgba(28,25,23,.10), 0 4px 8px rgba(28,25,23,.06);
  --radius-sm:6px; --radius:10px; --radius-lg:14px;
  --sidebar-bg:#1c2826; --sidebar-text:#9ca8a3; --sidebar-text-active:#ffffff;
  --sidebar-active-bg:rgba(217,119,6,.18); --sidebar-hover-bg:rgba(255,255,255,.04);
  --sidebar-accent:#d97706;
}
[data-theme="dark"]{
  --primary:#5eead4; --primary-light:#86efac; --accent:#fbbf24; --accent-2:#fcd34d;
  --bg:#0c0e0d; --surface:#15191a; --surface-2:#1a1d1e;
  --text:#f5f5f4; --muted:#a8a29e; --subtle:#78716c;
  --border:#27272a; --border-soft:#1f2122;
  --green:#4ade80; --green-soft:#0a2417;
  --red:#f87171; --red-soft:#2a0e0c;
  --yellow:#fbbf24; --yellow-soft:#2a1f08;
  --shadow-sm:0 1px 2px rgba(0,0,0,.30);
  --shadow-md:0 4px 12px rgba(0,0,0,.35);
  --shadow-lg:0 14px 36px rgba(0,0,0,.45);
  --sidebar-bg:#0a0c0b; --sidebar-text:#8a948f; --sidebar-text-active:#fbbf24;
  --sidebar-active-bg:rgba(251,191,36,.10); --sidebar-hover-bg:rgba(255,255,255,.03);
  --sidebar-accent:#fbbf24;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,sans-serif;
     background:var(--bg);color:var(--text);font-size:15px;line-height:1.55;
     -webkit-font-smoothing:antialiased;transition:background .2s,color .2s}
::selection{background:var(--accent);color:#fff}
a{color:var(--accent)}
a:hover{color:var(--accent-2)}
code{background:var(--surface-2);padding:2px 6px;border-radius:3px;font-size:12px;
     font-family:"SF Mono",Menlo,monospace;border:1px solid var(--border-soft);color:var(--primary)}

body[data-lang="sk"] [data-lang-en]{display:none}
body[data-lang="en"] [data-lang-sk]{display:none}

.app{display:flex;min-height:100vh}
aside{width:240px;flex:0 0 240px;background:var(--sidebar-bg);color:var(--sidebar-text);
      position:sticky;top:0;height:100vh;overflow-y:auto;
      display:flex;flex-direction:column;z-index:50;transition:transform .25s ease}
aside::-webkit-scrollbar{width:6px}
aside::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:3px}

.brand{padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.06)}
.brand-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.brand-text h1{font-size:17px;margin:0;color:#fff;font-weight:600;letter-spacing:.2px}
.brand-text .sub{font-size:10px;color:var(--sidebar-accent);margin-top:3px;text-transform:uppercase;letter-spacing:1.5px;font-weight:700}
.icon-btn{background:none;border:1px solid rgba(255,255,255,.10);color:#cfd6df;
          width:32px;height:32px;border-radius:7px;cursor:pointer;display:flex;
          align-items:center;justify-content:center;transition:all .2s;padding:0;flex:0 0 32px;box-shadow:none}
.icon-btn:hover{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.20);transform:none}
.icon-btn svg{width:16px;height:16px}
.lang-switch{display:flex;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
             border-radius:7px;overflow:hidden;font-size:11px;font-weight:600}
.lang-switch button{background:transparent;border:0;padding:5px 10px;color:#8a948f;cursor:pointer;
                    transition:all .15s;font:inherit;font-weight:600;box-shadow:none;letter-spacing:.5px}
.lang-switch button:hover{color:#fff;transform:none;box-shadow:none}
.lang-switch button.active{background:rgba(217,119,6,.20);color:var(--sidebar-accent)}

nav{padding:6px 0 24px;flex:1}
nav .group{padding:18px 22px 6px;font-size:10px;color:var(--sidebar-accent);text-transform:uppercase;
           letter-spacing:1.6px;font-weight:700;opacity:.7}
nav a{display:flex;align-items:center;gap:11px;padding:8px 22px;color:var(--sidebar-text);
      text-decoration:none;font-size:13.5px;border-left:2px solid transparent;
      transition:background .12s,color .12s,border-color .12s;font-weight:500}
nav a:hover{background:var(--sidebar-hover-bg);color:#fff}
nav a.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active);
             border-left-color:var(--sidebar-accent);font-weight:600}
nav a.active .nav-icon{color:var(--sidebar-text-active);opacity:1}
nav .nav-icon{width:16px;height:16px;flex:0 0 16px;opacity:.55;transition:opacity .12s}
nav a:hover .nav-icon{opacity:.9}
nav a.no-icon{padding-left:22px}
nav a.no-icon::before{content:'';display:inline-block;width:16px;flex:0 0 16px}
nav .kbd{margin-left:auto;font-size:10px;background:rgba(255,255,255,.06);
         padding:1px 6px;border-radius:3px;font-family:"SF Mono",Menlo,monospace;color:#6a7a78}

.mobile-header{display:none;position:sticky;top:0;background:var(--surface);
               border-bottom:1px solid var(--border);padding:10px 16px;z-index:40;
               justify-content:space-between;align-items:center;gap:10px}
.mobile-header .lang-switch{background:var(--surface-2);border-color:var(--border)}
.mobile-header .lang-switch button{color:var(--muted)}
.mobile-header .lang-switch button.active{background:var(--accent);color:#fff}
.hamburger{background:none;border:0;padding:8px;cursor:pointer;color:var(--text)}
.hamburger svg{width:22px;height:22px}
.backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:45;backdrop-filter:blur(2px)}
.backdrop.show{display:block}

main{flex:1;padding:36px 48px 80px;max-width:1100px;width:100%}

h1.title{color:var(--text);font-size:28px;margin:0 0 6px;font-weight:700;letter-spacing:-.3px}
h2{color:var(--text);font-size:21px;margin:32px 0 14px;font-weight:700;
   border-bottom:1px solid var(--border-soft);padding-bottom:8px}
h3{color:var(--primary);font-size:16px;margin:22px 0 10px;font-weight:600}
[data-theme="dark"] h3{color:var(--primary-light)}
h4{font-size:14px;margin:16px 0 8px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.4px}
.lead{color:var(--muted);font-size:15px;margin:0 0 24px;line-height:1.6}
p{margin:0 0 12px}
ul,ol{padding-left:22px;margin:8px 0 16px}
li{margin-bottom:5px}
blockquote{border-left:3px solid var(--accent);background:var(--surface-2);padding:14px 18px;
           margin:18px 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;
           color:var(--muted);font-style:italic}

.pill{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;
      font-weight:600;background:var(--surface-2);color:var(--muted);
      border:1px solid var(--border);margin-right:4px;margin-bottom:4px}
.pill.primary{background:var(--accent);color:#fff;border-color:transparent}
.pill.success{background:var(--green-soft);color:var(--green);border-color:transparent}
.pill.warn{background:var(--yellow-soft);color:#a07a06;border-color:transparent}
[data-theme="dark"] .pill.warn{color:#fbbf24}

.lang-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;
             background:var(--surface-2);border:1px solid var(--border);
             border-radius:var(--radius);padding:10px 14px;margin:0 0 18px;font-size:13px}
.lang-banner .left{display:flex;align-items:center;gap:8px;color:var(--muted)}
.lang-banner svg{width:16px;height:16px;flex:0 0 16px}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
      padding:20px;margin:14px 0;box-shadow:var(--shadow-sm)}
.card.highlight{border-color:var(--accent);box-shadow:0 0 0 3px rgba(217,119,6,.12),var(--shadow-md)}
[data-theme="dark"] .card.highlight{box-shadow:0 0 0 3px rgba(251,191,36,.15),var(--shadow-md)}
.grid{display:grid;gap:14px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}

table{width:100%;border-collapse:collapse;margin:14px 0;background:var(--surface);
      border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);
      font-size:14px;box-shadow:var(--shadow-sm)}
th{background:var(--surface-2);color:var(--text);text-align:left;padding:11px 14px;
   font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;
   border-bottom:1px solid var(--border)}
td{padding:10px 14px;border-top:1px solid var(--border-soft);vertical-align:top}
tr:hover td{background:var(--surface-2)}

input[type=text],input[type=number],input[type=date],input[type=file],textarea,select{
  width:100%;padding:8px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);
  font:inherit;font-size:14px;background:var(--surface);color:var(--text);
  transition:border-color .15s,box-shadow .15s}
input:focus,textarea:focus,select:focus{outline:0;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(217,119,6,.18)}
textarea{min-height:60px;resize:vertical;font-family:inherit}
label{display:block;font-size:11px;color:var(--muted);margin-bottom:4px;
      font-weight:600;text-transform:uppercase;letter-spacing:.6px}
.input-row{display:flex;gap:10px;align-items:flex-end;margin-bottom:12px;flex-wrap:wrap}
.input-row > div{flex:1;min-width:120px}

button{background:var(--primary);color:#fff;border:0;padding:9px 18px;
       border-radius:var(--radius-sm);font:inherit;font-weight:600;font-size:14px;
       cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm)}
button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);background:var(--primary-light)}
button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}
button.sec{background:var(--surface);color:var(--text);border:1px solid var(--border)}
button.sec:hover{background:var(--surface-2);border-color:var(--accent)}
button.danger{background:var(--red)}
button.ghost{background:transparent;color:var(--muted);box-shadow:none;padding:4px 10px;font-size:12px}
button.ghost:hover{background:var(--surface-2);color:var(--text);transform:none;box-shadow:none}

.check{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;
       border-radius:var(--radius-sm);margin-bottom:6px;cursor:pointer;
       transition:background .15s;background:var(--surface);border:1px solid var(--border-soft)}
.check:hover{background:var(--surface-2);border-color:var(--border)}
.check input{margin-top:3px;width:18px;height:18px;cursor:pointer;flex:0 0 18px;accent-color:var(--accent)}
.check label{font:inherit;font-size:14px;color:var(--text);margin:0;
             text-transform:none;letter-spacing:0;font-weight:400;flex:1;cursor:pointer}
.check.done{background:var(--green-soft);border-color:transparent}
.check.done label{text-decoration:line-through;color:var(--muted)}

.badge{display:inline-block;padding:3px 10px;border-radius:4px;font-size:12px;font-weight:600;white-space:nowrap}
.badge.win{background:var(--green-soft);color:var(--green)}
.badge.loss{background:var(--red-soft);color:var(--red)}

.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin:18px 0}
.stat{background:var(--surface);border:1px solid var(--border);
      border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);
      transition:transform .15s,box-shadow .15s}
.stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.stat .v{font-size:26px;font-weight:700;color:var(--text);line-height:1.1}
.stat .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:6px;font-weight:600}

.progress{height:8px;background:var(--border-soft);border-radius:4px;overflow:hidden;margin:6px 0 14px}
.progress > div{height:100%;background:linear-gradient(90deg,var(--accent),var(--primary));
                transition:width .4s ease;border-radius:4px}

/* ===== Sidebar nav groups (P03) ===== */
.nav-home{display:flex;align-items:center;gap:11px;padding:8px 22px;color:var(--sidebar-text);
          text-decoration:none;font-size:13.5px;font-weight:500;border-left:2px solid transparent;
          transition:background .12s,color .12s,border-color .12s}
.nav-home:hover{background:var(--sidebar-hover-bg);color:#fff}
.nav-home.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active);
                 border-left-color:var(--sidebar-accent);font-weight:600}
.nav-home .nav-icon{width:16px;height:16px;flex:0 0 16px;opacity:.55;transition:opacity .12s}
.nav-home:hover .nav-icon,.nav-home.active .nav-icon{opacity:1}
.nav-group-header{display:flex;align-items:center;gap:11px;width:100%;padding:8px 22px;
                  background:transparent;border:0;border-radius:0;border-left:2px solid transparent;
                  color:var(--sidebar-text);font:600 13.5px/1.4 inherit;cursor:pointer;
                  text-align:left;box-shadow:none;transition:background .12s,color .12s}
.nav-group-header:hover{background:var(--sidebar-hover-bg);color:#fff;transform:none;box-shadow:none}
.nav-group-header .nav-icon{width:16px;height:16px;flex:0 0 16px;opacity:.55;transition:opacity .12s}
.nav-group-header:hover .nav-icon{opacity:.9}
.nav-group-header .chevron{width:13px;height:13px;flex:0 0 13px;margin-left:auto;
                           opacity:.45;transition:transform .2s;pointer-events:none}
.nav-group.expanded .nav-group-header .chevron{transform:rotate(90deg)}
.nav-group-items{max-height:0;overflow:hidden;transition:max-height .25s ease}
.nav-group.expanded .nav-group-items{max-height:600px}
.nav-group-items a{padding:7px 22px 7px 36px!important}
.nav-group-items a .kbd{margin-left:auto}

/* ===== Dashboard redesign (P02) ===== */
.dash-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;font-weight:700;color:var(--muted)}
.hero-row{display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:14px;margin:18px 0}
.streak-card{}
.discipline-card{}
.today-action{background:linear-gradient(135deg,var(--accent),var(--primary));color:#fff;
              border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;
              box-shadow:var(--shadow-md)}
.today-action-btn{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);
                  color:#fff;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:600;
                  cursor:pointer;width:100%;margin-top:auto;transition:background .15s}
.today-action-btn:hover{background:rgba(255,255,255,.28)}
@media(max-width:768px){
  .hero-row{grid-template-columns:1fr}
  .today-action{order:-1}
  .streak-card .streak-emoji{font-size:18px!important}
}

section{display:none}
section.active{display:block;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0;align-items:center;
         background:var(--surface);border:1px solid var(--border);
         border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm)}
.toolbar input[type=text]{max-width:280px}

.toast-stack{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;
             gap:8px;z-index:1000;pointer-events:none}
.toast{background:var(--surface);color:var(--text);border:1px solid var(--border);
       padding:12px 18px;border-radius:var(--radius);box-shadow:var(--shadow-lg);
       font-weight:500;font-size:14px;animation:toastIn .25s ease;
       display:flex;align-items:center;gap:10px;min-width:200px;pointer-events:auto}
.toast.success{border-left:3px solid var(--green)}
.toast.error{border-left:3px solid var(--red)}
.toast.info{border-left:3px solid var(--accent)}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.toast.removing{animation:toastOut .25s ease forwards}
@keyframes toastOut{to{opacity:0;transform:translateX(20px)}}

/* ===== XP toast (P04) ===== */
.toast-xp{position:fixed;right:24px;padding:8px 16px;border-radius:20px;
          background:linear-gradient(135deg,var(--accent),var(--accent-2));
          color:#fff;font-weight:700;font-size:13px;
          box-shadow:0 8px 24px rgba(0,0,0,.22);
          animation:toastXpSlide 1.5s ease forwards;
          z-index:1001;pointer-events:none}
@keyframes toastXpSlide{
  0%{opacity:0;transform:translateY(20px)}
  20%{opacity:1;transform:translateY(0)}
  80%{opacity:1;transform:translateY(0)}
  100%{opacity:0;transform:translateY(-10px)}
}

/* ===== Level-up overlay (P04) ===== */
.level-up-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);
                  backdrop-filter:blur(4px);z-index:900;display:flex;
                  align-items:center;justify-content:center;animation:fadeIn .3s ease}
.level-up-overlay.hidden{display:none}
.level-up-box{background:var(--surface);border-radius:var(--radius-lg);
              padding:40px 48px;text-align:center;
              box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
              max-width:400px;width:90%}
.confetti-wrap{position:absolute;top:0;left:0;width:100%;height:100%;
               pointer-events:none;overflow:hidden}
.confetti-particle{position:absolute;top:-20px;width:10px;height:10px;
                   border-radius:2px;animation:confettiFall linear forwards}
@keyframes confettiFall{
  0%{opacity:1;transform:translateY(0) rotate(0deg)}
  100%{opacity:0;transform:translateY(320px) rotate(720deg)}
}
.level-up-icon{font-size:52px;margin-bottom:12px;position:relative;z-index:1}
.level-up-title{font-size:28px;font-weight:800;margin:0 0 12px;color:var(--text);position:relative;z-index:1}
.level-up-names{font-size:17px;font-weight:600;color:var(--text);margin-bottom:24px;
                display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:4px;
                position:relative;z-index:1}
.level-up-btn{background:linear-gradient(135deg,var(--accent),var(--accent-2));
              color:#fff;border:0;padding:12px 32px;border-radius:24px;
              font-size:15px;font-weight:700;cursor:pointer;position:relative;z-index:1;
              transition:transform .15s,box-shadow .15s;
              box-shadow:0 4px 16px rgba(217,119,6,.30)}
.level-up-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(217,119,6,.40)}

.empty{text-align:center;padding:50px 30px;color:var(--muted)}
.empty svg{width:56px;height:56px;color:var(--subtle);margin-bottom:14px;opacity:.7}
.empty h4{font-size:15px;color:var(--text);margin:0 0 8px;text-transform:none;letter-spacing:0}
.empty p{margin:0 0 14px;max-width:340px;display:inline-block}

.current-week{border-color:var(--accent)!important;
              box-shadow:0 0 0 3px rgba(217,119,6,.12),var(--shadow-md)!important}
.current-week .week-badge{background:var(--accent);color:#fff}

.equity-chart{background:var(--surface);border:1px solid var(--border);
              border-radius:var(--radius);padding:18px;margin:18px 0;box-shadow:var(--shadow-sm)}
.equity-chart svg{width:100%;height:auto;display:block}
.equity-chart .axis{stroke:var(--border)}
.equity-chart .grid-line{stroke:var(--border-soft)}
.equity-chart .line{fill:none;stroke-width:2.5;stroke-linejoin:round;stroke-linecap:round}
.equity-chart .dot{fill:var(--surface);stroke-width:2}

.pdf-embed{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
           overflow:hidden;box-shadow:var(--shadow-sm);margin:18px 0}
.pdf-embed iframe,.pdf-embed object{width:100%;height:80vh;min-height:600px;border:0;display:block}
.pdf-embed .fallback{padding:24px;text-align:center;color:var(--muted)}
.pdf-actions{display:flex;gap:10px;flex-wrap:wrap;padding:12px 14px;background:var(--surface-2);
             border-bottom:1px solid var(--border);align-items:center;font-size:13px}
.pdf-actions a.btn{background:var(--primary);color:#fff;text-decoration:none;padding:6px 12px;
                   border-radius:var(--radius-sm);font-weight:600;font-size:12px}

.small{font-size:12px;color:var(--muted)}
.row-actions{display:flex;gap:6px}
.filter-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.filter-row select,.filter-row input[type=text]{max-width:220px;font-size:13px}
.meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:8px}

/* ============ PDF PAGE GALLERY ============ */
.pdf-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin:18px 0}
.pdf-thumb{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
           overflow:hidden;box-shadow:var(--shadow-sm);cursor:zoom-in;transition:transform .15s,box-shadow .15s;position:relative}
.pdf-thumb:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.pdf-thumb img{width:100%;height:auto;display:block}
.pdf-thumb .page-label{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.7);color:#fff;
                       font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:200;display:none;
          align-items:center;justify-content:center;padding:40px;cursor:zoom-out}
.lightbox.show{display:flex}
.lightbox img{max-width:100%;max-height:100%;border-radius:6px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox .lb-close{position:absolute;top:18px;right:24px;color:#fff;background:none;border:0;
                    font-size:32px;cursor:pointer;line-height:1;padding:0}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);
                  color:#fff;border:0;width:48px;height:48px;border-radius:50%;cursor:pointer;font-size:24px;
                  display:flex;align-items:center;justify-content:center}
.lightbox .lb-nav:hover{background:rgba(255,255,255,.25)}
.lightbox .lb-prev{left:18px} .lightbox .lb-next{right:18px}
.lightbox .lb-counter{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
                      color:#fff;font-size:13px;background:rgba(0,0,0,.5);padding:6px 14px;border-radius:14px}

/* ============ STACK CALLOUT ============ */
.stack-callout{background:linear-gradient(135deg,var(--primary) 0%,#0a3823 100%);color:#fff;
               border-radius:var(--radius-lg);padding:24px;margin:20px 0;box-shadow:var(--shadow-lg);
               position:relative;overflow:hidden}
[data-theme="dark"] .stack-callout{background:linear-gradient(135deg,#0d2818 0%,#061410 100%);
               border:1px solid var(--primary)}
.stack-callout::before{content:'';position:absolute;top:0;right:0;width:200px;height:100%;
               background:radial-gradient(circle at top right,rgba(217,119,6,.25),transparent 70%);pointer-events:none}
.stack-callout h3{color:var(--accent);margin:0 0 12px;font-size:14px;text-transform:uppercase;letter-spacing:1.5px}
[data-theme="dark"] .stack-callout h3{color:var(--accent-2)}
.stack-callout .stack-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:20px;font-weight:700;margin-bottom:10px}
.stack-callout .stack-row .item{background:rgba(255,255,255,.10);padding:8px 16px;border-radius:8px;font-size:16px}
.stack-callout .stack-row .plus{color:var(--accent);font-weight:400;font-size:22px}
[data-theme="dark"] .stack-callout .stack-row .plus{color:var(--accent-2)}
.stack-callout p{margin:0;color:rgba(255,255,255,.85);font-size:14px}

/* ============ SEARCH OVERLAY ============ */
.search-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);
                z-index:150;display:none;align-items:flex-start;justify-content:center;padding-top:80px}
.search-overlay.show{display:flex}
.search-box{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:640px;
            box-shadow:var(--shadow-lg);overflow:hidden}
.search-box input{width:100%;padding:18px 22px;border:0;font-size:18px;background:transparent;
                  color:var(--text);border-bottom:1px solid var(--border)}
.search-box input:focus{outline:0;box-shadow:none}
.search-results{max-height:60vh;overflow-y:auto}
.search-results .sr-item{padding:12px 22px;border-bottom:1px solid var(--border-soft);cursor:pointer}
.search-results .sr-item:hover{background:var(--surface-2)}
.search-results .sr-section{font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:4px}
.search-results .sr-snippet{font-size:13px;color:var(--text);line-height:1.4}
.search-results .sr-snippet mark{background:var(--yellow-soft);color:inherit;padding:0 2px;border-radius:2px}
.search-results .sr-empty{padding:30px;text-align:center;color:var(--muted)}

/* ============ STREAK & PROGRESS BADGES ============ */
.streak-badge{display:inline-flex;align-items:center;gap:6px;background:var(--yellow-soft);
              color:var(--yellow);padding:6px 12px;border-radius:14px;font-size:12px;font-weight:700;
              border:1px solid var(--yellow)}
[data-theme="dark"] .streak-badge{color:#fbbf24}
.section-progress{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);
                  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);
                  padding:8px 14px;margin:0 0 18px;width:fit-content}
.section-progress button{background:var(--primary);color:#fff;border:0;padding:5px 12px;border-radius:4px;
                         cursor:pointer;font-size:12px;font-weight:600}
.section-progress.done{background:var(--green-soft);border-color:transparent;color:var(--green)}
.section-progress.done button{background:var(--green)}

/* ============ POMODORO TIMER ============ */
.pomodoro{position:fixed;bottom:20px;left:20px;background:var(--surface);border:1px solid var(--border);
          border-radius:var(--radius);padding:12px 16px;box-shadow:var(--shadow-md);
          display:flex;align-items:center;gap:10px;font-size:13px;z-index:90}
.pomodoro.hidden{display:none}
.pomodoro .timer{font-family:"SF Mono",Menlo,monospace;font-weight:700;font-size:18px;color:var(--accent);min-width:54px}
.pomodoro button{padding:4px 10px;font-size:12px;background:var(--surface-2);color:var(--text);border:1px solid var(--border);box-shadow:none}
.pomodoro button:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:none;box-shadow:none}
.pomodoro .label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}

/* ============ FLOATING NEXT/PREV ============ */
.floating-nav{display:flex;justify-content:space-between;gap:14px;margin:32px 0 0;padding-top:24px;border-top:1px solid var(--border-soft)}
.floating-nav a{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);
                border-radius:var(--radius);padding:10px 16px;text-decoration:none;color:var(--text);
                font-size:14px;font-weight:600;flex:1;transition:all .15s;box-shadow:var(--shadow-sm)}
.floating-nav a:hover{border-color:var(--accent);background:var(--surface-2)}
.floating-nav .fn-prev{justify-content:flex-start}
.floating-nav .fn-next{justify-content:flex-end}
.floating-nav .fn-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.floating-nav .fn-title{font-size:14px}

/* ============ LEVEL TOGGLE ============ */
body[data-level="beg"]    [data-level="adv"],
body[data-level="beg"]    [data-level="pro"],
body[data-level="adv"]    [data-level="pro"]{display:none!important}
.level-switch{display:flex;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
              border-radius:7px;overflow:hidden;font-size:11px;font-weight:600;margin-top:8px}
.level-switch button{background:transparent;border:0;padding:6px 0;color:#8a948f;cursor:pointer;
                     transition:all .15s;font:inherit;font-weight:600;box-shadow:none;letter-spacing:.5px;flex:1}
.level-switch button:hover{color:#fff;transform:none;box-shadow:none}
.level-switch button.active{background:rgba(217,119,6,.20);color:var(--sidebar-accent)}
.brand .level-label{font-size:10px;color:#5a6a7d;text-transform:uppercase;letter-spacing:1px;margin-top:10px}

/* ============ MARKETS CLOCK ============ */
.markets-clock{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
               padding:14px 16px;margin:14px 0 18px;box-shadow:var(--shadow-sm);
               display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.markets-clock .now{font-family:"SF Mono",Menlo,monospace;font-weight:700;font-size:15px;color:var(--text)}
.markets-clock .session{display:flex;gap:8px;flex-wrap:wrap;flex:1;justify-content:center}
.markets-clock .ses{padding:5px 12px;border-radius:14px;font-size:12px;font-weight:600;background:var(--surface-2);color:var(--muted);border:1px solid var(--border)}
.markets-clock .ses.active{background:var(--accent);color:#fff;border-color:transparent;box-shadow:0 0 0 3px rgba(217,119,6,.15)}
.markets-clock .next{font-size:12px;color:var(--muted)}
.markets-clock .next b{color:var(--text)}

/* ============ CME TABLE / SIZER ============ */
.contract-table{font-size:13px}
.contract-table td{padding:8px 12px}
.contract-table .sym{font-weight:700;color:var(--primary)}
[data-theme="dark"] .contract-table .sym{color:var(--primary-light)}
.sizer-result{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);
              padding:18px;margin:14px 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
.sizer-result .cell{text-align:center}
.sizer-result .cell .v{font-size:22px;font-weight:700;color:var(--text);line-height:1.1}
.sizer-result .cell .l{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px;font-weight:600}
.sizer-result .cell.warn .v{color:var(--red)}
.sizer-result .cell.good .v{color:var(--green)}

/* ============ MISTAKE TAGS ============ */
.mistake-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.mistake-tags .tag-chip{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;
                        background:var(--surface-2);color:var(--muted);border:1px solid var(--border);cursor:pointer;
                        transition:all .12s;user-select:none}
.mistake-tags .tag-chip:hover{border-color:var(--accent)}
.mistake-tags .tag-chip.active{background:var(--red-soft);color:var(--red);border-color:var(--red)}

/* ============ ANALYTICS BREAKDOWN ============ */
.breakdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
           padding:16px;margin:12px 0;box-shadow:var(--shadow-sm)}
.breakdown h4{margin:0 0 10px;text-transform:none;letter-spacing:0;font-size:14px;color:var(--text)}
.breakdown table{margin:0;font-size:13px;box-shadow:none;border:0}
.breakdown th{padding:6px 10px;font-size:11px}
.breakdown td{padding:6px 10px}
.breakdown .bar{display:inline-block;height:6px;background:var(--green);border-radius:3px;vertical-align:middle;margin-right:6px;min-width:2px}
.breakdown .bar.neg{background:var(--red)}

/* ============ ANDREJ + UČEBNICA ENHANCEMENTS ============ */
.concept-card{background:var(--surface);border-left:4px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;
              padding:16px 20px;margin:16px 0;box-shadow:var(--shadow-sm)}
.concept-card .label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:6px}
.concept-card h4{margin-top:0;text-transform:none;letter-spacing:0;font-size:16px}

.warn-box{background:var(--yellow-soft);border:1px solid var(--yellow);border-left:4px solid var(--yellow);
          border-radius:var(--radius-sm);padding:14px 18px;margin:16px 0;color:#7c5e0c}
[data-theme="dark"] .warn-box{color:#fbbf24}
.warn-box::before{content:'⚠ ';font-weight:700}

.tip-box{background:var(--green-soft);border:1px solid var(--green);border-left:4px solid var(--green);
         border-radius:var(--radius-sm);padding:14px 18px;margin:16px 0;color:#0f5132}
[data-theme="dark"] .tip-box{color:#4ade80}
.tip-box::before{content:'💡 ';font-weight:700}

.numbered-flow{counter-reset:flow-step;margin:18px 0}
.numbered-flow .step{position:relative;padding:18px 20px 18px 60px;background:var(--surface);
                     border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;
                     counter-increment:flow-step;box-shadow:var(--shadow-sm)}
.numbered-flow .step::before{content:counter(flow-step);position:absolute;left:14px;top:14px;
                             width:32px;height:32px;background:var(--accent);color:#fff;border-radius:50%;
                             display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px}
.numbered-flow .step h4{margin:0 0 6px;text-transform:none;letter-spacing:0;font-size:16px;color:var(--text)}
.numbered-flow .step p:last-child{margin-bottom:0}

@media(max-width:900px){
  .mobile-header{display:flex}
  aside{position:fixed;left:0;top:0;transform:translateX(-100%);box-shadow:var(--shadow-lg)}
  aside.open{transform:translateX(0)}
  main{padding:20px 18px 60px;max-width:100%}
  h1.title{font-size:22px}
  h2{font-size:18px}
  .input-row{flex-direction:column;gap:8px}
  .input-row > div{flex:1 1 100%;min-width:0}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .pdf-embed iframe,.pdf-embed object{height:70vh;min-height:500px}
}
@media print{aside,.mobile-header,.toast-stack{display:none!important}
  main{max-width:100%;padding:0}section{display:block!important}}

/* ============ NEON BORDER (login box) ============ */
@property --neon-angle {
  syntax: '<angle>';
  inherits: false;
  initial-value: 0deg;
}
@keyframes neon-spin { to { --neon-angle: 360deg; } }

/* ============ AUTH ============ */
.login-overlay{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;
               padding:20px;background:#070b13;overflow:hidden;animation:fadeIn .3s ease}
.login-overlay.hidden{display:none}

/* Animated candle background (canvas) */
.login-bg{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:1}

/* Jemný vignette aby login box „vystúpil" — výrazne menší overlay než predtým */
.login-overlay::after{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse 60% 50% at center,rgba(7,11,19,.55) 0%,rgba(7,11,19,.15) 50%,transparent 100%)}

/* Login box with neon animated border */
.login-box{position:relative;z-index:2;
  background:linear-gradient(#0e1622,#0e1622) padding-box,
             conic-gradient(from var(--neon-angle),
               transparent 0%, transparent 60%,
               #d97706 74%, #fbbf24 79%, #d97706 84%,
               transparent 98%) border-box;
  border:2px solid transparent; border-radius:18px;
  animation:neon-spin 4s linear infinite;
  padding:36px 32px; box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 60px rgba(217,119,6,.15);
  width:100%; max-width:380px; color:#fff}
.login-brand{text-align:center;margin-bottom:24px}
.login-brand h1{font-size:26px;color:#fff;margin:0 0 4px;font-weight:700;letter-spacing:.3px}
.login-brand .sub{font-size:11px;color:#fbbf24;text-transform:uppercase;letter-spacing:3px;font-weight:700}
.login-box form label{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:#9aa4b2;
                      margin-top:18px;display:block;font-weight:600}
.login-box form input{margin-top:6px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);
                      color:#fff;padding:10px 12px;border-radius:8px;font-size:14px;width:100%}
.login-box form input:focus{outline:0;border-color:#d97706;box-shadow:0 0 0 3px rgba(217,119,6,.20);background:rgba(255,255,255,.06)}
.login-box form button{width:100%;margin-top:22px;background:linear-gradient(135deg,#d97706,#fbbf24);
                       border:0;color:#0e1622;padding:12px;border-radius:8px;font-weight:700;font-size:14px;
                       cursor:pointer;letter-spacing:.5px;transition:transform .15s,box-shadow .15s}
.login-box form button:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(251,191,36,.30)}
.login-error{color:#ff6b5b;font-size:13px;min-height:18px;margin-top:10px}

.user-widget{display:flex;align-items:center;gap:10px;padding:10px 12px;margin:12px 0 0;
             background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:8px}
.user-widget[hidden]{display:none}

/* ===== XP widget (P04) ===== */
.xp-widget{padding:10px 12px;margin-top:8px;background:rgba(255,255,255,.04);
           border-radius:8px;border:1px solid rgba(255,255,255,.06)}
.xp-widget[hidden]{display:none}
.xp-level{font-size:12px;color:var(--sidebar-accent);font-weight:700;margin-bottom:6px}
.xp-bar{height:6px;background:rgba(255,255,255,.08);border-radius:3px;overflow:hidden;margin-bottom:4px}
.xp-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));
         transition:width .4s ease;border-radius:3px}
.xp-meta{font-size:10px;color:var(--sidebar-text);text-align:right;opacity:.7}
.user-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
             font-weight:700;font-size:13px;color:#fff;flex:0 0 32px}
.user-meta{flex:1;min-width:0}
.user-name{font-size:13px;font-weight:600;color:#fff;line-height:1.2}
.user-role{font-size:10px;color:var(--sidebar-accent);text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-top:2px}

body[data-role="guest"] [data-deny~="guest"]{display:none!important}

/* ============ BOOK CARDS ============ */
.book-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
           overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s;
           display:flex;gap:18px;padding:18px;cursor:pointer;margin:14px 0}
.book-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.book-cover{width:120px;flex:0 0 120px;height:170px;border-radius:8px;color:#fff;
            display:flex;align-items:flex-end;padding:14px;font-weight:700;font-size:15px;
            line-height:1.25;background:linear-gradient(135deg,var(--cover-c1,#0f5132),var(--cover-c2,#d97706));
            position:relative;overflow:hidden;box-shadow:inset 0 -40px 40px rgba(0,0,0,.3)}
.book-cover::before{content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.18),transparent 60%)}
.book-info{flex:1;display:flex;flex-direction:column}
.book-info h3{margin:0 0 4px;font-size:18px;color:var(--text)}
.book-info .author{font-size:13px;color:var(--muted);margin-bottom:10px}
.book-info .note{font-size:13px;color:var(--muted);margin-bottom:14px;line-height:1.5}
.book-progress{margin-top:auto}
.book-progress-bar{height:6px;background:var(--border-soft);border-radius:3px;overflow:hidden}
.book-progress-bar > div{height:100%;background:linear-gradient(90deg,var(--accent),var(--primary));
                         transition:width .4s ease;border-radius:3px}
.book-progress-text{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);
                    margin-top:6px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.book-actions{display:flex;gap:8px;margin-top:10px}

/* ============ PDF READER (full-screen) ============ */
.book-reader{position:fixed;inset:0;background:#000;z-index:250;display:flex;flex-direction:column;
             animation:fadeIn .25s ease}
.book-reader.hidden{display:none}
.br-bar{display:flex;align-items:center;gap:14px;padding:12px 18px;background:rgba(0,0,0,.6);
        backdrop-filter:blur(10px);color:#fff;border-bottom:1px solid rgba(255,255,255,.08);z-index:5}
.br-title{flex:1;font-weight:600;font-size:14px;text-align:center;color:#fff}
.br-pageinfo{display:flex;align-items:center;gap:8px;font-size:13px;color:#cbd5e1}
.br-pageinfo .br-sep{color:#5a6a7d}
.br-btn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10);color:#fff;
        padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;
        transition:background .15s;font-family:inherit;box-shadow:none}
.br-btn:hover{background:rgba(217,119,6,.30);border-color:#d97706;transform:none;box-shadow:none}
.br-btn.br-bm{background:transparent}
.br-canvas-wrap{flex:1;overflow:auto;display:flex;align-items:flex-start;justify-content:center;
                padding:30px 20px;background:#1a1a1a}
.br-canvas-wrap canvas{box-shadow:0 20px 60px rgba(0,0,0,.5);background:#fff;border-radius:4px}
.br-nav{position:fixed;bottom:60px;left:0;right:0;display:flex;justify-content:space-between;
        padding:0 20px;pointer-events:none;z-index:6}
.br-arrow{pointer-events:auto;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.10);
          color:#fff;width:56px;height:56px;border-radius:50%;font-size:30px;line-height:1;cursor:pointer;
          font-weight:300;transition:all .15s;box-shadow:0 8px 20px rgba(0,0,0,.40)}
.br-arrow:hover{background:rgba(217,119,6,.85);border-color:#fbbf24;transform:none}
.br-progress{position:fixed;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,.05);z-index:7}
.br-progress > div{height:100%;background:linear-gradient(90deg,#d97706,#fbbf24);transition:width .3s}
.br-status{position:fixed;bottom:12px;left:20px;color:#9aa4b2;font-size:11px;letter-spacing:.5px;z-index:7}

@media(max-width:768px){
  .br-canvas-wrap{padding:8px 4px}
  .br-arrow{width:44px;height:44px;font-size:22px}
  .br-nav{bottom:30px}
  .book-cover{width:96px;flex:0 0 96px;height:140px}
}
