/* ============================================================================
 * KoloPlus — new theme · core styles
 * v1.1.1.938
 *
 * Design principles:
 *   - One breath: off-white canvas, warm ink text, one accent.
 *   - Structure through whitespace, not decoration.
 *   - No gradients, no glow, no decorative shadows.
 *   - System font. Generous sizing for readability.
 *   - Motion is incidental, not a feature.
 *
 * Palette tokens — single source. Theme-mode flips only surfaces, not accents.
 * ========================================================================= */

:root {
  /* Surfaces */
  --n-bg:         #FBFAF7;   /* canvas — warm off-white */
  --n-bg-2:       #FFFFFF;   /* elevated — card, panel */
  --n-bg-sunk:    #F3F1EC;   /* subtle inset — input, hover chip */
  --n-bg-hover:   #EFECE5;   /* hoverable surface */

  /* Ink (text) */
  --n-text:       #1A1614;   /* primary */
  --n-text-soft:  #4A4340;   /* secondary */
  --n-text-mute:  #7A7370;   /* tertiary, labels */
  --n-text-dim:   #A8A19D;   /* faint, placeholder */

  /* Borders — gentle, hierarchical */
  --n-line:       #E6E1D8;
  --n-line-strong:#D2CBC0;

  /* Accent — single warm coral-red for actions */
  --n-accent:         #D94F2C;
  --n-accent-hover:   #C44320;
  --n-accent-soft:    #FCEFE9;
  --n-accent-ring:    rgba(217, 79, 44, 0.22);
  --n-text-on-accent: #FFFFFF;

  /* Semantic tones — used sparingly */
  --n-ok:         #2B7A4B;
  --n-ok-soft:    #E8F3EC;
  --n-warn:       #A56A0E;
  --n-warn-soft:  #FAF0DC;
  --n-danger:     #B8331F;
  --n-danger-soft:#FBEAE4;
  --n-info:       #3B6CA8;
  --n-info-soft:  #E7EFF8;

  /* Type scale */
  --n-font: -apple-system, BlinkMacSystemFont, "Segoe UI Variable", "Segoe UI",
            system-ui, Roboto, "Helvetica Neue", sans-serif;
  --n-font-mono: ui-monospace, "SF Mono", "Cascadia Mono", "Roboto Mono",
                 Menlo, Consolas, monospace;

  --n-fs-xs:   12px;
  --n-fs-sm:   14px;
  --n-fs-md:   16px;
  --n-fs-lg:   18px;
  --n-fs-xl:   21px;
  --n-fs-2xl:  26px;
  --n-fs-3xl:  34px;
  --n-fs-4xl:  44px;
  --n-fs-5xl:  56px;

  --n-lh-tight: 1.15;
  --n-lh-snug:  1.35;
  --n-lh-base:  1.55;
  --n-lh-loose: 1.7;

  --n-w-reg:  400;
  --n-w-med:  500;
  --n-w-sem:  600;
  --n-w-bold: 700;

  /* Spacing — 4px base */
  --n-s-1: 4px;
  --n-s-2: 8px;
  --n-s-3: 12px;
  --n-s-4: 16px;
  --n-s-5: 24px;
  --n-s-6: 32px;
  --n-s-7: 48px;
  --n-s-8: 64px;
  --n-s-9: 96px;

  /* Radius */
  --n-r-xs:   6px;
  --n-r-sm:   10px;
  --n-r-md:   14px;
  --n-r-lg:   20px;
  --n-r-pill: 9999px;

  /* Shadows — subtle, structural only */
  --n-shadow-sm: 0 1px 2px rgba(26, 22, 20, 0.04);
  --n-shadow-md: 0 2px 8px rgba(26, 22, 20, 0.06),
                 0 1px 2px rgba(26, 22, 20, 0.04);
  --n-shadow-lg: 0 8px 24px rgba(26, 22, 20, 0.08),
                 0 2px 6px rgba(26, 22, 20, 0.04);

  /* Motion */
  --n-dur-fast: 120ms;
  --n-dur-base: 180ms;
  --n-dur-slow: 280ms;
  --n-ease:     cubic-bezier(0.2, 0, 0, 1);

  /* Z-index scale */
  --n-z-base:    1;
  --n-z-sticky:  100;
  --n-z-header:  500;
  --n-z-modal:   1000;
  --n-z-toast:   2000;

  /* Layout */
  --n-header-h:  60px;
  --n-content-w: 680px;   /* reading column */
  --n-wide-w:   1080px;   /* wide column (feeds, dashboards) */
}

