/* =====================================================================
   rezervacije.info — formal / corporate stylesheet
   Neutral palette, conservative typography, no animations.
   ===================================================================== */

:root {
    --bg:            #eef0f3;
    --surface:       #ffffff;
    --ink:           #1f2733;
    --ink-soft:      #5a6473;
    --line:          #cdd3dc;
    --line-strong:   #b3bbc7;
    --navy:          #243447;   /* top bar / headings */
    --navy-dark:     #1b2734;
    --admin-bar:     #1a7a2e;   /* admin top bar */
    --admin-bar-dark:#125c21;
    --accent:        #2f4a6b;   /* primary action */
    --accent-dark:   #243a55;
    --error-bg:      #fcECEC;
    --error-line:    #d9a7a3;
    --error-ink:     #8a1f17;
    --ok-bg:         #eaf4ee;
    --ok-line:       #a8cdb6;
    --ok-ink:        #1d6b3f;
    --info-bg:       #eef2f7;
    --info-line:     #b7c4d6;
    --info-ink:      #2a4361;
    /* Distinct display font for section headings (loaded in header.php). */
    --font-head:     "Montserrat", "Segoe UI", Tahoma, Arial, sans-serif;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
}

body {
    font-family: "Segoe UI", Tahoma, Arial, "Helvetica Neue", sans-serif;
    font-size: 15px;
    line-height: 1.5;
    color: var(--ink);
    background: var(--bg);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* ---- Top bar ------------------------------------------------------- */
.topbar {
    background: var(--navy);
    border-bottom: 3px solid var(--navy-dark);
    color: #fff;
}
.topbar--admin {
    background: var(--admin-bar);
    border-bottom-color: var(--admin-bar);
}
.topbar-inner {
    position: relative;
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 24px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.topbar-inner.container--wide {
    max-width: 1340px;
}
.brand {
    color: #fff;
    text-decoration: none;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.3px;
}
.topnav {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 18px;
}
.topnav-user {
    color: #c6cedb;
    font-size: 13px;
}
.topnav-link {
    color: #e7ebf1;
    text-decoration: none;
    font-size: 14px;
    padding-bottom: 2px;
    border-bottom: 1px solid transparent;
}
.topnav-link:hover {
    border-bottom-color: #e7ebf1;
}
/* "Nadgradi paket" — crown image + text in the top bar. */
.topnav-upgrade {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: rgba(232, 187, 77, 0.12);
    color: #e8bb4d;
    font-size: 13px;
    font-weight: 600;
    padding: 6px 13px 6px 10px;
    border-radius: 999px;
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease;
}
.topnav-upgrade:hover {
    background: rgba(232, 187, 77, 0.22);
    color: #f2ca5f;
    transform: translateY(-1px);
}
.topnav-upgrade-ico {
    width: 18px;
    height: 18px;
    object-fit: contain;
    filter: brightness(0) saturate(100%) invert(78%) sepia(60%) saturate(500%) hue-rotate(5deg) brightness(105%);
}
/* Envelope icon (admin) — entry point to the e-mail system. */
.topnav-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 6px;
    color: #e7ebf1;
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
}
.topnav-icon:hover {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}
.topnav-icon.is-active {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
}

/* Admin: brand (left) + centred segmented tabs in the top bar. */
.topbar-left {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    align-items: center;
}
.header-tabs {
    flex: 0 0 auto;
    height: 100%;
    display: flex;
    justify-content: center;
    gap: 30px;
}
.header-tab {
    display: flex;
    align-items: center;
    height: 100%;
    font-size: 15px;
    font-weight: 600;
    color: #bbc5d1;
    text-decoration: none;
    border-bottom: 2px solid transparent;
    transition: color 0.15s ease, border-color 0.15s ease;
}
.header-tab:hover { color: #e7ebf1; }
.header-tab.is-active {
    color: #fff;
    border-bottom-color: #fff;
}

/* ---- Layout -------------------------------------------------------- */
.container {
    flex: 1;
    width: 100%;
    max-width: 1080px;
    margin: 0 auto;
    padding: 28px 24px 48px;
}
/* Wider variant for data-dense pages (e.g. the employee table). */
.container--wide { max-width: 1340px; }

.page-title {
    font-size: 22px;
    font-weight: 600;
    color: var(--navy);
    margin: 0 0 4px;
}
.page-subtitle {
    color: var(--ink-soft);
    margin: 0 0 24px;
    font-size: 14px;
}

/* ---- Card ---------------------------------------------------------- */
.card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 4px;
    box-shadow: 0 1px 2px rgba(20, 30, 45, 0.06);
}
.card-narrow {
    max-width: 440px;
    margin: 0 auto;
}
.card-body {
    padding: 28px 32px;
}
.card-header {
    padding: 18px 32px;
    border-bottom: 1px solid var(--line);
    background: #f7f9fb;
    border-radius: 4px 4px 0 0;
}
.card-header h1,
.card-header h2 {
    margin: 0;
    font-family: var(--font-head);
    font-size: 19px;
    color: var(--navy);
    font-weight: 700;
    letter-spacing: 0.2px;
}

/* ---- Collapsible card (accordion) --------------------------------- */
.collapse-card-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    width: 100%;
    font: inherit;
    text-align: left;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
    border: 0;
    border-bottom: 1px solid var(--line);
    color: var(--navy);
    transition: background-color 0.15s ease;
}
.collapse-card-toggle:hover { background: #eef2f7; }
.collapse-card-toggle:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
}
.collapse-card-arrow {
    flex: none;
    color: var(--ink-soft);
    transition: transform 0.2s ease;
}
.collapse-card.is-open .collapse-card-arrow { transform: rotate(180deg); }
.collapse-card-body { display: none; }
.collapse-card.is-open .collapse-card-body { display: block; }
/* When collapsed the header is the whole card, so round every corner. */
.collapse-card:not(.is-open) .collapse-card-toggle {
    border-bottom-color: transparent;
    border-radius: 4px;
}

/* ---- Forms --------------------------------------------------------- */
form { margin: 0; }

fieldset {
    border: 1px solid var(--line);
    border-radius: 4px;
    padding: 18px 22px 22px;
    margin: 0 0 22px;
}
legend {
    padding: 0 8px;
    font-weight: 600;
    color: var(--navy);
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px 20px;
}
.form-row { display: flex; flex-direction: column; }
.form-row.full { grid-column: 1 / -1; }

/* Radio / checkbox choice lists (e.g. company Parametri tab) */
.choice-list { display: flex; flex-direction: column; gap: 8px; margin-top: 2px; }
.choice {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    font-size: 14px;
    font-weight: 500;
    color: var(--ink);
    margin-bottom: 0;
    cursor: pointer;
}
.choice input { margin-top: 2px; flex: 0 0 auto; }
.choice .hint { margin-top: 0; }
.choice-sub { margin-left: 26px; }

label {
    font-size: 13px;
    font-weight: 600;
    color: var(--ink);
    margin-bottom: 5px;
}
label .req { color: var(--error-ink); }
label .opt { font-weight: 400; color: var(--ink-soft); font-size: 12px; }
.hint {
    font-size: 12px;
    color: var(--ink-soft);
    margin-top: 4px;
}
.field-error {
    display: block;
    margin-top: 5px;
    font-size: 12px;
    font-weight: 600;
    color: var(--error-ink);
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="url"],
input[type="number"],
input[type="date"],
input[type="file"],
select {
    width: 100%;
    padding: 9px 11px;
    font-size: 14px;
    color: var(--ink);
    background: #fff;
    border: 1px solid var(--line-strong);
    border-radius: 3px;
}
input[type="file"] { padding: 7px 11px; }
select { height: 38px; }
input:focus,
select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 2px rgba(47, 74, 107, 0.15);
}

/* Read-only fields the company may view but not edit (admin-managed). */
input.is-locked,
input.is-locked:focus,
select.is-locked,
select.is-locked:focus {
    background: #eef0f3;
    color: var(--ink-soft);
    border-color: var(--line);
    box-shadow: none;
    cursor: not-allowed;
}

/* Invalid fields highlighted after server-side validation failure. */
input.is-invalid,
select.is-invalid,
textarea.is-invalid {
    border-color: var(--error-line);
    background-color: var(--error-bg);
}
input.is-invalid:focus,
select.is-invalid:focus,
textarea.is-invalid:focus {
    border-color: var(--error-ink);
    box-shadow: 0 0 0 2px rgba(138, 31, 23, 0.15);
}

/* Three small inputs in a row (delovna doba: leta / meseci / dnevi). */
.triplet {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}
input::placeholder { color: #9aa3b0; }

.check-row {
    display: flex;
    align-items: center;
    gap: 8px;
}
.check-row input { width: auto; }
.check-row label { margin: 0; font-weight: 500; }

/* ---- Password show/hide toggle ------------------------------------ */
.pw-wrap { position: relative; }
.pw-wrap input { padding-right: 42px; }
.pw-toggle {
    position: absolute;
    top: 50%;
    right: 6px;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    padding: 5px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--ink-soft);
}
.pw-toggle:hover { color: var(--accent); }
.pw-toggle .icon-eye { display: none; }
.pw-toggle.is-on .icon-eye-off { display: none; }
.pw-toggle.is-on .icon-eye { display: inline; }

