/* jobbmotor.se — single hand-written stylesheet. */

@font-face {
    font-family: 'Fraunces';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('/fonts/Fraunces-500.woff2') format('woff2');
}

:root {
    --bg: #FBF4DC;
    --ink: #1F2A33;
    --body: #4A4030;
    --muted: #6B5E3D;

    --card-money: #C8DDB5;
    --card-stability: #B5C9D6;
    --card-variety: #F2D58A;
    --card-skill: #E8B5A6;
    --card-freedom: #BFD8DD;
    --card-change: #C9BEDD;
    --card-status: #DDC689;

    --font-sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --font-serif: 'Fraunces', Georgia, serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
    background: var(--bg);
    color: var(--body);
    font-family: var(--font-sans);
    font-size: 16px;
    line-height: 1.7;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}
main { flex: 1 0 auto; padding: 0 1.25rem; }

img, svg { max-width: 100%; }
a { color: var(--ink); }

/* Homepage "under uppbyggnad" banner — calm, informational, no dismiss. */
.under-construction {
    width: 100%;
    background: #F2EDE2;
    border-bottom: 1px solid #D6CDB9;
    padding: 0.75rem 1rem;
    text-align: center;
    color: #6B5E3D;
    font-size: 13px;
    font-family: var(--font-sans);
    margin: 0 -1.25rem;
}

/* Skip link for keyboard users. */
.skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    background: var(--ink);
    color: var(--bg);
    padding: 0.5rem 0.75rem;
    z-index: 100;
}
.skip-link:focus { left: 1rem; top: 1rem; }

/* Header & nav */
.site-header {
    background: var(--bg);
    border-bottom: 2px solid var(--ink);
}
.site-header__inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 1rem 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.brand {
    text-decoration: none;
    color: var(--ink);
    font-family: var(--font-serif);
    font-size: 22px;
    letter-spacing: 0;
    text-transform: none;
    font-weight: 500;
    line-height: 1;
}
.brand__mark { color: var(--ink); }
.primary-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    align-items: center;
}
.primary-nav a, .primary-nav .link-button {
    color: var(--ink);
    text-decoration: none;
    font-size: 14px;
    border: none;
    background: none;
    padding: 0;
    cursor: pointer;
    font-family: inherit;
}
.primary-nav a:hover,
.primary-nav .link-button:hover { text-decoration: underline; }
.logout-form { margin: 0; }

/* Footer */
.site-footer {
    border-top: 2px solid var(--ink);
    margin-top: 4rem;
    padding: 2rem 1.25rem;
    background: var(--bg);
}
.site-footer__inner {
    max-width: 960px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.site-footer ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 1.25rem;
}
.site-footer a {
    color: var(--ink);
    text-decoration: none;
    font-size: 14px;
}
.site-footer a:hover { text-decoration: underline; }
.site-footer__copy { color: var(--muted); font-size: 13px; margin: 0; }

/* Eyebrow labels */
.eyebrow {
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: lowercase;
    font-weight: 500;
    color: var(--muted);
    margin: 0;
}
.eyebrow--center { text-align: center; }
/* Sektionsrubriker som "Huvudspår" och "Guider" — ärver eyebrow-basen
   men är större, versaliserade och tyngre så de fungerar som riktiga
   sektionsrubriker, inte som svaga etiketter. */
.section-eyebrow {
    font-size: 16px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--ink);
    padding-left: 4px;
    margin-top: 0;
    margin-bottom: 1.25rem;
}

/* Hero */
.hero {
    max-width: 960px;     /* matchar track-gridens bredd under */
    margin: 3rem auto 2.5rem;
    text-align: center;
    padding: 0 1rem;
}
.hero__title {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: clamp(30px, 4vw, 34px);
    color: var(--ink);
    margin: 0.5rem 0 1.5rem;
    line-height: 1.2;
}
.hero__body {
    font-size: 16px;
    line-height: 1.7;
    max-width: none;       /* ärver hero — samma bredd som korten under */
    margin: 0 auto 2rem;
    color: var(--body);
    text-align: left;
}
.hero__question {
    font-size: 15px;
    font-weight: 500;
    color: var(--ink);
    max-width: none;
    margin: 2rem auto 0;
}

/* Tracks shared */
.tracks {
    max-width: 960px;
    margin: 1.5rem auto 0;
}
.tracks__grid--main {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 18px;
}
.tracks__grid--side {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
    max-width: 720px;
    margin: 0 auto;
}

.track-card,
.track-card *,
.track-card:hover,
.track-card:hover *,
.track-card:focus,
.track-card:focus *,
.track-card:visited,
.track-card:active { text-decoration: none !important; }
.track-card {
    background: var(--card-bg);
    color: var(--ink);
    border: 2.5px solid var(--ink);
    border-radius: 14px;
    box-shadow: 5px 5px 0 var(--ink);
    transition: transform 100ms ease, box-shadow 100ms ease;
    display: flex;
}
.track-card:focus-visible {
    outline: 4px solid rgba(31, 42, 51, 0.5);
    outline-offset: 4px;
}
.track-card:hover {
    transform: translate(3px, 3px);
    box-shadow: 2px 2px 0 var(--ink);
}

