/* ── TYPSNITT (self-hostade, variabla — CSP tillåter bara 'self') ───
   Fraunces: mjuk optisk serif för hjältesiffror/rubriker (almanacka-känsla).
   Hanken Grotesk: humanistisk sans för all UI/brödtext.
   font-display:swap → systemfont visas direkt, byts när fonten laddat. */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('vendor/fonts/fraunces.woff2') format('woff2');
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('vendor/fonts/hanken.woff2') format('woff2');
}

/* ── TOKENS (light) ──────────────────────────────────────────────── */
:root {
  --font-text:    'Hanken Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --font-display: 'Fraunces', 'Iowan Old Style', Georgia, 'Times New Roman', serif;
  --bg:           #F8F8F6;
  --surface:      #FFFFFF;
  --border:       #E6E6E2;
  --border-soft:  #EFEFEB;
  --text-1:       #1C1C1C;
  --text-2:       #565654;  /* ~6,9:1 mot bg — WCAG AA */
  --text-3:       #6E6E6C;  /* ~4,8:1 mot bg — WCAG AA */
  --green:        #2A5C47;
  --green-mid:    #3D7A60;
  --green-soft:   #EBF3EE;
  --amber:        #8B6534;
  --amber-soft:   #FBF3E8;
  --red:          #A83030;
  --red-soft:     #FCEAEA;
  --blue:         #2E5F8A;
  --blue-soft:    #EBF1F8;
  --purple:       #6B4A9A;
  --purple-soft:  #F0EAF8;
  --nav-h:        60px;
  --safe-b:       env(safe-area-inset-bottom, 0px);
  --safe-t:       env(safe-area-inset-top, 0px);
  --radius-s:     8px;
  --radius-m:     14px;
  --radius-l:     20px;
  --shadow-card:  0 1px 2px rgba(40,38,32,.04), 0 4px 14px -6px rgba(40,38,32,.10);
  --shadow-raise: 0 2px 4px rgba(40,38,32,.05), 0 12px 32px -10px rgba(40,38,32,.18);
  /* Varm halo bakom hjälteytan + diskret pappersgrain för djup */
  --halo:         var(--green-soft);
  --grain-opacity: .5;
}

/* ── DARK MODE ─────────────────────────────────────────────────────
   Aktiveras av: systemets mörka läge ELLER html.theme-dark
   Ljust läge tvingas av: html.theme-light (blockerar mediafrågan)
───────────────────────────────────────────────────────────────────── */
@media (prefers-color-scheme: dark) {
  html:not(.theme-light) {
    --bg:           #141412;
    --surface:      #1E1E1C;
    --border:       #2E2E2A;
    --border-soft:  #252523;
    --text-1:       #EFEFED;
    --text-2:       #A6A6A4;  /* ~7,6:1 mot mörk bg — WCAG AA */
    --text-3:       #8A8A88;  /* ~5,3:1 mot mörk bg — WCAG AA */
    --green:        #4DB880;
    --green-mid:    #5ACC8C;
    --green-soft:   #1A3028;
    --amber:        #C89050;
    --amber-soft:   #2C2018;
    --red:          #D06060;
    --red-soft:     #2C1A1A;
    --blue:         #5090C8;
    --blue-soft:    #182030;
    --purple:       #9070CC;
    --purple-soft:  #22183A;
    --shadow-card:  0 1px 2px rgba(0,0,0,.32), 0 6px 18px -8px rgba(0,0,0,.5);
    --shadow-raise: 0 2px 6px rgba(0,0,0,.4), 0 16px 36px -12px rgba(0,0,0,.6);
    --halo:         #16261E;
    --grain-opacity: .35;
  }
}

/* Manuellt tvingat mörkt läge (oberoende av system) */
html.theme-dark {
  --bg:           #141412;
  --surface:      #1E1E1C;
  --border:       #2E2E2A;
  --border-soft:  #252523;
  --text-1:       #EFEFED;
  --text-2:       #888886;
  --text-3:       #525250;
  --green:        #4DB880;
  --green-mid:    #5ACC8C;
  --green-soft:   #1A3028;
  --amber:        #C89050;
  --amber-soft:   #2C2018;
  --red:          #D06060;
  --red-soft:     #2C1A1A;
  --blue:         #5090C8;
  --blue-soft:    #182030;
  --purple:       #9070CC;
  --purple-soft:  #22183A;
  --shadow-card:  0 1px 2px rgba(0,0,0,.32), 0 6px 18px -8px rgba(0,0,0,.5);
  --shadow-raise: 0 2px 6px rgba(0,0,0,.4), 0 16px 36px -12px rgba(0,0,0,.6);
  --halo:         #16261E;
  --grain-opacity: .35;
}

/* ── RESET ──────────────────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Interaktiva element: ta bort 300ms-fördröjning, double-tap-zoom
   och blå highlight-flash i Safari — utan att störa scroll */
button, a, input, select, textarea, label, [role="button"] {
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
button { user-select: none; }
html { height: 100%; }
body {
  font-family: var(--font-text);
  background-color: var(--bg);
  /* Varm grön halo upptill ger djup utan att rubba kontrasten — "papper" */
  background-image: radial-gradient(135% 75% at 50% -18%, var(--halo) 0%, transparent 58%);
  background-attachment: fixed;
  color: var(--text-1);
  height: 100%;
  overflow: hidden;
  letter-spacing: -.005em;
  -webkit-tap-highlight-color: transparent;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Diskret pappersgrain — fast lager över bakgrunden, stör inte interaktion.
   feTurbulence-brus som data-URI (CSP: img-src tillåter data:). */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: 0;
  pointer-events: none;
  opacity: var(--grain-opacity);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.045'/%3E%3C/svg%3E");
  mix-blend-mode: multiply;
}
@media (prefers-color-scheme: dark) {
  html:not(.theme-light) body::before { mix-blend-mode: screen; }
}
html.theme-dark body::before { mix-blend-mode: screen; }
/* App-skalet över grain-lagret */
#app { position: relative; z-index: 1; }

/* ── SHELL ──────────────────────────────────────────────────────── */
#app {
  display: flex; flex-direction: column;
  height: 100dvh;
  max-width: 480px; margin: 0 auto;
  position: relative;
}

/* ── VIEWS ──────────────────────────────────────────────────────── */
.view {
  display: none; flex-direction: column; flex: 1;
  overflow-y: auto;
  padding-bottom: calc(var(--nav-h) + var(--safe-b) + 16px);
  padding-top: calc(var(--safe-t) + 8px);
}
.view.active { display: flex; }