/* ---- Date field (masked text + calendar picker) ------------------- */
.date-field { position: relative; }
.date-field .js-date { padding-right: 40px; }
.date-btn {
    position: absolute;
    top: 50%;
    right: 6px;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    padding: 5px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--ink-soft);
}
.date-btn:hover { color: var(--accent); }
/* Native picker is hidden — the calendar button triggers it via JS. */
.date-native {
    position: absolute;
    right: 8px;
    bottom: 0;
    width: 1px;
    height: 1px;
    padding: 0;
    border: 0;
    opacity: 0;
    pointer-events: none;
}

/* ---- Buttons ------------------------------------------------------- */
.btn {
    display: inline-block;
    padding: 10px 20px;
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    background: var(--accent);
    border: 1px solid var(--accent-dark);
    border-radius: 3px;
    cursor: pointer;
    text-decoration: none;
    transition: background-color 0.15s ease, border-color 0.15s ease;
}
.btn:hover { background: var(--accent-dark); }
.btn-block { display: block; width: 100%; text-align: center; }
.btn-secondary {
    background: #fff;
    color: var(--accent);
    border-color: var(--line-strong);
}
.btn-secondary:hover { background: #f1f4f8; }
.btn:disabled, .btn[disabled] {
    background: #6b7480 !important;
    border-color: #5b636e !important;
    color: #e3e6ea !important;
    cursor: not-allowed;
}

/* Neutral dark "back" button (so its white icon stays visible). */
.btn-back {
    background: #5a6473;
    border-color: #4a525e;
    color: #fff;
}
.btn-back:hover { background: #4a525e; }

/* Per-calculation action buttons (Individualni obračuni) — distinct colours
   so the three reports are easy to tell apart at a glance. */
.btn-penzija    { background: #335c8a; border-color: #2a4d74; }
.btn-penzija:hover    { background: #2a4d74; }
.btn-odpravnina { background: #2c7a5c; border-color: #246349; }
.btn-odpravnina:hover { background: #246349; }
.btn-jubilej    { background: #e8a820; border-color: #cc9218; color: #fff; }
.btn-jubilej:hover    { background: #cc9218; color: #fff; }

/* Icon images on buttons. .btn-ico--white recolours a black PNG to white. */
.btn.has-ico { display: inline-flex; align-items: center; }
.btn-ico {
    width: 16px;
    height: 16px;
    object-fit: contain;
    margin-right: 8px;
}
.btn-ico--right {
    margin-right: 0;
    margin-left: 8px;
}
.btn-ico--white { filter: brightness(0) invert(1); }

.form-actions {
    margin-top: 6px;
    display: flex;
    align-items: center;
    gap: 16px;
}

/* ---- Alerts -------------------------------------------------------- */
.alert {
    border: 1px solid var(--line);
    border-left-width: 4px;
    border-radius: 3px;
    padding: 11px 14px;
    margin: 0 0 18px;
    font-size: 14px;
}
.alert-error   { background: var(--error-bg); border-color: var(--error-line); color: var(--error-ink); }
.alert-success { background: var(--ok-bg);    border-color: var(--ok-line);    color: var(--ok-ink); }
.alert-info    { background: var(--info-bg);  border-color: var(--info-line);  color: var(--info-ink); }

/* Inline info strip (e.g. "active template: year XXXX") */
.info-banner {
    display: flex;
    align-items: center;
    gap: 6px;
    background: var(--info-bg);
    border: 1px solid var(--info-line);
    border-left: 4px solid var(--info-line);
    border-radius: 3px;
    padding: 9px 14px;
    font-size: 14px;
    color: var(--info-ink);
    margin-bottom: 18px;
}
.info-banner--center {
    justify-content: center;
    border-left-width: 1px;
    border-radius: 6px;
    font-size: 16px;
    padding: 13px 20px;
}
.info-banner-ico { font-style: normal; font-weight: 700; }
.info-banner-meta { color: var(--ink-soft); font-size: 13px; }

.error-list {
    margin: 0;
    padding-left: 18px;
}

/* ---- Two-step login ------------------------------------------------ */
.step-label {
    margin: 0 0 14px;
    font-size: 13px;
    font-weight: 600;
    color: var(--navy);
    text-transform: uppercase;
    letter-spacing: 0.4px;
}
.step-divider {
    border: 0;
    border-top: 1px solid var(--line);
    margin: 22px 0;
}

/* ---- Collapsible section (compress + fade out) -------------------- */
.collapsible {
    overflow: hidden;
    max-height: 500px;
    opacity: 1;
    transition: max-height 0.45s ease, opacity 0.35s ease, transform 0.45s ease;
}
.collapsible.collapsed {
    max-height: 0;
    opacity: 0;
    transform: translateY(-8px);
}

/* ---- Reveal (slide down + fade in) -------------------------------- */
.reveal {
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transform: translateY(-10px);
    transition: max-height 0.3s ease, opacity 0.3s ease, transform 0.3s ease;
}
.reveal.is-visible {
    max-height: 90px;
    opacity: 1;
    transform: translateY(0);
}

/* ---- Button loading spinner --------------------------------------- */
@keyframes btn-spin { to { transform: rotate(360deg); } }
.btn-spinner {
    display: inline-block;
    width: 13px;
    height: 13px;
    border: 2px solid rgba(47, 74, 107, 0.25);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: btn-spin 0.7s linear infinite;
    vertical-align: middle;
    margin-right: 7px;
}
.btn .btn-spinner {
    border-color: rgba(255,255,255,0.35);
    border-top-color: #fff;
}

/* ---- Save button with live state (clean / dirty / saving / saved) -- */
.btn-save { display: inline-flex; align-items: center; }
.btn-save .btn-spinner { display: none; }
.btn-save.is-saving .btn-spinner { display: inline-block; }
.btn-save.is-saved,
.btn-save.is-saved:hover {
    background: var(--ok-ink);
    border-color: var(--ok-ink);
    color: #fff;
}
.save-status {
    font-size: 13px;
    font-weight: 600;
    opacity: 0;
    transition: opacity 0.2s ease;
}
.save-status.is-shown { opacity: 1; }
.save-status.is-saved { color: var(--ok-ink); }
.save-status.is-error { color: var(--error-ink); }

/* ---- Copy-to-clipboard email button -------------------------------- */
.copy-email {
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    font: inherit;
    font-size: 13px;
    color: var(--accent);
    cursor: pointer;
    text-decoration: underline;
    text-decoration-style: dotted;
    text-underline-offset: 2px;
}
.copy-email:hover { color: var(--accent-dark); }
.copy-email.is-copied {
    color: var(--ok-ink);
    text-decoration: none;
    font-weight: 600;
}

/* ---- Pricing / packages page -------------------------------------- */
.pricing-intro {
    text-align: center;
    max-width: 620px;
    margin: 6px auto 38px;
}
.pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
    align-items: start;
    max-width: 1040px;
    margin: 0 auto;
}
.plan {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 30px 26px;
}
.plan--featured {
    border: 2px solid var(--accent);
    box-shadow: 0 12px 34px rgba(36, 52, 71, 0.13);
    margin-top: -8px;        /* lift it above the neighbours */
    padding-top: 38px;
}
.plan-badge {
    position: absolute;
    top: -13px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--accent);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    padding: 5px 16px;
    border-radius: 999px;
    white-space: nowrap;
}
.plan-name {
    display: flex;
    align-items: center;
    gap: 9px;
    margin: 0 0 4px;
    font-size: 19px;
    font-weight: 700;
    color: var(--navy);
}
.plan-chip {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--ok-ink);
    background: var(--ok-bg);
    border: 1px solid var(--ok-line);
    border-radius: 999px;
    padding: 2px 9px;
}
.plan-tagline {
    margin: 0 0 20px;
    font-size: 13px;
    color: var(--ink-soft);
    min-height: 34px;
}
.plan-price {
    display: flex;
    align-items: baseline;
    gap: 7px;
}
.plan-price .amount {
    font-size: 38px;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -0.5px;
}
.plan-price--free .amount { font-size: 30px; color: var(--ok-ink); }
.plan-price .period { font-size: 14px; color: var(--ink-soft); }
.plan-sub {
    margin: 5px 0 22px;
    font-size: 12px;
    color: var(--ink-soft);
}
.plan-cta { margin-bottom: 24px; }
.plan-features {
    list-style: none;
    margin: 0;
    padding: 20px 0 0;
    border-top: 1px solid var(--line);
    display: grid;
    gap: 12px;
}
.plan-features li {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    font-size: 14px;
    color: var(--ink);
}
.plan-features svg {
    flex: none;
    width: 18px;
    height: 18px;
    margin-top: 1px;
    color: var(--ok-ink);
}
.pricing-foot {
    text-align: center;
    margin: 32px 0 0;
    font-size: 13px;
    color: var(--ink-soft);
}
.pricing-foot a { color: var(--accent); }

@media (max-width: 880px) {
    .pricing-grid { grid-template-columns: 1fr; max-width: 420px; }
    .plan--featured { margin-top: 0; }
}

/* ---- Pricing v2: 5-tier cenik ------------------------------------- */
.pricing-grid5 {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
    align-items: start;
    max-width: 1320px;
    margin: 0 auto;
}
/* Denser cards so five tiers fit comfortably across. */
.pricing-grid5 .plan { padding: 24px 20px; }
.pricing-grid5 .plan-name { font-size: 17px; }
.pricing-grid5 .plan-tagline { min-height: 50px; font-size: 12.5px; margin-bottom: 16px; }
.pricing-grid5 .plan-price .amount { font-size: 32px; }
.pricing-grid5 .plan-features { font-size: 13.5px; gap: 10px; }

/* Contract-term segmented control */
.plan-term {
    display: flex;
    gap: 5px;
    margin: 16px 0 12px;
}
.term-opt {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 7px 3px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.1;
    color: var(--ink-soft);
    background: #f3f5f8;
    border: 1px solid var(--line);
    border-radius: 7px;
    cursor: pointer;
    transition: color .15s ease, background .15s ease, border-color .15s ease;
}
.term-opt:hover { border-color: var(--line-strong); }
.term-opt.is-active {
    color: #fff;
    background: var(--accent);
    border-color: var(--accent);
}
.term-off { font-size: 10px; font-weight: 700; color: var(--ok-ink); }
.term-opt.is-active .term-off { color: #cfe8d8; }

/* Add-on row (optional checkbox / included badge) */
.plan-addon {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 12px;
    font-size: 13px;
    color: var(--ink);
    cursor: pointer;
}
.plan-addon input { width: 16px; height: 16px; flex: none; cursor: pointer; }
.plan-addon b { font-weight: 700; color: var(--accent); }
.plan-addon--inc { cursor: default; color: var(--ok-ink); font-weight: 600; }
.plan-addon--inc svg { width: 16px; height: 16px; flex: none; color: var(--ok-ink); }

/* Live total for the selected term + add-on */
.plan-total {
    display: flex;
    flex-direction: column;
    gap: 1px;
    padding: 11px 13px;
    margin-bottom: 16px;
    background: #f3f5f8;
    border: 1px solid var(--line);
    border-radius: 8px;
}
.plan-total-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .4px;
    color: var(--ink-soft);
}
.plan-total-val { font-size: 21px; font-weight: 700; color: var(--ink); letter-spacing: -.3px; }
.plan-save { font-size: 11.5px; font-weight: 700; color: var(--ok-ink); }

/* Support line at the foot of each card */
.plan-support {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 16px 0 0;
    padding-top: 14px;
    border-top: 1px solid var(--line);
    font-size: 12.5px;
    color: var(--ink-soft);
}
.plan-support svg { width: 15px; height: 15px; flex: none; color: var(--accent); }

/* Extras: add-on explainer + professional services */
.extras {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    max-width: 900px;
    margin: 40px auto 0;
}
.extra-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 22px 24px;
}
.extra-title { margin: 0 0 8px; font-size: 16px; font-weight: 700; color: var(--navy); }
.extra-desc { margin: 0; font-size: 13px; line-height: 1.55; color: var(--ink-soft); }
.service-list { list-style: none; margin: 0; padding: 0; }
.service-list li {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 14px;
    padding: 11px 0;
    border-bottom: 1px solid var(--line);
}
.service-list li:last-child { border-bottom: none; }
.service-name {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 14px;
    font-weight: 600;
    color: var(--ink);
}
.service-desc { font-size: 12px; font-weight: 400; color: var(--ink-soft); }
.service-price { font-size: 14px; font-weight: 700; color: var(--accent); white-space: nowrap; }
.extra-note { margin: 10px 0 0; font-size: 12px; color: var(--ink-soft); font-style: italic; }

@media (max-width: 1200px) { .pricing-grid5 { grid-template-columns: repeat(3, 1fr); max-width: 860px; } }
@media (max-width: 820px) {
    .pricing-grid5 { grid-template-columns: repeat(2, 1fr); max-width: 560px; }
    .pricing-grid5 .plan--featured { margin-top: 0; }
    .extras { grid-template-columns: 1fr; max-width: 480px; }
}
@media (max-width: 520px) { .pricing-grid5 { grid-template-columns: 1fr; max-width: 380px; } }

/* ---- Excel import progress bar ------------------------------------- */
.import-progress { display: none; margin-top: 16px; }
.import-progress.is-active { display: block; }
.import-progress-track {
    height: 10px;
    background: #e7ebf1;
    border-radius: 999px;
    overflow: hidden;
}
.import-progress-bar {
    height: 100%;
    width: 0;
    background: var(--accent);
    border-radius: 999px;
    transition: width 0.25s ease, background 0.25s ease;
}
.import-progress-label {
    margin-top: 7px;
    font-size: 13px;
    color: var(--ink-soft);
}
/* Upload finished, server is crunching: indeterminate sweep. */
.import-progress.is-processing .import-progress-bar {
    width: 40% !important;
    animation: import-sweep 1.1s ease-in-out infinite;
}
@keyframes import-sweep {
    0%   { margin-left: -40%; }
    100% { margin-left: 100%; }
}
/* Done: full green bar + green label. */
.import-progress.is-done .import-progress-bar {
    width: 100% !important;
    margin-left: 0;
    background: var(--ok-ink);
    animation: none;
}
.import-progress.is-done .import-progress-label {
    color: var(--ok-ink);
    font-weight: 600;
}

/* ---- Auth footer link --------------------------------------------- */
.form-foot {
    text-align: center;
    margin-top: 18px;
    font-size: 14px;
    color: var(--ink-soft);
}
.form-foot a { color: var(--accent); }

/* ---- Definition / info table -------------------------------------- */
.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}
.data-table th,
.data-table td {
    text-align: left;
    padding: 9px 12px;
    border-bottom: 1px solid var(--line);
    vertical-align: top;
}
.data-table th {
    width: 230px;
    color: var(--ink-soft);
    font-weight: 600;
    background: #f7f9fb;
}

/* ---- Footer -------------------------------------------------------- */
.sitefooter {
    background: var(--surface);
    border-top: 1px solid var(--line);
    color: var(--ink-soft);
    font-size: 13px;
    text-align: center;
}
.sitefooter-inner {
    max-width: 1080px;
    margin: 0 auto;
    padding: 16px 24px;
}

/* ---- Company cards (dashboard) ------------------------------------ */
.section-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    margin: 0 0 18px;
}
.section-head .btn { flex: none; }
.section-head h2 { margin: 0; font-size: 18px; color: var(--navy); font-weight: 600; }

.company-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
    gap: 22px;
}

.company-card {
    display: flex;
    flex-direction: column;
    min-height: 190px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 4px;
    box-shadow: 0 1px 2px rgba(20, 30, 45, 0.06);
    padding: 24px 26px;
    text-decoration: none;
    color: var(--ink);
    position: relative;
    overflow: hidden;
}
.company-card:hover {
    border-color: var(--accent);
    box-shadow: 0 2px 6px rgba(20, 30, 45, 0.10);
}

.company-card-top {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
}
.company-card-logo {
    width: 32px;
    height: 32px;
    object-fit: contain;
    flex-shrink: 0;
}
.company-card-name {
    font-size: 18px;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.3;
    flex-grow: 1;
}
.company-card-meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 13px;
    color: var(--ink-soft);
}
.company-card-meta .lbl { color: #8a93a1; }
.company-card-open {
    align-self: flex-end;
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    padding: 6px 13px;
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    background: var(--accent);
    border: 1px solid var(--accent-dark);
    border-radius: 4px;
}
.company-card:hover .company-card-open { background: var(--accent-dark); }

.badge {
    display: inline-block;
    flex: none;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    padding: 2px 9px;
    border-radius: 10px;
    background: var(--info-bg);
    color: var(--info-ink);
    border: 1px solid var(--info-line);
}

/* Year chip on company cards / rows (shown for imported companies). */
.company-year {
    display: inline-block;
    flex: none;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.3px;
    padding: 2px 9px;
    border-radius: 10px;
    background: #eef2f7;
    color: var(--ink-soft);
    border: 1px solid var(--line);
}

/* "Add a company" tile */
.company-card--add {
    align-items: center;
    justify-content: center;
    text-align: center;
    border-style: dashed;
    border-color: var(--line-strong);
    background: #fbfcfd;
    color: var(--accent);
    font-weight: 600;
    box-shadow: none;
}
.company-card--add:hover {
    background: #f4f7fb;
    box-shadow: none;
}
.company-card-plus {
    display: block;
    font-size: 34px;
    line-height: 1;
    font-weight: 400;
    margin-bottom: 8px;
}

/* ---- Company colour palette (cards + list rows + detail header) ----
   Six vivid-glass tints. Each variant sets:
   --card-accent (strong strip/text), --card-tint (fill), --card-line. */
.company-card--c1, .co-row--c1, .company-profile--c1, .arow--c1 { --card-accent:#0e8fd6; --card-tint:#ceeaf8; --card-line:#90ccee; --logo-filter:brightness(0) saturate(100%) invert(42%) sepia(80%) saturate(900%) hue-rotate(185deg) brightness(100%); }
.company-card--c2, .co-row--c2, .company-profile--c2, .arow--c2 { --card-accent:#1e9e58; --card-tint:#d5f0e3; --card-line:#a8d8bc; --logo-filter:brightness(0) saturate(100%) invert(42%) sepia(65%) saturate(600%) hue-rotate(112deg) brightness(95%); }
.company-card--c3, .co-row--c3, .company-profile--c3, .arow--c3 { --card-accent:#c8302a; --card-tint:#fce8e7; --card-line:#f0bfbc; --logo-filter:brightness(0) saturate(100%) invert(22%) sepia(80%) saturate(900%) hue-rotate(342deg) brightness(96%); }
.company-card--c4, .co-row--c4, .company-profile--c4, .arow--c4 { --card-accent:#d4600a; --card-tint:#fdecd8; --card-line:#f0cfaa; --logo-filter:brightness(0) saturate(100%) invert(30%) sepia(100%) saturate(750%) hue-rotate(18deg) brightness(97%); }
.company-card--c5, .co-row--c5, .company-profile--c5, .arow--c5 { --card-accent:#c015a0; --card-tint:#fad8f4; --card-line:#ecaadf; --logo-filter:brightness(0) saturate(100%) invert(18%) sepia(90%) saturate(1100%) hue-rotate(288deg) brightness(100%); }
.company-card--c6, .co-row--c6, .company-profile--c6, .arow--c6 { --card-accent:#c4186e; --card-tint:#fce0ee; --card-line:#f0b4d0; --logo-filter:brightness(0) saturate(100%) invert(18%) sepia(90%) saturate(1000%) hue-rotate(305deg) brightness(96%); }

/* Company icons + name text coloured to match the card accent */
[class*="company-card--c"] .company-card-logo,
[class*="co-row--c"] .co-row-logo,
[class*="company-profile--c"] .company-profile-logo {
    filter: var(--logo-filter);
    opacity: 1;
}
[class*="company-card--c"] .company-card-name { color: var(--card-accent); }
[class*="co-row--c"] .co-row-name            { color: var(--card-accent); }

/* Coloured left accent strip (cards + list rows) */
[class*="company-card--c"]::before,
[class*="co-row--c"]::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 4px;
    background: var(--card-accent);
}

/* Admin dashboard table rows: coloured left accent strip, a tint that
   fades out to the right, a matching name link and a recoloured logo —
   so each company's row matches its detail-header colour. */
.list-table tr[class*="arow--c"] {
    background: linear-gradient(150deg, rgba(255,255,255,0.5) 0%, var(--card-tint) 100%);
}
.list-table tr[class*="arow--c"]:hover {
    background: linear-gradient(150deg, rgba(255,255,255,0.3) 0%, var(--card-tint) 100%);
}
.list-table tr[class*="arow--c"] td {
    border-bottom-color: var(--card-line);
}
.list-table tr[class*="arow--c"] td:first-child {
    box-shadow: inset 4px 0 0 var(--card-accent);
}
.list-table tr[class*="arow--c"] .list-link {
    color: var(--card-accent);
    font-weight: 600;
}
.arow-name {
    display: inline-flex;
    align-items: center;
    gap: 9px;
}
.arow-logo {
    width: 22px;
    height: 22px;
    object-fit: contain;
    flex-shrink: 0;
    filter: var(--logo-filter);
}

/* Grid cards: frosted tinted panel in the company colour */
.company-card[class*="company-card--c"] {
    background: linear-gradient(150deg, rgba(255,255,255,0.45) 0%, var(--card-tint) 100%);
    -webkit-backdrop-filter: blur(7px);
    backdrop-filter: blur(7px);
    border-color: var(--card-line);
    box-shadow: 0 2px 10px rgba(20, 30, 45, 0.08);
}
.company-card[class*="company-card--c"]:hover {
    border-color: var(--card-accent);
    box-shadow: 0 6px 20px rgba(20, 30, 45, 0.15);
}
/* "Odpri" button picks up the card colour */
.company-card[class*="company-card--c"] .company-card-open {
    background: var(--card-accent);
    border-color: var(--card-accent);
}
.company-card[class*="company-card--c"]:hover .company-card-open {
    background: var(--card-accent);
    filter: brightness(0.88);
}

/* List rows: tinted of the same colour */
.co-row[class*="co-row--c"] {
    background: linear-gradient(150deg, rgba(255,255,255,0.5) 0%, var(--card-tint) 100%);
    border-color: var(--card-line);
}
.co-row[class*="co-row--c"]:hover {
    border-color: var(--card-accent);
}
.co-row[class*="co-row--c"] .co-row-open {
    background: var(--card-accent);
    border-color: var(--card-accent);
}
.co-row[class*="co-row--c"]:hover .co-row-open {
    background: var(--card-accent);
    filter: brightness(0.88);
}

/* ---- Dashboard toolbar: view toggle + search --------------------- */
.dash-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}
.dash-tools {
    display: flex;
    align-items: center;
    gap: 12px;
}
.view-toggle {
    display: inline-flex;
    border: 1px solid var(--line-strong);
    border-radius: 4px;
    overflow: hidden;
}
.view-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: #fff;
    border: none;
    cursor: pointer;
    color: var(--ink-soft);
}
.view-btn + .view-btn { border-left: 1px solid var(--line-strong); }
.view-btn:hover { background: #f1f4f8; color: var(--accent); }
.view-btn.is-active { background: var(--accent); color: #fff; }
.dash-search input {
    width: 280px;
    max-width: 60vw;
    height: 36px;
    padding: 0 12px;
}

/* The [hidden] attribute must beat .company-grid's display:grid. */
[hidden] { display: none !important; }

/* ---- Company list view (wide-card rows) -------------------------- */
.company-list { display: flex; flex-direction: column; gap: 10px; }
.co-row {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 16px 20px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 6px;
    text-decoration: none;
    color: var(--ink);
    transition: border-color .15s, box-shadow .15s;
    position: relative;
    overflow: hidden;
}
.co-row:hover {
    border-color: var(--accent);
    box-shadow: 0 2px 8px rgba(20,30,45,.08);
}
.co-row-main {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 220px;
    flex-shrink: 0;
}
.co-row-logo {
    width: 32px;
    height: 32px;
    opacity: .7;
    flex-shrink: 0;
}
.co-row-name {
    font-size: 16px;
    font-weight: 700;
    color: var(--navy);
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.co-row-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 22px;
    flex: 1;
    font-size: 13px;
    color: var(--ink-soft);
}
.co-row-open {
    margin-left: auto;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    padding: 6px 13px;
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    background: var(--accent);
    border: 1px solid var(--accent-dark);
    border-radius: 4px;
    white-space: nowrap;
}
.co-row:hover .co-row-open { background: var(--accent-dark); }

.company-list-empty,
.company-grid-empty {
    margin: 18px 0 0;
    color: var(--ink-soft);
}

/* ---- Company detail header (back button + title) ------------------ */
.company-profile-header {
    margin: 0 0 24px;
}
.company-profile-top {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--line);
}
.company-profile-brand {
    display: flex;
    align-items: center;
    gap: 14px;
}
.company-profile-logo {
    width: 44px;
    height: 44px;
    object-fit: contain;
    flex-shrink: 0;
}
.company-profile-title {
    margin: 0;
    font-size: 26px;
    font-weight: 700;
    color: var(--navy);
}
.company-profile-leto {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    font-size: 52px;
    font-weight: 800;
    color: var(--navy);
    opacity: 0.18;
    letter-spacing: 4px;
    pointer-events: none;
    user-select: none;
    line-height: 1;
}
.company-profile-header[class*="company-profile--c"] .company-profile-leto {
    color: var(--card-accent);
    opacity: 0.5;
}

/* Coloured detail header — matches the company's dashboard card colour. */
.company-profile-header[class*="company-profile--c"] .company-profile-top {
    background: linear-gradient(150deg, rgba(255,255,255,0.45) 0%, var(--card-tint) 100%);
    -webkit-backdrop-filter: blur(7px);
    backdrop-filter: blur(7px);
    border: 1px solid var(--card-line);
    border-left: 4px solid var(--card-accent);
    border-radius: 8px;
    padding: 20px 24px;
    box-shadow: 0 2px 10px rgba(20, 30, 45, 0.08);
}
.company-profile-header[class*="company-profile--c"] .company-profile-title {
    color: var(--card-accent);
}
/* Back button — company accent colour */
.company-profile-header[class*="company-profile--c"] .btn-back {
    background: var(--card-accent);
    border-color: var(--card-accent);
}
.company-profile-header[class*="company-profile--c"] .btn-back:hover {
    filter: brightness(0.88);
    background: var(--card-accent);
}

/* ====================================================================
   Company-coloured theme — tints the whole company page (tabs, cards,
   fields, buttons) with the company's accent so each company feels
   distinct. Variables (--card-accent / --card-tint / --card-line) come
   from the .company-profile--cN class on the .company-theme wrapper.
   ==================================================================== */
.company-theme .tabs { border-bottom-color: var(--card-line); }
.company-theme .tab:hover { color: var(--card-accent); background: var(--card-tint); }
.company-theme .tab.active {
    color: var(--card-accent);
    background: var(--surface);
    border-color: var(--card-line);
    border-top: 2px solid var(--card-accent);
    border-bottom: 1px solid var(--surface);
}
.company-theme .tab.active .tab-count { background: var(--card-accent); color: #fff; }

/* Inner card sub-tabs */
.company-theme .subtabs { border-bottom-color: var(--card-line); }
.company-theme .subtab:hover { color: var(--card-accent); background: var(--card-tint); }
.company-theme .subtab.active {
    color: var(--card-accent);
    background: var(--surface);
    border-color: var(--card-line);
    border-top: 2px solid var(--card-accent);
    border-bottom: 1px solid var(--surface);
}

/* Card headers pick up a soft accent strip + accent heading */
.company-theme .card-header {
    background: linear-gradient(150deg, rgba(255, 255, 255, 0.6) 0%, var(--card-tint) 100%);
    border-bottom-color: var(--card-line);
    border-left: 3px solid var(--card-accent);
}
.company-theme .card-header h1,
.company-theme .card-header h2 {
    color: var(--card-accent);
    font-weight: 800;
    font-size: 20px;
    text-transform: uppercase;
    letter-spacing: 0.6px;
}
.company-theme .card { border-color: var(--card-line); }

/* Focused fields glow in the company accent (locked fields keep grey) */
.company-theme input:not(.is-locked):focus,
.company-theme select:not(.is-locked):focus,
.company-theme textarea:not(.is-locked):focus {
    border-color: var(--card-accent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--card-accent) 22%, transparent);
}

/* Primary action buttons use the company accent (secondary/back/calc-type keep theirs) */
.company-theme .btn:not(.btn-secondary):not(.btn-back):not(.btn-penzija):not(.btn-odpravnina):not(.btn-jubilej) {
    background: var(--card-accent);
    border-color: var(--card-accent);
}
.company-theme .btn:not(.btn-secondary):not(.btn-back):not(.btn-penzija):not(.btn-odpravnina):not(.btn-jubilej):hover {
    background: var(--card-accent);
    filter: brightness(0.9);
}

/* Selected radio/checkbox choices and section accents */
.company-theme .choice input { accent-color: var(--card-accent); }
.company-theme .subhead { color: var(--card-accent); }

/* Employees table — header strip in the company accent */
.company-theme .grid-table thead th { background: var(--card-accent); color: #fff; }
.company-theme .grid-table tbody tr:hover,
.company-theme .list-table tbody tr:hover { background: var(--card-tint); }
.company-theme .grid-table .emp-name { color: var(--card-accent); }

.badge-muted {
    background: #eef1f5;
    color: var(--ink-soft);
    border-color: var(--line);
}

/* ---- Admin: top-bar "skrbnik" tag --------------------------------- */
.topnav-tag {
    display: inline-block;
    margin-left: 4px;
    padding: 1px 7px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 9px;
    background: rgba(255, 255, 255, 0.14);
    color: #f0f3f8;
    vertical-align: middle;
}

/* ---- Admin: headline stat cards ----------------------------------- */
.stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 18px;
    margin: 0 0 26px;
}
.stat-card {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 16px;
    padding: 18px 20px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 4px;
    box-shadow: 0 1px 2px rgba(20, 30, 45, 0.06);
}
.stat-ico {
    width: 48px;
    height: 48px;
    object-fit: contain;
    flex-shrink: 0;
}
.stat-card-body {
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.stat-num {
    font-size: 30px;
    font-weight: 700;
    line-height: 1;
    color: var(--navy);
}
.stat-label {
    font-size: 13px;
    color: var(--ink-soft);
}

/* ---- Admin: row-based listing table ------------------------------- */
.list-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}
.list-table th,
.list-table td {
    text-align: left;
    padding: 11px 16px;
    border-bottom: 1px solid var(--line);
    vertical-align: middle;
}
.list-table thead th {
    color: var(--ink-soft);
    font-weight: 600;
    background: #f7f9fb;
    white-space: nowrap;
}
.list-table tbody tr:last-child td { border-bottom: 0; }
.list-table tbody tr:hover { background: #f7f9fb; }
.list-link {
    color: var(--accent);
    font-weight: 600;
    text-decoration: none;
}
.list-link:hover { text-decoration: underline; }
.tr-clickable { cursor: pointer; }
.tr-clickable:hover td { background: var(--hover-bg, rgba(0,0,0,.04)); }
.list-sub {
    display: inline-block;
    margin-left: 6px;
    font-size: 12px;
    color: var(--ink-soft);
}
.list-table .num,  .list-table th.num  { text-align: right; }
.list-table .ta-c, .list-table th.ta-c { text-align: center; }
.list-table .ta-r, .list-table th.ta-r { text-align: right; }
.list-table form { margin: 0; }

/* ---- Small + danger button variants ------------------------------- */
.btn-sm { padding: 5px 12px; font-size: 13px; }
.btn-danger {
    background: #9a2820;
    border-color: #7c201a;
    color: #fff;
}
.btn-danger:hover { background: #841f19; }
.btn-success {
    background: var(--ok-ink);
    border-color: #155a32;
    color: #fff;
}
.btn-success:hover { background: #155a32; }

/* ---- Custom confirm dialog ----------------------------------------- */
.confirm-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    z-index: 9000;
    align-items: center;
    justify-content: center;
}
.confirm-overlay.is-open { display: flex; }
.confirm-box {
    background: var(--surface);
    border: 1px solid var(--line-strong);
    border-top: 4px solid var(--error-line);
    border-radius: 4px;
    padding: 28px 28px 22px;
    max-width: 440px;
    width: calc(100% - 32px);
    box-shadow: 0 8px 28px rgba(0,0,0,0.18);
}
.confirm-box-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--error-ink);
    margin: 0 0 12px;
}
.confirm-box-body {
    font-size: 14px;
    color: var(--ink);
    line-height: 1.55;
    margin: 0 0 22px;
    white-space: pre-wrap;
}
.confirm-box-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
}

/* ---- Admin: select companies for transfer ------------------------- */
/* Checkbox column is hidden until selection mode is switched on. */
.co-check-col { display: none; width: 46px; text-align: center; }
#co-table.is-selecting .co-check-col { display: table-cell; }
#co-table.is-selecting tbody tr { cursor: pointer; }
.co-check-col input { width: 17px; height: 17px; pointer-events: none; }
.co-check-na { color: var(--ink-soft); }
#co-table.is-selecting tbody tr.co-main { cursor: default; }
#co-table tbody tr.is-picked td { background: rgba(47, 95, 191, 0.10); }

/* Transfer modal: a neutral variant of the confirm dialog. */
.transfer-box {
    border-top-color: var(--line-strong);
    max-width: 520px;
}
.transfer-box .confirm-box-title { color: var(--ink); }
.transfer-user-list {
    max-height: 320px;
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 4px;
}
.transfer-user-row {
    display: flex;
    gap: 11px;
    align-items: center;
    padding: 9px 13px;
    border-bottom: 1px solid var(--line);
    cursor: pointer;
}
.transfer-user-row:last-child { border-bottom: none; }
.transfer-user-row:hover { background: var(--surface-2, #f4f6fa); }
.transfer-user-sub { color: var(--ink-soft); font-size: 13px; }
.transfer-section-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--ink-soft);
    margin: 0 0 8px;
}
/* "ALI" divider between the existing-account list and the new-account input. */
.transfer-or {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 18px 0;
    color: var(--ink-soft);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 1px;
}
.transfer-or::before,
.transfer-or::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--line);
}
.transfer-email-input {
    width: 100%;
    padding: 9px 12px;
    border: 1px solid var(--line);
    border-radius: 4px;
    font-size: 14px;
    outline: none;
}
.transfer-email-input:focus { border-color: var(--line-strong); }

/* ---- Admin: XML import upload zone --------------------------------- */
.xml-upload-card { max-width: 560px; margin: 0 auto; }
.xml-drop-zone {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 36px 24px;
    border: 2px dashed var(--line-strong, #c8cfda);
    border-radius: 4px;
    cursor: pointer;
    text-align: center;
    color: var(--ink-soft);
    transition: border-color 0.15s, background 0.15s;
}
.xml-drop-zone:hover { border-color: var(--navy); background: var(--surface-2, #f4f6fa); }
.xml-drop-ico { width: 36px; height: 36px; opacity: 0.38; margin-bottom: 6px; }
.xml-drop-text { font-weight: 600; color: var(--ink); font-size: 15px; }
/* empty / chosen state switching */
.xml-state-empty { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.xml-state-chosen { display: none; flex-direction: column; align-items: center; gap: 4px; }
.xml-drop-zone.has-file { border-style: solid; border-color: var(--navy); background: rgba(47,95,191,0.05); }
.xml-drop-zone.has-file .xml-state-empty { display: none; }
.xml-drop-zone.has-file .xml-state-chosen { display: flex; }
/* chosen-state visuals */
.xml-chosen-ico { width: 40px; height: 40px; opacity: 0.80; margin-bottom: 6px; }
.xml-chosen-name { font-size: 16px; font-weight: 700; color: var(--navy); word-break: break-all; }
.xml-chosen-size { font-size: 13px; color: var(--ink-soft); }

/* A horizontal row of buttons / mini-forms (e.g. smrtnost actions). */
.btn-row { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.btn-row form { margin: 0; }

/* Inline add-forms: fields laid out in a wrapping row. */
.inline-form { display: flex; flex-wrap: wrap; gap: 16px; align-items: flex-start; }
.inline-form .form-row { margin-bottom: 0; }

/* ---- Podloge: full-width stacked year cards ----------------------- */
/* Year filter bar (admin Podloge) */
.year-filter {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    margin-bottom: 20px;
    padding: 8px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
}
.year-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    border-radius: 6px;
    text-decoration: none;
    color: var(--ink);
    font-weight: 700;
    font-size: 16px;
    border: 1px solid transparent;
    transition: background-color 0.12s ease, color 0.12s ease;
}
.year-pill:hover { background: var(--info-bg); }
.year-pill.is-active { background: var(--accent); color: #fff; }
.year-pill-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 10px;
    font-size: 12px;
    font-weight: 700;
    background: var(--info-bg);
    color: var(--info-ink);
}
.year-pill.is-active .year-pill-count {
    background: rgba(255, 255, 255, 0.22);
    color: #fff;
}
/* Small marker on the year that is the currently active template. */
.year-pill-dot { color: #2e9e4f; font-size: 11px; line-height: 1; }
.year-pill.is-active .year-pill-dot { color: #b6f0c4; }

/* Header row above the parametri form: year + status badge + actions. */
.version-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    margin: 0 0 14px;
}
.version-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.version-actions form { margin: 0; }

/* "Verzije za leto N" heading above the list */
.year-list-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 16px;
    color: var(--navy);
    margin: 0 0 14px;
}

.podloga-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.podloga-row {
    background: var(--surface);
    border: 1px solid var(--line);
    border-left: 4px solid var(--line-strong);
    border-radius: 6px;
    box-shadow: 0 1px 3px rgba(20, 30, 45, 0.07);
    padding: 18px 22px;
    transition: box-shadow 0.15s ease;
}
.podloga-row:hover { box-shadow: 0 3px 10px rgba(20, 30, 45, 0.10); }
.podloga-row.is-active {
    border-left-color: var(--ok-ink);
    background: linear-gradient(180deg, #fbfdfb 0%, var(--surface) 60%);
}
.podloga-row-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
    padding-bottom: 15px;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--line);
}
.podloga-row-ident {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.podloga-row-year {
    font-size: 28px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.5px;
    color: var(--navy);
}
.podloga-row-name {
    font-size: 15px;
    font-weight: 700;
    color: var(--ink);
}

/* Version picker cards (company Podloga tab): click a card to choose it. */
.podloga-cards {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 14px;
    margin: 0;
}
.podloga-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 240px;
    min-height: 124px;
    padding: 18px;
    text-align: center;
    font: inherit;
    color: var(--ink);
    background: #fff;
    border: 2px solid var(--line-strong);
    border-radius: 8px;
    cursor: pointer;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}
.podloga-card:hover {
    border-color: var(--accent);
    box-shadow: 0 2px 8px rgba(20, 30, 45, 0.08);
}
.podloga-card:focus-visible {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(47, 74, 107, 0.18);
}
.podloga-card.is-selected {
    border-color: #1f9d57;                 /* green */
    background: var(--ok-bg);
    box-shadow: 0 0 0 1px #1f9d57 inset;
}
.podloga-card-name {
    font-size: 14px;
    font-weight: 700;
    line-height: 1.3;
    color: var(--ink);
}
.podloga-card-year {
    font-size: 27px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.5px;
    color: var(--navy);
}
.podloga-card-check {
    height: 16px;
    line-height: 16px;
    font-size: 12px;
    font-weight: 700;
    color: #1f9d57;
}
.podloga-row-meta {
    font-size: 12px;
    color: var(--ink-soft);
}
.podloga-row-actions {
    display: flex;
    gap: 9px;
    align-items: center;
    flex-wrap: wrap;
}
.podloga-row-actions form { margin: 0; }
.podloga-row-actions .btn { white-space: nowrap; }

.podloga-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 12px;
}
.podloga-stat {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 12px 14px;
    background: #f6f8fa;
    border: 1px solid var(--line);
    border-radius: 5px;
}
.podloga-stat-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--ink-soft);
}
.podloga-stat-value {
    font-size: 18px;
    font-weight: 700;
    color: var(--navy);
}
.podloga-stat-sub {
    font-size: 11px;
    color: var(--ink-soft);
}

/* Podloga card: compact secondary params strip */
.podloga-params {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--line);
}
.podloga-param {
    display: flex;
    align-items: baseline;
    gap: 6px;
    padding: 4px 18px 4px 0;
    font-size: 12px;
}
.podloga-param-label {
    color: var(--ink-soft);
}
.podloga-param-value {
    font-weight: 600;
    color: var(--navy);
}

/* Active "aktivna" badge (green) */
.badge-active {
    background: var(--ok-bg);
    color: var(--ok-ink);
    border-color: var(--ok-line);
}

/* Two data tables side by side (e.g. smrtnost / fluktuacija per spol). */
.split-tables {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    align-items: start;
}

/* ---- Tabs (company detail) ---------------------------------------- */
.tabs {
    display: flex;
    gap: 4px;
    border-bottom: 1px solid var(--line);
    margin: 0 0 22px;
}
.tab {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    font-size: 14px;
    font-weight: 600;
    color: var(--ink-soft);
    text-decoration: none;
    border: 1px solid transparent;
    border-bottom: none;
    border-radius: 5px 5px 0 0;
    margin-bottom: -1px;
}
.tab:hover { color: var(--navy); background: #f3f6f9; }
.tab.active {
    color: var(--navy);
    background: var(--surface);
    border-color: var(--line);
    border-bottom: 1px solid var(--surface);
}
.tab-count {
    font-size: 12px;
    font-weight: 600;
    padding: 1px 8px;
    border-radius: 10px;
    background: #e7ecf2;
    color: var(--ink-soft);
}
.tab.active .tab-count { background: var(--accent); color: #fff; }

/* ---- Sub-tabs inside a card (Oblika odpravnine) ------------------- */
.subtabs {
    display: flex;
    gap: 4px;
    border-bottom: 1px solid var(--line);
    margin: -4px 0 18px;
    flex-wrap: wrap;
}
.subtab {
    padding: 8px 16px;
    font-size: 14px;
    font-weight: 600;
    color: var(--ink-soft);
    background: none;
    border: 1px solid transparent;
    border-bottom: none;
    border-radius: 5px 5px 0 0;
    margin-bottom: -1px;
    cursor: pointer;
}
.subtab:hover { color: var(--navy); background: #f3f6f9; }
.subtab.active {
    color: var(--navy);
    background: var(--surface);
    border-color: var(--line);
    border-bottom: 1px solid var(--surface);
}

/* ---- Panožne pogodbe bracket table -------------------------------- */
.js-go-panozne { margin-left: auto; }
.panozne-table th { width: auto; }
.panozne-table td { vertical-align: middle; padding: 6px 8px; }
.panozne-table input { width: 100%; }
.panozne-od,
.panozne-do[readonly] { background: #eef1f5; color: var(--ink-soft); cursor: default; }
.panozne-del { padding: 4px 10px; line-height: 1; }

/* ---- Jubilejne nagrade — panožne milestone tables ----------------- */
.subhead {
    font-size: 14px;
    font-weight: 600;
    color: var(--navy);
    margin: 20px 0 8px;
}
.jubilej-table th { width: auto; }
.jubilej-table td { vertical-align: middle; padding: 6px 8px; }
.jubilej-table input[type="text"] { width: 100%; max-width: 170px; }
.jubilej-table .doba-cell { display: flex; flex-wrap: wrap; gap: 8px 22px; }
.jubilej-table .doba-cell .choice { margin: 0; white-space: nowrap; }

/* ---- Company info (Podatki tab) — two columns of label/value ------ */
.info-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 52px;
}
.info-dl { margin: 0; }
.info-pair {
    display: grid;
    grid-template-columns: 165px 1fr;
    gap: 14px;
    align-items: baseline;
    padding: 12px 2px;
    border-bottom: 1px solid var(--line);
}
.info-dl .info-pair:last-child { border-bottom: none; }
.info-pair dt {
    margin: 0;
    font-size: 13px;
    font-weight: 600;
    color: var(--ink-soft);
}
.info-pair dd {
    margin: 0;
    font-size: 14px;
    color: var(--ink);
    word-break: break-word;
}

/* Wider label column for the read-only Podloga view, so long labels
   (e.g. "Upokojitvena starost – moški") fit on one line. */
.info-cols--wide .info-pair { grid-template-columns: 210px 1fr; }
@media (max-width: 640px) {
    .info-cols--wide .info-pair { grid-template-columns: 1fr; }
}

/* Small column heading inside an info-dl (e.g. Moški / Ženske). */
.info-col-head {
    margin: 0 0 2px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--accent);
}

/* Click-to-copy value (Osnovni podatki). */
.copyable {
    position: relative;
    cursor: pointer;
    border-radius: 3px;
    padding: 0 3px;
    margin: 0 -3px;
    transition: background-color 0.12s ease;
}
.copyable:hover { background: var(--info-bg); }
.copyable:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.copyable.is-copied { background: var(--ok-bg); }
.copyable.is-copied::after {
    content: "Kopirano";
    position: absolute;
    left: 50%;
    bottom: 100%;
    transform: translateX(-50%);
    margin-bottom: 5px;
    background: var(--navy);
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    line-height: 1.4;
    padding: 2px 8px;
    border-radius: 3px;
    white-space: nowrap;
    pointer-events: none;
    z-index: 2;
}
.info-tag {
    display: inline-block;
    margin-left: 6px;
    font-size: 11px;
    padding: 1px 8px;
    border-radius: 10px;
    background: var(--info-bg);
    color: var(--info-ink);
    border: 1px solid var(--info-line);
    vertical-align: middle;
}

/* ---- Employees toolbar -------------------------------------------- */
.emp-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin: 0 0 16px;
}
.emp-title {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: var(--navy);
}
/* ---- Export dropdown (Izvozi zaposlene) ----------------------------- */
.export-dropdown {
    position: relative;
}
.export-dropdown-arrow {
    margin-left: 4px;
    flex-shrink: 0;
    transition: transform 0.15s;
}
.export-dropdown.is-open .export-dropdown-arrow {
    transform: rotate(180deg);
}
.export-dropdown-menu {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    min-width: 180px;
    background: #fff;
    border: 1px solid #d0d8e4;
    border-radius: 5px;
    box-shadow: 0 4px 14px rgba(0,0,0,0.10);
    z-index: 200;
    padding: 4px 0;
}
.export-dropdown.is-open .export-dropdown-menu {
    display: block;
}
.export-dropdown-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 16px;
    font-size: 14px;
    font-weight: 500;
    color: var(--ink);
    text-decoration: none;
    white-space: nowrap;
}
.export-dropdown-item:hover {
    background: #f1f4f8;
    color: var(--navy);
}
.count-pill {
    font-size: 13px;
    font-weight: 600;
    padding: 2px 11px;
    border-radius: 12px;
    background: #eef1f5;
    color: var(--ink-soft);
    border: 1px solid var(--line);
}

/* ---- Columnar list table (employees) ------------------------------ */
.table-scroll {
    overflow-x: auto;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: var(--surface);
    box-shadow: 0 1px 2px rgba(20, 30, 45, 0.05);
}
.grid-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.grid-table th,
.grid-table td {
    text-align: left;
    padding: 10px 13px;
    border-bottom: 1px solid var(--line);
    white-space: nowrap;
}
.grid-table thead th {
    background: var(--navy);
    color: #eaeef3;
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    border-bottom: none;
}
.grid-table tbody tr:nth-child(even) { background: #f8fafb; }
.grid-table tbody tr:hover { background: #eef3f8; }
.grid-table tbody tr:last-child td { border-bottom: none; }
.grid-table th.num,
.grid-table td.num { text-align: right; }
.grid-table th.ta-c,
.grid-table td.ta-c { text-align: center; }
.grid-table .emp-name { font-weight: 600; color: var(--navy); }
.grid-table .mono { font-variant-numeric: tabular-nums; letter-spacing: 0.2px; }

/* Yes/No pill (Pogodba, Pripojen) */
.yn {
    display: inline-block;
    min-width: 34px;
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    padding: 1px 9px;
    border-radius: 10px;
    border: 1px solid transparent;
}
.yn-yes { background: var(--info-bg); color: var(--info-ink); border-color: var(--info-line); }
.yn-no  { background: #f0f2f5; color: var(--ink-soft); border-color: var(--line); }

.empty-note { color: var(--ink-soft); margin: 0; }

/* Doba unit labels (L / M / D) */
.doba-u {
    font-size: 0.72em;
    font-weight: 600;
    color: var(--ink-soft);
    margin-left: 1px;
    letter-spacing: 0.03em;
}

/* ---- Responsive ---------------------------------------------------- */
@media (max-width: 760px) {
    .split-tables { grid-template-columns: 1fr; }
    .info-cols { grid-template-columns: 1fr; column-gap: 0; }
    /* When stacked, the first column's last row needs its divider back. */
    .info-dl .info-pair:last-child { border-bottom: 1px solid var(--line); }
    .info-cols .info-dl:last-child .info-pair:last-child { border-bottom: none; }
}
@media (max-width: 640px) {
    .form-grid { grid-template-columns: 1fr; }
    .card-body { padding: 22px 18px; }
    .topbar-inner { padding: 0 16px; }
    .data-table th { width: 40%; }
    .company-grid { grid-template-columns: 1fr; }
    .section-head { flex-direction: column; align-items: stretch; }
    .emp-toolbar { flex-direction: column; align-items: stretch; }
    .info-pair { grid-template-columns: 140px 1fr; }
}

/* ---- Obračuni: employee search bar -------------------------------- */
.search-bar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.search-input {
    flex: 1 1 320px;
    min-width: 220px;
    padding: 9px 12px;
    font-size: 15px;
    color: var(--ink);
    background: #fff;
    border: 1px solid var(--line-strong);
    border-radius: 3px;
}
.search-input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 2px rgba(47, 74, 107, 0.15);
}

/* =====================================================================
   Individualni obračun — print-friendly report (obracun.php)
   ===================================================================== */
.report-body {
    background: #e9ecf1;
    margin: 0;
    padding: 24px 16px 60px;
}
.report-toolbar {
    max-width: 820px;
    margin: 0 auto 18px;
    display: flex;
    justify-content: space-between;
    gap: 12px;
}
.report-sheet {
    max-width: 820px;
    margin: 0 auto;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 4px;
    padding: 40px 44px;
    color: var(--ink);
}
.report-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
    padding-bottom: 18px;
    border-bottom: 2px solid var(--navy);
}
.report-brand { display: flex; gap: 14px; align-items: center; }
.report-logo { width: 46px; height: 46px; object-fit: contain; }
.report-title { margin: 0; font-size: 21px; color: var(--navy); }
.report-company { margin: 3px 0 0; color: var(--ink-soft); font-size: 14px; }
.report-meta { text-align: right; font-size: 13px; color: var(--ink); white-space: nowrap; }
.report-meta div { margin-bottom: 4px; }
.report-meta-lbl {
    display: block;
    color: var(--ink-soft);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.report-section { margin-top: 26px; }
.report-h2 {
    margin: 0 0 12px;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--accent);
}

.report-dl {
    margin: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 32px;
}
.report-dl div {
    display: grid;
    grid-template-columns: 180px 1fr;
    align-items: baseline;
    padding: 6px 0;
    border-bottom: 1px solid var(--line);
}
.report-dl dt { margin: 0; color: var(--ink-soft); font-size: 13px; }
.report-dl dd { margin: 0; font-weight: 600; }

.report-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.report-table th {
    text-align: left;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    color: var(--ink-soft);
    border-bottom: 2px solid var(--line-strong);
    padding: 8px 10px;
}
.report-table td { padding: 10px; border-bottom: 1px solid var(--line); vertical-align: top; }
.report-table th.num, .report-table td.num { text-align: right; }
.report-table .report-sub {
    display: block;
    font-weight: 400;
    color: var(--ink-soft);
    font-size: 12px;
    margin-top: 2px;
}
.report-table tr.is-binding { background: var(--info-bg); }
.report-table tr.report-total td {
    border-top: 2px solid var(--navy);
    border-bottom: none;
    font-weight: 700;
    background: #f4f7fb;
}
.report-ok { color: var(--ok-ink); font-weight: 700; }
.report-muted { color: var(--ink-soft); font-weight: 400; font-size: 12px; }

.report-note { margin: 12px 0 0; font-size: 12px; color: var(--ink-soft); line-height: 1.5; }
.report-warn {
    background: var(--error-bg);
    border: 1px solid var(--error-line);
    color: var(--error-ink);
    border-radius: 4px;
    padding: 12px 16px;
    font-size: 13px;
}
.report-warn ul { margin: 6px 0 0; padding-left: 18px; }
.report-foot {
    margin-top: 32px;
    padding-top: 14px;
    border-top: 1px solid var(--line);
    text-align: center;
    color: var(--ink-soft);
    font-size: 12px;
}

@media print {
    .no-print { display: none !important; }
    .report-body { background: #fff; padding: 0; }
    .report-sheet { max-width: none; margin: 0; border: none; border-radius: 0; padding: 0 6mm; }
    .report-table tr.is-binding,
    .report-table tr.report-total td {
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }
}
@media (max-width: 640px) {
    .report-sheet { padding: 24px 18px; }
    .report-head { flex-direction: column; }
    .report-meta { text-align: left; }
    .report-dl { grid-template-columns: 1fr; }
}

/* =====================================================================
   E-mail system (admin-email*.php)
   ===================================================================== */
.email-field { margin-bottom: 18px; }
.email-field > label {
    display: block;
    font-weight: 600;
    font-size: 14px;
    margin-bottom: 6px;
    color: var(--ink);
}
.email-field input[type="text"],
.email-field input[type="file"],
.email-field textarea,
.email-field select {
    width: 100%;
    padding: 9px 12px;
    font-size: 14px;
    font-family: inherit;
    color: var(--ink);
    background: #fff;
    border: 1px solid var(--line-strong);
    border-radius: 4px;
}
.email-field textarea { min-height: 200px; resize: vertical; line-height: 1.5; }
.email-field input:focus,
.email-field textarea:focus,
.email-field select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 2px rgba(47, 74, 107, 0.15);
}
.email-hint { font-size: 12px; color: var(--ink-soft); margin: 4px 0 0; }

/* Recipient mode chooser */
.rcpt-modes { display: grid; gap: 10px; margin-bottom: 14px; }
.rcpt-mode {
    display: flex;
    gap: 11px;
    align-items: flex-start;
    padding: 12px 14px;
    border: 1px solid var(--line-strong);
    border-radius: 6px;
    cursor: pointer;
    transition: border-color 0.15s ease, background 0.15s ease;
}
.rcpt-mode:hover { border-color: var(--accent); }
.rcpt-mode input { margin-top: 3px; }
.rcpt-mode.is-on { border-color: var(--accent); background: rgba(47, 74, 107, 0.05); }
.rcpt-mode-title { font-weight: 600; font-size: 14px; color: var(--ink); }
.rcpt-mode-desc { font-size: 12.5px; color: var(--ink-soft); margin-top: 2px; }
.rcpt-sub { margin: 4px 0 0 31px; }
.rcpt-sub[hidden] { display: none; }

/* Selectable list of company users */
.rcpt-list {
    max-height: 280px;
    overflow-y: auto;
    border: 1px solid var(--line);
    border-radius: 4px;
}
.rcpt-list label {
    display: flex;
    gap: 9px;
    align-items: center;
    padding: 7px 12px;
    border-bottom: 1px solid var(--line);
    font-size: 13.5px;
    cursor: pointer;
}
.rcpt-list label:last-child { border-bottom: none; }
.rcpt-list label:hover { background: var(--bg-soft, #f6f8fa); }
.rcpt-list .rcpt-email { color: var(--ink-soft); font-size: 12.5px; }

/* Queue / status pills */
.q-stat {
    display: inline-block;
    padding: 2px 9px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
}
.q-stat.is-pending  { background: #eef2f7; color: #5a6473; }
.q-stat.is-sending  { background: #fff4d6; color: #8a6d1a; }
.q-stat.is-done     { background: #e3f3e7; color: #2c7a3f; }
.q-stat.is-failed   { background: #fbe4e4; color: #a23535; }
.q-stat.is-canceled { background: #eceef1; color: #8a93a3; }

.email-stat-row { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 18px; }
.email-stat {
    flex: 1 1 130px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 6px;
    padding: 14px 16px;
}
.email-stat .n { display: block; font-size: 24px; font-weight: 700; color: var(--navy); }
.email-stat .l { font-size: 12.5px; color: var(--ink-soft); }

.email-2col { display: grid; grid-template-columns: 1fr 360px; gap: 20px; align-items: start; }
@media (max-width: 900px) { .email-2col { grid-template-columns: 1fr; } }

/* =====================================================================
   Analiza občutljivosti (obcutljivost.php) — sensitivity worksheet.
   Muted amber = "ob zvišanju", soft green = osnova; keeps the formal tone.
   ===================================================================== */
.obc-grid { width: 100%; border-collapse: collapse; font-size: 14px; }
.obc-grid th,
.obc-grid td { border: 1px solid var(--line); padding: 8px 10px; text-align: center; }
.obc-grid thead th { background: var(--info-bg); color: var(--info-ink); font-weight: 600; }
.obc-grid thead th.obc-sub { font-weight: 500; font-size: 12.5px; color: var(--ink-soft); }
.obc-grid td.obc-label { text-align: left; }
.obc-grid td.obc-num,
.obc-grid td.obc-res { text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
.obc-sep { color: var(--ink-soft); }

.obc-korek { background: #f7f9fc; vertical-align: top; }
.obc-korek-label { display: block; font-size: 12px; color: var(--ink-soft); margin-bottom: 6px; }
.obc-korek input { width: 64px; text-align: center; padding: 5px 6px; border: 1px solid var(--line-strong); border-radius: 4px; }
.obc-korek-unit { display: inline-block; margin-left: 4px; color: var(--ink-soft); font-size: 12px; }
.obc-uporabi {
    display: block;
    margin-top: 7px;
    width: 100%;
    font-size: 11px;
    font-weight: 600;
    padding: 3px 8px;
    background: #fff;
    color: var(--accent);
    border: 1px solid var(--line-strong);
    border-radius: 4px;
    cursor: pointer;
    letter-spacing: 0.2px;
}
.obc-uporabi:hover { background: #f1f4f8; border-color: var(--accent); }

/* Column colours: blue=aktualni, green=zvišanje, red=znižanje */
.obc-col-akt  { background: #eef4fb; }
.obc-col-gor  { background: #edf7ed; }
.obc-col-dol  { background: #fdf0f0; }
.obc-th-akt   { background: #d5e8f7 !important; color: #1a4d7a !important; }
.obc-th-gor   { background: #c8ecc8 !important; color: #1a5c1a !important; }
.obc-th-dol   { background: #f7d5d5 !important; color: #7a1a1a !important; }
.obc-th-res-gor { background: #b8e4b8 !important; color: #1a5c1a !important; }
.obc-th-res-dol { background: #f2c0c0 !important; color: #7a1a1a !important; }
.obc-res-gor  { background: #edf7ed; text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
.obc-res-dol  { background: #fdf0f0; text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
.obc-base  { background: #d5e8f7; color: #1a4d7a; font-weight: 700; text-align: right; }
.obc-foot-label { text-align: right; font-weight: 600; color: var(--ink); }

.obc-legend { display: flex; gap: 22px; flex-wrap: wrap; margin: 14px 2px 0; font-size: 13px; color: var(--ink-soft); }
.obc-legend .obc-key { display: inline-block; width: 14px; height: 14px; border: 1px solid var(--line-strong); border-radius: 3px; vertical-align: -2px; margin-right: 6px; }
.obc-legend .obc-key-akt { background: #eef4fb; }
.obc-legend .obc-key-gor { background: #edf7ed; }
.obc-legend .obc-key-dol { background: #fdf0f0; }
.obc-legend .obc-key-base { background: #d5e8f7; }

/* ---- Obračuni podjetja — report cards (big, centered) --------------- */
.obr-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 18px;
    margin-top: 6px;
}
.obr-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 12px;
    padding: 34px 26px 28px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 16px;
    text-decoration: none;
    color: var(--ink);
    transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.obr-card:hover {
    transform: translateY(-3px);
    border-color: var(--accent);
    box-shadow: 0 14px 30px rgba(31, 39, 51, .12);
}
.obr-card-ico {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 62px;
    height: 62px;
    border-radius: 18px;
    background: #eef4fb;
    color: var(--accent);
    margin-bottom: 4px;
    transition: transform .14s ease;
}
.obr-card:hover .obr-card-ico { transform: scale(1.06); }
.obr-card-title { font-size: 17.5px; font-weight: 700; line-height: 1.3; }
.obr-card-sub { font-size: 13.5px; color: var(--ink-soft); line-height: 1.45; max-width: 30ch; }
.obr-card-go { margin-top: 8px; font-size: 13.5px; font-weight: 600; color: var(--accent); }
.obr-card:hover .obr-card-go { color: var(--accent-dark); }

/* Distinct colour per report type for instant recognition. */
.obr-card--summary .obr-card-ico { background: #eaf1fa; color: #2f4a6b; }
.obr-card--analiza .obr-card-ico { background: #e4f3f2; color: #157a73; }
.obr-card--time    .obr-card-ico { background: #e7f4ec; color: #1f7a3d; }
.obr-card--sm      .obr-card-ico { background: #efeafa; color: #5b3f9e; }
.obr-card--people  .obr-card-ico { background: #fcefe2; color: #b56321; }