/* Main track card layout */
.track-card--main {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 1.5rem 1.25rem;
    min-height: 180px;
    gap: 0.5rem;
}
.track-card--main .track-card__icon {
    color: var(--ink);
    margin-bottom: 0.25rem;
}
.track-card--main .track-card__eyebrow {
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: lowercase;
    font-weight: 500;
    color: var(--card-dark);
}
.track-card--main .track-card__title {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 19px;
    color: var(--ink);
    margin-top: 0.1rem;
}
.track-card--main .track-card__desc {
    font-size: 13px;
    line-height: 1.5;
    color: var(--card-dark);
    margin-top: 0.4rem;
}

/* Side track card layout */
.track-card--side {
    border-width: 2px;
    border-radius: 12px;
    box-shadow: 4px 4px 0 var(--ink);
    padding: 1rem 1.125rem;
    flex-direction: row;
    align-items: center;
    gap: 0.75rem;
}
.track-card--side .track-card__icon {
    color: var(--ink);
    flex-shrink: 0;
}
.track-card--side .track-card__text {
    display: flex;
    flex-direction: column;
}
.track-card--side .track-card__eyebrow {
    font-size: 10px;
    letter-spacing: 0.06em;
    text-transform: lowercase;
    font-weight: 500;
    color: var(--card-dark);
}
.track-card--side .track-card__title {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 16px;
    color: var(--ink);
}

/* Divider with centered label */
.divider {
    max-width: 720px;
    margin: 3rem auto 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
}
.divider__line {
    flex: 1;
    height: 0;
    border-top: 1.5px solid var(--ink);
}
.divider__label {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 15px;
    color: var(--ink);
}

/* Guides section */
.guides {
    max-width: 960px;
    margin: 3rem auto 4rem;
    border-top: 2px solid var(--ink);
    padding-top: 2rem;
}
.guides__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 10px;
}
.guide-card,
.guide-card *,
.guide-card:hover,
.guide-card:hover *,
.guide-card:focus,
.guide-card:focus *,
.guide-card:visited,
.guide-card:active { text-decoration: none !important; }
.guide-card {
    background: #fff;
    color: var(--ink);
    border: 2px solid var(--ink);
    border-radius: 10px;
    box-shadow: 3px 3px 0 var(--ink);
    padding: 0.875rem 1rem;
    transition: transform 100ms ease, box-shadow 100ms ease;
    display: flex;
    align-items: center;
}
.guide-card:hover {
    transform: translate(2px, 2px);
    box-shadow: 1px 1px 0 var(--ink);
}
.guide-card:focus-visible {
    outline: 3px solid rgba(31, 42, 51, 0.5);
    outline-offset: 3px;
}
.guide-card__title {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 14px;
    color: var(--ink);
}

/* Generic page */
.page {
    max-width: 960px;
    margin: 2.5rem auto 4rem;
}
.page--narrow {
    max-width: 640px;
}
.page__title {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: clamp(26px, 3.6vw, 32px);
    color: var(--ink);
    margin: 0.25rem 0 1.5rem;
    line-height: 1.25;
}
.page__subtitle {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 22px;
    color: var(--ink);
    margin: 2.5rem 0 0.75rem;
}
.page__lede {
    font-size: 17px;
    color: var(--body);
    margin-bottom: 2rem;
}
.placeholder {
    font-size: 15px;
    color: var(--muted);
    font-style: italic;
}

/* Track detail page tints itself with --card-bg */
.track-page {
    background: var(--card-bg);
    border: 2.5px solid var(--ink);
    border-radius: 14px;
    box-shadow: 5px 5px 0 var(--ink);
    padding: 2.5rem 2rem;
    margin-top: 2.5rem;
}
.track-page .eyebrow { color: var(--card-dark); }

/* Forms */
.form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.5rem;
}
.field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}
.field__label {
    font-size: 14px;
    color: var(--ink);
    font-weight: 500;
}
.field input[type="text"],
.field input[type="email"],
.field input[type="password"],
.field input[type="date"],
.field select {
    height: 44px;
    border: 2px solid var(--ink);
    border-radius: 10px;
    background: #fff;
    color: var(--ink);
    font-size: 15px;
    padding: 0 0.75rem;
    font-family: inherit;
}
.field select { padding-right: 2rem; }
.field input:focus,
.field select:focus {
    outline: 4px solid rgba(31, 42, 51, 0.2);
    outline-offset: 0;
}
.field--checkbox {
    flex-direction: row;
    align-items: flex-start;
    gap: 0.6rem;
}
.field--checkbox input[type="checkbox"] {
    margin-top: 4px;
    width: 18px;
    height: 18px;
    accent-color: var(--ink);
}
.field__error {
    color: #6B3A2C;
    font-size: 13px;
    margin-top: 0.25rem;
}

.form-error {
    border: 2px solid #6B3A2C;
    background: #E8B5A6;
    color: #6B3A2C;
    padding: 0.75rem 1rem;
    border-radius: 10px;
    font-size: 14px;
    box-shadow: 4px 4px 0 #6B3A2C;
}
.form-success {
    border: 2px solid #3D5028;
    background: #C8DDB5;
    color: #3D5028;
    padding: 0.75rem 1rem;
    border-radius: 10px;
    font-size: 14px;
    box-shadow: 4px 4px 0 #3D5028;
}
.form-aside {
    margin-top: 1rem;
    font-size: 14px;
}

