/* =========================================================================
   1010monky design system - BASE
   Reset + element-defaults + ateranvandbara klasser. Bygger pa tokens.css.
   Ladda ALLTID tokens.css fore denna fil.
   ========================================================================= */

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; tab-size: 4; }
body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--text-primary);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: none; }
a { color: var(--accent); text-decoration: none; transition: color var(--dur-fast) var(--ease); }
a:hover { color: var(--accent-hover); }
ul[class], ol[class] { list-style: none; padding: 0; }
:focus-visible { outline: none; box-shadow: var(--shadow-focus); border-radius: var(--radius-sm); }
hr { border: 0; border-top: var(--border); }

/* ---------- Rubriker ----------
   Stora rubriker (h1-h3) i display-typsnittet for karaktar; sma (h4-h6) i sans
   for tydlig hierarki. Tight tracking pa de storsta = dyr, samlad kansla. */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: var(--font-sans);
  font-weight: var(--fw-bold);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text-primary);
  text-wrap: balance;
}
h1, .h1, h2, .h2, h3, .h3 { font-family: var(--font-display); }
h1, .h1 { font-size: var(--text-5xl); letter-spacing: var(--tracking-tighter); line-height: 1.05; }
h2, .h2 { font-size: var(--text-4xl); letter-spacing: var(--tracking-tighter); line-height: 1.1; }
h3, .h3 { font-size: var(--text-3xl); }
h4, .h4 { font-size: var(--text-2xl); letter-spacing: var(--tracking-normal); }
h5, .h5 { font-size: var(--text-xl);  letter-spacing: var(--tracking-normal); }
h6, .h6 { font-size: var(--text-lg);  letter-spacing: var(--tracking-normal); }

/* Signaturmoment: ett ord i grön gradient – sparsamt, en gång per sida */
.text-gradient {
  background: linear-gradient(100deg, var(--green-600), var(--green-400));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* Eyebrow: liten versal etikett ovanfor rubriker */
.eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent);
}

/* Ingress / lead */
.lead {
  font-size: var(--text-xl);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
}

/* ---------- Text-utilities ---------- */
.text-xs { font-size: var(--text-xs); }
.text-sm { font-size: var(--text-sm); }
.text-base { font-size: var(--text-base); }
.text-lg { font-size: var(--text-lg); }
.text-xl { font-size: var(--text-xl); }

.fw-regular { font-weight: var(--fw-regular); }
.fw-medium { font-weight: var(--fw-medium); }
.fw-semibold { font-weight: var(--fw-semibold); }
.fw-bold { font-weight: var(--fw-bold); }

.text-primary { color: var(--text-primary); }
.text-secondary { color: var(--text-secondary); }
.text-muted { color: var(--text-muted); }
.text-accent { color: var(--accent); }

.leading-tight { line-height: var(--leading-tight); }
.leading-snug { line-height: var(--leading-snug); }
.leading-normal { line-height: var(--leading-normal); }
.leading-relaxed { line-height: var(--leading-relaxed); }

.tracking-tight { letter-spacing: var(--tracking-tight); }
.tracking-normal { letter-spacing: var(--tracking-normal); }
.tracking-wide { letter-spacing: var(--tracking-wide); }
.tracking-widest { letter-spacing: var(--tracking-widest); }

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }
.text-balance { text-wrap: balance; }
.uppercase { text-transform: uppercase; }