/* ── BOTTOM NAV ─────────────────────────────────────────────────── */
.bottom-nav {
  position: fixed; bottom: 0; left: 0; right: 0;
  max-width: 480px; margin: 0 auto;
  height: calc(var(--nav-h) + var(--safe-b));
  padding-bottom: var(--safe-b);
  background: var(--surface); border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-around; z-index: 200;
}
.nav-btn {
  position: relative;
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 4px 12px; background: none; border: none;
  color: var(--text-3); font-size: 9.5px; font-weight: 500; letter-spacing: .3px;
  cursor: pointer; transition: color .2s ease; font-family: inherit;
}
.nav-btn svg { width: 21px; height: 21px; transition: transform .2s ease; }
.nav-btn.active { color: var(--green); }
.nav-btn.active svg { transform: translateY(-1px); }
/* Liten indikatorpunkt ovanför aktiv flik */
.nav-btn::before {
  content: ''; position: absolute; top: -1px;
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--green); opacity: 0; transform: scale(.4);
  transition: opacity .2s ease, transform .2s ease;
}
.nav-btn.active::before { opacity: 1; transform: scale(1); }

/* ── HOME ───────────────────────────────────────────────────────── */
.home-inner { display: flex; flex-direction: column; flex: 1; padding: 0 20px; gap: 14px; }

/* Topbar: datum + ikoner */
.home-topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 4px;
}
.topbar-actions { display: flex; align-items: center; gap: 6px; }
.btn-icon-sm {
  width: 44px; height: 44px;
  background: var(--border-soft);
  border: none; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--text-2);
  transition: background .15s, color .15s;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
.btn-icon-sm svg { width: 18px; height: 18px; }
.btn-icon-sm:active { background: var(--border); color: var(--text-1); }

.home-top { display: flex; flex-direction: column; align-items: center; padding-top: 8px; gap: 20px; }
.date-label { font-size: 13px; color: var(--text-2); letter-spacing: .2px; text-align: center; }
.status-area { display: flex; flex-direction: column; align-items: center; gap: 10px; padding: 28px 0 6px; }
.status-badge {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 500; letter-spacing: .2px;
  padding: 5px 12px; border-radius: 100px;
  background: var(--border-soft); color: var(--text-2); transition: background .3s, color .3s;
}
.status-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--text-3); transition: background .3s; flex-shrink: 0;
}
.status-badge.working  { background: var(--green-soft);  color: var(--green); }
.status-badge.working .status-dot  { background: var(--green-mid); }
.status-badge.on-break { background: var(--amber-soft); color: var(--amber); }
.status-badge.on-break .status-dot { background: var(--amber); }
.status-badge.done     { background: var(--green-soft);  color: var(--green); }
.status-badge.done .status-dot     { background: var(--green-mid); }

.big-time {
  font-family: var(--font-display); font-optical-sizing: auto;
  font-size: clamp(56px, 17vw, 86px); font-weight: 340; letter-spacing: -1.5px;
  color: var(--text-1); line-height: .98;
  font-variant-numeric: tabular-nums lining-nums;
  transition: color .4s ease;
}
.big-time.goal-reached { color: var(--green); }
.big-sublabel { font-size: 13px; color: var(--text-2); min-height: 18px; }
.big-sublabel .goal-tag { color: var(--green); font-weight: 600; }

/* Home actions */
.home-actions { display: flex; flex-direction: column; gap: 8px; }

/* Stillsam entré på hemskärmen — staggrad resning. Neutraliseras av
   prefers-reduced-motion (global regel längre ner). */
@keyframes riseIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
#view-home.active .home-topbar  { animation: riseIn .5s .02s ease both; }
#view-home.active .status-area  { animation: riseIn .6s .08s cubic-bezier(.2,.7,.2,1) both; }
#view-home.active .home-actions { animation: riseIn .6s .16s cubic-bezier(.2,.7,.2,1) both; }
#view-home.active #project-timer-row,
#view-home.active #today-card,
#view-home.active #flex-card    { animation: riseIn .55s .22s cubic-bezier(.2,.7,.2,1) both; }

/* Flex card */
/* Flexkort: visuellt underordnat "Idag"-kortet — platt, ingen skugga */
.flex-card {
  padding: 12px 16px;
  background: transparent;
  box-shadow: none;
  border: 1px solid var(--border);
}
.flex-row { display: flex; justify-content: space-between; align-items: baseline; }
.flex-label { font-size: 13px; color: var(--text-2); }
.flex-value { font-size: 16px; font-weight: 600; font-variant-numeric: tabular-nums; }
.flex-value.positive { color: var(--green); }
.flex-value.negative { color: var(--red); }
.flex-value.neutral  { color: var(--text-2); }
.flex-sub  { font-size: 12px; color: var(--text-3); margin-top: 2px; }

/* Today note */
.today-note {
  margin-top: 8px; font-size: 13px; color: var(--text-2);
  font-style: italic; padding-top: 6px;
  border-top: 1px solid var(--border-soft);
}

/* ── BUTTONS ────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: none; border-radius: var(--radius-m);
  font-size: 15px; font-weight: 500; cursor: pointer;
  transition: opacity .15s, transform .1s;
  padding: 14px 24px; letter-spacing: .1px; line-height: 1;
  font-family: inherit;
}
.btn:active { opacity: .82; transform: scale(.985); }
.btn-large  { padding: 18px 24px; font-size: 16px; border-radius: var(--radius-l); }
.btn-full   { width: 100%; }
.btn-primary {
  background: var(--text-1); color: var(--bg); width: 100%;
  box-shadow: 0 1px 2px rgba(40,38,32,.12), 0 8px 20px -8px rgba(40,38,32,.4);
}
.btn-primary.green { background: var(--green); }
.btn-primary.amber { background: var(--amber); }
.btn-ghost {
  background: transparent; color: var(--text-2);
  border: 1.5px solid var(--border); width: 100%;
}
.btn-danger { background: var(--red); color: #fff; }
.btn-add-inline {
  background: none; border: none; color: var(--green);
  font-size: 13px; font-weight: 500; cursor: pointer;
  padding: 12px 0; text-align: left; font-family: inherit; width: 100%;
  min-height: 44px;  /* full touch-yta */
  display: flex; align-items: center;
}
.btn-add-inline:active { opacity: .6; }
.hidden { display: none !important; }

/* Card header row with edit button */
.card-header-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.card-header-row .card-label { margin-bottom: 0; }
.btn-card-edit {
  display: flex; align-items: center; gap: 5px;
  background: none; border: none; color: var(--text-3);
  font-size: 12px; cursor: pointer; font-family: inherit; padding: 2px 4px;
}
.btn-card-edit svg { width: 14px; height: 14px; }
.btn-card-edit:active { color: var(--green); }

/* ── CARD ───────────────────────────────────────────────────────── */
.card { background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--radius-m); padding: 16px; box-shadow: var(--shadow-card); }
.card-label { font-size: 11px; font-weight: 600; letter-spacing: .7px; text-transform: uppercase; color: var(--text-3); margin-bottom: 12px; }
/* Återanvändbar kortnotering (ersätter upprepade inline-<p> i Inställningar) */
.card-note { font-size: 12px; color: var(--text-3); line-height: 1.5; padding-top: 8px; }
.today-row { display: flex; justify-content: space-between; align-items: baseline; padding: 7px 0; border-bottom: 1px solid var(--border-soft); }
.today-row:last-child { border-bottom: none; }
.today-row-key { font-size: 14px; color: var(--text-2); }
.today-row-val { font-size: 14px; font-weight: 500; color: var(--text-1); font-variant-numeric: tabular-nums; }
.today-row-val.accent { color: var(--green); font-weight: 600; }

