/* VaktLønn – main stylesheet
 * Grunnleggende layout og typografi for app-skjelettet + kontrakt, kalender, resultat.
 */

/* Reset / base */

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

:root {
  --vl-bg: #f5f5f5;
  --vl-surface: #ffffff;
  --vl-border: #dddddd;
  --vl-text: #222222;
  --vl-muted: #666666;
  --vl-accent: #00796b;
  --vl-accent-soft: #e0f2f1;
  --vl-danger: #c62828;
  --vl-radius: 8px;
  --vl-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);
}

body {
  margin: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background-color: var(--vl-bg);
  color: var(--vl-text);
}

#app {
  min-height: 100vh;
  padding: 1rem;
}

/* Header */

.vl-header {
  background-color: var(--vl-surface);
  border-radius: var(--vl-radius);
  box-shadow: var(--vl-shadow);
  padding: 1.25rem 1.5rem;
  margin-bottom: 1rem;
  border: 1px solid var(--vl-border);
}

.vl-header-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.vl-header-top-left {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.vl-header-top-right {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

/* Mobile mini header (app-like) */
.vl-mini-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 60;
  height: 3.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 0.85rem;
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid var(--vl-border);
}

.vl-mini-header-title {
  font-weight: 800;
  font-size: 1.35rem;
  letter-spacing: -0.02em;
}

.vl-mini-help-btn {
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 999px;
  border: 1px solid var(--vl-border);
  background: transparent;
  font-weight: 800;
  font-size: 1.15rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Header mode toggle (UI placeholder only — not wired up yet) */
.vl-header-mode-toggle-row {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.35rem;
}

.vl-header-mode-toggle {
  margin: 0; /* override default toggle-group margins in header */
}

.vl-header-nav-link {
  text-decoration: none;
  color: inherit;
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}

.vl-title {
  font-size: 1.6rem;
  margin: 0;
}

.vl-version-badge {
  font-size: 0.85rem;
  padding: 0.1rem 0.5rem;
  border-radius: 999px;
  border: 1px solid var(--vl-accent);
  color: var(--vl-accent);
}

/* Beta shell marker (visible only on beta.html via ui-init.js) */
.vl-beta-badge {
  display: inline-block;
  margin-left: 0.5rem;
  padding: 0.1rem 0.45rem;
  border: 1px solid rgba(0, 0, 0, 0.35);
  border-radius: 999px;
  font-size: 0.75rem;
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: 0.04em;
  vertical-align: middle;
}

.vl-tagline {
  margin: 0.5rem 0 0;
  color: var(--vl-muted);
}

.vl-template-info {
  margin: 0.25rem 0 0;
  font-size: 0.9rem;
  color: var(--vl-muted);
}

/* Main layout */

.vl-main {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1rem;
}

/* Panels */

.vl-panel {
  background-color: var(--vl-surface);
  border-radius: var(--vl-radius);
  box-shadow: var(--vl-shadow);
  padding: 1.25rem 1.5rem;
  border: 1px solid var(--vl-border);
}

.vl-panel > h2 {
  margin-top: 0;
  margin-bottom: 0.5rem;
}

/* Main panels as collapsible <details> (same mechanism as Resultat detail sections) */
.vl-panel > summary {
  cursor: pointer;
  user-select: none;
}

.vl-panel > summary:focus-visible {
  outline: 2px solid #00838f;
  outline-offset: 3px;
  border-radius: 6px;
}

.vl-panel > summary > h2 {
  display: inline;
  margin: 0;
}

.vl-panel[open] > summary {
  margin-bottom: 0.5rem; /* match previous h2 spacing */
}

.vl-panel > p {
  margin-top: 0;
  color: var(--vl-muted);
}

/* Footer, confidentiality and disclaimer */

.vl-footer {
  font-size: 0.8rem;
  color: var(--vl-muted);
  padding: 0.75rem 0.5rem 0.5rem;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.vl-confidential-label {
  margin: 0 0 0.25rem;
  font-weight: 600;
  color: var(--vl-danger);
}

.vl-short-disclaimer {
  margin: 0;
}

/* Form layout for contract panel */

.vl-panel-intro {
  margin-top: 0.25rem;
  margin-bottom: 0.75rem;
  color: var(--vl-muted);
}

/* When a panel intro is also a help-text, keep the intended spacing without enlarging text */
.vl-panel-intro.vl-help-text {
  font-size: inherit;
}

.vl-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.vl-field-group {
  margin-bottom: 0.5rem;
}

.vl-field-group-inner {
  margin-top: 0.5rem;
}

.vl-label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.25rem;
}

.vl-label-inline {
  font-weight: 500;
  margin-right: 0.5rem;
}

.vl-help-text {
  margin: 0 0 0.5rem;
  font-size: 0.85rem;
  color: var(--vl-muted);
}

/* Om: meta-linjer under beskrivelsesboksen (uten outline) */
.vl-about-meta {
  margin-top: 0.75rem;
}

.vl-about-meta .vl-help-text {
  margin: 0.35rem 0;
}

/* Vakter: short expandable tip line */
.vl-vakter-tip {
  margin: 0.2rem 0 0.6rem;
}

.vl-vakter-tip-line {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  width: 100%;
  text-align: left;
  font: inherit;
  color: var(--vl-muted);
  cursor: pointer;
}

.vl-vakter-tip-line:hover {
  text-decoration: underline;
}

.vl-vakter-tip-more {
  margin-top: 0.35rem;
  color: var(--vl-muted);
  font-size: 0.9rem;
  line-height: 1.35;
}

.vl-input,
.vl-select,
.vl-textarea {
  width: 100%;
  max-width: 100%;
  padding: 0.4rem 0.5rem;
  border-radius: 4px;
  border: 1px solid var(--vl-border);
  font: inherit;
}

.vl-input-small,
.vl-select-small {
  padding: 0.35rem 0.45rem;
  border-radius: 4px;
  border: 1px solid var(--vl-border);
  font: inherit;
  max-width: 10rem;
}

.vl-input-invalid {
  border-color: var(--vl-danger);
  outline: 2px solid var(--vl-danger);
  outline-offset: 0;
}

/* Ensure invalid styling also applies to selects */
.vl-select.vl-input-invalid {
  border-color: var(--vl-danger);
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.12);
}

/* Small inline validation message */
.vl-field-error {
  margin-top: 0.25rem;
  font-size: 0.95rem;
  color: var(--vl-danger);
}

.vl-textarea {
  resize: vertical;
}

.vl-inline-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.25rem;
}