/* ---------- Layout ---------- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.container-narrow { max-width: var(--container-narrow); }
.section { padding-block: var(--space-9); }
.section-sm { padding-block: var(--space-7); }
.stack > * + * { margin-top: var(--space-4); }     /* vertikal rytm */
.stack-sm > * + * { margin-top: var(--space-2); }
.stack-lg > * + * { margin-top: var(--space-6); }
.cluster { display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; }
.grid { display: grid; gap: var(--space-5); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-auto { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
@media (max-width: 768px) { .grid-2, .grid-3 { grid-template-columns: 1fr; } }

/* ---------- Tema-känsla: redaktionella mönster (mindre kort, mer luft) ---------- */

/* Sektion med svagt avvikande bakgrund – skiljer avsnitt åt utan boxar */
.section-alt { background: var(--surface-2); }

/* Tunn avdelare istället för kort-kanter */
.divider { height: 1px; background: var(--border-color); border: 0; margin-block: var(--space-7); }

/* Läsbar textspalt – rätt radlängd för editorial text */
.prose { max-width: 65ch; }
.prose > * + * { margin-top: var(--space-4); }
.prose h2, .prose h3 { margin-top: var(--space-6); }
.prose ul { padding-left: 1.2em; list-style: disc; }
.prose li + li { margin-top: var(--space-2); }

/* Feature-rader: ikon + rubrik + text, helt utan kortram */
.features { display: grid; gap: var(--space-6) var(--space-5); grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.feature-icon {
  width: 46px; height: 46px; border-radius: var(--radius-md);
  display: grid; place-items: center;
  background: var(--accent-soft); color: var(--accent);
  margin-bottom: var(--space-3);
}
.feature-title { font-size: var(--text-lg); font-weight: var(--fw-semibold); margin-bottom: var(--space-2); }
.feature-text { color: var(--text-secondary); }

/* Nyckeltal: stora siffror, ingen box */
.stats { display: flex; flex-wrap: wrap; gap: var(--space-6) var(--space-8); }
.stat-num { font-size: var(--text-4xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); color: var(--accent); line-height: 1; }
.stat-label { color: var(--text-secondary); font-size: var(--text-sm); margin-top: var(--space-2); }

/* Media: bild + text i två spalter */
.media { display: grid; gap: var(--space-6); grid-template-columns: 1fr 1fr; align-items: center; }
@media (max-width: 768px) { .media { grid-template-columns: 1fr; } }

/* ---------- Knappar ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-size: var(--text-base); font-weight: var(--fw-semibold); line-height: 1;
  padding: 0.75rem 1.4rem; border-radius: var(--radius-pill);
  border: var(--border-width) solid transparent; cursor: pointer;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease),
              border-color var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--accent); color: var(--text-on-accent); }
.btn-primary:hover { background: var(--accent-hover); color: var(--text-on-accent); }
.btn-secondary { background: var(--surface-2); color: var(--text-primary); border-color: var(--border-color); }
.btn-secondary:hover { background: var(--surface-sunken); }
.btn-outline { background: transparent; color: var(--accent); border-color: var(--accent); }
.btn-outline:hover { background: var(--accent); color: var(--text-on-accent); }
.btn-ghost { background: transparent; color: var(--text-primary); }
.btn-ghost:hover { background: var(--surface-2); }
.btn-sm { padding: 0.5rem 1rem; font-size: var(--text-sm); }
.btn-lg { padding: 0.95rem 1.8rem; font-size: var(--text-lg); }
.btn-block { display: flex; width: 100%; }

/* ---------- Ytor / kort ---------- */
.surface { background: var(--surface); border: var(--border); border-radius: var(--radius-lg); }
.surface-2 { background: var(--surface-2); }
.card {
  background: var(--surface); border-radius: 0;
  padding: var(--space-5);
  /* Fyrkantiga kort, helt utan ram - bara en ren, mjuk premium-skugga definierar
     kortet (i morkt lage skiljer ytfargen kortet fran bakgrunden). Lugnt, premium. */
  box-shadow: var(--shadow-md);
}
.card-hover { transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.card-hover:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }

/* ---------- Tabell ---------- */
.table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.table th, .table td { padding: 0.7rem 1rem; text-align: left; border-bottom: 1px solid var(--hairline); }
.table thead th { color: var(--text-secondary); font-weight: var(--fw-semibold); }
.table tbody tr:hover { background: var(--surface-2); }
.table .center { text-align: center; }
.table .num { text-align: right; white-space: nowrap; }
.table-wrap { overflow-x: auto; border-radius: var(--radius-lg); border: 1px solid var(--hairline); }
.table-wrap .table th, .table-wrap .table td { border-bottom: 1px solid var(--hairline); }

/* ---------- Badges / pills ---------- */
.badge {
  display: inline-flex; align-items: center; gap: var(--space-1);
  font-size: var(--text-xs); font-weight: var(--fw-semibold);
  padding: 0.3em 0.7em; border-radius: var(--radius-pill);
  background: var(--surface-2); color: var(--text-secondary);
}
.badge-accent { background: var(--accent-soft); color: var(--accent); }
.badge-success { background: var(--c-success-bg); color: var(--c-success); }
.badge-warning { background: var(--c-warning-bg); color: var(--c-warning); }
.badge-danger  { background: var(--c-danger-bg);  color: var(--c-danger); }

/* ---------- Formular ---------- */
.field { display: flex; flex-direction: column; gap: var(--space-2); }
.label { font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); }
.input, .textarea, .select {
  width: 100%; padding: 0.7rem 0.95rem;
  background: var(--surface-2); color: var(--text-primary);
  border: var(--border-width) solid transparent; border-radius: var(--radius);
  transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.input::placeholder, .textarea::placeholder { color: var(--text-muted); }
.input:focus, .textarea:focus, .select:focus {
  outline: none; background: var(--surface); border-color: var(--accent); box-shadow: var(--shadow-focus);
}
.textarea { resize: vertical; min-height: 120px; }

/* ---------- Hjalp-utilities ---------- */
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }
.shadow-xl { box-shadow: var(--shadow-xl); }
.rounded { border-radius: var(--radius); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-pill { border-radius: var(--radius-pill); }
.border { border: var(--border); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