/* ── VIEW HEADER ────────────────────────────────────────────────── */
.view-header-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px 12px; gap: 12px;
}
.view-title { font-family: var(--font-display); font-optical-sizing: auto; font-size: 28px; font-weight: 400; letter-spacing: -.4px; color: var(--text-1); }
.btn-back {
  width: 44px; height: 44px; margin-left: -10px;
  background: none; border: none; cursor: pointer; color: var(--text-1);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.btn-back svg { width: 22px; height: 22px; }
.btn-back:active { opacity: .5; }
.view-header-row > .btn-back + .view-title { flex: 1; }
.view-header-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

/* ── TOGGLE GROUP ───────────────────────────────────────────────── */
.toggle-group { display: flex; background: var(--border-soft); border-radius: var(--radius-s); padding: 2px; gap: 1px; }
.hist-toggle-row { padding: 0 20px 8px; }
.toggle-group-full { width: 100%; }
.toggle-group-full .toggle-btn { flex: 1; text-align: center; padding: 8px 4px; }
.toggle-btn {
  background: none; border: none; border-radius: 6px;
  padding: 5px 10px; font-size: 12px; font-weight: 500; color: var(--text-2);
  cursor: pointer; transition: background .15s, color .15s; font-family: inherit; white-space: nowrap;
}
.toggle-btn.active { background: var(--surface); color: var(--text-1); box-shadow: 0 1px 2px rgba(0,0,0,.08); }

/* Add day button */
.btn-icon-round {
  width: 44px; height: 44px; background: var(--surface);
  border: 1.5px solid var(--border); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--text-2); transition: border-color .15s, color .15s; flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
.btn-icon-round svg { width: 18px; height: 18px; }
.btn-icon-round:active { border-color: var(--green); color: var(--green); }

/* ── HISTORY LIST ───────────────────────────────────────────────── */
.history-list { display: flex; flex-direction: column; gap: 8px; padding: 4px 20px; }
.week-label { font-size: 11px; font-weight: 600; letter-spacing: .7px; text-transform: uppercase; color: var(--text-3); padding: 16px 0 8px; display: flex; justify-content: space-between; }
.week-label:first-child { padding-top: 4px; }
.week-summary { font-weight: 500; color: var(--text-2); font-variant-numeric: tabular-nums; }
.day-card {
  background: var(--surface); border-radius: var(--radius-m);
  padding: 14px 16px; box-shadow: var(--shadow-card);
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  cursor: pointer; transition: opacity .15s; border-left: 3px solid transparent;
}
.day-card:active { opacity: .7; }
.day-card.type-vacation { border-left-color: var(--blue); }
.day-card.type-sick     { border-left-color: var(--red); }
.day-card.type-vab      { border-left-color: var(--purple); }
.day-card.type-holiday  { border-left-color: var(--text-3); }
.day-card.type-comp     { border-left-color: var(--amber); }
.day-card-left { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.day-date { font-size: 14.5px; font-weight: 600; letter-spacing: -.1px; color: var(--text-1); }
.day-times { font-size: 12.5px; color: var(--text-2); font-variant-numeric: tabular-nums; }
.day-note-preview { font-size: 12px; color: var(--text-3); font-style: italic; margin-top: 1px; }
.day-card-right { display: flex; flex-direction: column; align-items: flex-end; gap: 1px; flex-shrink: 0; }
/* Totalen är radens svar — display-fonten ekar hjälteklockan och ger tydlig hierarki */
.day-total {
  font-family: var(--font-display); font-optical-sizing: auto;
  font-size: 21px; font-weight: 420; letter-spacing: -.3px; line-height: 1.05;
  color: var(--text-1); font-variant-numeric: tabular-nums lining-nums;
}
.day-breaks { font-size: 11.5px; color: var(--text-3); margin-top: 2px; }
.day-card-edit { width: 18px; height: 18px; color: var(--text-3); flex-shrink: 0; }
.history-empty { text-align: center; padding: 60px 24px; color: var(--text-2); font-size: 15px; line-height: 1.6; }
.history-empty-icon { width: 48px; height: 48px; color: var(--text-3); margin: 0 auto 16px; display: block; }

/* ── CALENDAR ───────────────────────────────────────────────────── */
.calendar-view { padding: 0 20px; display: flex; flex-direction: column; gap: 12px; }
.cal-nav { display: flex; align-items: center; justify-content: space-between; padding: 4px 0; }
.cal-nav-btn { width: 36px; height: 36px; background: var(--surface); border: 1.5px solid var(--border); border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text-2); }
.cal-nav-btn svg { width: 16px; height: 16px; }
.cal-nav-btn:active { opacity: .6; }
.cal-month-label { font-family: var(--font-display); font-optical-sizing: auto; font-size: 19px; font-weight: 460; letter-spacing: -.2px; color: var(--text-1); font-variant-numeric: tabular-nums lining-nums; }
.cal-weekdays { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.cal-weekdays span { text-align: center; font-size: 11px; font-weight: 600; letter-spacing: .4px; color: var(--text-3); padding: 4px 0; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal-day {
  aspect-ratio: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 3px; border-radius: var(--radius-s);
  cursor: pointer; font-size: 14px; color: var(--text-1); transition: background .15s; position: relative;
}
.cal-day:active { opacity: .7; }
.cal-day.empty-cell { cursor: default; }
.cal-day.is-weekend { color: var(--text-2); }
.cal-day.is-today { font-weight: 600; color: var(--green); }
.cal-day.is-today:not(.has-data):not(.has-active)::after {
  content: ''; position: absolute; bottom: 4px;
  width: 4px; height: 4px; border-radius: 50%; background: var(--green);
}
.cal-day.has-data   { background: var(--green-soft); }
.cal-day.has-data .cal-day-num { color: var(--green); font-weight: 600; }
.cal-day.has-active { background: var(--amber-soft); }
.cal-day.has-active .cal-day-num { color: var(--amber); font-weight: 600; }
/* Day type colors in calendar */
.cal-day.type-vacation { background: var(--blue-soft) !important; }
.cal-day.type-vacation .cal-day-num { color: var(--blue) !important; font-weight: 600; }
.cal-day.type-sick     { background: var(--red-soft) !important; }
.cal-day.type-sick .cal-day-num { color: var(--red) !important; font-weight: 600; }
.cal-day.type-vab      { background: var(--purple-soft) !important; }
.cal-day.type-vab .cal-day-num { color: var(--purple) !important; font-weight: 600; }
.cal-day.type-holiday  { background: var(--border-soft) !important; }
.cal-day.type-comp     { background: var(--amber-soft) !important; }
.cal-day.type-comp .cal-day-num { color: var(--amber) !important; font-weight: 600; }
.cal-day-num { line-height: 1; font-variant-numeric: tabular-nums lining-nums; }
.cal-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--green-mid); flex-shrink: 0; }
.cal-dot.amber { background: var(--amber); }
.cal-dot.red   { background: var(--red); }
.cal-legend { display: flex; gap: 12px; justify-content: center; padding: 4px 0 8px; flex-wrap: wrap; }
.legend-item { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text-2); }
.legend-dot { width: 10px; height: 10px; border-radius: 3px; }
.legend-dot.green  { background: var(--green-soft);  border: 1.5px solid var(--green-mid); }
.legend-dot.blue   { background: var(--blue-soft);   border: 1.5px solid var(--blue); }
.legend-dot.red    { background: var(--red-soft);    border: 1.5px solid var(--red); }
/* Röd dag visas som röd siffra i kalendern — legenden speglar det */
.legend-dot-num { font-size: 11px; font-weight: 700; color: var(--red); width: 10px; text-align: center; }