/* Dark mode — single flip */
[data-theme="dark"] {
  --n-bg:         #15120F;
  --n-bg-2:       #1E1A16;
  --n-bg-sunk:    #13100D;
  --n-bg-hover:   #292420;

  --n-text:       #F3EFE8;
  --n-text-soft:  #C7BFB4;
  --n-text-mute:  #948A7E;
  --n-text-dim:   #6B6158;

  --n-line:       #2F2A25;
  --n-line-strong:#3E3832;

  --n-accent:         #E85F3A;
  --n-accent-hover:   #F27049;
  --n-accent-soft:    rgba(232, 95, 58, 0.12);
  --n-accent-ring:    rgba(232, 95, 58, 0.28);

  --n-ok-soft:     rgba(43, 122, 75, 0.18);
  --n-warn-soft:   rgba(165, 106, 14, 0.18);
  --n-danger-soft: rgba(184, 51, 31, 0.2);
  --n-info-soft:   rgba(59, 108, 168, 0.18);

  --n-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
  --n-shadow-md: 0 2px 8px rgba(0, 0, 0, 0.36),
                 0 1px 2px rgba(0, 0, 0, 0.24);
  --n-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.4),
                 0 2px 6px rgba(0, 0, 0, 0.24);
}

/* ─── RESET — minimal, modern ────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; }

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--n-font);
  font-size: var(--n-fs-md);
  line-height: var(--n-lh-base);
  color: var(--n-text);
  background: var(--n-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* Typography base */
h1, h2, h3, h4, h5, h6 {
  margin: 0 0 var(--n-s-3);
  font-weight: var(--n-w-sem);
  line-height: var(--n-lh-tight);
  color: var(--n-text);
  letter-spacing: -0.01em;
}
h1 { font-size: var(--n-fs-4xl); letter-spacing: -0.025em; font-weight: var(--n-w-bold); }
h2 { font-size: var(--n-fs-3xl); letter-spacing: -0.02em; }
h3 { font-size: var(--n-fs-2xl); letter-spacing: -0.015em; }
h4 { font-size: var(--n-fs-xl); }
h5 { font-size: var(--n-fs-lg); }
h6 { font-size: var(--n-fs-md); }

p { margin: 0 0 var(--n-s-3); line-height: var(--n-lh-base); }
p:last-child { margin-bottom: 0; }

a {
  color: var(--n-accent);
  text-decoration: none;
  transition: color var(--n-dur-fast) var(--n-ease);
}
a:hover { color: var(--n-accent-hover); }
a:focus-visible {
  outline: 2px solid var(--n-accent);
  outline-offset: 2px;
  border-radius: 2px;
}

strong, b { font-weight: var(--n-w-sem); color: var(--n-text); }
em, i     { font-style: italic; }
small     { font-size: var(--n-fs-sm); color: var(--n-text-mute); }

code, kbd, samp {
  font-family: var(--n-font-mono);
  font-size: 0.92em;
}
code {
  padding: 1px 5px;
  background: var(--n-bg-sunk);
  border-radius: 4px;
  color: var(--n-text);
}
pre {
  margin: 0 0 var(--n-s-3);
  padding: var(--n-s-3);
  background: var(--n-bg-sunk);
  border: 1px solid var(--n-line);
  border-radius: var(--n-r-sm);
  overflow-x: auto;
  font-size: var(--n-fs-sm);
}
pre code { background: transparent; padding: 0; }