.vl-section-subheader {
  font-size: 1.25rem;
  font-weight: 700;
}

/* Toggle control (segmented buttons) */
.vl-toggle-group {
  display: inline-flex;
  border: 1px solid var(--vl-border);
  border-radius: 6px;
  overflow: hidden;
  background: #fff;
  margin: 0.25rem 0 0.5rem;
}

.vl-toggle-button {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0.35rem 0.7rem;
  font: inherit;
  cursor: pointer;
  line-height: 1.2;
}

.vl-toggle-button:hover {
  background: var(--vl-accent-soft);
}

.vl-toggle-button.active {
  background: var(--vl-accent);
  color: #ffffff;
  font-weight: 600;
}

.vl-toggle-button:focus-visible {
  outline: 2px solid #00838f;
  outline-offset: -2px;
}

/* Vakter: single mode swap button (shows only the alternative) */
.vl-mode-swap-wrap {
  display: inline-flex;
  margin: 0.25rem 0 0.5rem;
}

/* Vakter: single mode swap button (shows only the alternative) */
.vl-mode-swap-btn {
  border: 1px solid var(--vl-border);
  border-radius: 999px;
  background: transparent;
  padding: 0.45rem 0.85rem;
  font-weight: 700;
  font-size: 0.98rem;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

/* Warning badge (future date) */
.vl-warning-badge {
  display: inline-block;
  padding: 0.35rem 0.6rem;
  border-radius: var(--vl-radius);
  background: #fff8e1;
  color: #6b4b00;
  border: 1px solid #ffe08a;
  font-size: 0.9rem;
  margin: 0.4rem 0 0.6rem;
}

/* Checkbox list for allowances */

.vl-checkbox-list {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.vl-checkbox-row {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: 0.25rem 0.35rem;
  border-radius: 4px;
}

.vl-checkbox-row input[type="checkbox"] {
  margin-top: 0.15rem;
}

.vl-checkbox-text {
  display: flex;
  flex-direction: column;
}

.vl-checkbox-label {
  font-size: 0.9rem;
}

.vl-checkbox-sub {
  font-size: 0.8rem;
  color: var(--vl-muted);
}

.vl-checkbox-row-disabled {
  opacity: 0.5;
}

/* Disclaimer overlay */

.vl-disclaimer-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.4);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vl-disclaimer-dialog {
  background-color: var(--vl-surface);
  border-radius: var(--vl-radius);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
  max-width: 520px;
  width: calc(100% - 2rem);
  padding: 1.25rem 1.5rem 1rem;
  border: 1px solid var(--vl-border);
}

.vl-disclaimer-dialog h2 {
  margin-top: 0;
  margin-bottom: 0.5rem;
}

.vl-disclaimer-body {
  margin: 0 0 0.75rem;
  font-size: 0.9rem;
  line-height: 1.4;
}

.vl-disclaimer-hint {
  margin: 0 0 0.75rem;
  font-size: 0.85rem;
  color: var(--vl-muted);
}

.vl-disclaimer-buttons {
  display: flex;
  justify-content: flex-end;
}

.help-icon-button{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  line-height: 1;
  border: 1px solid rgba(0,0,0,0.12);
  background: rgba(0,0,0,0.04);
  color: inherit;
  -webkit-tap-highlight-color: transparent;
}

.help-icon-button:focus{
  outline: 2px solid rgba(0,0,0,0.25);
  outline-offset: 2px;
}

.help-icon-button:hover{
  background: rgba(0,0,0,0.08);
}

/* Quick-entry (Enkelte skift): boxed input sections */
.vl-quick-entry-box {
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 10px;
  padding: 0.75rem;
  background: var(--vl-surface);
}

/* Quick-entry: always-visible clear button row (outside collapsible subsection) */
.vl-quick-global-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.75rem;
}