.flash {
    max-width: 640px;
    margin: 1rem auto 0;
    padding: 0.75rem 1rem;
    border-radius: 10px;
    border: 2px solid var(--ink);
    background: #fff;
    box-shadow: 4px 4px 0 var(--ink);
    font-size: 14px;
}
.flash--success { background: var(--card-money); }

/* Buttons */
.btn {
    display: inline-block;
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 16px;
    padding: 0.625rem 1.25rem;
    border: 2px solid var(--ink);
    border-radius: 10px;
    background: #fff;
    color: var(--ink);
    box-shadow: 4px 4px 0 var(--ink);
    text-decoration: none;
    cursor: pointer;
    transition: transform 100ms ease, box-shadow 100ms ease;
    align-self: flex-start;
}
.btn:hover {
    transform: translate(2px, 2px);
    box-shadow: 2px 2px 0 var(--ink);
}
.btn:focus-visible {
    outline: 4px solid rgba(31, 42, 51, 0.3);
    outline-offset: 2px;
}
.btn--primary { background: var(--card-money); }
.btn--danger {
    background: var(--card-skill);
    border-color: #6B3A2C;
    color: #6B3A2C;
    box-shadow: 4px 4px 0 #6B3A2C;
}
.btn--danger:hover {
    box-shadow: 2px 2px 0 #6B3A2C;
}
.btn--small {
    font-size: 13px;
    padding: 0.4rem 0.75rem;
    box-shadow: 3px 3px 0 var(--ink);
}
.btn--small.btn--danger { box-shadow: 3px 3px 0 #6B3A2C; }

/* Choice grid for register-choice */
.choice-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin-top: 1.5rem;
}
.choice-card {
    border: 2.5px solid var(--ink);
    border-radius: 14px;
    box-shadow: 5px 5px 0 var(--ink);
    background: #fff;
    text-decoration: none;
    color: var(--ink);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    transition: transform 100ms ease, box-shadow 100ms ease;
}
.choice-card:hover {
    transform: translate(3px, 3px);
    box-shadow: 2px 2px 0 var(--ink);
}
.choice-card__title {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 20px;
}
.choice-card__desc {
    font-size: 14px;
    color: var(--muted);
}

/* Tables (admin) */
.data-table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0 2rem;
    font-size: 14px;
    background: #fff;
    border: 2px solid var(--ink);
    border-radius: 10px;
    overflow: hidden;
}
.data-table th,
.data-table td {
    padding: 0.6rem 0.75rem;
    border-bottom: 1px solid #ddd;
    text-align: left;
    vertical-align: top;
}
.data-table th {
    background: var(--bg);
    font-weight: 500;
    color: var(--ink);
}
.data-table tr:last-child td { border-bottom: none; }
.data-table__actions { white-space: nowrap; }
.inline-form { display: inline-block; margin: 0 0.25rem 0 0; }
.muted { color: var(--muted); font-size: 12px; }

.data-list {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0.4rem 1.5rem;
    margin: 1rem 0 2rem;
    font-size: 15px;
}
.data-list dt { color: var(--muted); }
.data-list dd { margin: 0; color: var(--ink); }

/* Punctuality test grid */
.progress-grid {
    display: grid;
    grid-template-columns: repeat(10, 1fr);
    gap: 8px;
    margin: 1.5rem 0 1rem;
}
@media (max-width: 560px) {
    .progress-grid { grid-template-columns: repeat(5, 1fr); gap: 10px; }
}
.progress-grid__cell {
    aspect-ratio: 1 / 1;
    border: 2px solid var(--ink);
    border-radius: 10px;
    background: #fff;
    color: var(--ink);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 18px;
}
.progress-grid__cell.is-future { background: #fff; }
.progress-grid__cell.is-today {
    background: #fff;
}
.progress-grid__cell.is-today::after {
    content: '';
    position: absolute;
    bottom: 6px;
    left: 50%;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--ink);
    transform: translateX(-50%);
}
.progress-grid__cell.is-now {
    background: var(--card-variety);
    border-width: 2.5px;
    box-shadow: 4px 4px 0 var(--ink);
    animation: punkt-pulse 1.6s ease-in-out infinite;
}
.progress-grid__cell.is-valid {
    background: var(--card-money);
    box-shadow: 3px 3px 0 var(--ink);
}
.progress-grid__cell.is-exemplary {
    background: var(--card-status);
    box-shadow: 3px 3px 0 var(--ink);
}
.progress-grid__cell.is-missed {
    background: var(--card-skill);
    box-shadow: 3px 3px 0 var(--ink);
}
.progress-grid__cell.is-skipped {
    border: 2px dashed var(--ink);
    background: transparent;
    color: var(--muted);
    font-size: 11px;
}
.progress-grid__num { position: absolute; top: 4px; left: 6px; font-size: 11px; color: var(--muted); }
.progress-grid__icon { width: 60%; height: 60%; }
.progress-grid__star {
    position: absolute;
    top: 4px;
    right: 6px;
    font-size: 12px;
    color: #6B5226;
}
@keyframes punkt-pulse {
    0%, 100% { transform: translate(0, 0); box-shadow: 4px 4px 0 var(--ink); }
    50%      { transform: translate(1px, 1px); box-shadow: 3px 3px 0 var(--ink); }
}
.punkt-status {
    margin: 1.25rem 0;
    font-size: 15px;
    color: var(--ink);
}
.punkt-checkin-form {
    margin: 1.5rem 0;
}
.punkt-checkin-btn {
    font-size: 22px;
    padding: 1rem 2rem;
}
.punkt-question {
    font-family: var(--font-serif);
    font-size: 22px;
    color: var(--ink);
    margin: 1.5rem 0 1rem;
    line-height: 1.3;
}
.punkt-timer {
    font-size: 14px;
    color: var(--muted);
    margin: 0.5rem 0 1rem;
}
.progress-status { margin: 0.5rem 0 1.5rem; font-size: 14px; color: var(--body); }

