/* ============================================================
   1-portal.css (Rensad)
   - Tar bort gamla tabb-regler (vita bakgrunder etc.)
   - Behåller nuvarande ordning men utan dubletter
   - Tabbar: använder var(--bg) och är lite lägre i höjd
   ============================================================ */

/* PRINT */
@media print {
  .no-print,
  .no-print * {
    display: none !important;
  }
}

/* LINKS */
a.text-link {
  text-decoration: none;
  box-shadow: inset 0 -3px 0 var(--warn);
  color: inherit;
  transition: background 0.1s cubic-bezier(.33, .66, .66, 1);
}
a.text-link:hover {
  color: var(--warn);
}

a.portal-pdf {
  text-decoration: none;
  color: var(--text);
}
.portal-pdf-icon:before {
  font-family: "Font Awesome 5 Free";
  font-weight: 300;
  content: "\f1c1 ";
  padding-right: 5px;
  color: var(--error);
}

/* SCROLLBAR */
.scrollbar::-webkit-scrollbar {
  width: 15px;
  background-color: rgb(211, 211, 211);
}
.scrollbar::-webkit-scrollbar-thumb {
  border-radius: 10px;
  --webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .3);
  background-color: var(--muted);
}

/* STANDARD COLORS */
.evx-standard-color-blue { color: var(--accent); }
.evx-standard-color-green { color: var(--ok); }
.evx-standard-color-yellow { color: yellow; }
.evx-standard-color-red { color: red; }
.evx-standard-color-orange { color: var(--warn); }

/* ============================================================
   TABS
   ============================================================ */
.EVX-Tab {
  width: 100%;
}

/* Tab bar */
.EVX-Tab-Buttons {
  border-bottom: 1px solid var(--accent);
  background: var(--bg);
  padding: 8px 10px 0;        /* lite tightare */
  gap: 14px;
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
}

/* Tab button (inactive) */
.EVX-Tab-Btn {
  background: var(--bg);
  color: #e6e6e6 !important;

  border: 1px solid var(--accent) !important;
  border-bottom: 0 !important;
  border-radius: 10px 10px 0 0 !important;

  display: inline-flex;
  align-items: center;
  gap: 8px;

  /* ↓ mindre höjd */
  min-height: 28px;
  padding: 4px 14px;

  width: auto !important;
  margin-right: 0 !important;

  box-shadow: none !important;
  font-weight: 400;
}
.EVX-Tab-Btn:focus { outline: 0; }

.EVX-Tab-Btn:hover {
  background: var(--accent) !important;
  color: #ffffff !important;
}

.EVX-Tab-Btn-Active,
.EVX-Tab-Btn-Active-Editor{
  background: var(--bg) !important;
  color: var(--text) !important;
  font-weight: 700;
  box-shadow: 0 1px 0 var(--bg) !important; /* täcker linjen under */
  position: static; /* ingen pixel-förskjutning */
}

@media (max-width: 980px) {
  .EVX-Tab-Btn-Active,
  .EVX-Tab-Btn-Active-Editor {
    background: var(--accent) !important;
    color: #ffffff !important;
    box-shadow: none !important;
  }
}


/* Icons inherit color */
.EVX-Tab-Btn i,
.EVX-Tab-Btn svg,
.EVX-Tab-Btn .fa {
  color: inherit !important;
  fill: currentColor;
}

/* ============================================================
   TAB FLEX LAYOUT
   ============================================================ */
.EVX-Tab-Flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  gap: 16px;
  width: 100%;
  box-sizing: border-box;
  background: var(--bg);
}

.EVX-Tab-Flex > .EVX-Tab-Flex-1,
.EVX-Tab-Flex > fieldset.EVX-Tab-Flex-1 {
  flex: 0 1 25%;
  max-width: 25%;
  box-sizing: border-box;
}

.EVX-Tab-Flex > .EVX-Tab-Flex-2,
.EVX-Tab-Flex > fieldset.EVX-Tab-Flex-2 {
  flex: 0 1 50%;
  max-width: 50%;
  box-sizing: border-box;
}

.EVX-Tab-Flex > .EVX-Tab-Flex-3,
.EVX-Tab-Flex > fieldset.EVX-Tab-Flex-3 {
  flex: 0 1 75%;
  max-width: 75%;
  box-sizing: border-box;
}

.EVX-Tab-Flex > .EVX-Tab-Full-Width,
.EVX-Tab-Flex > fieldset.EVX-Tab-Full-Width {
  flex: 0 0 100%;
  max-width: 100%;
  width: 100%;
  min-width: 100%;
  display: block;
  box-sizing: border-box;
}

