/* ================================================================
   Hjemmelading – Egendefinert stilark
   Bootstrap 5 brukes som base, dette overrider/supplerer
   ================================================================ */

:root {
    --hl-primær:    #2c5f2e;   /* mørk skoggrønn */
    --hl-aksent:    #97bc62;   /* olivengrønn */
    --hl-bakgrunn:  #f5f5f0;
    --hl-kortkant:  #d8d8d0;
    --hl-tekst:     #2a2a28;
    --hl-fare:      #c0392b;
    --hl-advarsel:  #e67e22;
}

/* ── Global layout ─────────────────────────────────────────── */
.app-container {
    max-width: 1600px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}

body {
    background-color: var(--hl-bakgrunn);
    color: var(--hl-tekst);
    font-family: 'Segoe UI', system-ui, sans-serif;
    font-size: .95rem;
}

/* ── Toppmeny ──────────────────────────────────────────────── */
.navbar {
    background-color: var(--hl-primær) !important;
    box-shadow: 0 2px 6px rgba(0,0,0,.25);
}

.navbar-brand {
    font-weight: 700;
    letter-spacing: .04em;
    color: #fff !important;
}

.navbar .nav-link {
    color: rgba(255,255,255,.85) !important;
}

.navbar .nav-link:hover,
.navbar .nav-link.active {
    color: #fff !important;
}

/* ── Sidemeny ──────────────────────────────────────────────── */
.sidemeny {
    min-height: calc(100vh - 56px);
    background: #fff;
    border-right: 1px solid var(--hl-kortant);
    padding-top: 1.25rem;
}

.sidemeny .nav-link {
    color: var(--hl-tekst);
    padding: .45rem 1.25rem;
    border-radius: 4px;
    margin: 1px 8px;
    font-size: .9rem;
}

.sidemeny .nav-link:hover {
    background: var(--hl-bakgrunn);
    color: var(--hl-primær);
}

.sidemeny .nav-link.active {
    background: var(--hl-primær);
    color: #fff !important;
}

.sidemeny .nav-link i {
    width: 20px;
    margin-right: 6px;
    opacity: .75;
}

/* ── Innhold ───────────────────────────────────────────────── */
.innhold {
    padding: 1.5rem 2rem;
    min-width: 0;        /* forhindrer flex-overflow */
}

/* ── Sidetittel ────────────────────────────────────────────── */
.sidetittel {
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--hl-primær);
    margin-bottom: 1.25rem;
    padding-bottom: .5rem;
    border-bottom: 2px solid var(--hl-aksent);
    overflow-wrap: break-word;
    word-break: break-word;
    min-width: 0;
}

.sidetittel code {
    font-size: .9em;
    word-break: break-all;
}

/* ── Dashboard-kort ────────────────────────────────────────── */
.stat-kort {
    background: #fff;
    border: 1px solid var(--hl-kortant);
    border-radius: 8px;
    padding: 1.25rem 1.5rem;
    text-align: center;
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

.stat-kort .tall {
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--hl-primær);
    line-height: 1.1;
}

.stat-kort .etikett {
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #777;
    margin-top: .25rem;
}

/* ── Batchstatus-merker ────────────────────────────────────── */
.status-merke {
    display: inline-block;
    padding: .2em .65em;
    border-radius: 4px;
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .03em;
    text-transform: capitalize;
}

