/* =============================================================
   staff-modern.css
   Globale UI-finpudsninger.
   Loaded fra scripts/meta.php efter custom.css.
   Skal kun lave subtile, ikke-stukturelle \xc3\xa6ndringer.
   ============================================================= */

/* ---- Design tokens ------------------------------------------ */
:root {
    --sm-line: #e6eaf0;
    --sm-line-soft: #eef0f3;
    --sm-ink: #1f2d3d;
    --sm-ink-soft: #5d6b7c;
    --sm-bg-soft: #f7f9fc;
    --sm-accent: #002557;
    --sm-radius: 8px;
    --sm-shadow-1: 0 1px 2px rgba(20, 30, 60, 0.04);
    --sm-shadow-2: 0 4px 14px rgba(20, 30, 60, 0.07);
    --sm-trans: 120ms ease;
}

/* ---- Sektions-overskrifter (panel-heading) ------------------
   Bootstrap 3's gr\xc3\xa5 panel-heading er gammeldags. Vi g\xc3\xb8r
   default panel-heading til en hvid card-header med bundstreg
   og bold tekst. Panel-primary/info/success bevares som de er.
   ------------------------------------------------------------- */
.panel {
    border: 1px solid var(--sm-line);
    border-radius: var(--sm-radius);
    box-shadow: var(--sm-shadow-1);
    transition: box-shadow var(--sm-trans), border-color var(--sm-trans);
}

.panel-default,
.panel:not(.panel-primary):not(.panel-success):not(.panel-warning):not(.panel-danger):not(.panel-info) {
    background: #fff;
}

.panel-default > .panel-heading,
.panel:not(.panel-primary):not(.panel-success):not(.panel-warning):not(.panel-danger):not(.panel-info) > .panel-heading {
    background: #fff !important;
    color: var(--sm-ink) !important;
    border: none !important;
    border-bottom: 1px solid var(--sm-line) !important;
    border-radius: var(--sm-radius) var(--sm-radius) 0 0 !important;
    padding: 14px 18px !important;
    font-weight: 600;
    letter-spacing: -0.1px;
    font-size: 15px;
}

.panel-default > .panel-heading .panel-title,
.panel:not(.panel-primary):not(.panel-success):not(.panel-warning):not(.panel-danger):not(.panel-info) > .panel-heading .panel-title {
    font-weight: 600;
    color: var(--sm-ink);
    font-size: 15px;
    letter-spacing: -0.1px;
}

.panel-default > .panel-heading i.fa,
.panel:not(.panel-primary):not(.panel-success):not(.panel-warning):not(.panel-danger):not(.panel-info) > .panel-heading i.fa {
    color: var(--sm-accent);
    margin-right: 6px;
}

.panel-default > .panel-heading h3,
.panel:not(.panel-primary):not(.panel-success):not(.panel-warning):not(.panel-danger):not(.panel-info) > .panel-heading h3 {
    margin: 0;
    font-weight: 600;
    color: var(--sm-ink);
    font-size: 15px;
}

/* "Naked" sektionsoverskrifter — h2/h3 der bruges som section-titler udenfor paneler */
.section-title,
.panel-body > h3:first-child {
    font-size: 16px;
    font-weight: 700;
    color: var(--sm-ink);
    margin: 0 0 12px 0;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--sm-line);
    letter-spacing: -0.2px;
}

/* ---- 8/16/24 spacing-system ---------------------------------
   Vi b\xc3\xb8r ikke ramme grid-systemet, kun "luft" omkring kort,
   tabeller og sektioner.
   ------------------------------------------------------------- */
.panel { margin-bottom: 16px; }

.panel-body { padding: 16px 18px; }

.row + .row { margin-top: 8px; }

/* "section" wrapper (vi tilf\xc3\xb8jer ogs\xc3\xa5 hjul der virker
   p\xc3\xa5 generiske <section> elementer) */
section + section { margin-top: 24px; }

.container, .container-fluid {
    padding-top: 8px;
    padding-bottom: 24px;
}

/* Fix close-spacing mellem dashboard-stat-kort */
.col-xs-12 + .col-xs-12 .panel,
.col-sm-3 + .col-sm-3 .panel {
    margin-top: 0;
}