.EVX-Tab-Flex fieldset,
.EVX-Tab-Full-Width fieldset,
fieldset.EVX-Tab-Full-Width {
  border: 1px solid var(--accent);
  border-radius: 6px;
  background: var(--bg);
  margin: 0;
  padding: 0.75em;
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .EVX-Tab-Flex > * {
    flex: 1 1 100% !important;
    max-width: 100% !important;
    min-width: 100% !important;
  }
}

/* ============================================================
   jQuery UI / FontAwesome icon tweaks
   ============================================================ */
.ui-icon[class*=" icon-"] {
  background: none repeat scroll 0 0 transparent;
  text-indent: 0;
  margin-top: -0.5em;
}
.ui-icon.icon-large {
  margin-top: -0.75em;
}
.ui-button-icon-only .ui-icon[class*=" icon-"] {
  margin-left: -7px;
}

/* ============================================================
   STATUS / DHCP HIGHLIGHTS
   ============================================================ */
.dhcp-span-start { background-color: var(--warn) !important; }
.dhcp-span-mid { background-color: #fff8c3 !important; }
.dhcp-span-end { background-color: var(--warn) !important; }

.status-error { background-color: var(--error) !important; }
.status-warning { background-color: var(--warn) !important; }
.status-ok { background-color: var(--ok) !important; }

/* ============================================================
   MESSAGE ICONS
   ============================================================ */
.message-icon,
.message-icon-no-message,
.message-icon-default {
  color: var(--accent);
}
.message-icon-quote { color: var(--accent) !important; }
.message-icon-health-check,
.message-icon-information { color: var(--ok) !important; }
.message-icon-warning { color: #ffe628 !important; }
.message-icon-permission-denied,
.message-icon-error { color: var(--error) !important; }

/* ============================================================
   MODAL
   ============================================================ */
.evxmodal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 21;
}

.evxmodal-box {
  display: none;
  opacity: 1 !important;
  position: fixed;
  top: 25%;
  left: 50%;
  width: 500px;
  margin-top: -100px;
  margin-left: -250px;
  background-color: var(--card);
  border: 2px solid var(--card);
  box-shadow: 15px 15px 30px rgba(0, 0, 0, 0.3);
  border-radius: 3px;
  text-align: center;
  z-index: 25;
}

.evxmodal-hidden { display: none !important; }

.evxmodal-box-title {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid var(--border);
  background-color: var(--accent);
  color: #fff !important;
}

.evxmodal-box-title-info,
.evxmodal-box-title-help,
.evxmodal-box-title-message,
.evxmodal-box-title-password-change,
.evxmodal-box-title-input,
.evxmodal-box-title-sign,
.evxmodal-box-title-login {
  background-color: var(--accent);
}
.evxmodal-box-title-warning { background-color: orange; }
.evxmodal-box-title-success { background-color: #006D00; }
.evxmodal-box-title-fail,
.evxmodal-box-title-error { background-color: var(--error); }

.evxmodal-box-title-center,
.evxmodal-box-title-left,
.evxmodal-box-title-right {
  font-size: 18px;
  padding: 5px;
  font-weight: normal;
  color: #fff;
  border: 0;
}
.evxmodal-box-title-center { text-align: center; }
.evxmodal-box-title-left { text-align: left; margin-left: 5px; }
.evxmodal-box-title-right { text-align: right; margin-right: 5px; }

.evxmodal-box-msg { padding: 1em; color: var(--text); }

.evxmodal-box-buttons {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid var(--border);
  background-color: var(--card);
  color: #fff !important;
}

.evxmodal-box-buttons-center,
.evxmodal-box-buttons-left,
.evxmodal-box-buttons-right {
  font-size: 18px;
  padding: 5px;
  font-weight: normal;
  color: #fff;
  border: 0;
}
.evxmodal-box-buttons-center { text-align: center; }
.evxmodal-box-buttons-left { text-align: left; margin-left: 5px; }
.evxmodal-box-buttons-right { text-align: right; margin-right: 5px; }

.evxmodal-box-button-confirm,
.evxmodal-box-button-cancel {
  transition-duration: 0.4s;
  position: relative;
  box-sizing: border-box;
  margin-right: 0.333em;
  margin-bottom: 0.333em;
  padding: 0.5em 1em;
  border: 0;
  border-radius: 2px;
  cursor: pointer;
  font-size: 0.88em;
  line-height: 1.6em;
  opacity: 0.8;
  color: #fff;
  width: 100px;
  background-image: none;
}
.evxmodal-box-button-confirm { background-color: var(--ok); }
.evxmodal-box-button-cancel { background-color: rgb(179, 51, 51); }

.evxmodal-box-button-close {
  cursor: pointer;
  background-color: transparent;
  font-size: 18px;
  padding: 5px;
  margin-left: 5px;
  font-weight: normal;
  color: #fff;
  text-align: right;
  border: 0;
}

.evxmodal-box-input-container,
.evxmodal-box-username-container,
.evxmodal-box-password-current-container,
.evxmodal-box-password-new-container,
.evxmodal-box-password-new-confirm-container {
  margin-top: 20px;
  margin-bottom: 20px;
}

.evxmodal-box-username-container:before,
.evxmodal-box-password-current-container:before,
.evxmodal-box-password-new-container:before,
.evxmodal-box-password-new-confirm-container:before {
  font-weight: 900;
  font-size: 1.5em;
  color: var(--accent);
  top: 12px;
  right: 10px;
  padding-right: 10px;
  text-align: center;
}

/* ============================================================
   MESSAGES / HEADER
   ============================================================ */
a.menu_active,
a.menu,
a.remove-from-log {
  text-decoration: none;
  font-family: 'Monda';
}
a.menu_active { font-weight: 600; color: var(--accent); }
a.menu { font-weight: 400; color: var(--accent); }
a.remove-from-log { font-weight: 400; color: red; }

.msg_warnings {
  text-indent: 25px;
  width: 100%;
  background-color: var(--error);
  border-color: var(--text);
  border-width: thin;
  color: white;
  border-style: solid;
  font-size: 1em;
}

.msg_information {
  text-indent: 25px;
  width: 100%;
  background-color: var(--accent);
  border-color: var(--text);
  border-width: thin;
  color: white;
  border-style: solid;
  font-size: 1em;
}

.msg_downloads {
  width: 100%;
  background-color: rgb(179, 221, 255);
  border-color: var(--text);
  border-width: thin;
  color: black;
  border-style: solid;
  font-size: 1em;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}

.msg_downloads_header {
  font-weight: bold !important;
  color: var(--accent) !important;
  height: 30px;
}

a.msg_download_url {
  text-indent: 25px;
  color: var(--accent);
}
a.msg_download_url:visited { text-decoration: none; }
a.msg_download_url:hover { color: var(--accent); }

.msg_download_filesize { color: var(--accent); }

button.btn-space { margin-left: 1em; }

.portal-header {
  display: flex;
  top: 0;
  border: 0;
  border-style: solid;
  border-color: green; /* verkar debug: låt vara */
  background-color: var(--card);
  border-bottom: 0 solid var(--ok);
}

.portal-header-left {
  flex: 1;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin: 0 5px;

  background-image: url('/img/logo.png');
  height: 130px;
  background-repeat: no-repeat;
  background-size: 150px;

  min-width: 150px;
  flex-basis: auto;
  flex-grow: 1;
}

.portal-header-right {
  flex: 1;
  display: flex;
  justify-content: flex-end;
  margin: 0 5px;
}

.portal-header-right-flex {
  display: flex;
  flex-direction: column;
}

.portal-header-right-category {
  flex: 1;
  text-align: right;
  font-weight: 600;
  font-size: 1.8em;
}

.portal-header-right-name {
  flex: 1;
  text-align: right;
  font-weight: 500;
  font-size: 1.4em;
}

.portal-header-right-desc1,
.portal-header-right-desc2 {
  flex: 1;
  text-align: right;
  font-weight: 400;
  font-size: 1em;
}

/* ============================================================
   RESPONSIVE (<= 800px)
   ============================================================ */
@media screen and (max-width: 800px) {
  .evxmodal-box {
    display: none;
    margin-top: 0;
    margin-left: 0;
    top: 45%;
    left: 5%;
    width: 90%;
  }

  .EVX-Tab-Buttons {
    justify-content: space-around;
    width: 100%;
  }

  .healthBarTotal,
  .healthBarNormal,
  .healthBarWarning,
  .healthBarCritical {
    width: 100%;
  }

  a.msg_download_url { text-indent: 1px; }
  .msg_information { text-indent: 0; }

  .portal_header {
    background-image: none;
    height: unset;
    background-position: left;
    background-repeat: no-repeat;
    background-size: contain;
  }

  .portal_header_info {
    height: 100%;
    width: 100%;
  }

  .portal_header_info_category,
  .portal_header_info_name,
  .portal_header_info_desc_1,
  .portal_header_info_desc_2 {
    clear: right;
    text-align: center;
  }
}

/* DATE RANGE PICKER */
#reportrange > .fa {
  color: var(--accent);
}