/* Quick-entry: separator above always-visible global actions (Slett alle vakter) */
.vl-quick-global-actions-hr {
  width: 100%;
  border: 0;
  border-top: 1px solid var(--vl-border);
  margin: 0.75rem 0 0;
}

/* Avoid excessive vertical spacing: the HR already provides separation */
.vl-quick-global-actions-hr + .vl-quick-global-actions {
  margin-top: 0.5rem;
}

/* Enkelte skift: collapsible rows sub-section (match Results disclosure style) */
.vl-subsection-toggle {
  width: 100%;
  text-align: left;

  /* remove "boxed button" look */
  border: 0;
  border-radius: 0;
  background: transparent;

  /* use HR-style separator like Results details */
  border-top: 1px solid var(--vl-border);
  margin-top: 0.75rem;
  padding: 0.5rem 0;

  /* match subheader size/weight */
  font: inherit;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--vl-text);

  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.6rem;

  -webkit-tap-highlight-color: transparent;
  appearance: none;
  -webkit-appearance: none;
}

/* Left-side disclosure arrow (collapsed/expanded) */
.vl-subsection-toggle::before {
  content: "▸";
  display: inline-block;
  flex: 0 0 auto;
  width: 1.1rem;
  text-align: center;
  line-height: 1;
  font-weight: 700;
  opacity: 0.75;
}

.vl-subsection-toggle[aria-expanded="true"]::before {
  content: "▾";
}

/* Registrerte vakter header: no disclosure arrow; use Vis/Skjul pill on the right */
.vl-subsection-toggle--pill::before {
  content: none;
  display: none;
}

.vl-subsection-pill {
  margin-left: auto;
  border: 1px solid var(--vl-border);
  border-radius: 999px;
  padding: 0.18rem 0.6rem;
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.2;
  color: var(--vl-text);
  background: transparent;
  opacity: 0.95;
}

.vl-subsection-content {
  padding-top: 0.35rem;
}

/* Registrerte vakter: collapsed summary badges (no outline) */
.vl-subsection-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.75rem;
  margin-top: 0.2rem;
  color: var(--vl-muted);
  font-size: 0.95rem;
  font-weight: 500;
  line-height: 1.2;
  pointer-events: none; /* clicks still toggle the header */
}

.vl-subsection-badge {
  white-space: nowrap;
  pointer-events: none;
}

/* Quick-entry: subtle feedback flash after OK (non-intrusive) */
@keyframes vlFlashBadge {
  0% { background: transparent; box-shadow: 0 0 0 0 rgba(0,0,0,0); }
  20% { background: var(--vl-accent-soft); box-shadow: 0 0 0 4px var(--vl-accent-soft); }
  100% { background: transparent; box-shadow: 0 0 0 0 rgba(0,0,0,0); }
}

.vl-flash-badge {
  border-radius: 6px;
  animation: vlFlashBadge 650ms ease-out;
}

@keyframes vlFlashRow {
  0% { background: transparent; }
  25% { background: var(--vl-accent-soft); }
  100% { background: transparent; }
}

.vl-quick-row-flash {
  animation: vlFlashRow 700ms ease-out;
}

/* Collapsed badges shown below the header: align with title text (not under the arrow) */
.vl-subsection-badges--below {
  padding-left: 1.7rem; /* arrow width (1.1rem) + gap (~0.6rem) */
  margin-top: -0.15rem;
  margin-bottom: 0.35rem;
}

/* Hide badges when expanded (badges sit directly after the toggle button) */
.vl-subsection-toggle[aria-expanded="true"] + .vl-subsection-badges {
  display: none;
}

.vl-subsection-toggle--pill + .vl-subsection-badges--below {
  padding-left: 0;
}

/* Header salary badges (under ? button, right-justified) */
.vl-header-badges {
  display: flex;
  gap: 0.4rem;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 0.35rem;
}

.vl-header-badge {
  border: 1px solid rgba(0, 0, 0, 0.22);
  border-radius: 999px;
  padding: 0.2rem 0.55rem;
  font-size: 0.85rem;
  line-height: 1.2;
  background: transparent;
  white-space: nowrap;
}

/* Beta quick-entry row lock button (padlock) */

.vl-quick-row-card {
  position: relative;
}

.vl-lock-button {
  position: absolute;
  top: 0.45rem;
  right: 0.45rem;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.12);
  background: rgba(0,0,0,0.06);
  color: inherit;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  font-size: 1rem;
  -webkit-tap-highlight-color: transparent;
}