/* Seal display blocks. SVG scales to its container; .seal-display caps the size. */
.seal-display { max-width: 460px; margin: 1.5rem auto; }
.seal-display svg { width: 100%; height: auto; display: block; }
.seal-display--small { max-width: 280px; }
.seal-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin: 1.5rem 0;
}

/* Verification page accents */
.verify-page { text-align: center; }
.verify-badge {
    display: inline-block;
    background: var(--card-money);
    color: #3D5028;
    border: 2px solid #3D5028;
    border-radius: 10px;
    padding: 0.25rem 0.75rem;
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin: 0.5rem auto 0;
    box-shadow: 3px 3px 0 #3D5028;
}
.verify-name { font-family: var(--font-serif); }
.verify-line { font-size: 16px; color: var(--body); }
.verify-page .data-list { justify-content: center; max-width: 320px; margin-left: auto; margin-right: auto; }

/* Inline form embellishment for revoke */
.revoke-form input[type="text"] {
    height: 32px;
    padding: 0 0.5rem;
    border: 2px solid var(--ink);
    border-radius: 8px;
    font-size: 13px;
    margin-right: 0.25rem;
}

.admin-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem;
    margin: 1rem 0 2rem;
}
.stat {
    border: 2px solid var(--ink);
    border-radius: 10px;
    box-shadow: 4px 4px 0 var(--ink);
    padding: 1rem;
    background: #fff;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.stat__label {
    font-size: 12px;
    letter-spacing: 0.06em;
    text-transform: lowercase;
    color: var(--muted);
}
.stat__value {
    font-family: var(--font-serif);
    font-size: 28px;
    color: var(--ink);
}

/* ===========================================================================
   CV editor (phase 3). Mobile-first; tested at 375px width.
   =========================================================================== */

.cv-editor__header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.5rem;
}
.cv-saved {
    font-size: 13px;
    color: var(--muted);
    font-style: italic;
    min-height: 1.2em;
    transition: opacity 200ms ease;
}

.cv-section {
    margin: 1rem 0;
    border: 2px solid var(--ink);
    border-radius: 12px;
    background: #fff;
    box-shadow: 4px 4px 0 var(--ink);
    overflow: hidden;
}
.cv-section__summary {
    padding: 0.75rem 1rem;
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 17px;
    color: var(--ink);
    cursor: pointer;
    background: var(--bg);
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.cv-section__summary::-webkit-details-marker { display: none; }
.cv-section__summary::after {
    content: '+';
    font-family: var(--font-sans);
    font-weight: 500;
    font-size: 18px;
}
.cv-section[open] .cv-section__summary::after { content: '–'; }
.cv-section__count { color: var(--muted); font-size: 14px; font-weight: 400; margin-left: 0.5rem; }
.cv-section__body {
    padding: 1rem;
    border-top: 1px solid var(--ink);
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* Two-column rows that stack on mobile. */
.field-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}
@media (min-width: 480px) {
    .field-row { grid-template-columns: 1fr 1fr; }
}

.cv-checkboxes { display: flex; flex-direction: column; gap: 0.5rem; }

/* Locality autocomplete */
.cv-locality { position: relative; }
.cv-locality__menu {
    list-style: none;
    margin: 0;
    padding: 0;
    background: #fff;
    border: 2px solid var(--ink);
    border-radius: 10px;
    box-shadow: 4px 4px 0 var(--ink);
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    z-index: 10;
    max-height: 320px;
    overflow-y: auto;
    margin-top: 0.4rem;
}
.cv-locality__item {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.6rem 0.75rem;
    cursor: pointer;
    border-bottom: 1px solid #eee;
}
.cv-locality__item:last-child { border-bottom: 0; }
.cv-locality__item:hover, .cv-locality__item:focus { background: var(--bg); outline: none; }
.cv-locality__name { font-size: 14px; color: var(--ink); }
.cv-locality__meta { font-size: 12px; color: var(--muted); white-space: nowrap; }

/* Radius slider */
.cv-radius {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    border: none;
    padding: 0;
    margin: 0;
}
.cv-radius__labels {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.25rem;
    font-size: 11px;
    text-align: center;
    color: var(--muted);
}
.cv-radius__label.is-selected {
    color: var(--ink);
    font-weight: 500;
}
.cv-radius__slider {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 44px;
    background: transparent;
    cursor: pointer;
    margin: 0;
}
.cv-radius__slider::-webkit-slider-runnable-track {
    height: 4px;
    background: var(--ink);
    border-radius: 2px;
    margin-top: 20px;
}
.cv-radius__slider::-moz-range-track {
    height: 4px;
    background: var(--ink);
    border-radius: 2px;
}
.cv-radius__slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 32px;
    height: 32px;
    background: var(--card-money);
    border: 2.5px solid var(--ink);
    border-radius: 50%;
    box-shadow: 3px 3px 0 var(--ink);
    margin-top: -16px;
}
.cv-radius__slider::-moz-range-thumb {
    width: 32px;
    height: 32px;
    background: var(--card-money);
    border: 2.5px solid var(--ink);
    border-radius: 50%;
    box-shadow: 3px 3px 0 var(--ink);
}