/* ---- Tabeller — l\xc3\xa6sbarhed + hover --------------------- */
.table > thead > tr > th {
    border-bottom: 1px solid var(--sm-line);
    color: var(--sm-ink-soft);
    font-weight: 600;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    padding: 12px 12px;
    background: #fff;
}

.table > tbody > tr > td {
    padding: 12px 12px;
    border-top: 1px solid var(--sm-line-soft);
    vertical-align: middle;
    transition: background-color var(--sm-trans);
}

.table-hover > tbody > tr {
    transition: background-color var(--sm-trans);
}
.table-hover > tbody > tr:hover {
    background-color: var(--sm-bg-soft);
}

/* Striped table — make zebra mere subtilt */
.table-striped > tbody > tr:nth-of-type(odd) {
    background-color: #fbfcfd;
}

/* ---- Hover/transitions p\xc3\xa5 alt klikbart ---------------- */
a, .btn, .label, .badge {
    transition: background-color var(--sm-trans),
                color var(--sm-trans),
                border-color var(--sm-trans),
                box-shadow var(--sm-trans),
                transform var(--sm-trans);
}

.btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(20, 30, 60, 0.08);
}
.btn:active {
    transform: translateY(0);
    box-shadow: none;
}

/* Subtle interactive feel p\xc3\xa5 paneler — kun hvor de fungerer som klik-kort */
.panel.clickable,
a > .panel,
.panel a.panel-link {
    cursor: pointer;
}
.panel.clickable:hover,
a:hover > .panel {
    border-color: #d4dbe5;
    box-shadow: var(--sm-shadow-2);
}

/* ---- Sidebar — bl\xc3\xb8d hover/active uden at \xc3\xa6ndre struktur */
.navbar-default .navbar-nav > li > a,
.navbar-inverse .navbar-nav > li > a,
.sidebar a,
.sidebar-nav a,
.dropdown-menu > li > a {
    transition: background-color var(--sm-trans), color var(--sm-trans);
}
.sidebar a:hover,
.sidebar-nav a:hover,
.dropdown-menu > li > a:hover {
    background-color: var(--sm-bg-soft);
}

/* Aktive menu-punkter — diskret venstre-accent (kun i sidebar-niveau) */
.sidebar > ul > li.active > a,
.sidebar-nav > li.active > a,
.sidebar > ul > li > a.active {
    box-shadow: inset 3px 0 0 var(--sm-accent);
}

/* ---- Forms — let opfriskning ----------------------------- */
.form-control {
    border: 1px solid var(--sm-line);
    border-radius: 6px;
    box-shadow: none;
    transition: border-color var(--sm-trans), box-shadow var(--sm-trans);
}
.form-control:focus {
    border-color: #93b4e1;
    box-shadow: 0 0 0 3px rgba(0, 60, 140, 0.08);
}

/* ---- Modal-headers — fjerne den gamle bl\xc3\xa5lige kant --- */
.modal-content {
    border-radius: 10px;
    border: none;
    box-shadow: 0 18px 50px rgba(20, 30, 60, 0.18);
}
.modal-header {
    border-bottom: 1px solid var(--sm-line);
    padding: 14px 20px;
}
.modal-footer {
    border-top: 1px solid var(--sm-line);
    padding: 12px 20px;
}

/* ---- Quick-Action tiles (case_details.php sidebar) ---------- */
.qa-tile {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    text-align: left;
    background: #fff;
    border: 1px solid var(--sm-line);
    border-radius: 10px;
    padding: 12px 14px;
    margin: 0 0 8px 0;
    cursor: pointer;
    color: var(--sm-ink);
    font-family: inherit;
    transition: background-color var(--sm-trans),
                border-color var(--sm-trans),
                box-shadow var(--sm-trans),
                transform var(--sm-trans);
}
.qa-tile:hover,
.qa-tile:focus {
    border-color: #d4dbe5;
    box-shadow: var(--sm-shadow-2);
    transform: translateY(-1px);
    outline: none;
}
.qa-tile:active {
    transform: translateY(0);
    box-shadow: var(--sm-shadow-1);
}