/* SVG lock icons: clearer than emoji at small sizes */
.vl-lock-button .vl-lock-icon {
  width: 1.15rem;
  height: 1.15rem;
  display: block;
  pointer-events: none;
}

.vl-lock-button .vl-lock-icon path,
.vl-lock-button .vl-lock-icon rect {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.vl-lock-button:hover {
  background: rgba(0,0,0,0.08);
}

/* Locked vs unlocked tint (keep icon shape difference as primary cue) */
.vl-lock-button--locked {
  background: rgba(0,0,0,0.10);
}

.vl-lock-button--locked:hover {
  background: rgba(0,0,0,0.14);
}

.vl-lock-button--unlocked {
  background: rgba(0,128,0,0.14);
}

.vl-lock-button--unlocked:hover {
  background: rgba(0,128,0,0.20);
}

.vl-lock-button:focus {
  outline: 2px solid rgba(0,0,0,0.25);
  outline-offset: 2px;
}

.vl-quick-row-card--locked {
  opacity: 0.9;
}

/* Quick-entry row: cleaner unlocked editor layout */
.vl-quick-row-top {
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
}

.vl-quick-row-hours-label {
  font-weight: 600;
  white-space: nowrap;
}

.vl-quick-row-top .vl-input {
  flex: 1 1 6rem;
  min-width: 6rem;
}

/* Place category dropdown on its own line for readability */
.vl-quick-row-top .vl-select {
  flex: 1 1 100%;
  order: 10;
}

/* Keep delete near the hours input */
.vl-quick-row-top .vl-quick-row-delete {
  order: 5;
}

/* Locked rows: show compact summary, hide the technical editor UI */
.vl-quick-row-summary {
  display: none;
  margin-top: 0.2rem;
}

.vl-quick-row-card--locked .vl-quick-row-editor {
  display: none;
}

.vl-quick-row-card--locked .vl-quick-row-summary {
  display: block;
}

.vl-quick-row-summary-line {
  display: flex;
  gap: 0.35rem;
  align-items: baseline;
  margin-top: 0.25rem;
}

.vl-quick-row-summary-label {
  font-weight: 600;
  white-space: nowrap;
}

.vl-quick-row-summary-value {
  font-weight: 700;
}

.vl-quick-row-summary-type {
  margin-top: 0.2rem;
  font-weight: 600;
  color: rgba(0,0,0,0.70);
}

.vl-quick-row-summary-muted {
  color: rgba(0,0,0,0.70);
}

/* Beta quick-entry: disable + grey out row delete when row is locked */
.vl-quick-row-delete:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.vl-quick-row-delete:disabled:hover {
  background-color: var(--vl-surface); /* prevent hover highlight */
}

.vl-results-month-controls {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  margin-top: 0.25rem;
}

.vl-results-month-controls.is-hidden {
  display: none;
}

/* Beta Resultat: compact month selector controls (contextual, not primary) */
.vl-results-month-nav {
  padding: 0.32rem 0.6rem;
  font-size: 0.95rem;
  line-height: 1.1;
  border-radius: 999px;
}

.vl-button-primary {
  border: none;
  border-radius: 999px;
  padding: 0.4rem 0.9rem;
  font: inherit;
  cursor: pointer;
  background-color: var(--vl-accent);
  color: #ffffff;
}

.vl-button-primary:hover {
  background-color: #006057;
}

/* Shared primary button colours for day-detail sheet (colour only) */
.vl-daydetail-primary-btn {
  background: var(--vl-accent);
  border-color: var(--vl-accent);
  color: #fff;
}

.vl-daydetail-primary-btn:hover {
  background: #006057;
  border-color: #006057;
}

.vl-daydetail-primary-btn:active {
  background: #006057;
  border-color: #006057;
}

/* Calendar panel */

.vl-calendar-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
  gap: 0.5rem;
}

.vl-calendar-period-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin: 0.5rem 0;
}

.vl-calendar-period-field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 180px;
  flex: 1 1 220px;
}

.vl-calendar-period-note {
  color: #6b4b00;
}

.vl-calendar-period-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin: 0.35rem 0 0.5rem;
}

.vl-calendar-period-label {
  font-weight: 600;
  text-align: center;
  flex: 1 1 auto;
}

.vl-calendar-week-table {
  margin-top: 0.25rem;
}

.vl-calendar-navblock {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  gap: 0.35rem;
}

.vl-calendar-navrow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  width: 100%;
}

.vl-calendar-navblock .vl-calendar-monthlabel {
  text-align: center;
}

.vl-calendar-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  flex: 0 0 auto;
  align-self: flex-start;
}

.vl-calendar-monthlabel {
  font-weight: 600;
}

.vl-calendar-navbtn {
  border-radius: 999px;
  border: 1px solid var(--vl-border);
  padding: 0.25rem 0.7rem;
  background-color: var(--vl-surface);
  cursor: pointer;
  font: inherit;
}