/* ── KALENDER: MÅNADSSAMMANFATTNING + HELGDAGAR ──────────────────── */
.cal-summary { display: flex; flex-direction: column; gap: 14px; padding: 4px 2px 8px; }
.cal-summary-row {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: 14px; color: var(--text-2);
  padding: 12px 14px; background: var(--surface);
  border-radius: var(--radius-m); box-shadow: var(--shadow-card);
}
.cal-summary-total { font-weight: 600; color: var(--green); font-variant-numeric: tabular-nums; }
.cal-holiday-list { display: flex; flex-direction: column; gap: 2px; }
.cal-holiday-head {
  font-size: 11px; font-weight: 600; letter-spacing: .7px;
  text-transform: uppercase; color: var(--text-3); padding: 0 2px 4px;
}
.cal-holiday-item {
  display: flex; gap: 12px; font-size: 13px; color: var(--text-2);
  padding: 5px 2px; border-bottom: 1px solid var(--border-soft);
}
.cal-holiday-item:last-child { border-bottom: none; }
.cal-holiday-date { color: var(--red); font-weight: 500; min-width: 38px; font-variant-numeric: tabular-nums; }

/* ── STATISTICS ─────────────────────────────────────────────────── */
.statistics-view { padding: 0 20px; display: flex; flex-direction: column; gap: 12px; }
.stat-section-label { font-size: 11px; font-weight: 600; letter-spacing: .7px; text-transform: uppercase; color: var(--text-3); padding: 12px 0 4px; }
.stat-section-label:first-child { padding-top: 4px; }
.stat-card { background: var(--surface); border-radius: var(--radius-m); padding: 16px; box-shadow: var(--shadow-card); display: flex; flex-direction: column; gap: 10px; }
.stat-row { display: flex; justify-content: space-between; align-items: baseline; }
.stat-key { font-size: 14px; color: var(--text-2); }
.stat-val { font-size: 15px; font-weight: 500; font-variant-numeric: tabular-nums; color: var(--text-1); }
.stat-val.green  { color: var(--green); }
.stat-val.red    { color: var(--red); }
.stat-val.muted  { color: var(--text-3); font-size: 13px; }
.stat-divider { height: 1px; background: var(--border-soft); }
.stat-big { font-family: var(--font-display); font-optical-sizing: auto; font-size: 32px; font-weight: 380; letter-spacing: -.5px; font-variant-numeric: tabular-nums lining-nums; line-height: 1; }
.stat-big.green { color: var(--green); }
.stat-big.red   { color: var(--red); }
.stat-big-label { font-size: 12px; color: var(--text-3); }
.progress-bar { height: 4px; background: var(--border-soft); border-radius: 2px; overflow: hidden; margin-top: 2px; }
.progress-fill { height: 100%; background: var(--green); border-radius: 2px; transition: width .4s ease; max-width: 100%; }
.progress-fill.over { background: var(--amber); }

/* ── EXPORT ─────────────────────────────────────────────────────── */
.export-body { display: flex; flex-direction: column; gap: 16px; padding: 4px 20px; }
.export-desc { font-size: 14px; color: var(--text-2); line-height: 1.6; }
.radio-group { display: flex; flex-direction: column; gap: 2px; }
.radio-row { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border-soft); cursor: pointer; font-size: 14px; color: var(--text-1); }
.radio-row:last-child { border-bottom: none; }
.radio-row input[type="radio"] { accent-color: var(--green); width: 16px; height: 16px; }
.export-preview { overflow: hidden; }
.export-preview-row { display: flex; justify-content: space-between; align-items: baseline; padding: 7px 0; border-bottom: 1px solid var(--border-soft); font-size: 13px; }
.export-preview-row:last-of-type { border-bottom: none; }
.export-preview-date { color: var(--text-2); }
.export-preview-time { color: var(--text-1); font-weight: 500; font-variant-numeric: tabular-nums; }
.export-total { padding-top: 12px; font-size: 14px; font-weight: 600; color: var(--green); text-align: right; }
.export-actions { display: flex; flex-direction: column; gap: 10px; }
.copy-feedback { text-align: center; font-size: 13px; color: var(--green); font-weight: 500; padding: 4px; }

/* ── SETTINGS ───────────────────────────────────────────────────── */
.settings-body { display: flex; flex-direction: column; gap: 16px; padding: 4px 20px; }
.settings-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 4px 0; }
.settings-row-info { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.settings-row-label { font-size: 15px; color: var(--text-1); }
.settings-row-hint  { font-size: 12px; color: var(--text-3); }
.settings-sub-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 0 4px; border-top: 1px solid var(--border-soft); margin-top: 8px; }
.settings-sub-row .settings-row-label { font-size: 13px; color: var(--text-2); }
/* Avdelande rad i ett inställningskort (ersätter upprepad inline-style) */
.settings-row-sep { border-top: 1px solid var(--border-soft); margin-top: 8px; padding-top: 12px; }
#schedule-simple  { margin-top: 14px; }
#schedule-weekday { margin-top: 8px; }
.settings-time-input {
  background: var(--bg); border: 1.5px solid var(--border);
  border-radius: var(--radius-s); padding: 7px 10px;
  font-size: 15px; color: var(--text-1); font-family: inherit; outline: none; width: 110px;
}
.settings-time-input:focus { border-color: var(--green); }