.qa-tile-icon {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 16px;
}
.qa-tile-text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.qa-tile-title {
    display: block;
    font-weight: 600;
    color: var(--sm-ink);
    font-size: 14px;
    line-height: 1.3;
}
.qa-tile-sub {
    display: block;
    color: var(--sm-ink-soft);
    font-size: 12px;
    line-height: 1.35;
}
.qa-tile-arrow {
    color: #c4ccd9;
    flex-shrink: 0;
    margin-left: 4px;
    font-size: 13px;
    transition: color var(--sm-trans), transform var(--sm-trans);
}
.qa-tile:hover .qa-tile-arrow {
    color: var(--sm-accent);
    transform: translateX(2px);
}

/* Variants — kun ikonet farves; resten af kortet forbliver rent */
.qa-tile-success .qa-tile-icon { background: #e6f7ec; color: #15803d; }
.qa-tile-info    .qa-tile-icon { background: #e8f3fc; color: #1d4ed8; }
.qa-tile-warn    .qa-tile-icon { background: #fff4e0; color: #b45309; }
.qa-tile-danger  .qa-tile-icon { background: #fde7e9; color: #b91c1c; }

/* Eventuel hover-tone p\xc3\xa5 hele tile efter variant */
.qa-tile-success:hover { background: #fafdfb; }
.qa-tile-info:hover    { background: #fafcfe; }

/* ---- Phone field (med integreret prefix) -------------------- */
.phone-field {
    position: relative;
}
.phone-field-prefix {
    position: absolute;
    left: 1px;
    top: 1px;
    bottom: 1px;
    display: flex;
    align-items: center;
    padding: 0 12px 0 14px;
    color: var(--sm-ink);
    font-weight: 600;
    font-size: 14px;
    background: var(--sm-bg-soft);
    border-right: 1px solid var(--sm-line);
    border-radius: 5px 0 0 5px;
    pointer-events: none;
    user-select: none;
    letter-spacing: 0.2px;
}
.phone-field-input {
    padding-left: 56px !important;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.5px;
}
.phone-field-input:focus + .phone-field-prefix,
.phone-field:focus-within .phone-field-prefix {
    color: var(--sm-accent);
    background: #f0f4fb;
}
.phone-field-hint {
    color: var(--sm-ink-soft);
    font-size: 12px;
    margin-top: 6px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.phone-field-hint i.fa {
    color: #93b4e1;
}

/* ---- Case action chips (StaffAI / Find reservedele / brugt) ---- */
.case-chip-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin: 12px 0 4px 0;
}
.case-chip {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 8px 14px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
    border: 1px solid transparent;
    user-select: none;
    transition: background var(--sm-trans),
                background-position var(--sm-trans),
                color var(--sm-trans),
                border-color var(--sm-trans),
                box-shadow var(--sm-trans),
                transform var(--sm-trans);
}
.case-chip:hover,
.case-chip:focus {
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 3px 10px rgba(20, 30, 60, 0.10);
    outline: none;
}
.case-chip:active {
    transform: translateY(0);
    box-shadow: var(--sm-shadow-1);
}
.case-chip i.fa { font-size: 12px; }

/* StaffAI Fejls\xc3\xb8gning — beh\xc3\xb8ld AI-flair, men subtilere */
.case-chip-ai {
    background: linear-gradient(135deg, #00ffe0 0%, #00ff80 50%, #00ffe0 100%);
    background-size: 200% 100%;
    background-position: 0% 0%;
    color: #11331b;
    border-color: rgba(0, 80, 50, 0.18);
}
.case-chip-ai:hover {
    color: #11331b;
    background-position: 100% 0%;
}

/* Find reservedele — neutral handling */
.case-chip-parts {
    background: #eaf0fb;
    color: #1d4ed8;
    border-color: #d3def3;
}
.case-chip-parts:hover {
    background: #dde7f7;
    color: #1d4ed8;
}

/* Fundet brugt reservedel — opm\xc3\xa6rksomhed (rabat-mulighed) */
.case-chip-found {
    background: linear-gradient(135deg, #fff4d6 0%, #ffe1a1 100%);
    color: #7c4a03;
    border-color: #f0c98a;
}
.case-chip-found:hover {
    color: #7c4a03;
}
.case-chip-found i.fa {
    color: #b45309;
}

/* ---- btn-default — ren visuel opfriskning -------------------
   Vi r\xc3\xb8rer KUN farver/border/hover/focus. Padding, font-size,
   line-height og border-radius p\xc3\xa5 .btn arves fra Bootstrap,
   s\xc3\xa5 alle knappers st\xc3\xb8rrelser p\xc3\xa5 systemet f\xc3\xb8lger uforandret.
   ------------------------------------------------------------- */
.btn-default {
    background-color: #ffffff;
    background-image: none;
    border-color: #d8dde5;
    color: #2c3e50;
    box-shadow: 0 1px 1px rgba(20, 30, 60, 0.03);
}
.btn-default:hover,
.btn-default:focus,
.btn-default.focus {
    background-color: #f4f7fb;
    border-color: #c3cad6;
    color: #1f2d3d;
    box-shadow: 0 2px 6px rgba(20, 30, 60, 0.06);
    outline: none;
}
.btn-default:active,
.btn-default.active,
.open > .btn-default.dropdown-toggle {
    background-color: #eef2f8 !important;
    background-image: none;
    border-color: #b9c2d0;
    color: #1f2d3d;
    box-shadow: inset 0 1px 2px rgba(20, 30, 60, 0.10);
}
.btn-default:active:hover,
.btn-default:active:focus,
.btn-default.active:hover,
.btn-default.active:focus {
    background-color: #e6ecf4 !important;
    border-color: #a8b3c4;
    color: #1f2d3d;
}

/* Disabled state — bl\xc3\xb8d/d\xc3\xa6mpet, ingen hover */
.btn-default.disabled,
.btn-default[disabled],
fieldset[disabled] .btn-default,
.btn-default.disabled:hover,
.btn-default[disabled]:hover,
fieldset[disabled] .btn-default:hover,
.btn-default.disabled:focus,
.btn-default[disabled]:focus,
fieldset[disabled] .btn-default:focus {
    background-color: #f7f8fa !important;
    border-color: #e6eaf0;
    color: #aab2bf;
    box-shadow: none;
    cursor: not-allowed;
}

/* Keyboard-focus — pr\xc3\xa6cis ring, ingen "hop" i layout */
.btn-default:focus-visible {
    box-shadow: 0 0 0 3px rgba(0, 60, 140, 0.16);
    border-color: #93b4e1;
}

/* Et lille touch p\xc3\xa5 ikon-kun-knapper s\xc3\xa5 de ikke bare er hvide kasser */
.btn-default > i.fa {
    color: #5d6b7c;
    transition: color var(--sm-trans);
}
.btn-default:hover > i.fa,
.btn-default:focus > i.fa {
    color: var(--sm-accent);
}

/* ---- Smooth scroll p\xc3\xa5 anchor-navigation -------------- */
html { scroll-behavior: smooth; }


/* =============================================================
   v=6 — Header & sidebar finpudsning
   Det blå fundament (custom.css) bevares; vi tilføjer kun:
   - skygge under topbjælken
   - lodret divider efter logo
   - synligt aktivt menupunkt (4px hvid accent + bg-tint)
   - læsbar hover på sidebar-links
   - translucent søgefelt der matcher den blå sidebar
   - dæmpet bg på udfoldede submenu-grupper
   - subtil markering af aktiv top-nav (afdeling/sektion)
   ============================================================= */

/* Topbjælke — skygge så header "sidder ovenpå" indholdet */
.navbar.navbar-fixed-top.navbar-inverse {
    box-shadow: 0 2px 8px rgba(10, 20, 50, 0.18);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

/* Logo-område — lodret divider mod menuen til højre */
.navbar.navbar-inverse .navbar-header {
    border-right: 1px solid rgba(255, 255, 255, 0.12);
}
.navbar.navbar-inverse .navbar-brand {
    transition: opacity var(--sm-trans);
}
.navbar.navbar-inverse .navbar-brand:hover {
    opacity: 0.85;
}

/* ---- Sidebar — synligt aktivt punkt -----------------------
   custom.css bruger #4e73df og #000 til hhv. .active og .active2,
   som enten forsvinder i gradienten eller bliver for hård.
   Vi giver i stedet en hvid 4px accent-bar + let bg-tint, og
   sikrer at submenu-aktive også er læsbare.
   ----------------------------------------------------------- */

.sidebar > ul > li.active > a,
.sidebar > ul > li.active2 > a,
.sidebar-nav > li.active > a,
.sidebar-nav > li.active2 > a {
    box-shadow: inset 4px 0 0 #ffffff !important;
    background-color: rgba(0, 0, 0, 0.18) !important;
    color: #ffffff !important;
    font-weight: 600;
}

/* Sub-niveau aktivt punkt — samme accent, lidt smallere */
.sidebar .nav-second-level > li.active2 > a,
.sidebar .nav-second-level > li.active > a {
    box-shadow: inset 3px 0 0 #ffffff !important;
    background-color: rgba(0, 0, 0, 0.22) !important;
    color: #ffffff !important;
}

/* Hover på sidebar-links — læsbar uanset niveau.
   custom.css' hover-bg er #4e73df (samme som sidebar-top) → usynlig.
   Vi overstyrer med en blød mørk tint. */
.sidebar a:hover,
.sidebar a:focus,
.sidebar-nav a:hover,
.sidebar-nav a:focus {
    background-color: rgba(0, 0, 0, 0.15) !important;
    color: #ffffff !important;
}

/* Udfoldet submenu-gruppe — diskret nedtoning så hierarkiet ses */
.sidebar .nav-second-level {
    background-color: rgba(0, 0, 0, 0.10);
}
.sidebar .nav-second-level > li > a {
    padding-left: 38px;
    color: rgba(255, 255, 255, 0.78) !important;
}

/* ---- Sidebar-søgefelt — translucent i stedet for hvid kasse ---
   Bemærk: custom.css:3227 sætter bg: #f8f9fc !important — derfor
   skal vi selv bruge !important her. */
.sidebar .sidebar-search {
    padding: 12px 14px 8px 14px;
}
.sidebar .sidebar-search .form-control,
#page-wrapper .sidebar .sidebar-search .form-control,
.sidebar-search .form-control {
    background-color: rgba(255, 255, 255, 0.10) !important;
    border: 1px solid rgba(255, 255, 255, 0.22) !important;
    color: #ffffff !important;
    box-shadow: none !important;
    border-radius: 6px !important;
    transition: background-color var(--sm-trans),
                border-color var(--sm-trans),
                box-shadow var(--sm-trans);
}
.sidebar .sidebar-search .form-control::placeholder,
.sidebar-search .form-control::placeholder {
    color: rgba(255, 255, 255, 0.60) !important;
}
.sidebar .sidebar-search .form-control:focus,
.sidebar-search .form-control:focus {
    background-color: rgba(255, 255, 255, 0.18) !important;
    border-color: rgba(255, 255, 255, 0.50) !important;
    color: #ffffff !important;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.12) !important;
    outline: none;
}

/* ---- Top-nav (afdelings-dropdowns) — synlig "current" --------
   Tidligere brugte vi en inset-bottom box-shadow som "underline",
   men <a> fylder ikke navbarens fulde højde, så stregen flød
   offset midt i baren. Vi bruger nu kun en blød mørk bg-tint. */
.navbar-top-links > li > a.active,
.navbar-top-links > li.active > a,
.navbar-top-links > li > a.dropdown-toggle.active,
.navbar-top-links > li.open > a,
.navbar-top-links > li.open > a:hover,
.navbar-top-links > li.open > a:focus,
.navbar-inverse .navbar-top-links > li.open > a,
.navbar-inverse .navbar-top-links > li.open > a:hover,
.navbar-inverse .navbar-top-links > li.open > a:focus {
    background-color: rgba(0, 0, 0, 0.22) !important;
    box-shadow: none !important;
    color: #ffffff !important;
}
.navbar-top-links > li > a:hover,
.navbar-top-links > li > a:focus {
    background-color: rgba(255, 255, 255, 0.08) !important;
}

/* Caret-ikon i navbar — let dæmpet så det ikke "støjer" */
.navbar-top-links .fa-caret-down {
    opacity: 0.7;
    margin-left: 4px;
}


/* =============================================================
   v=8 — Blødgør "kantet" header/sidebar
   Tre samtidige greb:
   1) Rigere gradient på både header og sidebar (mindre flad)
   2) Soft højreskygge på sidebar + stærkere bundskygge på header
      → blødere overgang til indholdsfladen
   3) Afrundet top-venstre hjørne på #page-wrapper, med en blå
      "strip" bag det rundede hjørne så sidebar visuelt fortsætter
      under hjørnet
   ============================================================= */

/* Rigere gradient — mere dybde, mindre "flad blå klods".
   Vi rammer samme selektorer som custom.css for at vinde
   specificitet/source-order (staff-modern.css loades sidst). */
.navbar-inverse {
    background-image: linear-gradient(160deg,
        #5b86f5 0%,
        #3a5ed1 45%,
        #1f3aa6 100%) !important;
}

.sidebar-nav,
.sidebar {
    background-color: transparent !important;
    background-image: linear-gradient(180deg,
        #4d72e3 0%,
        #2f50b8 50%,
        #1c3796 100%) !important;
}

/* Soft højreskygge på sidebaren — kaster en blød skygge ind
   over indholdsfladen, så kanten ikke føles knivskarp.
   Sidebar ligger som .navbar-inverse.sidebar inde i header.php. */
.sidebar,
.sidebar-nav.navbar-collapse {
    box-shadow: 4px 0 24px rgba(10, 20, 50, 0.18),
                inset -1px 0 0 rgba(255, 255, 255, 0.04);
}

/* Topbjælke — løft skyggen lidt så header også føles "ovenpå" */
.navbar.navbar-fixed-top.navbar-inverse {
    box-shadow: 0 4px 18px rgba(10, 20, 50, 0.22) !important;
}

/* (v=8 ::before radial-glow + > * z-index-trick fjernet i v=9.1
   `> *` lavede sidebaren `position: relative` — den ligger i samme
   <nav> som logoet, så navbaren blev 900px høj og dækkede skærmen.
   Den 3-stops gradient på navbar-inverse + bundskygge er nok i
   sig selv.) */

/* (v=8 body-stripe + rundet hjørne fjernet i v=9 — body-stripen
   gjorde hele skærmen blå hvor #page-wrapper ikke 100% dækkede.
   Vi beholder skyggerne og den rigere gradient.) */


/* =============================================================
   v=11 — Bløde hjørner hvor sidebar møder topbjælken
   Kun sidebars hjørner rundes; navbar og indhold rør vi ikke.
   - Top-højre rundes 14px → blødgør mødet med navbaren
   - Bund-højre rundes 14px → konsistent "pille"-look
   - Lille indre lys-streg langs top-højre kurven så kanten ses
     mod den lyse indholdsflade
   ============================================================= */

.sidebar.mobile-hide,
.sidebar {
    border-top-right-radius: 14px;
    border-bottom-right-radius: 14px;
    /* sikrer at evt. baggrund/gradient ikke flyder ud over
       det rundede hjørne (Safari/iOS quirk) */
    overflow: hidden;
}

/* Pas på: .sidebar har allerede box-shadow fra v=8.
   Vi bibeholder den men tilføjer en blød indre top-kant så det
   rundede hjørne har lidt visuel "lift" mod det lyse indhold. */
.sidebar {
    box-shadow: 4px 0 24px rgba(10, 20, 50, 0.18),
                inset 0 1px 0 rgba(255, 255, 255, 0.06),
                inset -1px 0 0 rgba(255, 255, 255, 0.04);
}

/* Mobil: drop afrunding (sidebar fylder fuld bredde) */
@media (max-width: 767px) {
    .sidebar.mobile-hide,
    .sidebar {
        border-radius: 0;
    }
}

/* =============================================================
   v=12 — Floating sidebar: luft mellem header og sidebar
   Sidebar bruger margin-top:50px (= navbar højde) for at sidde
   lige under headeren. Vi øger til 58px for 8px synlig luft, og
   reducerer max-height tilsvarende så bunden ikke skubbes under
   viewport. Det rundede top-højre hjørne bliver dermed fuldt
   synligt mod den lyse indholdsbaggrund.
   ============================================================= */
.sidebar.mobile-hide,
.sidebar {
    margin-top: 78px !important;
    max-height: calc(90vh - 28px) !important;
}

/* Mobil: behold gammel margin-top (ingen floating-effekt nødvendig) */
@media (max-width: 767px) {
    .sidebar.mobile-hide,
    .sidebar {
        margin-top: 50px !important;
        max-height: 90vh !important;
    }
}


/* =============================================================
   v=14 — Hvidt logo via CSS-filter
   Det nye logo (logo-transparent-no-graphic.webp) er designet
   til lys baggrund (grøn + mørkenavy + mørk tagline) og er ikke
   læsbart på den blå navbar. brightness(0) gør alt sort, invert(1)
   gør sort til hvidt → ren hvid silhuet på blå.

   Filteret rammer KUN navbar-brand med en bg-image (vores logo),
   ikke admin-panelets røde "Forlad Admin"-tekst-link.
   ============================================================= */
.navbar-inverse .navbar-brand[style*="background-image"] {
    filter: brightness(0) invert(1);
}


/* =============================================================
   v=15 — Logo breathing room + fjern grå skille-streg
   ============================================================= */

/* Fjern den 1px hvide skille-streg vi tilføjede i v=8/9.
   Vi vil gerne have flydende overgang fra logo til menu nu. */
.navbar.navbar-inverse .navbar-header {
    border-right: none !important;
}

/* Mere afstand fra logo til første menu-punkt ("PCSC Nørrebro") */
@media (min-width: 768px) {
    .navbar.navbar-inverse .navbar-header {
        margin-right: 28px;
    }
}

/* Luft rundt om selve logo-billedet inde i brand-elementet.
   background-origin: content-box gør at padding rent faktisk
   krymper bg-billedet, så vi får visuel "marginal" omkring
   logoet uden at flytte selve elementet. */
.navbar-inverse .navbar-brand[style*="background-image"] {
    background-origin: content-box !important;
    padding: 4px 12px !important;
    width: 250px !important;
}


/* =============================================================
   v=17 — Sidebar som ø: 10px luft til venstre + alle hjørner runde
   Højre hjørner var allerede runde (v=11). Nu rundes venstre også
   så sidebaren bliver en fritstående pille. Indholdsfladen flyttes
   10px til højre så den ikke overlapper sidebaren.
   ============================================================= */
.sidebar.mobile-hide,
.sidebar {
    margin-left: 10px !important;
    border-top-left-radius: 14px !important;
    border-bottom-left-radius: 14px !important;
}

/* Indholdet skal følge: sidebar 250px + margin 10px = 260px offset */
@media (min-width: 768px) {
    #page-wrapper {
        margin-left: 260px !important;
    }
}

/* Mobil: drop ø-effekten igen (sidebar fylder fuld bredde) */
@media (max-width: 767px) {
    .sidebar.mobile-hide,
    .sidebar {
        margin-left: 0 !important;
        border-top-left-radius: 0 !important;
        border-bottom-left-radius: 0 !important;
    }
}


/* =============================================================
   v=18 — Mere moderne form-controls (uden at ændre alt)
   - Hvid baggrund i stedet for grå #f8f9fc
   - Hover-state (border bliver mørkere)
   - Brand-blå focus-ring der matcher den nye header-gradient
   - Custom chevron på <select> i stedet for browser-default
   - Pænere disabled/readonly-look
   custom.css:3227 sætter bg-color med !important — derfor kører
   vi !important + højere specificitet alle steder.
   ============================================================= */

input.form-control,
select.form-control,
textarea.form-control,
#page-wrapper input.form-control,
#page-wrapper select.form-control,
#page-wrapper textarea.form-control,
.modal .form-control {
    background-color: #ffffff !important;
    border: 1px solid #d8dde5 !important;
    color: #1f2d3d !important;
    box-shadow: 0 1px 2px rgba(20, 30, 60, 0.03) !important;
    transition: border-color 120ms ease,
                box-shadow 120ms ease,
                background-color 120ms ease !important;
}

input.form-control:hover,
select.form-control:hover,
textarea.form-control:hover {
    border-color: #b8c2d0 !important;
}

input.form-control:focus,
select.form-control:focus,
textarea.form-control:focus {
    border-color: #4d72e3 !important;
    box-shadow: 0 0 0 3px rgba(77, 114, 227, 0.16),
                0 1px 2px rgba(20, 30, 60, 0.04) !important;
    outline: none !important;
}

.form-control:disabled,
.form-control[readonly],
input.form-control:disabled,
select.form-control:disabled,
textarea.form-control:disabled {
    background-color: #f5f7fa !important;
    color: #6c7a89 !important;
    cursor: not-allowed;
}

/* Custom chevron til <select> i stedet for browser-default trekant */
select.form-control,
#page-wrapper select.form-control {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%234d72e3' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' d='M1.5 2l4.5 4.5L10.5 2'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    background-size: 12px 8px !important;
    padding-right: 34px !important;
}

/* Re-erklæring af sidebar-søgefelt så det IKKE rammes af de hvide
   form-controls (har sin egen translucent-on-blue look). */
.sidebar .sidebar-search .form-control,
.sidebar-search .form-control {
    background-color: rgba(255, 255, 255, 0.10) !important;
    border: 1px solid rgba(255, 255, 255, 0.22) !important;
    color: #ffffff !important;
    background-image: none !important;
    padding-right: 12px !important;
}
.sidebar .sidebar-search .form-control:focus,
.sidebar-search .form-control:focus {
    background-color: rgba(255, 255, 255, 0.18) !important;
    border-color: rgba(255, 255, 255, 0.50) !important;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.12) !important;
}


/* =============================================================
   v=19 — Modernisering af top-nav dropdowns (PCSC-afdeling,
   Infoboards, TOOLS, Mere, Intern fragt). Skipper specielle
   dropdowns: dropdown-messages, dropdown-warnings, dropdown-noti,
   dropdown-sms, dropdown-user — de har deres egen styling.

   Eksisterende regler i custom.css gør dem #eee grå, mørk tekst
   og ingen depth — det får et lift med:
   - Hvid baggrund + blød skygge + rundede hjørner
   - Lille "luft" til navbaren ovenfor (so de svæver)
   - Hover med blød blå tint (matcher header-gradient)
   - Brand-blå icon-color
   - Smooth fade-in
   ============================================================= */

/* Container */
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) {
    background-color: #ffffff !important;
    border: 1px solid rgba(20, 30, 60, 0.06) !important;
    border-radius: 10px !important;
    box-shadow: 0 8px 24px rgba(20, 30, 60, 0.12),
                0 2px 6px rgba(20, 30, 60, 0.06) !important;
    padding: 6px !important;
    margin-top: 8px !important;
    min-width: 200px;
    overflow: hidden;
    animation: sm-dropdown-in 140ms ease-out;
}

@keyframes sm-dropdown-in {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Item-link */
body #wrapper .navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li > a,
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li > a {
    color: #1f2d3d !important;
    padding: 9px 14px !important;
    border-radius: 6px !important;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.3;
    margin: 1px 0;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: background-color 120ms ease, color 120ms ease, transform 120ms ease;
}

/* Ikoner inden i dropdown-items — brand-blå farve så de ikke står og flyder grå */
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li > a > i.fa,
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li > a > i {
    color: #4d72e3;
    width: 16px;
    text-align: center;
    flex-shrink: 0;
    transition: color 120ms ease;
}

/* Hover — blød blå tint, ingen layout-shift */
body #wrapper .navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li > a:hover,
body #wrapper .navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li > a:focus,
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li > a:hover,
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li > a:focus {
    background-color: #eef3fc !important;
    color: #1f3aa6 !important;
}
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li > a:hover > i.fa,
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li > a:hover > i {
    color: #1f3aa6;
}

/* Active item (det aktuelt valgte) får en svag "current"-fyld */
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li.active > a {
    background-color: #e3ebfb !important;
    color: #1f3aa6 !important;
    font-weight: 600;
}

/* Divider — pænere streg end Bootstraps default */
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li.divider {
    background-color: rgba(20, 30, 60, 0.06);
    margin: 5px 4px;
    height: 1px;
}

/* Header (hvis der er .dropdown-header inde i nogle af menuerne) */
.navbar-inverse .dropdown-menu:not(.dropdown-messages):not(.dropdown-warnings):not(.dropdown-noti):not(.dropdown-sms):not(.dropdown-user) > li.dropdown-header {
    color: #5d6b7c !important;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    padding: 8px 14px 4px 14px;
}