blockquote {
  margin: var(--n-s-4) 0;
  padding: var(--n-s-2) 0 var(--n-s-2) var(--n-s-4);
  border-left: 3px solid var(--n-line-strong);
  color: var(--n-text-soft);
  font-style: italic;
}

hr {
  height: 1px;
  background: var(--n-line);
  border: 0;
  margin: var(--n-s-5) 0;
}

img, video, svg, canvas { max-width: 100%; display: block; }

ul, ol {
  margin: 0 0 var(--n-s-3);
  padding-left: var(--n-s-5);
}
li { margin-bottom: 4px; }
ul.n-plain, ol.n-plain { list-style: none; padding: 0; }
ul.n-plain li, ol.n-plain li { margin: 0; }

/* Form defaults */
input, textarea, select, button {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
}
button { cursor: pointer; }
:disabled { cursor: not-allowed; opacity: 0.5; }

::selection { background: var(--n-accent-soft); color: var(--n-accent); }

/* Scrollbar — subtle */
* { scrollbar-width: thin; scrollbar-color: var(--n-line-strong) transparent; }
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-thumb {
  background: var(--n-line-strong);
  border-radius: var(--n-r-pill);
  border: 2px solid transparent;
  background-clip: padding-box;
}
*::-webkit-scrollbar-thumb:hover { background: var(--n-text-dim); background-clip: padding-box; border: 2px solid transparent; }
*::-webkit-scrollbar-track { background: transparent; }

/* ─── LAYOUT PRIMITIVES ──────────────────────────────────────────────────── */

.n-app {
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}

.n-main {
  flex: 1;
  width: 100%;
  padding-top: var(--n-header-h);
}

.n-container {
  width: 100%;
  max-width: var(--n-wide-w);
  margin: 0 auto;
  padding: 0 var(--n-s-4);
}
.n-container--narrow { max-width: var(--n-content-w); }

.n-section {
  padding: var(--n-s-7) 0;
}
.n-section--tight  { padding: var(--n-s-5) 0; }
.n-section--loose  { padding: var(--n-s-9) 0; }

@media (min-width: 768px) {
  .n-container { padding: 0 var(--n-s-5); }
}

/* ─── COMPONENTS ─────────────────────────────────────────────────────────── */

/* Buttons — three variants only */
.n-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--n-s-2);
  height: 44px;
  padding: 0 var(--n-s-5);
  font-family: var(--n-font);
  font-size: var(--n-fs-sm);
  font-weight: var(--n-w-med);
  line-height: 1;
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: var(--n-r-sm);
  background: transparent;
  color: var(--n-text);
  cursor: pointer;
  transition: background var(--n-dur-fast) var(--n-ease),
              border-color var(--n-dur-fast) var(--n-ease),
              color var(--n-dur-fast) var(--n-ease);
  white-space: nowrap;
  user-select: none;
}
.n-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--n-accent-ring);
}

.n-btn--primary {
  background: var(--n-accent);
  color: var(--n-text-on-accent);
  border-color: var(--n-accent);
}
.n-btn--primary:hover   { background: var(--n-accent-hover); border-color: var(--n-accent-hover); color: var(--n-text-on-accent); }
.n-btn--primary:active  { transform: translateY(1px); }

.n-btn--secondary {
  background: var(--n-bg-2);
  color: var(--n-text);
  border-color: var(--n-line-strong);
}
.n-btn--secondary:hover { background: var(--n-bg-hover); border-color: var(--n-text-mute); color: var(--n-text); }

.n-btn--ghost {
  color: var(--n-text);
}
.n-btn--ghost:hover { background: var(--n-bg-hover); color: var(--n-text); }

.n-btn--sm   { height: 34px; padding: 0 var(--n-s-3); font-size: var(--n-fs-xs); border-radius: var(--n-r-xs); }
.n-btn--lg   { height: 52px; padding: 0 var(--n-s-6); font-size: var(--n-fs-md); }
.n-btn--block{ width: 100%; }