.status-planlagt    { background: #e8f4fd; color: #1a5276; }
.status-produsert   { background: #eaf5ea; color: #1a5c1a; }
.status-testet      { background: #fef9e7; color: #7d6608; }
.status-godkjent    { background: #d5f5e3; color: #1d6a3a; }
.status-kun-trening { background: #fde8d8; color: #7e5109; }
.status-avvist      { background: #fddede; color: var(--hl-fare); }

/* ── Alvorlighetsgrad-merker ───────────────────────────────── */
.alv-lav      { background: #eaf5ea; color: #1a5c1a; }
.alv-middels  { background: #fef9e7; color: #7d6608; }
.alv-høy      { background: #fde8d8; color: #7e5109; }
.alv-kritisk  { background: #fddede; color: var(--hl-fare); }

/* ── Tabeller ──────────────────────────────────────────────── */
.tabell-container {
    background: #fff;
    border: 1px solid var(--hl-kortant);
    border-radius: 8px;
    overflow-x: auto;   /* horisontal scroll på små skjermer */
    overflow-y: hidden; /* beholder rundet toppseksjon */
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    -webkit-overflow-scrolling: touch; /* myk scroll på iOS */
}

.table th {
    background: var(--hl-primær);
    color: #fff;
    font-weight: 500;
    font-size: .88rem;
    letter-spacing: .03em;
    border: none;
}

.table td {
    vertical-align: middle;
    font-size: .9rem;
}

.table tbody tr:hover {
    background-color: rgba(44, 95, 46, .05);
}

/* ── Skjema-panel ──────────────────────────────────────────── */
.skjema-panel {
    background: #fff;
    border: 1px solid var(--hl-kortant);
    border-radius: 8px;
    padding: 2rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    max-width: 880px;
}

/* ── Detalje-panel ─────────────────────────────────────────── */
.detalje-panel {
    background: #fff;
    border: 1px solid var(--hl-kortant);
    border-radius: 8px;
    padding: 1.5rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    margin-bottom: 1.25rem;
}

.detalje-panel h5 {
    color: var(--hl-primær);
    font-weight: 600;
    font-size: 1rem;
    border-bottom: 1px solid var(--hl-kortant);
    padding-bottom: .5rem;
    margin-bottom: 1rem;
}

/* ── Knapper ───────────────────────────────────────────────── */
.btn-primær {
    background-color: var(--hl-primær);
    border-color: var(--hl-primær);
    color: #fff;
}

.btn-primær:hover {
    background-color: #22491f;
    border-color: #22491f;
    color: #fff;
}

/* ── Blinkbilde ────────────────────────────────────────────── */
.blinkbilde-forhåndsvisning {
    max-width: 100%;
    max-height: 400px;
    border-radius: 6px;
    border: 2px solid var(--hl-kortant);
}

/* ── Flash-meldinger ───────────────────────────────────────── */
.flash-melding {
    border-radius: 6px;
    padding: .75rem 1.25rem;
    margin-bottom: 1rem;
}

/* ── Innloggingsside ───────────────────────────────────────── */
.innlogging-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--hl-primær) 0%, #1a3d1c 100%);
}

.innlogging-kort {
    background: #fff;
    border-radius: 12px;
    padding: 2.5rem 2rem;
    width: 100%;
    max-width: 420px;
    box-shadow: 0 8px 32px rgba(0,0,0,.2);
}

.innlogging-logo {
    text-align: center;
    margin-bottom: 1.75rem;
    color: var(--hl-primær);
    font-size: 1.5rem;
    font-weight: 700;
}

/* ── Mobil (< 768px) ───────────────────────────────────────── */
@media (max-width: 767.98px) {
    .innhold {
        padding: 1rem .85rem;
    }

    .skjema-panel {
        padding: 1.25rem .9rem;
        max-width: 100%;
    }

    .detalje-panel {
        padding: 1rem .85rem;
    }

    .sidetittel {
        font-size: 1.15rem;
        margin-bottom: 1rem;
    }

    /* Topplinje med tittel+knapper – stables vertikalt */
    .d-flex.justify-content-between.align-items-start {
        flex-direction: column;
        gap: .5rem;
    }

    /* Knapper i topplinje tar full bredde */
    .d-flex.justify-content-between.align-items-start > div.d-flex {
        width: 100%;
        justify-content: flex-start;
    }

    /* Statusvelger og knapp */
    .form-select.w-auto {
        width: 100% !important;
    }

    /* Stat-kort på dashboard */
    .stat-kort {
        padding: 1rem;
    }
}

/* ── Utskrift ──────────────────────────────────────────────── */
@media print {
    .sidemeny, .navbar, .btn, .no-print { display: none !important; }
    .innhold { padding: 0; }
    .detalje-panel { box-shadow: none; border: 1px solid #ccc; }
    body { background: #fff; font-size: 11pt; }
}