/* Hour stepper */
.hour-stepper { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.stepper-btn {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--border-soft); border: none; color: var(--text-1);
  font-size: 20px; font-weight: 300; cursor: pointer;
  display: flex; align-items: center; justify-content: center; line-height: 1;
  /* Säkerställ att alla snabba tryck registreras */
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
.stepper-btn:active { background: var(--border); }
.stepper-val { font-size: 16px; font-weight: 500; min-width: 48px; text-align: center; font-variant-numeric: tabular-nums; }

/* Toggle switch */
.toggle-switch { position: relative; width: 44px; height: 26px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle-track {
  position: absolute; inset: 0; border-radius: 13px;
  background: var(--border); cursor: pointer; transition: background .2s;
}
.toggle-track::before {
  content: ''; position: absolute;
  width: 20px; height: 20px; border-radius: 50%;
  background: #fff; top: 3px; left: 3px;
  transition: transform .2s; box-shadow: 0 1px 2px rgba(0,0,0,.2);
}
.toggle-switch input:checked + .toggle-track { background: var(--green); }
.toggle-switch input:checked + .toggle-track::before { transform: translateX(18px); }

/* Notification permission */
.notif-permission-row { display: flex; align-items: center; gap: 10px; padding-top: 10px; border-top: 1px solid var(--border-soft); margin-top: 8px; }
.notif-status { font-size: 12px; color: var(--text-3); }

/* Templates */
.template-item { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border-soft); }
.template-item:last-child { border-bottom: none; }
.template-item-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.template-item-name { font-size: 14px; font-weight: 500; color: var(--text-1); }
.template-item-times { font-size: 12px; color: var(--text-3); font-variant-numeric: tabular-nums; }
.btn-delete-template {
  background: none; border: none; padding: 6px;
  color: var(--text-3); cursor: pointer; line-height: 0;
}
.btn-delete-template:active { color: var(--red); }

/* Settings action buttons */
.settings-action-btn {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 0; border: none; background: none;
  color: var(--text-1); font-size: 14px; cursor: pointer;
  font-family: inherit; width: 100%; border-bottom: 1px solid var(--border-soft); text-align: left;
}
.settings-action-btn:last-of-type { border-bottom: none; }
.settings-action-btn:active { opacity: .6; }
.settings-action-btn.danger { color: var(--red); }
.settings-version { text-align: center; font-size: 12px; color: var(--text-3); padding: 8px; }

/* ── TYPE CHIPS ─────────────────────────────────────────────────── */
.type-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.type-chip {
  padding: 6px 12px; border-radius: 100px;
  font-size: 13px; font-weight: 500; border: 1.5px solid var(--border);
  background: none; color: var(--text-2); cursor: pointer; white-space: nowrap; font-family: inherit;
  transition: background .15s, border-color .15s, color .15s;
}
.type-chip[data-type="work"].active    { background: var(--green);   border-color: var(--green);   color: #fff; }
.type-chip[data-type="vacation"].active { background: var(--blue);    border-color: var(--blue);    color: #fff; }
.type-chip[data-type="sick"].active    { background: var(--red);     border-color: var(--red);     color: #fff; }
.type-chip[data-type="vab"].active     { background: var(--purple);  border-color: var(--purple);  color: #fff; }
.type-chip[data-type="holiday"].active { background: var(--text-2);  border-color: var(--text-2);  color: #fff; }
.type-chip[data-type="comp"].active    { background: var(--amber);   border-color: var(--amber);   color: #fff; }
.type-chip[data-type="other"].active   { background: var(--text-2);  border-color: var(--text-2);  color: #fff; }

/* Template quick-apply row */
.template-quick { display: flex; gap: 6px; overflow-x: auto; padding-bottom: 4px; }
.template-quick-btn {
  flex-shrink: 0; padding: 6px 12px; border-radius: 100px;
  font-size: 12px; font-weight: 500; border: 1.5px solid var(--border);
  background: var(--bg); color: var(--text-2); cursor: pointer; white-space: nowrap; font-family: inherit;
}
.template-quick-btn:active { border-color: var(--green); color: var(--green); }

/* ── OVERLAY / SHEET ────────────────────────────────────────────── */
.overlay { position: fixed; inset: 0; z-index: 500; display: flex; align-items: flex-end; justify-content: center; }
.overlay.dialog-mode { align-items: center; }
.overlay.hidden { display: none; }
.overlay-backdrop {
  position: absolute; inset: 0; background: rgba(28,26,22,.42);
  -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
  animation: fadeIn .2s ease;
}
.sheet {
  position: relative; background: var(--surface);
  border-top: 1px solid var(--border-soft);
  border-radius: var(--radius-l) var(--radius-l) 0 0;
  width: 100%; max-width: 480px;
  padding: 12px 20px calc(20px + var(--safe-b));
  box-shadow: var(--shadow-raise);
  animation: slideUp .28s cubic-bezier(.2,.7,.2,1); display: flex; flex-direction: column; gap: 16px;
  overflow-x: hidden;        /* förhindra horisontell scroll */
  box-sizing: border-box;
}
/* sheet-tall: formuläret scrollar, footer sitter fast i botten */
.sheet-tall {
  max-height: 88dvh;
  overflow: hidden;          /* sheeten i sig scrollar INTE */
  padding-bottom: 0;         /* footer hanterar sitt eget padding */
}
.sheet-tall .edit-body,
.sheet-tall .help-body {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  flex: 1;
  min-height: 0;             /* krävs för att flex-scroll ska fungera */
}
.sheet-tall .sheet-footer {
  flex-shrink: 0;
  padding-top: 12px;
  padding-bottom: calc(16px + var(--safe-b));
  background: var(--surface);
  border-top: 1px solid var(--border-soft);
}
.sheet-handle { width: 36px; height: 4px; background: var(--border); border-radius: 2px; margin: 0 auto 4px; flex-shrink: 0; }
.sheet-title { font-family: var(--font-display); font-optical-sizing: auto; font-size: 20px; font-weight: 460; letter-spacing: -.2px; color: var(--text-1); }
.sheet-options { display: flex; flex-direction: column; gap: 4px; }
.sheet-option { position: relative; display: flex; align-items: center; gap: 14px; padding: 14px 12px; border: none; background: var(--bg); border-radius: var(--radius-s); cursor: pointer; text-align: left; transition: background .15s; }
.sheet-option:active { background: var(--green-soft); }
.sheet-option.option-suggested { border: 1.5px solid var(--green); background: var(--green-soft); }
.option-suggest-tag {
  position: absolute; top: 10px; right: 12px;
  font-size: 10px; font-weight: 600; letter-spacing: .4px;
  color: var(--green); background: var(--surface);
  padding: 2px 7px; border-radius: 100px;
}
.option-icon { width: 38px; height: 38px; background: var(--surface); border-radius: var(--radius-s); display: flex; align-items: center; justify-content: center; color: var(--text-2); flex-shrink: 0; box-shadow: var(--shadow-card); }
.option-icon svg { width: 18px; height: 18px; }
.option-info { display: flex; flex-direction: column; gap: 2px; }
.option-name { font-size: 15px; font-weight: 500; color: var(--text-1); }
.option-hint { font-size: 12px; color: var(--text-3); }

.sheet-field { display: flex; flex-direction: column; gap: 6px; }
.sheet-fields-row {
  display: flex;
  gap: 12px;
}
/* På riktigt smala skärmar (<360px) stapla fälten vertikalt */
@media (max-width: 360px) {
  .sheet-fields-row { flex-direction: column; }
}
.flex1 { flex: 1; min-width: 0; }
.field-label { font-size: 11px; font-weight: 600; letter-spacing: .5px; text-transform: uppercase; color: var(--text-3); }
.field-error { font-size: 13px; color: var(--red); padding: 2px 0; }
.time-input-large {
  background: var(--bg); border: 1.5px solid var(--border); border-radius: var(--radius-s);
  padding: 12px 8px; font-size: 18px; font-weight: 300; color: var(--text-1);
  font-family: inherit; outline: none; width: 100%; min-width: 0;
  text-align: center; font-variant-numeric: tabular-nums;
  box-sizing: border-box;
}
.time-input-large:focus { border-color: var(--green); }
.seg-group { display: flex; background: var(--border-soft); border-radius: var(--radius-s); padding: 2px; gap: 2px; }
.seg-btn { flex: 1; background: none; border: none; border-radius: 6px; padding: 8px 4px; font-size: 13px; font-weight: 500; color: var(--text-2); cursor: pointer; font-family: inherit; transition: background .15s, color .15s; }
.seg-btn.active { background: var(--surface); color: var(--text-1); box-shadow: 0 1px 2px rgba(0,0,0,.08); }
.sheet-footer { display: flex; gap: 10px; flex-shrink: 0; }
.sheet-footer .btn { flex: 1; }

/* Edit body */
.edit-body { display: flex; flex-direction: column; gap: 16px; overflow-y: auto; flex: 1; }
.edit-field { display: flex; flex-direction: column; gap: 6px; }
.edit-field label { font-size: 12px; font-weight: 600; letter-spacing: .5px; text-transform: uppercase; color: var(--text-3); }
.edit-field input[type="time"], .edit-field input[type="date"], .edit-field input[type="text"] {
  background: var(--bg); border: 1.5px solid var(--border); border-radius: var(--radius-s);
  padding: 11px 12px; font-size: 15px; color: var(--text-1); font-family: inherit; outline: none; width: 100%;
}
.edit-field input:focus { border-color: var(--green); }
.edit-break-row { display: flex; align-items: center; gap: 8px; background: var(--bg); border-radius: var(--radius-s); padding: 10px 12px; }
.edit-break-label { font-size: 13px; color: var(--text-2); flex: 1; }
.edit-break-times { display: flex; align-items: center; gap: 6px; font-size: 13px; }
.edit-break-times input[type="time"] { background: var(--surface); border: 1.5px solid var(--border); border-radius: 6px; padding: 5px 8px; font-size: 13px; color: var(--text-1); font-family: inherit; outline: none; width: 90px; }
.edit-break-sep { color: var(--text-3); }
.btn-remove-break { background: none; border: none; padding: 4px; cursor: pointer; color: var(--text-3); line-height: 0; }
.btn-remove-break:active { color: var(--red); }
.edit-add-break { background: none; border: 1.5px dashed var(--border); border-radius: var(--radius-s); padding: 10px; color: var(--text-2); font-size: 13px; cursor: pointer; width: 100%; text-align: center; font-family: inherit; margin-top: 4px; display: block; }
.edit-add-break:active { background: var(--green-soft); color: var(--green); border-color: var(--green); }
.btn-delete-day { background: none; border: none; padding: 8px 0; color: var(--red); font-size: 14px; cursor: pointer; font-family: inherit; width: 100%; text-align: center; }

/* Dialog */
.dialog { position: relative; background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--radius-l); padding: 24px 20px; width: calc(100% - 48px); max-width: 340px; display: flex; flex-direction: column; gap: 12px; box-shadow: var(--shadow-raise); animation: scaleIn .2s cubic-bezier(.2,.7,.2,1); }
.dialog-title { font-family: var(--font-display); font-optical-sizing: auto; font-size: 19px; font-weight: 460; letter-spacing: -.2px; }
.dialog-msg { font-size: 14px; color: var(--text-2); line-height: 1.5; }
.dialog-actions { display: flex; gap: 10px; padding-top: 4px; }
.dialog-actions .btn { flex: 1; padding: 13px; }

/* ── ONBOARDING ─────────────────────────────────────────────────── */
.onboarding {
  position: fixed; inset: 0; z-index: 1000;
  background-color: var(--bg);
  background-image: radial-gradient(135% 62% at 50% 2%, var(--halo) 0%, transparent 56%);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: calc(var(--safe-t) + 40px) 32px calc(var(--safe-b) + 40px);
}
.onboarding.hidden { display: none; }
.ob-step {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 16px; width: 100%; max-width: 360px;
  animation: riseIn .55s cubic-bezier(.2,.7,.2,1) both;
}
.ob-step.hidden { display: none; }
/* Ikon i mjuk cirkel-badge med grön glöd (ersätter emoji) */
.ob-icon {
  width: 88px; height: 88px; margin-bottom: 8px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: var(--green-soft); color: var(--green);
  box-shadow: 0 14px 30px -14px var(--green);
  animation: obPop .55s cubic-bezier(.2,.8,.2,1) both;
}
.ob-icon svg { width: 40px; height: 40px; }
@keyframes obPop { from { opacity: 0; transform: scale(.72); } to { opacity: 1; transform: none; } }
.ob-title { font-family: var(--font-display); font-optical-sizing: auto; font-size: 30px; font-weight: 400; letter-spacing: -.4px; color: var(--text-1); line-height: 1.2; }
.ob-desc  { font-size: 15px; color: var(--text-2); line-height: 1.6; }
.ob-btn   { margin-top: 8px; }
.ob-stepper { margin: 8px 0; }
.ob-dots { display: flex; gap: 7px; margin-top: 32px; align-items: center; }
.ob-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--border); transition: background .25s, width .25s; }
.ob-dot.active { background: var(--green); width: 22px; border-radius: 4px; }

/* ── ANOMALY BANNER ──────────────────────────────────────────────── */
.anomaly-banner {
  display: flex; align-items: center; gap: 10px;
  background: var(--amber-soft); border: 1px solid var(--amber);
  border-radius: var(--radius-s); padding: 10px 12px;
  font-size: 13px; color: var(--amber);
}
.anomaly-banner.hidden { display: none; }
.anomaly-banner svg { flex-shrink: 0; }
.anomaly-banner span { flex: 1; }
.anomaly-dismiss {
  background: none; border: none; color: var(--amber);
  cursor: pointer; font-size: 14px; padding: 2px 4px; line-height: 1;
}

/* ── VAD ÄR NYTT-NOTIS ───────────────────────────────────────────── */
.whatsnew-banner {
  display: flex; align-items: flex-start; gap: 11px;
  background: var(--surface); border: 1px solid var(--border-soft);
  border-radius: var(--radius-m); padding: 12px 14px;
  box-shadow: var(--shadow-card);
  animation: riseIn .5s cubic-bezier(.2,.7,.2,1) both;
}
.whatsnew-banner.hidden { display: none; }
.whatsnew-icon { color: var(--green); flex-shrink: 0; margin-top: 1px; line-height: 0; }
.whatsnew-icon svg { width: 18px; height: 18px; }
.whatsnew-text { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }
.whatsnew-text strong { font-size: 13.5px; font-weight: 600; color: var(--text-1); }
.whatsnew-text span { font-size: 12.5px; color: var(--text-2); line-height: 1.5; }
.whatsnew-dismiss { color: var(--text-3); margin: -2px -4px 0 0; }

/* ── SMART SUGGESTION ────────────────────────────────────────────── */
.smart-suggestion {
  display: flex; align-items: center; gap: 10px;
  background: var(--green-soft); border-radius: var(--radius-s);
  padding: 10px 12px;
}
.smart-suggestion.hidden { display: none; }
.smart-suggestion-label { font-size: 12px; color: var(--green); font-weight: 500; }
.smart-suggestion-chip {
  background: var(--surface); border: 1.5px solid var(--green);
  border-radius: 100px; padding: 5px 14px;
  font-size: 14px; font-weight: 500; color: var(--green);
  cursor: pointer; font-family: inherit; font-variant-numeric: tabular-nums;
}
.smart-suggestion-chip:active { background: var(--green-soft); }

/* ── VERSION ─────────────────────────────────────────────────────── */
.version-block { text-align: center; padding: 8px 0 4px; }
.version-label { font-size: 12px; color: var(--text-3); font-variant-numeric: tabular-nums; }

/* ── KOMPBANK ────────────────────────────────────────────────────── */
.comp-bank-val { font-size: 16px; font-weight: 500; color: var(--green); font-variant-numeric: tabular-nums; }

/* ── ÖVERTID STEPPER ─────────────────────────────────────────────── */
.overtime-stepper-row { display: flex; align-items: center; gap: 12px; padding: 4px 0; }
.overtime-val { color: var(--amber); }
.field-hint { font-size: 12px; color: var(--text-3); margin-top: 4px; line-height: 1.4; }
.stat-hint  { font-size: 12px; color: var(--text-3); margin-top: 6px; line-height: 1.4; }

/* ── HOLIDAY CALENDAR ────────────────────────────────────────────── */
.cal-day.is-holiday .cal-day-num { color: var(--red) !important; font-weight: 600; }
.cal-day.is-afton .cal-day-num   { color: var(--amber) !important; }

/* ── INSTALL GUIDE ───────────────────────────────────────────────── */
.install-platform-tabs { display: flex; gap: 4px; background: var(--border-soft); border-radius: var(--radius-s); padding: 2px; }
.install-tab {
  flex: 1; background: none; border: none; border-radius: 6px;
  padding: 7px 4px; font-size: 13px; font-weight: 500; color: var(--text-2);
  cursor: pointer; font-family: inherit; transition: background .15s, color .15s;
}
.install-tab.active { background: var(--surface); color: var(--text-1); box-shadow: 0 1px 2px rgba(0,0,0,.08); }
.install-steps { display: flex; flex-direction: column; gap: 16px; }
.install-step { display: flex; gap: 14px; align-items: flex-start; position: relative; }
/* Förbindande tidslinje mellan stegnumren */
.install-step:not(:last-child)::before {
  content: ''; position: absolute;
  left: 14px; top: 30px; bottom: -16px;
  width: 1.5px; transform: translateX(-50%);
  background: var(--green-soft);
}
.install-step-num {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--green-soft); color: var(--green);
  font-size: 13px; font-weight: 600; display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; position: relative; z-index: 1;
  font-variant-numeric: tabular-nums;
}
.install-step-text { font-size: 14px; color: var(--text-1); line-height: 1.5; padding-top: 4px; }
.install-step-text strong { font-weight: 600; }
.install-note { font-size: 13px; color: var(--text-2); line-height: 1.5; background: var(--border-soft); border-radius: var(--radius-s); padding: 10px 12px; }

/* ── HJÄLP SHEET ─────────────────────────────────────────────────── */
.help-body {
  display: flex; flex-direction: column; gap: 20px;
  overflow-y: auto; flex: 1; padding-bottom: 4px;
}
.help-section { display: flex; flex-direction: column; gap: 10px; }
.help-section-title {
  font-size: 11px; font-weight: 600; letter-spacing: .7px;
  text-transform: uppercase; color: var(--text-3);
}
.help-item { display: flex; flex-direction: column; gap: 3px; }
.help-item-label { font-size: 14px; font-weight: 500; color: var(--text-1); }
.help-item-desc  { font-size: 13px; color: var(--text-2); line-height: 1.5; }

/* ── PUNKT 4 + SPÅR A ────────────────────────────────────────────── */
/* Veckodagsschema-rader */
.wk-row { padding: 7px 0; border-bottom: 1px solid var(--border-soft); }
.wk-row:last-child { border-bottom: none; }
.wk-row .settings-row-label { font-size: 14px; }
.wk-val { min-width: 56px; }

/* Select i formulär */
.edit-select {
  background: var(--bg); border: 1.5px solid var(--border); border-radius: var(--radius-s);
  padding: 11px 12px; font-size: 15px; color: var(--text-1);
  font-family: inherit; outline: none; width: 100%; -webkit-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237A7A78' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
}
.edit-select:focus { border-color: var(--green); }

/* Delad, mjuk fokus-ring på alla textfält — palett-konsekvent premiumkänsla.
   Gäller mus/touch-fokus; tangentbordsfokus får dessutom den globala
   :focus-visible-outlinen längre ned (WCAG 2.4.7). */
.time-input-large:focus,
.settings-time-input:focus,
.edit-field input:focus,
.edit-select:focus,
.edit-break-times input[type="time"]:focus {
  box-shadow: 0 0 0 3px var(--green-soft);
}
/* Tidsfält visar tabulära siffror så kolonen inte vandrar */
.edit-field input[type="time"], .edit-field input[type="date"] { font-variant-numeric: tabular-nums; }

/* Projektrad i Idag-kortet */
.today-project-row { cursor: pointer; }
.today-project-row:active { opacity: .6; }
.today-project-val { color: var(--green); }

/* Projekttag i historik */
.day-project-tag {
  display: inline-block; font-size: 11px; font-weight: 500;
  color: var(--green); background: var(--green-soft);
  padding: 1px 8px; border-radius: 100px; margin-top: 2px;
}

/* Backup-status i inställningar */
.backup-status {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text-2);
  padding: 0 0 12px; border-bottom: 1px solid var(--border-soft); margin-bottom: 4px;
}
.backup-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.backup-dot.ok   { background: var(--green-mid); }
.backup-dot.warn { background: var(--amber); }

/* Backup-banner på hemskärmen */
.backup-banner {
  display: flex; align-items: center; gap: 10px;
  background: var(--green-soft); border: 1px solid var(--green-mid);
  border-radius: var(--radius-s); padding: 10px 12px;
  font-size: 13px; color: var(--green);
}
.backup-banner.hidden { display: none; }
.backup-banner svg { flex-shrink: 0; }
.backup-banner span { flex: 1; }
.backup-banner-btn {
  background: var(--green); color: #fff; border: none;
  border-radius: 100px; padding: 6px 12px; font-size: 12px; font-weight: 600;
  cursor: pointer; font-family: inherit; flex-shrink: 0;
}

/* ── PROJEKTTIMER-RAD ────────────────────────────────────────────── */
.project-timer-row {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--surface); border-radius: var(--radius-m);
  padding: 10px 14px; box-shadow: var(--shadow-card);
  border-left: 3px solid var(--border);
  transition: border-color .3s;
}
.project-timer-row.active { border-left-color: var(--green); background: linear-gradient(90deg, var(--green-soft) 0%, var(--surface) 38%); }
.project-timer-row.hidden { display: none !important; }
.project-timer-left { display: flex; align-items: center; gap: 9px; }
.project-timer-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
  background: var(--text-3);
}
/* Lugnt "andande" prick signalerar att timern är aktiv (live) */
.project-timer-row.active .project-timer-dot { background: var(--green-mid); animation: pulseDot 2.4s ease-in-out infinite; }
@keyframes pulseDot { 0%, 100% { opacity: 1; } 50% { opacity: .4; } }
.project-timer-name { font-size: 14px; font-weight: 500; color: var(--text-1); }
.project-timer-dur  { font-size: 13px; color: var(--text-2); font-variant-numeric: tabular-nums; }
.project-timer-switch {
  display: flex; align-items: center; gap: 3px;
  background: none; border: none; color: var(--green);
  font-size: 13px; font-weight: 500; cursor: pointer;
  font-family: inherit; padding: 4px 0;
}
.project-timer-switch:active { opacity: .6; }

/* Fördela-knapp */
.btn-allocate { color: var(--blue); }

/* ── PROJEKTFÖRDELNING SHEET ──────────────────────────────────────── */
.project-dist-body { display: flex; flex-direction: column; gap: 14px; overflow-y: auto; flex: 1; min-height: 0; }
.dist-row { display: flex; flex-direction: column; gap: 6px; }
.dist-row-top { display: flex; justify-content: space-between; align-items: baseline; }
.dist-proj-name { font-size: 15px; font-weight: 500; color: var(--text-1); }
.dist-pct { font-size: 13px; color: var(--text-2); font-variant-numeric: tabular-nums; }
.dist-controls { display: flex; align-items: center; gap: 12px; }
.dist-time { font-size: 16px; font-weight: 300; color: var(--text-1); min-width: 60px; font-variant-numeric: tabular-nums; }
.project-dist-summary {
  display: flex; flex-direction: column; gap: 4px;
  padding: 12px 0 4px; border-top: 1px solid var(--border-soft);
  flex-shrink: 0;
}
.dist-summary-row {
  display: flex; justify-content: space-between;
  font-size: 13px; color: var(--text-2); font-variant-numeric: tabular-nums;
}
.dist-summary-row.warn span:last-child { color: var(--amber); font-weight: 600; }
.dist-summary-row.ok  span:last-child { color: var(--green);  font-weight: 600; }

/* ── UPPDATERINGS-BANNER ─────────────────────────────────────────── */
.update-banner {
  position: fixed;
  bottom: calc(var(--nav-h) + var(--safe-b) + 8px);
  left: 8px; right: 8px;
  max-width: 464px;          /* matchar app max-width - marginaler */
  margin: 0 auto;
  background: var(--surface);
  border: 1.5px solid var(--green);
  border-radius: var(--radius-l);
  padding: 14px 16px;
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
  z-index: 1000;
  display: flex; flex-direction: column; gap: 12px;
  animation: slideUpBanner .3s ease;
}
.update-banner.hidden { display: none !important; }
@keyframes slideUpBanner {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.update-banner-content {
  display: flex; align-items: flex-start; gap: 10px; color: var(--text-1);
}
.update-banner-text {
  display: flex; flex-direction: column; gap: 2px;
}
.update-banner-text strong { font-size: 14px; font-weight: 600; color: var(--green); }
.update-banner-text span   { font-size: 13px; color: var(--text-2); line-height: 1.4; }
.update-banner-actions { display: flex; gap: 8px; }
.update-btn-primary {
  flex: 1; background: var(--green); color: #fff;
  border: none; border-radius: var(--radius-m);
  padding: 11px 8px; font-size: 14px; font-weight: 500;
  cursor: pointer; font-family: inherit; font-variant-numeric: tabular-nums;
}
.update-btn-primary:active { opacity: .8; }
.update-btn-secondary {
  flex: 1; background: var(--bg); color: var(--text-1);
  border: 1.5px solid var(--border); border-radius: var(--radius-m);
  padding: 11px 8px; font-size: 14px; font-weight: 500;
  cursor: pointer; font-family: inherit;
}
.update-btn-secondary:active { border-color: var(--green); color: var(--green); }

/* ── ANIMATIONS ─────────────────────────────────────────────────── */
@keyframes fadeIn  { from { opacity: 0 } to { opacity: 1 } }
@keyframes slideUp { from { transform: translateY(100%) } to { transform: translateY(0) } }
@keyframes scaleIn { from { opacity: 0; transform: scale(.93) } to { opacity: 1; transform: scale(1) } }
::-webkit-scrollbar { display: none; }
* { scrollbar-width: none; }

/* ── TILLGÄNGLIGHET (granskningsåtgärder A-02, A-03, A-05) ─────────── */
/* Synlig fokusindikering för tangentbordsnavigering (WCAG 2.4.7).
   :where() håller specificiteten låg; !important vinner över äldre
   outline:none på inputfälten. */
:where(a, button, input, select, textarea, [tabindex]):focus-visible {
  outline: 2px solid var(--green) !important;
  outline-offset: 2px;
  border-radius: 4px;
}

/* Visuellt dold men läsbar för skärmläsare (live-region för statusbyten) */
.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  margin: -1px; padding: 0; border: 0;
  clip: rect(0 0 0 0); clip-path: inset(50%);
  overflow: hidden; white-space: nowrap;
}

/* Respektera nedsatt rörelsetolerans (WCAG 2.3.3) */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* A-06: uppdateringsknappens text mot grön bakgrund — mörk text i mörkt tema
   (vit på ljusgrön #4DB880 gav ~2:1; mörkgrön text ger >6:1). */
:root { --on-green: #fff; }
@media (prefers-color-scheme: dark) { :root { --on-green: #0E211A; } }
.theme-light { --on-green: #fff; }
.theme-dark  { --on-green: #0E211A; }
.update-btn-primary { color: var(--on-green); }