.n-btn--icon {
  width: 44px; padding: 0;
  border-radius: var(--n-r-pill);
}
.n-btn--icon.n-btn--sm { width: 34px; }

/* Cards */
.n-card {
  background: var(--n-bg-2);
  border: 1px solid var(--n-line);
  border-radius: var(--n-r-md);
  padding: var(--n-s-5);
}
.n-card--tight { padding: var(--n-s-4); }
.n-card--loose { padding: var(--n-s-6); }
.n-card--flush { padding: 0; overflow: hidden; }

/* Form inputs */
.n-input, .n-textarea, .n-select {
  display: block;
  width: 100%;
  height: 44px;
  padding: 0 var(--n-s-3);
  font-family: var(--n-font);
  font-size: var(--n-fs-md);
  line-height: 1.4;
  color: var(--n-text);
  background: var(--n-bg-2);
  border: 1px solid var(--n-line-strong);
  border-radius: var(--n-r-sm);
  transition: border-color var(--n-dur-fast) var(--n-ease),
              box-shadow var(--n-dur-fast) var(--n-ease);
  -webkit-appearance: none;
  appearance: none;
}
.n-textarea { height: auto; min-height: 88px; padding: var(--n-s-3); resize: vertical; line-height: var(--n-lh-base); }
.n-select {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A7370' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
  cursor: pointer;
}
.n-input:hover, .n-textarea:hover, .n-select:hover { border-color: var(--n-text-mute); }
.n-input:focus, .n-textarea:focus, .n-select:focus {
  outline: none;
  border-color: var(--n-accent);
  box-shadow: 0 0 0 3px var(--n-accent-ring);
}
.n-input::placeholder, .n-textarea::placeholder { color: var(--n-text-dim); }

.n-label {
  display: block;
  margin-bottom: var(--n-s-2);
  font-size: var(--n-fs-sm);
  font-weight: var(--n-w-med);
  color: var(--n-text-soft);
}
.n-field {
  display: flex;
  flex-direction: column;
  gap: var(--n-s-2);
  margin-bottom: var(--n-s-4);
}
.n-hint {
  font-size: var(--n-fs-xs);
  color: var(--n-text-mute);
  margin-top: 2px;
}

/* Chips / Pills */
.n-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--n-s-1);
  padding: 6px 12px;
  font-size: var(--n-fs-xs);
  font-weight: var(--n-w-med);
  color: var(--n-text-soft);
  background: var(--n-bg-sunk);
  border: 1px solid transparent;
  border-radius: var(--n-r-pill);
  text-decoration: none;
  transition: background var(--n-dur-fast) var(--n-ease),
              color var(--n-dur-fast) var(--n-ease);
  cursor: pointer;
  white-space: nowrap;
}
.n-chip:hover { background: var(--n-bg-hover); color: var(--n-text); }
.n-chip.is-active {
  background: var(--n-text);
  color: var(--n-bg);
}
.n-chip--accent.is-active { background: var(--n-accent); color: var(--n-text-on-accent); }

/* Eyebrow label */
.n-eyebrow {
  display: inline-block;
  font-size: var(--n-fs-xs);
  font-weight: var(--n-w-sem);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--n-accent);
}

/* Alerts */
.n-alert {
  padding: var(--n-s-3) var(--n-s-4);
  border-radius: var(--n-r-sm);
  border: 1px solid var(--n-line);
  background: var(--n-bg-2);
  color: var(--n-text);
  font-size: var(--n-fs-sm);
  line-height: var(--n-lh-snug);
}
.n-alert--info    { background: var(--n-info-soft);   border-color: color-mix(in srgb, var(--n-info)   20%, var(--n-line)); }
.n-alert--ok      { background: var(--n-ok-soft);     border-color: color-mix(in srgb, var(--n-ok)     20%, var(--n-line)); }
.n-alert--warn    { background: var(--n-warn-soft);   border-color: color-mix(in srgb, var(--n-warn)   20%, var(--n-line)); }
.n-alert--danger  { background: var(--n-danger-soft); border-color: color-mix(in srgb, var(--n-danger) 20%, var(--n-line)); }

