/* Frontend styles for NKPP (scoped) */
.nk-wrap, .nk-wrap *{ box-sizing:border-box; }
.nk-wrap{
  /* Try to inherit Foxiz/theme variables when available, otherwise use safe defaults */
  --card: var(--rb-bg, #ffffff);
  --card2: var(--rb-soft-bg, #f7f8fb);
  --text: var(--rb-text, #0b1220);
  --muted: var(--rb-meta, rgba(11,18,32,0.74));
  --border: var(--rb-border, rgba(11,18,32,0.14));
  --primary: var(--rb-accent, #8b5cf6);
  --radius:16px;
  --shadow:0 10px 24px rgba(11,18,32,0.10);
  --nk-score-bg: rgba(11,18,32,0.12);
  --nk-score-border: rgba(11,18,32,0.18);
  --nk-soft: rgba(11,18,32,0.06);

  --c1:#60a5fa;
  --c2:#f59e0b;
  --c3:#a78bfa;

  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
  color: var(--text);
  color-scheme: light;
}

/* OS-level dark mode */
@media (prefers-color-scheme: dark){
  .nk-wrap{
    --card: rgba(15,23,42,0.96);
    --card2: rgba(2,6,23,0.60);
    --text: rgba(255,255,255,0.94);
    --muted: rgba(255,255,255,0.72);
    --border: rgba(255,255,255,0.18);
    --shadow:0 18px 36px rgba(0,0,0,0.35);
  --nk-score-bg: rgba(255,255,255,0.10);
  --nk-score-border: rgba(255,255,255,0.18);
  --nk-soft: rgba(255,255,255,0.06);
    color-scheme: dark;
  }
}

/* Theme-level dark mode (Foxiz + common variants) */
html.dark-mode .nk-wrap, body.dark-mode .nk-wrap,
html.is-dark .nk-wrap, body.is-dark .nk-wrap,
html.rb-dark .nk-wrap, body.rb-dark .nk-wrap,
html.rb-dark-mode .nk-wrap, body.rb-dark-mode .nk-wrap,
html.dark .nk-wrap, body.dark .nk-wrap,
[data-theme="dark"] .nk-wrap, body[data-theme="dark"] .nk-wrap, html[data-theme="dark"] .nk-wrap,
[data-color-scheme="dark"] .nk-wrap, body[data-color-scheme="dark"] .nk-wrap, html[data-color-scheme="dark"] .nk-wrap{
  --card: rgba(15,23,42,0.96);
  --card2: rgba(2,6,23,0.60);
  --text: rgba(255,255,255,0.94);
  --muted: rgba(255,255,255,0.72);
  --border: rgba(255,255,255,0.18);
  --shadow:0 18px 36px rgba(0,0,0,0.35);
  --nk-score-bg: rgba(255,255,255,0.10);
  --nk-score-border: rgba(255,255,255,0.18);
  --nk-soft: rgba(255,255,255,0.06);
  color-scheme: dark;
}

/* Theme-level explicit light mode (if theme adds it) */
html.light-mode .nk-wrap, body.light-mode .nk-wrap,
html.is-light .nk-wrap, body.is-light .nk-wrap,
[data-theme="light"] .nk-wrap, body[data-theme="light"] .nk-wrap, html[data-theme="light"] .nk-wrap,
[data-color-scheme="light"] .nk-wrap, body[data-color-scheme="light"] .nk-wrap, html[data-color-scheme="light"] .nk-wrap{
  --card: #ffffff;
  --card2:#f7f8fb;
  --text:#0b1220;
  --muted:rgba(11,18,32,0.74);
  --border:rgba(11,18,32,0.14);
  --shadow:0 10px 24px rgba(11,18,32,0.10);
  color-scheme: light;
}

/* JS-assisted mode detection (fallback when theme doesn't expose classes) */
.nk-wrap.nk-mode-dark{
  --card: rgba(15,23,42,0.96);
  --card2: rgba(2,6,23,0.60);
  --text: rgba(255,255,255,0.94);
  --muted: rgba(255,255,255,0.72);
  --border: rgba(255,255,255,0.18);
  --shadow:0 18px 36px rgba(0,0,0,0.35);
  --nk-score-bg: rgba(255,255,255,0.10);
  --nk-score-border: rgba(255,255,255,0.18);
  --nk-soft: rgba(255,255,255,0.06);
  color-scheme: dark;
}
.nk-wrap.nk-mode-light{
  --card: #ffffff;
  --card2:#f7f8fb;
  --text:#0b1220;
  --muted:rgba(11,18,32,0.74);
  --border:rgba(11,18,32,0.14);
  --shadow:0 10px 24px rgba(11,18,32,0.10);
  color-scheme: light;
}

.nk-shell{ max-width: 980px; margin: 0 auto; display:grid; grid-template-columns:1fr; gap:14px; }
.nk-card{ background:var(--card); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow); padding:16px; overflow:hidden; }
.nk-card h2{ margin:0 0 10px 0; font-size:18px; letter-spacing:.2px; }
.nk-sub{ color:var(--muted); font-size:13px; margin-top:-2px; margin-bottom:12px; }

.nk-form{ display:grid; grid-template-columns:1fr; gap:12px; }
@media(min-width: 640px){
  .nk-form.two{ grid-template-columns: 1fr 1fr; }
  .nk-full{ grid-column: 1 / -1; }
}
.nk-field label{ display:block; font-size:13px; color:var(--muted); margin-bottom:6px; }
.nk-input, .nk-select{
  width:100%;
  border-radius:12px;
  border:1px solid var(--border);
  background: var(--card2);
  color: var(--text);
  outline:none;
  transition: border-color .15s ease, transform .15s ease;
  padding: 10px 12px;
}
.nk-input:focus, .nk-select:focus{ border-color: rgba(139,92,246,.55); transform: translateY(-1px); }
.nk-invalid{ border-color: rgba(239,68,68,.65) !important; }
.nk-select{ appearance:auto; }

@media (prefers-color-scheme: dark){ .nk-select option{ color:##000000; } }

.nk-help{ font-size:12px; color: rgba(239,68,68,.9); margin-top: 6px; }
.nk-alert{ border:1px solid rgba(239,68,68,.28); background: rgba(239,68,68,.08); border-radius:14px; padding:10px 12px; margin-bottom:12px; }
.nk-alert ul{ margin:8px 0 0 18px; }

.nk-toggles{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
@media (max-width:520px){ .nk-toggles{ grid-template-columns:1fr; } }
.nk-togglebox{ position:relative; min-width:0; }
.nk-toggle-input{ position:absolute; opacity:0; width:1px; height:1px; pointer-events:none; }
.nk-toggle-label{
  display:grid; grid-template-columns:46px 1fr; align-items:center; gap:12px;
  padding:12px; border:1px solid var(--border); border-radius:14px;
  background: rgba(11,18,32,0.04); cursor:pointer; width:100%;
}
@media (prefers-color-scheme: dark){ .nk-toggle-label{ background: rgba(255,255,255,0.06); } }
.nk-switch{ width:46px; height:28px; border-radius:999px; border:1px solid var(--border); background: rgba(11,18,32,0.10); position:relative; }
@media (prefers-color-scheme: dark){ .nk-switch{ background: rgba(255,255,255,0.18); } }
.nk-switch::after{ content:""; width:22px; height:22px; border-radius:999px; background:#fff; position:absolute; top:2px; left:2px; box-shadow:0 2px 10px rgba(0,0,0,0.22); transition:transform .16s ease; }
.nk-toggle-input:checked + .nk-toggle-label{ border-color: rgba(139,92,246,.55); background: rgba(139,92,246,.08); }
.nk-toggle-input:checked + .nk-toggle-label .nk-switch{ background: rgba(139,92,246,.55); border-color: rgba(139,92,246,.55); }
.nk-toggle-input:checked + .nk-toggle-label .nk-switch::after{ transform: translateX(18px); }
.nk-toggle-text strong{ display:block; font-size:13px; line-height:1.2; }
.nk-toggle-text small{ display:block; font-size:12px; color:var(--muted); margin-top:2px; line-height:1.2; }

.nk-accordion{ border:1px solid var(--border); border-radius:14px; overflow:hidden; }
.nk-acc-head{ padding:10px 12px; display:flex; justify-content:space-between; align-items:center; cursor:pointer; background: rgba(11,18,32,0.04); }
@media (prefers-color-scheme: dark){ .nk-acc-head{ background: rgba(255,255,255,0.06); } }
.nk-acc-body{ display:none; border-top:1px solid var(--border); padding:12px; }
.nk-acc-open .nk-acc-body{ display:block; }

.nk-btn{
  width:100%;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:11px 14px; border-radius:14px;
  border:1px solid rgba(139,92,246,.55);
  background: rgba(139,92,246,.14);
  color: var(--text); cursor:pointer; font-weight:800; letter-spacing:.2px;
  transition:transform .12s ease, background .12s ease;
}
.nk-btn:hover{ transform: translateY(-1px); background: rgba(139,92,246,.22); }

.nk-results{ animation:nkFade .28s ease both; }
@keyframes nkFade{ from{ opacity:0; transform: translateY(6px);} to{ opacity:1; transform: translateY(0);} }

.nk-badge{
  display:inline-flex; align-items:center; gap:8px; padding:6px 10px; border-radius:999px;
  border:1px solid var(--border); background: rgba(11,18,32,0.04); font-size:13px; margin:4px 6px 4px 0;
}
@media (prefers-color-scheme: dark){ .nk-badge{ background: rgba(255,255,255,0.06); } }
.nk-ok{ border-color: rgba(34,197,94,.35); background: rgba(34,197,94,.10); }
.nk-bad{ border-color: rgba(239,68,68,.35); background: rgba(239,68,68,.10); }

.nk-kpi{ display:grid; grid-template-columns:1fr; gap:10px; }
@media(min-width:640px){ .nk-kpi{ grid-template-columns:1fr 1fr; } }
.nk-k{ background: rgba(11,18,32,0.04); border:1px solid var(--border); border-radius:14px; padding:10px 12px; }
@media (prefers-color-scheme: dark){ .nk-k{ background: rgba(255,255,255,0.06); } }
.nk-k .nk-t{ font-size:12px; color:var(--muted); }
.nk-k .nk-v{ font-size:20px; font-weight:900; margin-top:2px; }
.nk-k .nk-s{ font-size:12px; color:var(--muted); margin-top:2px; }

.nk-break{ display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.nk-chip{ padding:6px 10px; border-radius:999px; border:1px solid var(--border); background: rgba(11,18,32,0.04); font-size:12px; }
@media (prefers-color-scheme: dark){ .nk-chip{ background: rgba(255,255,255,0.06); } }

/* Tabs */
.nk-tabs{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px; }
.nk-tab{ padding:8px 10px; border-radius:999px; border:1px solid var(--border); background: rgba(11,18,32,0.04); color:var(--text); font-size:13px; cursor:pointer; }
@media (prefers-color-scheme: dark){ .nk-tab{ background: rgba(255,255,255,0.06); } }
.nk-tab.active{ border-color: rgba(139,92,246,.55); background: rgba(139,92,246,.12); }
.nk-panel{ display:none; }
.nk-panel.active{ display:block; }

.nk-section{ margin-top:14px; border:1px solid var(--border); border-radius:16px; padding:14px; background: rgba(11,18,32,0.02); }
@media (prefers-color-scheme: dark){
  .nk-section{ background: rgba(255,255,255,0.03); }
}
.nk-section-head{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:10px; }
.nk-section-badge{ display:inline-flex; align-items:center; padding:4px 10px; border-radius:999px; font-size:11px; letter-spacing:.08em; text-transform:uppercase; font-weight:900; border:1px solid var(--border); background: var(--nk-soft); }
.nk-section-title{ margin:6px 0 0 0; font-size:16px; font-weight:900; }
.nk-section-sub{ margin:4px 0 0 0; font-size:12px; color: var(--muted); }
.nk-section-personal .nk-section-badge{ border-color: rgba(59,130,246,.45); background: rgba(59,130,246,.10); }
.nk-section-partner .nk-section-badge{ border-color: rgba(236,72,153,.45); background: rgba(236,72,153,.10); }

.nk-partner-split{ display:grid; gap:12px; }
@media(min-width:740px){ .nk-partner-split{ grid-template-columns:1fr 1fr; } }
.nk-partner-col{ border:1px solid var(--border); border-radius:14px; padding:12px; background: rgba(255,255,255,.45); }
@media (prefers-color-scheme: dark){
  .nk-partner-col{ background: rgba(255,255,255,.04); }
}
.nk-partner-meta{ font-size:12px; color: var(--muted); margin-bottom:6px; }
.nk-partner-h{ margin:0 0 8px 0; font-size:14px; font-weight:900; }
.nk-section-partner .nk-partner-col{ border-color: rgba(236,72,153,.20); }

/* Share */
.nk-share{ margin-top: 12px; display:grid; grid-template-columns:1fr; gap:10px; }
.nk-share-row{ display:flex; gap:10px; flex-wrap:wrap; }
.nk-share input{ flex:1 1 320px; }
.nk-copy{ flex:0 0 auto; padding:11px 14px; border-radius:14px; border:1px solid var(--border); background: rgba(11,18,32,0.04); cursor:pointer; font-weight:800; color:var(--text); }
@media (prefers-color-scheme: dark){ .nk-copy{ background: rgba(255,255,255,0.06); } }

/* Chart */
.nk-chart svg{ width:100%; height:auto; display:block; margin-top:10px; }
.nk-gridline{ stroke: rgba(11,18,32,0.16); stroke-width:1; }
.nk-frame{ fill:transparent; stroke: rgba(11,18,32,0.12); stroke-width:1; }
@media (prefers-color-scheme: dark){
  .nk-gridline{ stroke: rgba(255,255,255,0.22); }
  .nk-frame{ stroke: rgba(255,255,255,0.14); }
}
.nk-line{ fill:none; stroke-width:2.2; opacity:.95; }
.nk-line-p{ stroke: var(--c1); }
.nk-line-e{ stroke: var(--c2); }
.nk-line-i{ stroke: var(--c3); }
.nk-legend{ display:flex; gap:12px; flex-wrap:wrap; margin-top:8px; color:var(--muted); font-size:12px; }
.nk-legend-item{ display:inline-flex; align-items:center; gap:8px; }
.nk-dot{ width:10px; height:10px; border-radius:999px; display:inline-block; }
.nk-dot-p{ background: var(--c1); }
.nk-dot-e{ background: var(--c2); }
.nk-dot-i{ background: var(--c3); }

/* Week UI */
.nk-topdays{ display:grid; grid-template-columns:1fr; gap:10px; margin-top:10px; }
@media(min-width:640px){ .nk-topdays{ grid-template-columns: repeat(3, 1fr);} }
.nk-topday{ border:1px solid var(--border); border-radius:14px; padding:10px 12px; background: rgba(11,18,32,0.04); }
@media (prefers-color-scheme: dark){ .nk-topday{ background: rgba(255,255,255,0.06); } }
.nk-topday.is-today{ border-color: rgba(139,92,246,.55); box-shadow: 0 0 0 3px rgba(139,92,246,.12); }
.nk-topday .nk-d{ font-weight:900; font-size:16px; }
.nk-topday .nk-s{ color:var(--muted); font-size:12px; margin-top:2px; }
.nk-topday .nk-v{ margin-top:6px; font-weight:900; font-size:20px; }
.nk-topday .m{ color:var(--muted); font-size:12px; margin-top:2px; }

.nk-week{ display:grid; gap:10px; margin-top:10px; }
.nk-day{ border:1px solid var(--border); border-radius:14px; overflow:hidden; }
.nk-day.is-today{ border-color: rgba(139,92,246,.55); box-shadow: 0 0 0 3px rgba(139,92,246,.12); }
.nk-day-head{
  width:100%;
  text-align:left;
  background: rgba(11,18,32,0.04);
  border:0;
  padding: 12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 10px;
  cursor:pointer;
}
@media (prefers-color-scheme: dark){ .nk-day-head{ background: rgba(255,255,255,0.06); } }
.nk-day-head .nk-t{ font-weight:900; font-size:14px; color: #bfa6fa; }
.nk-day-head .nk-m{ color:var(--muted); font-size:12px; margin-top:4px; }
.nk-day-body{ display:none; padding: 12px; border-top:1px solid var(--border); background: var(--card); }
.nk-pill{ display:inline-flex; padding:2px 8px; border-radius:999px; font-size:11px; border:1px solid rgba(139,92,246,.45); background: rgba(139,92,246,.12); margin-left:8px; }

.nk-score{ min-width: 66px; text-align:center; padding:8px 10px; border-radius:999px; border:1px solid var(--nk-score-border, var(--border)); background: var(--nk-score-bg, rgba(11,18,32,0.10)); color: var(--text); font-weight:900; }
@media (prefers-color-scheme: dark){ .nk-score{ min-width: 66px; text-align:center; padding:8px 10px; border-radius:999px; border:1px solid var(--nk-score-border, var(--border)); background: var(--nk-score-bg, rgba(11,18,32,0.10)); color: var(--text); font-weight:900; } }

.nk-highlight{ border:1px solid rgba(139,92,246,.45); border-radius:16px; overflow:hidden; }
.nk-highlight-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; padding:12px; background: rgba(139,92,246,.10); }
.nk-rich p{ margin: 0 0 10px 0; }
.nk-rich ul{ margin: 8px 0 10px 18px; }
.nk-rich hr{ border:0; border-top:1px solid var(--border); margin:12px 0; }

.nk-grid2{ display:grid; gap:10px; margin-top: 12px; }
@media(min-width:640px){ .nk-grid2{ grid-template-columns: 1fr 1fr; } }
.nk-mini{ border:1px solid var(--border); border-radius:14px; padding:10px 12px; background: rgba(11,18,32,0.04); }
@media (prefers-color-scheme: dark){ .nk-mini{ background: rgba(255,255,255,0.06); } }
.nk-mini .nk-h{ font-size:12px; color:var(--muted); }
.nk-mini .nk-b{ margin-top:6px; font-weight:800; font-size:13px; }
.nk-mini .nk-s{ margin-top:4px; font-size:12px; color:var(--muted); }


/* Score contrast: dark mode */
@media (prefers-color-scheme: dark){
  .nk-score{ min-width: 66px; text-align:center; padding:8px 10px; border-radius:999px; border:1px solid var(--nk-score-border, var(--border)); background: var(--nk-score-bg, rgba(11,18,32,0.10)); color: var(--text); font-weight:900; }
}
html.dark-mode .nk-score, body.dark-mode .nk-score,
html.is-dark .nk-score, body.is-dark .nk-score,
html.rb-dark .nk-score, body.rb-dark .nk-score,
html.rb-dark-mode .nk-score, body.rb-dark-mode .nk-score,
html.dark .nk-score, body.dark .nk-score,
[data-theme="dark"] .nk-score, [data-color-scheme="dark"] .nk-score{ min-width: 66px; text-align:center; padding:8px 10px; border-radius:999px; border:1px solid var(--nk-score-border, var(--border)); background: var(--nk-score-bg, rgba(11,18,32,0.10)); color: var(--text); font-weight:900; }

/* Ensure muted text is readable */
.nk-sub, .t, .nk-k .nk-s, .nk-toggle-text small, .nk-legend{ color: var(--muted); }

.nk-wrap.nk-mode-dark .nk-score{ min-width: 66px; text-align:center; padding:8px 10px; border-radius:999px; border:1px solid var(--nk-score-border, var(--border)); background: var(--nk-score-bg, rgba(11,18,32,0.10)); color: var(--text); font-weight:900; }


/* =========================
   Foxiz theme light/dark support
   - Foxiz lahko preklaplja dark-mode/light-mode neodvisno od OS
   ========================= */
body.dark-mode .nk-wrap,
html.dark-mode .nk-wrap,
body.is-dark .nk-wrap,
html.is-dark .nk-wrap,
body.rb-dark .nk-wrap,
html.rb-dark .nk-wrap,
body[data-theme="dark"] .nk-wrap,
html[data-theme="dark"] .nk-wrap,
body[data-mode="dark"] .nk-wrap,
html[data-mode="dark"] .nk-wrap,
.nk-wrap.nk-mode-dark{
  --card:rgba(15,23,42,0.96);
  --card2:rgba(2,6,23,0.55);
  --text:rgba(255,255,255,0.92);
  --muted:rgba(255,255,255,0.74);
  --border:rgba(255,255,255,0.14);
  --shadow:0 18px 36px rgba(0,0,0,0.35);
  --nk-score-bg: rgba(255,255,255,0.10);
  --nk-score-border: rgba(255,255,255,0.18);
  --nk-soft: rgba(255,255,255,0.06);
}

body.light-mode .nk-wrap,
html.light-mode .nk-wrap,
body.is-light .nk-wrap,
html.is-light .nk-wrap,
body[data-theme="light"] .nk-wrap,
html[data-theme="light"] .nk-wrap,
body[data-mode="light"] .nk-wrap,
html[data-mode="light"] .nk-wrap,
.nk-wrap.nk-mode-light{
  --card:#ffffff;
  --card2:#f7f8fb;
  --text:#0b1220;
  --muted:rgba(11,18,32,0.72);
  --border:rgba(11,18,32,0.12);
  --shadow:0 10px 24px rgba(11,18,32,0.10);
  --nk-score-bg: rgba(11,18,32,0.12);
  --nk-score-border: rgba(11,18,32,0.18);
  --nk-soft: rgba(11,18,32,0.06);
}