.vl-calendar-navbtn:hover {
  background-color: var(--vl-accent-soft);
}

.vl-calendar-resetbtn {
  padding: 0.45rem 0.75rem;
  border-radius: 0.5rem;
  border: 1px solid var(--vl-border);
  background: #fff;
  font: inherit;
  cursor: pointer;
}

.vl-calendar-resetbtn:active {
  transform: translateY(1px);
}

.vl-results-details {
  margin-top: 0.75rem;
  border-top: 1px solid var(--vl-border);
  padding-top: 0.5rem;
}

/* Kontrakt: no separator line above the first internal section ("Basislønn") */
#vl-settings-panel .vl-results-details {
  border-top: 0;
}

/* Re-add the separator for all subsequent Kontrakt sections */
#vl-settings-panel .vl-results-details ~ .vl-results-details {
  border-top: 1px solid var(--vl-border);
}

.vl-results-details summary {
  cursor: pointer;
  font-weight: 600;
  user-select: none;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  list-style: none; /* avoid native marker inconsistencies on mobile */
}

/* Hide native disclosure markers (we render our own for cross-browser consistency) */
.vl-results-details > summary::-webkit-details-marker {
  display: none;
}

.vl-results-details > summary::marker {
  content: "";
}

/* Custom disclosure arrow (works even when summary is display:flex on iOS Safari) */
.vl-results-details > summary::before {
  content: "▸";
  display: inline-block;
  flex: 0 0 auto;
  width: 1.1rem;
  text-align: center;
  line-height: 1;
  transform: rotate(0deg);
  transition: transform 0.15s ease-in-out;
}

.vl-results-details[open] > summary::before {
  transform: rotate(90deg);
}

/* Results: MinGat check uses a button-style header (no disclosure arrow) */
.vl-results-details.vl-ttla-toggle > summary::before {
  content: none;
  display: none;
}

/* Keep the button header compact (avoid default toggle-group margins in a summary row) */
.vl-results-details.vl-ttla-toggle > summary .vl-toggle-group {
  margin: 0;
}

/* Summary itself is not the interactive control (button is) */
.vl-results-details.vl-ttla-toggle > summary {
  cursor: default;
  gap: 0.5rem;
}

.vl-results-details summary .vl-section-subheader {
  display: inline-flex;
  align-items: center;
  flex: 1 1 auto;
}

/* Kontrakt: interne seksjoner skal alltid være åpne og ikke-kollapsbare */
#vl-settings-panel .vl-results-details > summary {
  cursor: default;
  font-weight: 750;
  font-size: 1.10rem;
  gap: 0.45rem;
  pointer-events: none;
}

/* Fjern custom disclosure-arrow kun i Kontrakt */
#vl-settings-panel .vl-results-details > summary::before {
  content: none;
  display: none;
}

/* Ingen ekstra padding beregnet for pil på mobil, kun i Kontrakt */
@media (max-width: 600px) {
  #vl-settings-panel .vl-results-details > summary {
    padding-left: 0;
  }

  #vl-settings-panel .vl-results-details[open] > summary::before {
    content: none;
    display: none;
  }
}

/* Resultater: enkelte seksjoner skal alltid være åpne og ikke-kollapsbare (ingen pil) */
.vl-results-details--static > summary {
  cursor: default;
  pointer-events: none;
}

.vl-results-details--static > summary::before {
  content: none;
  display: none;
}

/* Resultater: kompakt indre <details> (brukes f.eks. i forskyvning-detaljer) */
.vl-results-details--inner {
  margin-top: 0.5rem;
  border-top: 0;
  padding-top: 0;
}

/* Resultater: tapp på beløpskortet (Kr ...) for å vise/skjule detaljer */
.vl-results-card-details {
  margin-top: 0.4rem;
}

.vl-results-card-details > summary {
  cursor: pointer;
  user-select: none;
  list-style: none; /* avoid native marker inconsistencies */
  display: block;
  position: relative;
}

/* Hide native disclosure markers */
.vl-results-card-details > summary::-webkit-details-marker {
  display: none;
}
.vl-results-card-details > summary::marker {
  content: "";
}

/* Subtle chevron on the right to indicate expand/collapse */
.vl-results-card-summary::after {
  content: "▸";
  position: absolute;
  right: 0.1rem;
  top: 0.15rem;
  line-height: 1;
  font-size: 1.05rem;
  opacity: 0.75;
}

.vl-results-card-details[open] > summary.vl-results-card-summary::after {
  content: "▾";
}

.vl-results-card-body {
  margin-top: 0.35rem;
}

/* Small, generic heading inside opened card details */
.vl-results-subtitle {
  font-weight: 600;
  margin: 0.25rem 0 0.25rem;
}

@media (max-width: 600px) {
  .vl-results-details--static > summary {
    padding-left: 0;
  }

  .vl-results-details--static[open] > summary::before {
    content: none;
    display: none;
  }
}