/* Tables */
.n-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--n-fs-sm);
}
.n-table th, .n-table td {
  padding: var(--n-s-2) var(--n-s-3);
  text-align: left;
  border-bottom: 1px solid var(--n-line);
}
.n-table th {
  font-weight: var(--n-w-med);
  color: var(--n-text-mute);
  font-size: var(--n-fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.n-table tbody tr:last-child td { border-bottom: 0; }

/* Divider */
.n-divider {
  height: 1px;
  background: var(--n-line);
  margin: var(--n-s-5) 0;
  border: 0;
}

/* Link */
.n-link {
  color: var(--n-accent);
  font-weight: var(--n-w-med);
}
.n-link--plain { color: var(--n-text); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: var(--n-line-strong); }
.n-link--plain:hover { color: var(--n-accent); text-decoration-color: var(--n-accent); }

/* ─── UTILITIES ──────────────────────────────────────────────────────────── */

.n-center    { text-align: center; }
.n-right     { text-align: right; }
.n-truncate  { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.n-stack     { display: flex; flex-direction: column; gap: var(--n-s-3); }
.n-stack--sm { gap: var(--n-s-2); }
.n-stack--lg { gap: var(--n-s-5); }
.n-row       { display: flex; align-items: center; gap: var(--n-s-2); flex-wrap: wrap; }
.n-row--nowrap { flex-wrap: nowrap; }
.n-row--between { justify-content: space-between; }
.n-row--end  { justify-content: flex-end; }
.n-row--center { justify-content: center; }

.n-grid      { display: grid; gap: var(--n-s-4); }
.n-grid--2   { grid-template-columns: repeat(2, 1fr); }
.n-grid--3   { grid-template-columns: repeat(3, 1fr); }
.n-grid--auto{ grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }

@media (max-width: 640px) {
  .n-grid--2, .n-grid--3 { grid-template-columns: 1fr; }
}
@media (min-width: 641px) and (max-width: 900px) {
  .n-grid--3 { grid-template-columns: repeat(2, 1fr); }
}

.n-spacer   { flex: 1; }
.n-hidden   { display: none !important; }
.n-sr-only  {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Bridges — allow old .kp-* classes from default theme to inherit basic look
 * when fallback kicks in. Minimal, gentle: no over-specific rules.
 * Keep surfaces coherent so a fall-through page doesn't look jarring. */
.kp-page, .kp-container { padding-left: var(--n-s-4); padding-right: var(--n-s-4); }
.kp-btn { display: inline-flex; align-items: center; justify-content: center; height: 44px; padding: 0 var(--n-s-5); border-radius: var(--n-r-sm); font-weight: var(--n-w-med); border: 1px solid var(--n-line-strong); background: var(--n-bg-2); color: var(--n-text); cursor: pointer; transition: background var(--n-dur-fast) var(--n-ease); }
.kp-btn:hover { background: var(--n-bg-hover); }
.kp-btn.kp-btn--primary { background: var(--n-accent); color: var(--n-text-on-accent); border-color: var(--n-accent); }
.kp-btn.kp-btn--primary:hover { background: var(--n-accent-hover); border-color: var(--n-accent-hover); color: var(--n-text-on-accent); }
.kp-card { background: var(--n-bg-2); border: 1px solid var(--n-line); border-radius: var(--n-r-md); padding: var(--n-s-5); }
.kp-input, .kp-textarea, .kp-select { display: block; width: 100%; height: 44px; padding: 0 var(--n-s-3); background: var(--n-bg-2); border: 1px solid var(--n-line-strong); border-radius: var(--n-r-sm); color: var(--n-text); font-family: var(--n-font); }
.kp-input:focus, .kp-textarea:focus, .kp-select:focus { outline: none; border-color: var(--n-accent); box-shadow: 0 0 0 3px var(--n-accent-ring); }