/* Repeating rows */
.cv-rows { display: flex; flex-direction: column; gap: 1rem; }
.cv-row {
    border: 1.5px dashed var(--ink);
    border-radius: 10px;
    padding: 0.75rem;
    background: var(--bg);
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.cv-row__controls {
    display: flex;
    gap: 0.75rem;
    justify-content: flex-end;
    border-top: 1px solid #ddd;
    padding-top: 0.5rem;
}
.cv-row__remove { color: #6B3A2C; font-size: 13px; }

.cv-add-form { margin-top: 0.5rem; }

/* Tags (interests) */
.cv-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    min-height: 1px;
}
.cv-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.3rem 0.7rem;
    border: 2px solid var(--ink);
    border-radius: 999px;
    background: var(--card-stability);
    font-size: 13px;
}
.cv-tag__remove {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    font-size: 16px;
    color: var(--ink);
    line-height: 1;
}
.cv-tag-add { display: flex; gap: 0.5rem; margin-top: 0.75rem; }
.cv-tag-add input { flex: 1; height: 40px; padding: 0 0.75rem; border: 2px solid var(--ink); border-radius: 8px; }

.cv-merit-cert {
    background: var(--card-status);
    border: 2px solid var(--ink);
    border-radius: 10px;
    padding: 0.75rem 1rem;
    box-shadow: 3px 3px 0 var(--ink);
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.cv-editor__footer {
    margin-top: 2rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

/* ===========================================================================
   CV render — used by preview, PDF, and (later) the employer detail view.
   The .cv-render--pdf modifier triggers print-style typography for Dompdf.
   =========================================================================== */

.cv-render { color: var(--ink); line-height: 1.55; }
.cv-render__head {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
    border-bottom: 2px solid var(--ink);
    padding-bottom: 1rem;
    margin-bottom: 1.5rem;
}
.cv-render__identity { flex: 1; min-width: 0; }
.cv-render__name {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 28px;
    margin: 0 0 0.25rem;
    line-height: 1.15;
}
.cv-render__born { color: var(--muted); font-size: 14px; margin: 0 0 0.5rem; }
.cv-render__contact {
    list-style: none; padding: 0; margin: 0.5rem 0 0;
    display: flex; flex-wrap: wrap; gap: 0.25rem 1rem;
    font-size: 14px;
}
.cv-render__photo {
    flex: 0 0 auto;
    width: 110px;
    aspect-ratio: 3 / 4;
    background: #eee;
    border: 2px solid var(--ink);
    border-radius: 8px;
    overflow: hidden;
}
.cv-render__photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

.cv-render__section { margin: 1.25rem 0; }
.cv-render__h2 {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 17px;
    color: var(--ink);
    margin: 0 0 0.5rem;
    padding-bottom: 0.25rem;
    border-bottom: 1px solid #ddd;
}
.cv-render__entry { margin: 0.6rem 0; }
.cv-render__entry-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.cv-render__entry-title { font-weight: 500; }
.cv-render__entry-meta { color: var(--muted); font-size: 13px; white-space: nowrap; }
.cv-render__paragraph { margin: 0.25rem 0 0; }
.cv-render__list { padding-left: 1.25rem; margin: 0.25rem 0 0; }
.cv-render__entry--cert { background: var(--bg); border: 1.5px solid var(--ink); border-radius: 8px; padding: 0.5rem 0.75rem; }

/* PDF-mode tweaks: print-friendly type sizes and the seal stamp */
.cv-render--pdf { font-family: Helvetica, Arial, sans-serif; font-size: 10pt; }
.cv-render--pdf .cv-render__name { font-family: Georgia, serif; font-size: 22pt; }
.cv-render--pdf .cv-render__h2 { font-family: Georgia, serif; font-size: 13pt; }
.cv-render--pdf .cv-render__seal {
    text-align: center;
    margin-top: 1.5rem;
    page-break-inside: avoid;
}
.cv-render--pdf .cv-render__seal img { width: 50mm; height: 50mm; }
.cv-render--pdf .cv-render__seal span { display: block; font-size: 9pt; margin-top: 4mm; font-family: monospace; }

/* Preview-page banner */
.cv-preview-banner {
    background: var(--card-money);
    border: 2px solid var(--ink);
    border-radius: 10px;
    box-shadow: 4px 4px 0 var(--ink);
    padding: 0.75rem 1rem;
    margin: 1rem 0 1.5rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: space-between;
    align-items: center;
}
.cv-preview-banner p { margin: 0; }

/* Publish consent screen */
.publish-consent .field--checkbox { padding: 0.5rem 0; }
.publish-consent .btn[disabled] {
    opacity: 0.5;
    pointer-events: none;
    box-shadow: 2px 2px 0 var(--ink);
}
.publish-gaps {
    border: 2px solid #6B3A2C;
    background: #E8B5A6;
    color: #6B3A2C;
    padding: 0.75rem 1rem;
    border-radius: 10px;
    box-shadow: 4px 4px 0 #6B3A2C;
    margin: 1rem 0;
}
.publish-gaps ul { margin: 0.5rem 0 0 1.25rem; padding: 0; }

/* Letter editor + list */
.letter-list { display: flex; flex-direction: column; gap: 0.75rem; margin: 1rem 0; }
.letter-list__item {
    border: 2px solid var(--ink);
    border-radius: 10px;
    background: #fff;
    box-shadow: 3px 3px 0 var(--ink);
    padding: 0.75rem 1rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.5rem;
    align-items: baseline;
}
.letter-list__title { font-family: var(--font-serif); font-size: 17px; }
.letter-list__meta { color: var(--muted); font-size: 13px; }
.letter-actions { display: flex; gap: 0.5rem; }

/* ===========================================================================
   Public job search (/jobb, /jobb/{id}) and homepage CTA block.
   =========================================================================== */

/* --- Sökform --- */
.jobs-form { margin: 1rem 0 1.5rem; }

.jobs-form__hero {
    display: flex;
    gap: 0.6rem;
    align-items: stretch;
}
.jobs-form__search {
    flex: 1;
    min-width: 0;
    height: 68px;
    padding: 0 1.4rem;
    border: 2.5px solid var(--ink);
    border-radius: 16px;
    background: #fff;
    color: var(--ink);
    font-family: inherit;
    font-size: 19px;
    box-shadow: 5px 5px 0 var(--ink);
    transition: box-shadow 120ms ease, transform 120ms ease;
}
.jobs-form__search:focus {
    outline: none;
    transform: translate(1px, 1px);
    box-shadow: 4px 4px 0 var(--ink);
}
.jobs-form__search::placeholder { color: var(--muted); }
.jobs-form__submit {
    height: 68px;
    padding: 0 1.75rem;
    border: 2.5px solid var(--ink);
    border-radius: 16px;
    background: var(--card-money);
    color: var(--ink);
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 19px;
    cursor: pointer;
    box-shadow: 5px 5px 0 var(--ink);
    transition: box-shadow 120ms ease, transform 120ms ease;
    flex-shrink: 0;
}
.jobs-form__submit:hover, .jobs-form__submit:focus {
    transform: translate(2px, 2px);
    box-shadow: 3px 3px 0 var(--ink);
    outline: none;
}

.jobs-form__row {
    display: flex;
    align-items: end;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}
.jobs-form__kommun { flex: 1; min-width: 200px; max-width: 360px; }
/* Matcha kommun-selectens höjd och botten-alignering. .btn har
   align-self: flex-start från sin globala stil — overrida explicit
   så knappen alignar med selectens nedkant, inte med "Kommun"-labelraden. */
.jobs-form__row .btn {
    align-self: flex-end;
    height: 44px;
    display: inline-flex;
    align-items: center;
}

/* "Fler filter"-disclosure */
.jobs-filters {
    margin-top: 1rem;
    background: var(--bg);
    border: 2px solid var(--ink);
    border-radius: 12px;
    padding: 0.75rem 1rem;
}
.jobs-filters > summary {
    cursor: pointer;
    list-style: none;
    font-size: 14px;
    color: var(--ink);
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}
.jobs-filters > summary::-webkit-details-marker { display: none; }
.jobs-filters > summary::before {
    content: '+';
    font-family: var(--font-sans);
    font-weight: 500;
    font-size: 18px;
    width: 1em;
    display: inline-block;
}
.jobs-filters[open] > summary::before { content: '–'; }
.jobs-filters__active {
    background: var(--card-money);
    border: 1.5px solid #3D5028;
    color: #3D5028;
    border-radius: 999px;
    padding: 0.05rem 0.5rem;
    font-size: 11px;
    font-weight: 500;
    text-transform: lowercase;
    letter-spacing: 0.04em;
}
.jobs-filters__grid {
    display: grid;
    /* minmax(0, 1fr) i stället för bara 1fr — bara 1fr ärver auto min-content
       som låter cellerna växa över sin tilldelade andel om innehållet är
       bredare. minmax(0, 1fr) tillåter krympning till noll. */
    grid-template-columns: minmax(0, 1fr);
    gap: 0.75rem;
    margin-top: 0.85rem;
}
@media (min-width: 600px) {
    .jobs-filters__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 900px) {
    .jobs-filters__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
/* Default min-width: auto på grid items hindrar dem från att krympa under
   sin innehållsbredd — så långa option-texter (t.ex. "Hotell, restaurang
   och storhushåll") trycker ut layouten. min-width: 0 + width: 100% på
   själva selecten löser overflow. */
.jobs-filters__grid .field { min-width: 0; }
.jobs-filters__grid select,
.jobs-filters__grid input[type="text"] { width: 100%; min-width: 0; }
.jobs-filters__checkbox {
    grid-column: 1 / -1;
    align-items: center;
}

/* --- Resultatcounter --- */
.jobs-page__count {
    font-size: 14px;
    color: var(--body);
    margin: 0.5rem 0 1rem;
}
.jobs-page__count strong { font-size: 18px; color: var(--ink); font-weight: 500; }

.jobs-empty {
    border: 2.5px dashed var(--ink);
    border-radius: 14px;
    padding: 1.5rem 1.25rem;
    background: #fff;
    text-align: center;
    margin: 1.5rem 0;
}
.jobs-empty p { margin: 0.25rem 0; }

/* --- Jobblista --- */
.job-list {
    list-style: none;
    padding: 0;
    margin: 1rem 0;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.job-list__item { margin: 0; }

/* Hela kortet är ett <a>-element. text-decoration ärvs inte alltid prydligt
   till nestade block-element, och vissa webbläsartillägg tvingar tillbaka
   underline. !important garanterar att inget får återinföra strecket. */
.job-card,
.job-card *,
.job-card:hover,
.job-card:hover *,
.job-card:focus,
.job-card:focus *,
.job-card:visited,
.job-card:active { text-decoration: none !important; }

/* Hela kortet får pastellbakgrund — samma stil som track-korten på startsidan.
   --card-bg sätts per kort av :nth-child-reglerna nedan. */
.job-card {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
        "title    date"
        "employer date"
        "chips    chips"
        "excerpt  excerpt"
        "footer   footer";
    column-gap: 1rem;
    row-gap: 0.4rem;
    color: var(--ink);
    background: var(--card-bg, var(--card-money));
    border: 2.5px solid var(--ink);
    border-radius: 14px;
    box-shadow: 5px 5px 0 var(--ink);
    padding: 1.1rem 1.25rem;
    transition: transform 120ms ease, box-shadow 120ms ease;
}
.job-list__item:nth-child(7n+1) .job-card { --card-bg: var(--card-money); }
.job-list__item:nth-child(7n+2) .job-card { --card-bg: var(--card-stability); }
.job-list__item:nth-child(7n+3) .job-card { --card-bg: var(--card-variety); }
.job-list__item:nth-child(7n+4) .job-card { --card-bg: var(--card-skill); }
.job-list__item:nth-child(7n+5) .job-card { --card-bg: var(--card-freedom); }
.job-list__item:nth-child(7n+6) .job-card { --card-bg: var(--card-change); }
.job-list__item:nth-child(7n)   .job-card { --card-bg: var(--card-status); }
.job-card:hover {
    transform: translate(3px, 3px);
    box-shadow: 2px 2px 0 var(--ink);
}
.job-card:focus-visible {
    outline: 4px solid rgba(31, 42, 51, 0.5);
    outline-offset: 4px;
}

.job-card__title {
    grid-area: title;
    font-family: var(--font-serif);
    font-size: 19px;
    font-weight: 500;
    margin: 0;
    color: var(--ink);
    line-height: 1.25;
}
.job-card__employer {
    grid-area: employer;
    margin: 0;
    font-size: 14px;
    font-weight: 500;
    color: var(--ink);
    opacity: 0.85;
}
.job-card__date-corner {
    grid-area: date;
    align-self: start;
    font-size: 12px;
    color: var(--ink);
    opacity: 0.65;
    white-space: nowrap;
    text-align: right;
}

/* Chips ligger ovanpå färgad bakgrund — vit/transparent kontrast. */
.job-card__chips {
    grid-area: chips;
    list-style: none;
    padding: 0;
    margin: 0.35rem 0 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}
.job-card__chips .chip {
    background: rgba(255, 255, 255, 0.7);
    border: 1.5px solid var(--ink);
    color: var(--ink);
    font-size: 12px;
    padding: 0.2rem 0.6rem;
    line-height: 1.4;
}
.job-card__chips .chip--location { background: #fff; font-weight: 500; }
.job-card__chips .chip--employment { background: #fff; font-weight: 500; }
.job-card__chips .chip--neutral { background: rgba(255, 255, 255, 0.4); border-color: var(--ink); color: var(--ink); }

.job-card__excerpt {
    grid-area: excerpt;
    margin: 0.5rem 0 0;
    font-size: 14px;
    color: var(--ink);
    line-height: 1.55;
    opacity: 0.85;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.job-card__footer {
    grid-area: footer;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    font-size: 12px;
    color: var(--ink);
    opacity: 0.7;
    border-top: 1.5px solid rgba(31, 42, 51, 0.2);
    padding-top: 0.6rem;
    margin-top: 0.5rem;
}
.job-card__deadline { color: #6B3A2C; opacity: 1; font-weight: 500; }

/* --- Paginering --- */
.job-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin: 2rem 0 1rem;
    padding: 0.75rem 1rem;
    border: 2px solid var(--ink);
    border-radius: 12px;
    background: var(--bg);
}

/* === Jobbdetalj-sida === */
.job-detail__back { margin: 0 0 0.5rem; font-size: 14px; }

/* Färgad hero-ruta — samma kort-stil som listan */
.job-detail__hero {
    background: var(--card-stability);
    border: 2.5px solid var(--ink);
    border-radius: 14px;
    box-shadow: 5px 5px 0 var(--ink);
    padding: 1.5rem 1.5rem 1.25rem;
    margin: 0.5rem 0 1.25rem;
}
.job-detail__hero .eyebrow { margin-bottom: 0.25rem; }
.job-detail__title {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: clamp(24px, 3.5vw, 30px);
    color: var(--ink);
    line-height: 1.2;
    margin: 0.25rem 0 0.75rem;
}
.job-detail__employer {
    margin: 0;
    font-size: 17px;
    font-weight: 500;
    color: var(--ink);
}
.job-detail__workplace { margin: 0.1rem 0 0; font-size: 14px; color: var(--ink); opacity: 0.75; }
.job-detail__location { margin: 0.5rem 0 0; font-size: 14px; color: var(--ink); opacity: 0.85; }

/* CTA-rad högst upp */
.job-detail__cta {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    border: 2.5px solid var(--ink);
    background: var(--card-money);
    border-radius: 14px;
    box-shadow: 5px 5px 0 var(--ink);
    padding: 1rem 1.25rem;
    margin: 1.25rem 0;
}
.job-detail__cta .btn--primary { background: #fff; }
.job-detail__cta .btn--primary:hover { background: #fff; }
.job-detail__deadline {
    font-size: 14px;
    color: var(--ink);
}
.job-detail__deadline strong { color: #6B3A2C; }

/* Metadata key/value-grid */
.job-detail__meta { margin: 1.5rem 0; }
.job-meta-list {
    margin: 0;
    padding: 0;
    border: 2px solid var(--ink);
    border-radius: 12px;
    background: #fff;
    overflow: hidden;
}
.job-meta-list__row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.1rem;
    padding: 0.65rem 1rem;
    border-bottom: 1px solid #eee;
}
.job-meta-list__row:last-child { border-bottom: 0; }
.job-meta-list dt {
    font-size: 12px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted);
    font-weight: 500;
    margin: 0;
}
.job-meta-list dd { margin: 0; font-size: 15px; color: var(--ink); }
@media (min-width: 640px) {
    .job-meta-list__row {
        grid-template-columns: 200px 1fr;
        gap: 1.5rem;
        align-items: baseline;
    }
}

/* Beskrivningssektion */
.job-detail__body { margin: 2rem 0 1.5rem; }
.job-detail__h2 {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 22px;
    color: var(--ink);
    margin: 0 0 0.75rem;
}
.job-detail__text {
    font-size: 15px;
    line-height: 1.7;
    color: var(--body);
    max-width: 65ch; /* läsbart paragrafmått */
}
.job-detail__text p { margin: 0 0 1em; }
.job-detail__text p:last-child { margin-bottom: 0; }

/* Andra ansökningsknappen längst ner — påminnelse efter att man läst igenom */
.job-detail__apply-bottom {
    margin: 2rem 0 1rem;
    padding: 1.25rem;
    border: 2px dashed var(--ink);
    border-radius: 12px;
    text-align: center;
}
.job-detail__apply-bottom p { margin: 0 0 0.75rem; }

.job-detail__source {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid #ddd;
}

/* Generisk chip — används av home-jobs och flera ställen.
   Behåll så övriga komponenter som ärver inte bryts. */
.chip {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    border: 1.5px solid var(--ink);
    border-radius: 999px;
    background: var(--card-stability);
    font-size: 12px;
    color: var(--ink);
}

/* Homepage job search block */
.home-jobs {
    background: var(--card-freedom);
    border: 2.5px solid var(--ink);
    border-radius: 14px;
    box-shadow: 5px 5px 0 var(--ink);
    padding: 1.5rem;
    margin: 2rem auto;
    max-width: 720px;
    text-align: center;
}
.home-jobs__title {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 22px;
    color: var(--ink);
    margin: 0 0 0.4rem;
}
.home-jobs__count { font-size: 14px; color: #2F5560; margin: 0 0 1rem; }
.home-jobs__form {
    display: flex;
    gap: 0.5rem;
    align-items: stretch;
    max-width: 480px;
    margin: 0 auto;
}
.home-jobs__form input[type="search"] {
    flex: 1;
    height: 44px;
    padding: 0 0.75rem;
    border: 2px solid var(--ink);
    border-radius: 10px;
    background: #fff;
    font-size: 15px;
    font-family: inherit;
    min-width: 0;
}
.home-jobs__form button {
    height: 44px;
    padding: 0 1.25rem;
    border: 2px solid var(--ink);
    border-radius: 10px;
    background: #fff;
    box-shadow: 3px 3px 0 var(--ink);
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: 15px;
    color: var(--ink);
    cursor: pointer;
}
.home-jobs__form button:hover {
    transform: translate(1px, 1px);
    box-shadow: 2px 2px 0 var(--ink);
}

/* Visually hide an element but keep it for screen readers (used for form
   labels paired with placeholders). */
.visually-hidden {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Admin: migration-lista */
.migration-list { list-style: none; padding: 0; margin: 1rem 0; display: flex; flex-direction: column; gap: 0.5rem; }
.migration-list__item {
    border: 1.5px solid var(--ink);
    border-radius: 8px;
    background: #fff;
}
.migration-list__item summary {
    cursor: pointer;
    padding: 0.5rem 0.75rem;
    font-size: 14px;
    list-style: none;
}
.migration-list__item summary::-webkit-details-marker { display: none; }
.migration-list__item summary::before {
    content: '▸';
    display: inline-block;
    margin-right: 0.5rem;
    transition: transform 100ms ease;
}
.migration-list__item details[open] > summary::before { transform: rotate(90deg); }
.migration-sql {
    margin: 0;
    padding: 0.75rem 1rem;
    background: var(--bg);
    border-top: 1px solid var(--ink);
    font-size: 12px;
    line-height: 1.5;
    overflow-x: auto;
    white-space: pre;
    color: var(--ink);
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
}