/* Mobile: ensure disclosure arrows are visible for nested <details> summaries (iOS Safari can hide markers when summary is flex) */
@media (max-width: 600px) {
  /* Mobile: hide app version badge in header to save space */
  .vl-version-badge {
    display: none;
  }

  .vl-results-details > summary {
    position: relative;
    padding-left: 1.1rem; /* space for our arrow */
  }

  /* Hide native markers (avoid double icons) */
  .vl-results-details > summary::-webkit-details-marker {
    display: none;
  }

  .vl-results-details > summary::marker {
    content: "";
  }

  /* Custom arrow */
  .vl-results-details > summary::before {
    content: "▸";
    position: absolute;
    left: 0;
    top: 0.05rem;
    line-height: 1;
    font-size: 1rem;
  }

  .vl-results-details[open] > summary::before {
    content: "▾";
  }
}

.vl-results-otday-table,
.vl-results-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 0.5rem;
  font-size: 0.9rem;
}

.vl-results-otday-table th,
.vl-results-otday-table td,
.vl-results-table th,
.vl-results-table td {
  border: 1px solid var(--vl-border);
  padding: 0.35rem 0.5rem;
  text-align: left;
}

.vl-results-otday-table th,
.vl-results-table th {
  background-color: #fafafa;
  font-weight: 600;
}

.vl-results-table th.num,
.vl-results-table td.num {
  text-align: right;
}

/* Results breakdown table: keep amounts on one line and prioritise the Beløp column */
.vl-results-table-breakdown th:nth-child(2),
.vl-results-table-breakdown td:nth-child(2) {
  width: 4.5rem; /* Timer column */
}

.vl-results-table-breakdown th:nth-child(3),
.vl-results-table-breakdown td:nth-child(3) {
  width: 8.5rem;          /* Beløp column */
  white-space: nowrap;    /* prevent "Kr 3 601,09" wrapping */
}

.vl-calendar-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.vl-calendar-table th,
.vl-calendar-table td {
  border: 1px solid var(--vl-border);
  padding: 0.25rem 0.4rem;
  text-align: left;
}

.vl-calendar-table th {
  background-color: #fafafa;
  font-weight: 600;
}

.vl-calendar-row-permisjon {
  opacity: 0.55;
}

.vl-calendar-perm-cb {
  transform: scale(1.15);
  cursor: pointer;
}

.vl-calendar-overtime-btn {
  border: 1px solid transparent;
  background: transparent;
  padding: 0.2rem 0.5rem;
  border-radius: 6px;
  margin-left: 0.15rem;
  font-size: 0.85rem;
  line-height: 1;
  cursor: pointer;
}

.vl-calendar-overtime-btn.active {
  background: #2e7d32;
  border-color: #2e7d32;
  color: #ffffff;
  font-weight: 600;
}

.vl-calendar-overtime-btn:focus-visible {
  outline: 2px solid #00838f;
  outline-offset: 2px;
}

.vl-calendar-red-day {
  color: var(--vl-danger);
  background-color: #ffecec;
}

.vl-calendar-red-row td {
  color: var(--vl-danger);
  background-color: #ffecec;
}

.vl-calendar-overtime-detail {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: #ffffff;
  display: none;
  overflow-y: auto;
}

.vl-calendar-overtime-detail-inner {
  box-sizing: border-box;
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
  min-height: 100vh;
  padding: 1.25rem 1.5rem calc(env(safe-area-inset-bottom, 0px) + 12rem);
  background: #ffffff;
  box-shadow: none;
  border-radius: 0;
}

.vl-calendar-overtime-close-row {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 0.25rem;
}

.vl-calendar-overtime-close {
  border: none;
  background: transparent;
  font-size: 0.9rem;
  text-decoration: underline;
  cursor: pointer;
}

.vl-calendar-overtime-title {
  margin-top: 0;
  margin-bottom: 0.5rem;
}

.vl-calendar-overtime-date {
  margin-top: 0;
  margin-bottom: 0.35rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--vl-text);
}

.vl-calendar-overtime-info {
  margin-top: 0;
  margin-bottom: 0.75rem;
  font-size: 0.9rem;
  color: #444;
}

.vl-calendar-overtime-row {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 0.75rem;

  /* tydelig seksjon */
  border: 1px solid var(--vl-border);
  border-radius: var(--vl-radius);
  padding: 0.75rem;
  background: var(--vl-accent-soft);
}

.vl-calendar-overtime-row label {
  font-size: 1rem;
  font-weight: 700;
  color: var(--vl-text);
  margin: 0 0 0.25rem 0;
}

.vl-calendar-overtime-subline {
  margin: 0;
  font-size: 0.9rem;
  color: #555;
}

.vl-calendar-overtime-row input[type="number"] {
  width: 100%;
  padding: 0.4rem 0.6rem;
  font-size: 1rem;
}

.vl-calendar-overtime-row .vl-calendar-overtime-inline {
  margin-top: 0.1rem;
}

.vl-calendar-overtime-row .vl-calendar-extra-list {
  margin-top: 0.25rem;
}

.vl-calendar-overtime-row input[type="time"],
.vl-calendar-overtime-row input[type="date"],
.vl-calendar-overtime-row select {
  width: 100%;
  padding: 0.4rem 0.6rem;
  font: inherit;
}

.vl-calendar-extra-list {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin: 0.25rem 0 0.5rem;
}

.vl-quickreg-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.hr-actions-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  margin-top: 0.6rem;
}

.hr-actions-row > button {
  width: auto;
}

.hr-actions-row > button:first-child {
  margin-right: auto;
}

.hr-actions-row > button:last-child {
  margin-left: auto;
}

.vl-quickreg-actions-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.help-steps{
  margin-top: 0.6rem;
}

.help-note{
  margin-top: 0.8rem;
  opacity: 0.9;
}

.faq-content h2, .faq-content h3{
  margin-top: 1rem;
}

.faq-content .faq-field{
  margin-bottom: 0.3rem;
  color: var(--vl-text);
}

.faq-content hr{
  border: 0;
  border-top: 1px solid var(--vl-border);
  margin: 1rem 0;
}

.faq-content code{
  background: var(--vl-accent-soft);
  padding: 0.1rem 0.3rem;
  border-radius: 4px;
}

.help-footer{
  margin: 1rem 0 2rem 0;
  display: flex;
  justify-content: center;
}

.help-back-button{
  padding: 0.6rem 0.9rem;
  border-radius: 0.8rem;
  border: 1px solid rgba(0,0,0,0.12);
  background: rgba(0,0,0,0.04);
  color: inherit;
  cursor: pointer;
}

.help-back-button:focus-visible{
  outline: 2px solid var(--vl-accent);
  outline-offset: 2px;
}

.vl-quickreg-divider {
  width: 100%;
  border: 0;
  border-top: 1px solid var(--vl-border);
  margin: 0.25rem 0;
}

.vl-quickreg-standardvakt {
  padding-top: 0.1rem;
}

.vl-calendar-extra-row {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  align-items: flex-start;
}

.vl-calendar-extra-row > * {
  align-self: flex-start;
}

.vl-calendar-note-input {
  width: 100%;
  min-height: 4.5rem;
  padding: 0.6rem;
  border: 1px solid var(--vl-border);
  border-radius: var(--vl-radius);
  font: inherit;
  resize: vertical;
  background: #fff;
}

.vl-calendar-note-counter {
  margin: 0.25rem 0 0;
  font-size: 0.9rem;
  color: #555;
  text-align: right;
}

.vl-no-shift-badge {
  display: inline-block;
  padding: 0.35rem 0.6rem;
  border-radius: var(--vl-radius);
  background: #fff1f0;
  color: #8a1c1c;
  border: 1px solid #f0c8c4;
  font-size: 0.9rem;
  margin: 0.4rem 0 0.6rem;
}

.vl-calendar-extra-remove {
  border: 1px solid var(--vl-border);
  background: #fff;
  padding: 0.35rem 0.6rem;
  font: inherit;
  border-radius: 4px;
  cursor: pointer;
}

/* Make OK button (extra-remove + daydetail-primary) match "Legg til ekstra vakt" colours */
.vl-calendar-extra-remove.vl-daydetail-primary-btn {
  background: var(--vl-accent);
  border-color: var(--vl-accent);
  color: #ffffff;
}

.vl-calendar-extra-remove.vl-daydetail-primary-btn:hover {
  background: #006057;
  border-color: #006057;
}

.vl-calendar-extra-remove.vl-daydetail-primary-btn:active {
  background: #006057;
  border-color: #006057;
}

/* Compact extension controls */
.vl-calendar-overtime-inline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}

.vl-calendar-overtime-timecompact {
  width: 7.5rem;
  flex: 0 0 auto;
}

/* Narrow controls (fit-to-content) for overtime inputs */
.vl-overtime-time-narrow,
.vl-overtime-time-narrow[type="time"] {
  width: 7.5rem !important;
  max-width: 8rem;
  min-width: 6.5rem;
  flex: 0 0 auto;
  text-align: center;
  font-size: 1.05rem;
  background: #f5f7fa;
}

.vl-overtime-rule-narrow {
  width: auto !important;
  max-width: 14rem;
  min-width: 8rem;
  flex: 0 0 auto;
  text-align: center;
}

/* Ensure the row does not stretch the narrow controls */
.vl-overtime-extension-section .vl-calendar-overtime-inline {
  align-items: center;
}

.vl-calendar-overtime-summary {
  margin: 0.25rem 0 0.75rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--vl-text);
}

/* Forskyvning: warning when actual equals planned (no displacement) */
.vl-calendar-overtime-warning {
  color: var(--vl-danger);
}

.vl-calendar-overtime-planned {
  margin-top: 0.75rem;
  margin-bottom: 0;
  font-size: 0.9rem;
  color: #555;
}

.vl-calendar-col-code {
  width: 6ch;
}

.vl-calendar-col-date {
  width: 4.5ch;
}

.vl-calendar-col-name {
  width: 40%;
}

.vl-calendar-row-weekend {
  background-color: #fffdf5;
}

.vl-calendar-shift-select {
  width: 100%;
  max-width: 100%;
  font: inherit;
  padding: 0.2rem 0.3rem;
  border-radius: 4px;
  border: 1px solid var(--vl-border);
}

/* Results panel */

.vl-results-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.vl-results-monthlabel {
  font-weight: 500;
}

.vl-button-secondary {
  border-radius: 999px;
  border: 1px solid var(--vl-border);
  padding: 0.3rem 0.9rem;
  background-color: var(--vl-surface);
  cursor: pointer;
  font: inherit;
  text-decoration: none;
  color: inherit;
}

.vl-button-secondary:hover {
  background-color: var(--vl-accent-soft);
}

.vl-button-secondary-small {
  padding: 0.25rem 0.75rem;
  font-size: 0.95rem;
}

.vl-results-summary {
  background-color: #fafafa;
  border-radius: var(--vl-radius);
  border: 1px solid var(--vl-border);
  padding: 0.75rem 0.9rem;
}

/* Resultater: main total box is tappable to show/hide breakdown */
.vl-results-summary--tappable {
  cursor: pointer;
  user-select: none;
  position: relative;
}

/* Subtle chevron indicator, matching the card-expander pattern */
.vl-results-summary--tappable::after {
  content: "▸";
  position: absolute;
  right: 0.6rem;
  top: 0.65rem;
  line-height: 1;
  font-size: 1.05rem;
  opacity: 0.75;
}

.vl-results-summary--tappable.vl-is-open::after {
  content: "▾";
}

/* Keyboard focus */
.vl-results-summary--tappable:focus {
  outline: 2px solid var(--vl-border);
  outline-offset: 2px;
}

.vl-results-total {
  display: flex;
  flex-direction: column;
  margin-bottom: 0.75rem;
}

.vl-results-total-label {
  font-size: 0.9rem;
  color: var(--vl-muted);
}

.vl-results-total-value {
  font-size: 1.4rem;
  font-weight: 600;
}

.vl-results-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 0.25rem 0.75rem;
}

.vl-results-item {
  display: contents;
}

.vl-results-label {
  font-size: 0.85rem;
  color: var(--vl-muted);
}

.vl-results-value {
  font-size: 0.9rem;
  text-align: right;
}

.vl-results-error {
  margin-top: 0.5rem;
  font-size: 0.85rem;
  color: var(--vl-danger);
}

/* Mobile main tabs (app-like navigation) */
.vl-main-tabs {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.96);
  border-top: 1px solid var(--vl-border);
  padding: 0.5rem 0.75rem calc(0.5rem + env(safe-area-inset-bottom));
  display: none; /* enabled via .vl-has-main-tabs under mobile breakpoint */
}

.vl-main-tabs-group {
  width: 100%;
  display: flex;          /* override inline-flex from .vl-toggle-group */
}

.vl-main-tab-btn {
  flex: 1 1 0;
  text-align: center;
  justify-content: center;
  white-space: nowrap;
}

.vl-main-tab-btn {
  font-size: 0.95rem;
  padding-top: 0.55rem;
  padding-bottom: 0.55rem;
}

/* Only enable the tabbar and single-panel mode on small screens */
@media (max-width: 899px) {
  #app.vl-has-main-tabs .vl-main-tabs {
    display: block;
  }

  /* Prevent content being hidden behind the fixed tabbar */
  #app.vl-has-main-tabs {
    padding-bottom: calc(4.25rem + env(safe-area-inset-bottom));
  }

  /* Make room for fixed mini header on mobile */
  #app.vl-has-main-tabs {
    padding-top: 3.25rem;
  }

  /* Hide the main panel <details> summaries; tabs replace this UI on mobile */
  #app.vl-has-main-tabs .vl-panel > summary {
    display: none;
  }

  /* Reduce vertical noise when only one panel is visible */
  #app.vl-has-main-tabs .vl-main {
    margin-bottom: 0;
  }
}

/* Larger screens */

@media (min-width: 900px) {
  #app {
    max-width: 1100px;
    margin: 0 auto;
  }

  .vl-main {
    flex-direction: row;
    align-items: flex-start;
  }

  .vl-panel {
    flex: 1;
  }
}
/* Results – month stats based on calendar */

.vl-results-stats {
  margin-top: 0.75rem;
  border-top: 1px solid var(--vl-border);
  padding-top: 0.5rem;
  font-size: 0.85rem;
}

.vl-results-stats-title {
  font-weight: 600;
  margin-bottom: 0.25rem;
}

.vl-results-stats-body ul {
  margin: 0.25rem 0 0;
  padding-left: 1.2rem;
}
