/* ============================= */
/* FIRON ? Brand CSS (FULL FILE) */
/* ============================= */

/* Fonts */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600&family=Roboto:wght@400;500;700&display=swap');

/* ============================= */
/* BRAND TOKENS */
/* ============================= */
:root{
  /* Brand palette */
  --firon-sage: #A5B4A4;
  --firon-olive: #626C4F;
  --firon-dark: #313822;
  --firon-sand: #B9A58F;
  --firon-offwhite: #E1E0DA;

  /* UI neutrals */
  --bg: var(--firon-offwhite);
  --surface: #ffffff;
  --surface-soft: rgba(49,56,34,0.035);
  --border: rgba(49,56,34,0.14);
  --border-soft: rgba(49,56,34,0.10);
  --text: var(--firon-dark);
  --muted: rgba(49,56,34,0.62);

  /* Accent */
  --accent: var(--firon-olive);
  --accent-hover: #556042; /* a bit darker than olive */
  --accent-soft: rgba(98,108,79,0.14);

  /* Feedback */
  --good-bg: rgba(165,180,164,0.28);
  --good-bd: rgba(98,108,79,0.45);
  --bad-bg: rgba(185,165,143,0.30);
  --bad-bd: rgba(49,56,34,0.20);

  /* Typography */
  --font-body: "Roboto", system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  --font-head: "Oswald", "Roboto", system-ui, sans-serif;

  /* Radius */
  --r-sm: 10px;
  --r-md: 12px;
  --r-lg: 14px;

  /* Shadow */
  --shadow-sm: 0 6px 16px rgba(0,0,0,0.03);
  --shadow-md: 0 10px 25px rgba(0,0,0,0.08);
}

/* ============================= */
/* GLOBAL RESET */
/* ============================= */
*{ margin:0; padding:0; box-sizing:border-box; font-family: var(--font-body); }
html, body{ height:100%; width:100%; }
body{ overflow-x:hidden; background: var(--bg); color: var(--text); }

h1,h2,h3,h4,.page-title,.filter-card-title,.panel-title,.section-title{
  font-family: var(--font-head);
  letter-spacing: 0.3px;
}

.muted{ color: var(--muted); font-size: 13px; }

/* Links */
a{ color: var(--accent); }
a:hover{ color: var(--accent-hover); }

/* ============================= */
/* LOGIN PAGE */
/* ============================= */
.login-page{
  background-color: var(--bg);
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:100vh;
  flex-direction:column;
  gap: 0;
}

/* Login: hold logo og kort adskilt (undgår overlap pga. inline-img baseline) */
.login-page .brand-logo{
  margin: 0 0 24px 0;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
}

.brand-logo.small{
  margin-bottom:20px;
  display:flex;
  justify-content:flex-start;
  align-items:center;
}

.brand-logo.small img{ height:80px; width:auto; }
.brand-logo img{
  height:100px;
  width:auto;
  max-width:min(280px, 85vw);
  display:block;
  object-fit:contain;
}

.login-card{
  background: var(--surface);
  width:420px;
  padding:40px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
}

.login-card h2{ margin-bottom:10px; font-size:22px; }
.subtitle{ font-size:14px; color: var(--muted); margin-bottom:30px; }

.form-group{ margin-bottom:20px; text-align:left; }
.form-group label{ font-size:14px; margin-bottom:6px; display:block; }

/* ============================= */
/* BUTTONS (GLOBAL CONSISTENCY) */
/* ============================= */
.btn,
.btn-primary,
.btn-primary-inline,
.add-btn,
.btn-ghost,
.btn-secondary,
.btn-danger,
.btn-danger-outline,
.seg-btn,
.pg-btn,
.filter-toggle-btn,
.filter-pill,
.logout-btn {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  padding: 10px 16px;
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: all 0.2s ease;
  border: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  line-height: 1;
}

/* Primary Buttons */
.btn-primary,
.btn-primary-inline,
.add-btn {
  background: var(--accent);
  color: #fff;
  border: 1px solid var(--accent);
}

.btn-primary:hover,
.btn-primary-inline:hover,
.add-btn:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  box-shadow: var(--shadow-sm);
}

/* Ghost / Secondary Buttons */
.btn-ghost,
.btn-secondary,
.pg-btn,
.filter-toggle-btn,
.filter-pill {
  background: #fff;
  color: var(--text);
  border: 1px solid var(--border);
}

.btn-ghost:hover,
.btn-secondary:hover,
.pg-btn:hover,
.filter-toggle-btn:hover,
.filter-pill:hover,
.btn-ghost.active {
  background: rgba(49, 56, 34, 0.04);
  border-color: var(--border-soft);
}

/* Specifikke farver for valg af resultat i trial run */
#outcomeGood.active {
  background: var(--good-bg);
  border-color: var(--good-bd);
  color: var(--firon-dark);
}

#outcomeBad.active {
  background: var(--bad-bg);
  border-color: var(--bad-bd);
  color: var(--firon-dark);
}

/* Danger Buttons */
.btn-danger,
.btn-danger-outline {
  background: transparent;
  color: #e74c3c;
  border: 1px solid rgba(231, 76, 60, 0.3);
}

.btn-danger:hover,
.btn-danger-outline:hover {
  background: rgba(231, 76, 60, 0.05);
  border-color: #e74c3c;
}

/* Small Buttons */
.small {
  padding: 6px 10px;
  font-size: 12px;
}

/* ============================= */
/* FAVORITES (Machines & Tools) */
/* ============================= */
.favorite-toggle{
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border-soft);
  background: #fff;
  color: rgba(49, 56, 34, 0.45);
  cursor: pointer;
  transition: all 0.15s ease;
  padding: 0;
  flex: 0 0 auto;
}

.favorite-toggle:hover{
  background: rgba(49, 56, 34, 0.04);
  border-color: var(--border-soft);
}

.favorite-toggle.active{
  background: rgba(49, 56, 34, 0.04);
  border-color: rgba(132, 204, 22, 0.45);
  color: var(--accent);
}

.favorite-icon{
  font-size: 16px;
  line-height: 1;
  transform: translateY(-0.5px);
}

.favorites-section{
  margin-top: 24px;
}

.favorites-section .panel-title{
  margin-bottom: 12px;
}

.tool-row-actions{
  display: flex;
  align-items: center;
  gap: 10px;
}

.tool-name-with-logo{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.tool-brand-logo{
  width: 18px;
  height: 18px;
  object-fit: contain;
  flex: 0 0 auto;
}

.tool-package-note{
  margin-top: 4px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 100%;
  font-size: 12px;
  color: var(--muted);
}

.tool-package-label{
  color: var(--muted);
  white-space: nowrap;
}

.firon-package-link{
  appearance: none;
  border: 1px solid var(--border-soft);
  background: rgba(49,56,34,0.03);
  color: var(--accent);
  border-radius: 999px;
  padding: 2px 10px;
  cursor: pointer;
  max-width: 220px;
}

.firon-package-link:hover{
  background: rgba(49,56,34,0.07);
  border-color: var(--border);
}

.tool-package-link-text{
  display: inline-block;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: bottom;
}

.package-visibility-item{
  display: flex;
  align-items: center;
  gap: 8px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: var(--r-sm);
  padding: 6px 8px;
  min-height: 36px;
}

.package-visibility-item .package-visibility-checkbox{
  width: 14px;
  height: 14px;
  accent-color: var(--accent);
  margin: 0;
  flex: 0 0 auto;
}

.package-open-btn{
  appearance: none;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text);
  font-size: 13px;
  text-align: left;
  padding: 2px 6px;
  border-radius: 999px;
  cursor: pointer;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.package-open-btn:hover{
  color: var(--accent);
  background: rgba(49,56,34,0.04);
  border-color: var(--border-soft);
}

.machine-profile-card .favorite-toggle{
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(255, 255, 255, 0.75);
  background: rgba(255, 255, 255, 0.96);
  color: rgba(49, 56, 34, 0.85);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
  backdrop-filter: blur(2px);
}

.machine-profile-card .favorite-toggle:hover{
  background: #fff;
  border-color: rgba(255, 255, 255, 0.95);
  transform: scale(1.05);
}

.machine-profile-card .favorite-toggle.active{
  background: linear-gradient(135deg, #f9cf58, #f4b400);
  border-color: rgba(244, 180, 0, 0.95);
  color: #fff;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.22);
}

.machine-profile-card .favorite-toggle .favorite-icon{
  font-size: 20px;
  transform: translateY(-1px);
}

/* Tool quick popup (same card style as compare) */
.tool-quick-modal-card{
  max-width: 760px;
}
.tool-quick-compare-card{
  padding: 0;
  overflow: hidden;
}
.tool-quick-compare-header{
  background: var(--firon-olive);
  color: #fff;
  padding: 20px;
  text-align: center;
}
.tool-quick-compare-header h3{
  margin: 0;
  font-size: 1.3rem;
}
.tool-quick-accordion{
  border-top: 1px solid var(--border-soft);
}
.tool-quick-accordion .accordion-item{
  border-bottom: 1px solid var(--border-soft);
}
.tool-quick-accordion .accordion-item:last-child{
  border-bottom: none;
}
.tool-quick-accordion .accordion-header{
  width: 100%;
  padding: 15px 20px;
  background: #fff;
  border: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  font-weight: 600;
  font-family: var(--font-head);
  font-size: 14px;
  color: var(--text);
}
.tool-quick-accordion .accordion-header:hover{
  background: rgba(49, 56, 34, 0.03);
}
.tool-quick-accordion .accordion-header .chev{
  transition: transform 0.3s;
  font-size: 12px;
  color: var(--muted);
}
.tool-quick-accordion .accordion-item.open .accordion-header .chev{
  transform: rotate(180deg);
}
.tool-quick-accordion .accordion-content{
  display: none;
  padding: 15px 20px;
  background: #fafafa;
  border-top: 1px solid var(--border-soft);
}
.tool-quick-accordion .accordion-item.open .accordion-content{
  display: block;
}

.tool-quick-compare-card .info-row{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(0,0,0,0.05);
}

.tool-quick-compare-card .info-row:last-child{
  border-bottom: none;
}

.tool-quick-compare-card .info-label{
  font-weight: 500;
  color: var(--muted);
  font-size: 13px;
  flex: 0 0 42%;
}

.tool-quick-compare-card .info-value{
  font-weight: 500;
  color: var(--text);
  font-size: 13px;
  text-align: right;
  flex: 1 1 auto;
}

.tool-quick-compare-card .info-value .material-badges{
  justify-content: flex-end;
}

.tool-quick-compare-card .placeholder-box{
  background: #fff;
  border: 1px dashed var(--border);
  border-radius: var(--r-sm);
  padding: 16px;
  text-align: center;
  color: var(--muted);
  font-size: 13px;
}

.tool-quick-table-wrap{
  overflow-x: auto;
  border: 1px solid var(--border-soft);
  border-radius: var(--r-sm);
  background: #fff;
}

.tool-quick-table{
  width: 100%;
  min-width: 920px;
  border-collapse: collapse;
  font-size: 13px;
}

.tool-quick-table th{
  text-align: left;
  padding: 10px 12px;
  background: rgba(49, 56, 34, 0.04);
  border-bottom: 1px solid var(--border-soft);
  color: var(--muted);
  font-weight: 600;
  white-space: nowrap;
}

.tool-quick-table td{
  padding: 10px 12px;
  border-bottom: 1px solid rgba(49, 56, 34, 0.08);
  vertical-align: middle;
}

.tool-quick-table tbody tr:last-child td{
  border-bottom: none;
}

.tool-quick-table tbody tr.tool-practical-row{
  cursor: pointer;
}

.tool-quick-table tbody tr.tool-practical-row:hover{
  background: rgba(49, 56, 34, 0.04);
}

.tool-quick-table td.is-id{
  font-weight: 600;
  color: var(--accent);
  white-space: nowrap;
}

.tool-quick-table td.is-num{
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* Full Width */
.full-width, .full {
  width: 100%;
}

/* ============================= */
/* CARDS & PANELS (CONSISTENCY)  */
/* ============================= */
.panel, .card, .machine-card, .stat-card, .filter-card, .machine-profile-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px;
  box-shadow: var(--shadow-sm);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.panel:hover, .card:hover, .machine-card:hover, .machine-profile-card:hover {
  box-shadow: var(--shadow-md);
}

.panel-title, .card-header .panel-title, .filter-card-title {
  font-family: var(--font-head);
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 20px;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 10px;
}

/* ============================= */
/* TABLES (CONSISTENCY)          */
/* ============================= */
.table-wrap {
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  overflow: hidden;
  margin-top: 10px;
}

.simple-table, .data-table, .admin-table, .log-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.simple-table th, .data-table th, .admin-table th, .log-table th {
  background: rgba(49, 56, 34, 0.03);
  color: var(--muted);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.5px;
  padding: 14px 16px;
  text-align: left;
  border-bottom: 1px solid var(--border-soft);
}

.simple-table td, .data-table td, .admin-table td, .log-table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-soft);
  color: var(--text);
  vertical-align: middle;
}

.simple-table tr:last-child td {
  border-bottom: none;
}

.simple-table tr:hover {
  background: rgba(49, 56, 34, 0.015);
}

/* ============================= */
/* FORMS (CONSISTENCY)           */
/* ============================= */
.field {
  margin-bottom: 20px;
}

.field label, .field-label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 8px;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
select {
  width: 100%;
  padding: 0 14px; /* Fjernet vertikal padding for at undg? afsk?ring */
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-size: 14px;
  background: #fff;
  color: var(--text);
  transition: all 0.2s ease;
  height: 46px; /* ?get til 46px for maksimal plads */
  line-height: 46px; /* Centrerer teksten vertikalt */
  display: block;
}

/* Specifik fix for select da de kan drille med line-height */
select {
  line-height: normal;
  padding-top: 0;
  padding-bottom: 0;
}

textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-size: 14px;
  background: #fff;
  color: var(--text);
  transition: all 0.2s ease;
  height: auto;
  min-height: 100px;
  line-height: 1.5;
}

input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.req {
  color: #e74c3c;
  margin-left: 2px;
}

.form-actions, .modal-actions, .form-actions-admin {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 24px;
}

/* ============================= */
/* DASHBOARD LAYOUT */
/* ============================= */
.app-layout{
  display:flex;
  width:100vw;
  min-height:100vh;
  background: var(--bg);
}

/* ============================= */
/* SIDEBAR */
/* ============================= */
.sidebar{
  width:260px;
  background: var(--bg);
  padding:25px;
  height:100vh;
  position: sticky;
  top:0;
  display:flex;
  flex-direction: column;
  border-right: 1px solid var(--border-soft);
}

.sidebar-nav{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.nav-section{
  display:flex;
  align-items:center;
  justify-content:space-between;
  width:100%;
  background:none;
  border:none;
  padding:10px 0;
  text-align:left;
  font-size:14px;
  cursor:pointer;
  color: var(--text);
  user-select:none;
}

.nav-link{
  text-decoration:none;
  color: var(--text);
}

.nav-link:hover{ color: var(--accent); }
.nav-active{ font-weight:700; }

.sidebar-bottom{ margin-top:auto; }

.logout-btn{
  width:100%;
  padding:10px 14px;
  border-radius: var(--r-sm);
  border:1px solid var(--border);
  background:#fff;
  cursor:pointer;
  font-size:14px;
  transition: 0.2s ease;
}
.logout-btn:hover{ background: rgba(185,165,143,0.18); }

/* ============================= */
/* MAIN CONTENT */
/* ============================= */
.main-content{
  flex:1;
  padding:40px;
  background: var(--surface);
}

.topbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-bottom:20px;
  margin-bottom:30px;
  border-bottom: 1px solid var(--border-soft);
}

.topbar-left{ flex:1; }
.topbar-right{
  flex: 0 0 33%;
  display:flex;
  justify-content:flex-end;
}

.search-input{
  width:100%;
  padding:10px 14px;
  border-radius: var(--r-sm);
  border:1px solid var(--border);
  font-size:14px;
  transition: 0.2s ease;
}

.search-input:focus{
  outline:none;
  border-color: rgba(98,108,79,0.55);
  box-shadow: 0 0 0 4px var(--accent-soft);
}

.page-title{
  margin-bottom:25px;
  font-size:28px;
  line-height: 1.2;
}

/* ============================= */
/* STATS + MACHINE CARDS */
/* ============================= */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px,1fr));
  gap:20px;
  margin-bottom:40px;
}

.stat-card{
  background: var(--surface-soft);
  padding:20px;
  border-radius: var(--r-lg);
  border:1px solid var(--border);
}

.stat-card p{ font-size:13px; color: var(--muted); margin-bottom:8px; }
.stat-card h3{ font-size:22px; margin-bottom:6px; }

.machine-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px,1fr));
  gap:25px;
  margin-bottom:30px;
}

.machine-card{
  background: var(--surface-soft);
  padding:25px;
  border-radius: var(--r-lg);
  border:1px solid var(--border);
  transition:0.2s ease;
}

.machine-card:hover{ box-shadow: var(--shadow-sm); }
.machine-card h3{ margin-bottom:8px; }
.machine-card p{ font-size:14px; margin-bottom:6px; color: rgba(49,56,34,0.85); }

/* ============================= */
/* TOOLS PAGE HEADER */
/* ============================= */
.tools-page-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-top:10px;
  margin-bottom:14px;
}

.tools-header-actions{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

/* ============================= */
/* FILTER CARD (TOOLS + GENERIC) */
/* ============================= */
.filter-card{
  background: var(--surface-soft);
  padding:16px;
  border-radius: var(--r-lg);
  border:1px solid var(--border);
}

.filter-card-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:12px;
}

.filter-card-title{
  font-weight:700;
  font-size:14px;
  margin-bottom:4px;
}

.filter-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px,1fr));
  gap:14px;
}

.filter-group label{
  display:block;
  font-size:13px;
  font-weight: 500;
  margin-bottom:8px;
  color: var(--text);
}

.filter-group input,
.filter-group select{
  border-radius: var(--r-sm);
}

.range-group{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

.filter-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid rgba(0,0,0,0.06);
}

.tool-filter-card .field label{
  margin-bottom: 7px;
}

.tools-filter-toggle{
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas:
    "title icon"
    "sub icon"
    "meta icon";
  gap: 2px 12px;
  text-align: left;
  border: 0;
  background: transparent;
  cursor: pointer;
  padding: 2px 0 8px;
}

.tools-filter-toggle-title{ grid-area: title; font-family: var(--font-head); font-size: 16px; font-weight: 600; color: var(--text); }
.tools-filter-toggle-sub{ grid-area: sub; font-size: 12px; }
.tools-filter-meta{ grid-area: meta; margin-top: 2px; font-size: 12px; }
.tools-filter-toggle-icon{ grid-area: icon; align-self: center; color: var(--muted); transition: transform 0.2s ease; }
.tool-filter-card.is-collapsed .tools-filter-toggle-icon{ transform: rotate(-90deg); }
.tools-filter-body{ display:block; }
.tool-filter-card.is-collapsed .tools-filter-body{ display:none; }

.tool-filter-card .grid-2{
  gap: 12px;
}

.tool-filter-card .accordion summary{
  font-weight: 600;
  color: var(--accent);
  list-style: none;
}

.tool-filter-card .accordion summary::-webkit-details-marker{
  display: none;
}

.tool-filter-card .accordion summary::before{
  content: "▾ ";
  font-size: 12px;
}

.tool-filter-card .accordion:not([open]) summary::before{
  content: "▸ ";
}

.tools-filter-actions{
  position: sticky;
  bottom: -1px;
  background: linear-gradient(180deg, rgba(255,255,255,0.85) 0%, #fff 40%);
  margin-top: 10px;
  padding-top: 10px;
}

.tools-results-summary{
  margin-top: 12px;
  padding: 14px 16px;
}

.tools-pre-apply-state{
  margin-top: 12px;
  border: 1px dashed var(--border-soft);
  background: rgba(49,56,34,0.02);
}

.tools-results-summary-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:8px;
}

.tools-results-found{
  margin:0;
  font-size: 20px;
}

.tools-active-chips{
  gap: 8px;
}

.tools-summary-chip{
  display:inline-flex;
  align-items:center;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid var(--border-soft);
  background:#fff;
  font-size:12px;
  color:var(--text);
}

.tools-summary-chip.is-neutral{
  color: var(--muted);
}

#toolMatchesPanel .table-wrap,
#toolsResultsPanel .table-wrap{
  max-height: 520px;
  overflow: auto;
}

#toolMatchesPanel .simple-table thead th,
#toolsResultsPanel .simple-table thead th{
  position: sticky;
  top: 0;
  z-index: 2;
  background: #f8f9f6;
}

#toolMatchesPanel .simple-table tbody tr:nth-child(even),
#toolsResultsPanel .simple-table tbody tr:nth-child(even){
  background: rgba(49,56,34,0.017);
}

#toolMatchesPanel .simple-table tbody tr:hover,
#toolsResultsPanel .simple-table tbody tr:hover{
  background: rgba(49,56,34,0.05);
}

.tools-package-panel{
  padding: 10px 12px;
}

.tools-package-summary{
  display:flex;
  justify-content:space-between;
  align-items:center;
  cursor:pointer;
  font-weight:600;
  list-style:none;
}

.tools-package-summary::-webkit-details-marker{
  display:none;
}

.tools-package-options{
  margin-top:10px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.tools-package-panel .package-visibility-item{
  min-height: 34px;
  border-radius: 999px;
  padding: 6px 10px;
  background: rgba(49,56,34,0.02);
}

.tools-sticky-compare-bar{
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: 20px;
  z-index: 40;
  background: #fff;
  border: 1px solid var(--border);
  box-shadow: 0 14px 35px rgba(0,0,0,0.14);
  border-radius: 999px;
  padding: 8px 10px 8px 14px;
  display:flex;
  align-items:center;
  gap: 10px;
}

.tools-sticky-compare-label{
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

/* ============================= */
/* PANELS + TABLES */
/* ============================= */
.panel{
  background: var(--surface);
  border:1px solid var(--border);
  border-radius: var(--r-lg);
  padding:16px;
}

.panel-title{
  font-weight:600;
  margin-bottom:12px;
}

.table-wrap{
  border:1px solid var(--border-soft);
  border-radius: var(--r-lg);
  overflow:hidden;
  overflow-x:auto;
}

.simple-table{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
}

.simple-table th,
.simple-table td{
  text-align:left;
  padding:10px 8px;
  border-bottom:1px solid rgba(49,56,34,0.10);
}

.simple-table th{
  background: rgba(49,56,34,0.04);
  color: rgba(49,56,34,0.70);
  white-space:nowrap;
}

.row-link{ cursor:pointer; }
.row-link:hover{ background: rgba(49,56,34,0.03); }

.holder-group-card{
  cursor: pointer;
  border: 1px solid var(--border);
  text-align: left;
  font: inherit;
  color: inherit;
  display: block;
  width: 100%;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.holder-group-card:hover{
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.holder-group-card:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.holder-pick-list{
  display: grid;
  gap: 10px;
}

.holder-list-item{
  width: 100%;
  text-align: left;
  padding: 14px 16px;
  border-radius: var(--r-md);
  border: 1px solid var(--border-soft);
  background: #fff;
  cursor: pointer;
  font: inherit;
  color: inherit;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.holder-list-item:hover{
  background: rgba(49, 56, 34, 0.03);
  border-color: var(--border);
}

.holder-list-item:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.holder-list-item-title{
  font-weight: 600;
  font-size: 15px;
  margin-bottom: 4px;
}

.holder-list-item-meta{
  font-size: 13px;
  color: var(--muted);
}

.holder-detail-modal .detail-section{
  margin-bottom: 20px;
}

.tool-detail-link{
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  cursor: pointer;
  color: var(--accent);
  font: inherit;
  text-align: left;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.tool-detail-link:hover{
  color: var(--accent-hover);
  text-decoration: underline;
}

/* Pills */
.pill{
  display:inline-block;
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  border:1px solid rgba(49,56,34,0.14);
  background: rgba(49,56,34,0.03);
}

.pill.good{
  background: var(--good-bg);
  border-color: var(--good-bd);
  color: var(--firon-dark);
}
.pill.bad{
  background: var(--bad-bg);
  border-color: var(--bad-bd);
  color: var(--firon-dark);
}

/* ============================= */
/* EGENTEST PAGE */
/* ============================= */
.card{
  background: var(--surface);
  border:1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
}

.eg-grid{
  display:grid;
  grid-template-columns:1.05fr 0.95fr;
  gap:22px;
  align-items:start;
}

.eg-grid.eg-grid-single{
  grid-template-columns: 1fr;
}

.eg-left, .eg-right{ padding:18px; }
.card-header{ padding:18px 18px 0 18px; }

.trial-run-drafts-compact{
  margin-bottom: 10px;
  padding: 10px 12px;
  background: rgba(49,56,34,0.02);
}

.trial-run-drafts-summary{
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  list-style: none;
  font-weight: 600;
  font-size: 14px;
}

.trial-run-drafts-summary::-webkit-details-marker{
  display: none;
}

.trial-run-drafts-summary::after{
  content: "▸";
  color: var(--muted);
  margin-left: 8px;
}

.trial-run-drafts-compact[open] .trial-run-drafts-summary::after{
  content: "▾";
}

.trial-run-drafts-note{
  margin-top: 6px;
  margin-bottom: 8px;
  font-size: 12px;
}

.trial-run-drafts-row{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  margin-bottom: 8px;
}

.trial-run-drafts-row + .trial-run-drafts-row{
  grid-template-columns: 1fr auto auto;
}

.trial-run-drafts-row input,
.trial-run-drafts-row select{
  height: 34px;
}

.trial-run-drafts-list{
  margin-top: 2px;
}

.trial-run-draft-empty{
  font-size: 12px;
  padding: 2px 0;
}

.filter-stack{
  display:grid;
  gap:12px;
  margin-top:12px;
  margin-bottom:14px;
}

.two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.field-label{
  display:block;
  font-size:12px;
  color: rgba(49,56,34,0.75);
  margin-bottom:6px;
}

.req{ color:#b00020; font-weight:700; }

/* Trial run table */
.data-table{
  width:100%;
  border-collapse:collapse;
  font-size:13px;
}

.data-table thead th{
  text-align:left;
  background: rgba(49,56,34,0.04);
  color: rgba(49,56,34,0.70);
  padding:10px 10px;
  border-bottom:1px solid rgba(49,56,34,0.12);
  white-space:nowrap;
}

.data-table tbody td{
  padding:10px 10px;
  border-bottom:1px solid rgba(49,56,34,0.08);
  color: rgba(49,56,34,0.85);
  vertical-align:middle;
}

.data-table tbody tr:hover{ background: rgba(49,56,34,0.02); }

.w-check{ width:34px; }

.table-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 6px 2px 6px;
}

.pager{ display:flex; gap:6px; }

.pg-btn{
  border:1px solid var(--border);
  background:#fff;
  padding:6px 10px;
  border-radius: var(--r-sm);
  cursor:pointer;
}
.pg-btn.active{ background: rgba(49,56,34,0.05); font-weight:700; }

/* Right form */
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px 16px;
}
.span-2{ grid-column:span 2; }
.span-3{ grid-column:span 3; }

.form-section-compact {
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  padding: 16px;
  margin-bottom: 15px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.02);
}

.form-section-compact .modal-section-title {
  margin-top: 0;
  margin-bottom: 15px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border-soft);
  color: var(--accent);
  font-size: 11px;
}

.form-section-compact .form-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 12px 20px;
}

/* Trial-run dropdown fix (Windows): prevent clipped bottom text */
#trialRunCreateForm select {
  height: 46px !important;
  min-height: 46px;
  line-height: 1.25;
  padding-top: 0;
  padding-bottom: 0;
}

/* Practical data: ensure feed unit text is fully visible */
#trialRunCreateForm #egFeedUnit {
  width: 130px !important;
  min-width: 130px;
  padding-right: 30px;
}

@media (max-width: 1200px) {
  .form-section-compact .form-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .form-section-compact .span-3 { grid-column: span 2; }
}

@media (max-width: 768px) {
  .form-section-compact .form-grid {
    grid-template-columns: 1fr;
  }
  .form-section-compact .span-3 { grid-column: span 1; }
}

.section-title{ font-weight:700; margin-top:6px; color: var(--text); }

/* Segmented */
.segmented{ display:flex; gap:10px; }
.seg-btn{
  padding:8px 14px;
  border-radius: var(--r-sm);
  border:1px solid var(--border);
  background:#fff;
  cursor:pointer;
}
.seg-btn.active{
  border-color: rgba(98,108,79,0.55);
  background: var(--good-bg);
}
.seg-btn:focus{ outline:none; box-shadow:none; }

/* Unit */
.input-unit{
  display:grid;
  grid-template-columns:1fr 110px;
  gap:10px;
  align-items:center;
}
.input-unit .unit{
  width:100%;
  border-radius: var(--r-sm);
}

/* Trial run form actions */
.form-actions{
  display:flex;
  justify-content:flex-end;
  gap:12px;
  margin-top:14px;
  grid-column: 1 / -1;
}

/* ============================= */
/* CATEGORY PAGE */
/* ============================= */
/* Breadcrumb layout/styling lives under .firon-breadcrumb (Bootstrap .breadcrumb on <ol>) */

.category-header h2{
  font-size:26px;
  margin-bottom:6px;
}

.soft-divider{
  border:none;
  border-top:1px solid rgba(49,56,34,0.10);
  margin:18px 0;
}

.filter-bar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  flex-wrap:nowrap;

  background: var(--surface-soft);
  border:1px solid var(--border);
  border-radius: var(--r-lg);
  padding:18px 20px;
  margin-bottom:25px;
}

.filter-left{
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:nowrap;
  flex:1;
}

.filter-right{
  display:flex;
  align-items:center;
  gap:12px;
  white-space:nowrap;
}

.filter-label{ font-weight:600; color: var(--text); }

.filter-search{
  width:220px;
  padding:10px 12px;
  border-radius: var(--r-sm);
  border:1px solid var(--border);
  font-size:14px;
}

.inline-field select{ min-width:160px; }
.inline-field label{ font-size:13px; color: rgba(49,56,34,0.70); }

.range-inline input[type="range"]{ width:180px; }
.range-value{ font-size:12px; color: rgba(49,56,34,0.70); }

.check-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius: var(--r-sm);
  border:1px solid var(--border);
  background:#fff;
  font-size:13px;
  color: var(--text);
}

.section-h3{
  font-size:18px;
  margin:14px 0 16px;
}

.machine-cards-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(340px, 1fr));
  gap:22px;
}

.machine-profile-card{
  border:1px solid var(--border);
  border-radius: var(--r-lg);
  overflow:hidden;
  background:#fff;
  position: relative;
}

.machine-img{
  height:160px;
  background: rgba(49,56,34,0.04);
  display:flex;
  align-items:center;
  justify-content:center;
}

.machine-img img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.machine-card-body{
  padding:14px 14px 12px;
}

.machine-card-body h4{
  font-size:16px;
  margin-bottom:4px;
}

.small-text{ font-size:12px; }

.spec-list{
  list-style:none;
  margin-top:10px;
  display:grid;
  gap:6px;
  font-size:13px;
  color: rgba(49,56,34,0.85);
}

.spec-dot{
  display:inline-block;
  width:8px;
  height:8px;
  border-radius:999px;
  background: rgba(49,56,34,0.25);
  margin-right:8px;
  vertical-align:middle;
}
.spec-dot.ok{ background: var(--accent); }
.spec-dot.bad{ background: var(--firon-sand); }

.card-footer-stats{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid rgba(49,56,34,0.10);
  display:grid;
  gap:6px;
  font-size:13px;
  color: rgba(49,56,34,0.85);
}

.card-link{
  text-decoration:none;
  color:inherit;
  display:block;
}

.brand-link{
  text-decoration:none;
  color:inherit;
  display:inline-flex;
}

.brand-link:hover img{ opacity:0.9; }

/* ============================= */
/* MODAL */
/* ============================= */
body.modal-open{ overflow:hidden; }

.modal-overlay{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,0.55);
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  z-index:1000;
}

.modal-overlay.open{ display:flex; }

/* Bootstrap also defines .modal as position:fixed; top:0; left:0 — that breaks our overlay flex centering on pages that load Bootstrap (e.g. tool-compare). */
.modal-overlay > .modal{
  position: relative;
  inset: auto;
  margin: 0;
  z-index: 1;
  transform: none;
}

.modal{
  width:100%;
  max-width:560px;
  background:#fff;
  border-radius: var(--r-lg);
  box-shadow: 0 20px 50px rgba(0,0,0,0.18);
  overflow:hidden;
  max-height: 85vh;
  display:flex;
  flex-direction:column;
  border: 1px solid rgba(49,56,34,0.10);
}

.modal-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 18px;
  border-bottom:1px solid rgba(49,56,34,0.10);
}

.modal-header h3{ font-size:16px; }
.modal-close{
  border:none;
  background:transparent;
  font-size:20px;
  cursor:pointer;
  line-height:1;
  padding:6px 10px;
  border-radius: var(--r-sm);
}
.modal-close:hover{ background: rgba(49,56,34,0.04); }

.modal-body{
  padding:16px 18px 18px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}

.modal-section-title{
  font-size:12px;
  color: rgba(49,56,34,0.70);
  margin-bottom:12px;
}

.modal-form{ display:grid; gap:12px; }
.grid-2{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:15px;
}
.grid-3{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:15px;
}
.grid-4{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:15px;
}
@media (max-width:1100px){ .grid-3{ grid-template-columns:1fr 1fr; } }
@media (max-width:768px){ 
  .grid-2, .grid-3, .grid-4 { grid-template-columns:1fr; } 
}

/* Better field spacing */
.filter-form .field {
  margin-bottom: 5px;
}

.filter-form .grid-2, 
.filter-form .grid-3 {
  margin-bottom: 10px;
}

/* Compact range inputs */
.filter-form .grid-2 input {
  padding: 8px 10px;
  font-size: 13px;
}

/* Workpiece section spacing */
.workpiece-filter-section {
  background: #fff;
  padding: 5px;
}

.field label{
  display:block;
  font-size:12px;
  color: rgba(49,56,34,0.75);
  margin-bottom:6px;
}

.field input,
.field select,
.field textarea{
  width:100%;
  border:1px solid var(--border);
  border-radius: var(--r-sm);
  padding:10px 12px;
  font-size:14px;
}

.field textarea{
  resize:vertical;
  min-height:70px;
}

/* Practical data form validation (Bootstrap-compatible .is-invalid / .invalid-feedback) */
.field input.is-invalid,
.field select.is-invalid,
.field textarea.is-invalid,
.modal-form input.is-invalid,
.modal-form select.is-invalid,
.modal-form textarea.is-invalid {
  border-color: #dc3545 !important;
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.18);
}
/* Pop-up på Bootstrap-sider: sikr rød kant mod andre regler */
.modal-overlay .field input.is-invalid,
.modal-overlay .field select.is-invalid,
.modal-overlay .field textarea.is-invalid {
  border-color: #dc3545 !important;
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.2);
}
.segmented.is-invalid {
  outline: 2px solid #dc3545;
  outline-offset: 2px;
  border-radius: var(--r-sm);
}
.invalid-feedback {
  width: 100%;
  margin-top: 0.25rem;
  font-size: 0.875em;
  color: #dc3545;
}
.invalid-feedback.d-block {
  display: block;
}
/* Bootstrap sætter .invalid-feedback { display: none } og viser kun som .is-invalid ~ .sibling — vores beskeder sidder ofte efter .input-unit, så de skal tvinges synlige */
.invalid-feedback[data-practical="1"] {
  display: block !important;
}
.trial-run-form-summary-alert {
  padding: 10px 14px;
  border-radius: var(--r-sm);
  margin-bottom: 14px;
  font-size: 14px;
  border: 1px solid #f5c2c7;
  background: #f8d7da;
  color: #842029;
}

.input-addon{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:10px;
}

.addon{
  font-size:12px;
  color: rgba(49,56,34,0.70);
  padding: 0 10px;
  border:1px solid var(--border);
  border-radius: var(--r-sm);
  height:40px;
  display:flex;
  align-items:center;
  background: rgba(49,56,34,0.03);
}

.modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:6px;
}

/* Accordion */
.accordion{
  border:1px solid rgba(49,56,34,0.10);
  border-radius: var(--r-lg);
  padding:10px 12px;
  background: rgba(49,56,34,0.03);
}
.accordion summary{
  cursor:pointer;
  font-size:13px;
  color: var(--text);
  user-select:none;
}
.accordion-content{
  margin-top:12px;
  display:grid;
  gap:12px;
}

/* Switch */
.switch-row{ display:flex; align-items:center; gap:10px; }
.switch{ position:relative; width:42px; height:24px; display:inline-block; }
.switch input{ opacity:0; width:0; height:0; }
.slider{
  position:absolute;
  inset:0;
  background: rgba(49,56,34,0.16);
  border-radius:999px;
  transition:0.2s ease;
}
.slider:before{
  content:"";
  position:absolute;
  height:18px;
  width:18px;
  left:3px;
  top:3px;
  background:#fff;
  border-radius:999px;
  transition:0.2s ease;
}
.switch input:checked + .slider{ background: var(--accent); }
.switch input:checked + .slider:before{ transform: translateX(18px); }

/* ============================= */
/* DOUBLE RANGE SLIDER (if used) */
/* ============================= */
.range-2{ gap:12px; }
.range-wrap{
  position:relative;
  width:260px;
  height:22px;
  display:flex;
  align-items:center;
}
.range-track{
  position:absolute;
  left:0;
  right:0;
  height:6px;
  border-radius:999px;
  background: rgba(49,56,34,0.12);
}
.range-fill{
  position:absolute;
  height:6px;
  border-radius:999px;
  background: var(--accent);
}
.range-input{
  position:absolute;
  left:0;
  right:0;
  width:100%;
  background:none;
  pointer-events:none;
  -webkit-appearance:none;
  appearance:none;
  height:22px;
  margin:0;
}
.range-input::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:16px;
  height:16px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(49,56,34,0.25);
  box-shadow: 0 2px 6px rgba(0,0,0,0.12);
  pointer-events:auto;
  cursor:pointer;
}
.range-input::-moz-range-thumb{
  width:16px;
  height:16px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(49,56,34,0.25);
  box-shadow: 0 2px 6px rgba(0,0,0,0.12);
  pointer-events:auto;
  cursor:pointer;
}
.range-input::-webkit-slider-runnable-track{ background:transparent; }
.range-input::-moz-range-track{ background:transparent; }

/* Make sure max slider thumb is on top when overlapping */
#rpmMax{ z-index:3; }
#rpmMin{ z-index:2; }

/* ============================= */
/* MACHINE DETAILS */
/* ============================= */
.detail-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
}

.detail-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.machine-detail-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  margin-top:10px;
}

.kv-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.kv-k{
  font-size:12px;
  color: rgba(49,56,34,0.70);
  margin-bottom:4px;
}
.kv-v{
  font-size:14px;
  color: var(--text);
}

.panel-footer{ margin-top:10px; }

.link-muted{
  color: rgba(49,56,34,0.70);
  text-decoration:none;
}
.link-muted:hover{ text-decoration:underline; }

.machine-name-hover{
  position:relative;
  display:inline-block;
}

.machine-hover-box{
  position:absolute;
  top:120%;
  left:0;
  background:#fff;
  border:1px solid var(--border);
  border-radius: var(--r-lg);
  padding:14px 16px;
  min-width:220px;
  box-shadow: var(--shadow-md);
  opacity:0;
  visibility:hidden;
  transform: translateY(5px);
  transition:0.2s ease;
  z-index:50;
  font-size:13px;
}

.machine-name-hover:hover .machine-hover-box{
  opacity:1;
  visibility:visible;
  transform: translateY(0);
}

/* Global search dropdown hover (if used) */
#globalSearchDropdown a:hover{ background: rgba(49,56,34,0.03); }

/* Material Icons in tables */
.material-icons img {
  width: 20px;
  height: 20px;
  object-fit: contain;
  transition: transform 0.1s ease;
}

.material-icons img:hover {
  transform: scale(1.2);
}

/* Simulation checkmark */
.sim-check {
  color: #27ae60;
  font-weight: bold;
  font-size: 1.2em;
}

/* Material Badges */
.material-badges {
  display: inline-flex;
  gap: 4px;
  flex-wrap: wrap;
  align-items: center;
}

.material-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 4px; /* Rounded square */
  font-family: var(--font-head);
  font-weight: 700;
  font-size: 12px;
  color: #000;
  text-transform: uppercase;
  user-select: none;
  border: 1px solid rgba(0,0,0,0.1);
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
  position: relative;
  cursor: help;
}

/* Custom Tooltip Style */
.material-badge::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: 125%;
  left: 50%;
  transform: translateX(-50%) translateY(10px);
  background: var(--firon-dark);
  color: #fff;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 400;
  text-transform: none;
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: var(--shadow-md);
  z-index: 100;
}

.material-badge:hover::after {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

/* Triangle for tooltip */
.material-badge::before {
  content: "";
  position: absolute;
  bottom: 110%;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: var(--firon-dark);
  opacity: 0;
  visibility: hidden;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 100;
}

.material-badge:hover::before {
  opacity: 1;
  visibility: visible;
}

.material-badge.material-p { background-color: #3b82f6; color: #fff; } /* Blue */
.material-badge.material-m { background-color: #fde047; color: #000; } /* Yellow */
.material-badge.material-k { background-color: #ec4899; color: #fff; } /* Pink/Magenta */
.material-badge.material-n { background-color: #22c55e; color: #fff; } /* Green */
.material-badge.material-s { background-color: #f97316; color: #fff; } /* Orange */
.material-badge.material-h { background-color: #94a3b8; color: #fff; } /* Gray */

/* Clickable and Selected states for material badges in filters */
.clickable-badges .material-badge {
  cursor: pointer;
  transition: transform 0.1s ease, box-shadow 0.1s ease, opacity 0.2s ease;
  opacity: 0.6;
}

.clickable-badges .material-badge:hover {
  transform: scale(1.1);
  opacity: 1;
}

.clickable-badges .material-badge.selected {
  opacity: 1;
  transform: scale(1.1);
  box-shadow: 0 0 0 2px var(--firon-dark);
  z-index: 2;
}

.clickable-row:hover {
  background-color: rgba(49, 56, 34, 0.05);
}

/* Property badges (KC1, HRC, HB) */
.property-badges {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.property-badge {
  padding: 6px 12px;
  border-radius: 6px;
  background-color: #f3f4f6;
  color: #374151;
  font-weight: 600;
  font-size: 0.85rem;
  border: 1px solid #d1d5db;
  cursor: pointer;
  transition: all 0.2s ease;
}

.property-badge:hover {
  background-color: #e5e7eb;
  border-color: #9ca3af;
}

.property-badge.selected {
  background-color: var(--firon-dark);
  color: #fff;
  border-color: var(--firon-dark);
  transform: scale(1.05);
}

/* ============================= */
/* BREADCRUMB (Bootstrap <ol class="breadcrumb"> + Firon tokens) */
/* ============================= */
.firon-breadcrumb {
  border-bottom: 1px solid var(--border-soft);
  padding-bottom: 0.5rem;
  /* Bootstrap divider + colors (BS 5.3+) */
  --bs-breadcrumb-divider: ">";
  --bs-breadcrumb-divider-color: var(--muted);
  --bs-breadcrumb-item-padding-x: 0.45rem;
  --bs-breadcrumb-margin-bottom: 0;
}

.firon-breadcrumb-scroll {
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}

.firon-breadcrumb .breadcrumb {
  font-size: 0.875rem;
  line-height: 1.35;
  color: var(--muted);
  flex-wrap: nowrap;
  min-width: min(100%, max-content);
}

.firon-breadcrumb .breadcrumb-item {
  min-width: 0;
  color: var(--muted);
}

.firon-breadcrumb .firon-breadcrumb-link {
  color: var(--accent);
  max-width: min(14rem, 42vw);
  display: inline-block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: bottom;
}

.firon-breadcrumb .breadcrumb-item:not(.active) .firon-breadcrumb-label {
  color: var(--muted);
  max-width: min(14rem, 42vw);
  display: inline-block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: bottom;
}

.firon-breadcrumb .firon-breadcrumb-link:hover {
  color: var(--accent-hover);
}

.firon-breadcrumb .breadcrumb-item.active {
  color: var(--text);
  font-weight: 500;
}

.firon-breadcrumb .breadcrumb-item.active .firon-breadcrumb-label {
  max-width: min(20rem, 55vw);
  display: inline-block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: bottom;
}

/* ============================= */
/* RESPONSIVE */
/* ============================= */
@media (max-width: 1100px){
  .eg-grid{ grid-template-columns:1fr; }
  .machine-cards-grid{ grid-template-columns:1fr; }
  .machine-detail-grid{ grid-template-columns:1fr; }
}

@media (max-width: 900px){
  .sidebar{ display:none; }
  .main-content{ padding:20px; }
  .topbar{ flex-direction:column; align-items:flex-start; gap:15px; }
  .topbar input{ width:100%; }
}

/* Mobile: hide sidebar; keep breadcrumb (horizontal scroll via .firon-breadcrumb-scroll) */
@media (max-width: 768px){
  .sidebar{ display:none !important; }
  .app-layout{ display:block !important; }
  .main-content{ margin-left:0 !important; width:100% !important; }
}

/* ============================= */
/* MACHINE FILTERS (RESTORE)     */
/* (Fixer trial-run filters UI) */
/* ============================= */

/* Layout under machine details: venstre indhold + h?jre filterkolonne */
.machine-lower-grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
  gap: 22px;
  align-items: start;
  margin-top: 18px;
}
@media (max-width: 1100px){
  .machine-lower-grid{ grid-template-columns: 1fr; }
}

.left-column{
  display: flex;
  flex-direction: column;
  gap: 22px;
}

/* Prevent wide table content from pushing filter column out of view */
.machine-lower-grid > div{
  min-width: 0;
}

/* Filter panels container (h?jre side) */
.filters-two{
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 14px;
  margin-top: 18px;
  margin-bottom: 18px;
}

/* Selve ?accordion/panel? */
.filter-panel{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  width: 100%;
  max-width: 520px;
  box-shadow: var(--shadow-sm);
}

/* Header-bar der klikkes p? */
.filter-panel-head{
  width: 100%;
  background: var(--surface);
  border: none;
  padding: 14px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  font-weight: 700;
  font-family: var(--font-head);
  letter-spacing: .2px;
}
.filter-panel-head-left{
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.filter-group-toggle{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.filter-group-toggle input{
  width: 14px;
  height: 14px;
  accent-color: var(--accent);
}
.filter-panel-head:hover{
  background: rgba(49,56,34,0.03);
}

/* Body indhold */
.filter-panel-body{
  display: none;
  padding: 14px 16px 16px;
  border-top: 1px solid rgba(49,56,34,0.10);
}
.filter-panel.open .filter-panel-body{
  display: block;
}

/* Chevron rotation */
.filter-panel .chev{
  transition: 0.2s ease;
}
.filter-panel.open .chev{
  transform: rotate(180deg);
}

/* Selve filter-formen */
.filter-form{
  display: grid;
  gap: 12px;
}

.filter-minmax{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.filter-minmax > input{
  width: 100%;
  min-width: 0;
}

.filter-section-title{
  font-weight: 700;
  font-size: 13px;
  margin-top: 4px;
  color: rgba(49,56,34,0.85);
  font-family: var(--font-head);
}

.filter-divider{
  border: none;
  border-top: 1px solid rgba(49,56,34,0.10);
  margin: 6px 0;
}

/* Radios / checkbox rows */
.radio-row{
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: center;
}

.radio-pill{
  display: inline-flex;
  gap: 10px;
  align-items: center;
  font-size: 13px;
  color: rgba(49,56,34,0.85);
}

.radio-pill input{
  accent-color: var(--accent);
}

.check-row{
  display:flex;
  gap:10px;
  align-items:center;
  font-size:13px;
  color: rgba(49,56,34,0.85);
}

/* Input med unit/h?jre side */
.input-addon-right{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
}
.input-addon-right .unit{
  font-size: 12px;
  color: rgba(49,56,34,0.70);
}

/* Results box (den du har p? machinesiden) */
.results-box{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 16px;
  margin: 14px 0 18px;
  box-shadow: var(--shadow-sm);
}

.results-title{
  font-weight: 700;
  margin-bottom: 6px;
  font-family: var(--font-head);
}

.results-sub{
  color: rgba(49,56,34,0.70);
  font-size: 13px;
}

.results-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:10px;
}

/* S?rg for inputs i filter-panel ser ens ud */
.filter-panel input[type="text"],
.filter-panel input[type="number"],
.filter-panel select{
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
}

/* Hvis du bruger en ?filter toggle bar? nogen steder */
.filter-toggle-bar{
  display:flex;
  gap:12px;
  margin: 12px 0 18px;
  flex-wrap: wrap;
}
.filter-toggle-btn{
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #fff;
  cursor: pointer;
}
.filter-toggle-btn:hover{
  background: rgba(49,56,34,0.03);
}


/* MOBILE LAYOUT FIX */
@media (max-width: 768px) {

  /* Fjern s?gefelt */
  .search-input {
    display: none;
  }

  /* G?r grid til ?n kolonne */
  .eg-grid {
    display: flex;
    flex-direction: column;
  }

  /* Add trial runs first */
  .eg-right {
    order: 1;
  }

  /* Filters bagefter */
  .eg-left {
    order: 2;
  }

}

@media (max-width: 768px) {

  .card {
    border-radius: 12px;
  }

  .main-content {
    padding: 16px;
  }

  .table-wrap {
    overflow-x: auto;
  }

}

@media (max-width: 768px) {
  /* 1) Skjul s?gefeltet i topbaren */
  .topbar-right,
  .search-input {
    display: none !important;
  }

  /* 2) Brug flex (den p?ne) i stedet for grid p? mobil */
  .eg-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px;
  }

  /* 3) Fjern evt. grid-l?sning p? kortene (det er d?t, der driller) */
  .eg-left,
  .eg-right {
    grid-column: auto !important;
    grid-row: auto !important;
    grid-area: auto !important;
    width: 100%;
  }

  /* 4) Order: Add trial runs first, filters after */
  .eg-right { order: 1; }
  .eg-left  { order: 2; }

  /* 5) G?r tabellen h?ndterbar p? mobil */
  .table-wrap {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  /* (valgfrit) lidt mere luft i cards p? mobil */
  .card {
    border-radius: 14px;
  }
}

.eg-grid {
  display: flex !important;
  flex-direction: row !important;
  gap: 18px;
}

.eg-right, .eg-left {
  flex: 1;
  min-width: 0;
  width: 50%;
}

.eg-right { order: 1; } /* venstre */
.eg-left  { order: 2; } /* h?jre */

@media (max-width: 768px) {
  .eg-grid {
    display: flex !important;
    flex-direction: column !important;
  }

  .eg-right { order: 1 !important; width: 100% !important; min-width: 0 !important; }
  .eg-left  { order: 2 !important; width: 100% !important; min-width: 0 !important; }

  /* Trial-run form: one column on mobile */
  .form-grid,
  .eg-form-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .form-grid .span-2,
  .eg-form-grid .span-2 {
    grid-column: 1 !important;
  }
  /* Filtre (Resultat/Holder, Maskine/Værktøj osv.) stables */
  .filter-stack .two-col {
    grid-template-columns: 1fr !important;
  }
  /* Tilføj trial-run-panel: lidt mindre padding på mobil */
  .panel.eg-right {
    padding: 16px !important;
  }
  /* Input-unit (Fremføring + enhed) kan blive smalere på mobil */
  .input-unit {
    flex-wrap: wrap;
  }
  .input-unit .unit {
    min-width: 100px;
  }
}

/* ============================= */
/* MODERN ADMIN UI (REDESIGN)    */
/* ============================= */

/* Shadows & Radii */
.shadow-sm { box-shadow: 0 4px 20px rgba(0,0,0,0.03); }
.shadow-md { box-shadow: 0 10px 30px rgba(0,0,0,0.08); }

/* Layout Grid */
.admin-main-grid {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 30px;
  align-items: start;
}

@media (max-width: 1200px) {
  .admin-main-grid { grid-template-columns: 1fr; }
}

/* Sticky Panel */
.sticky-panel {
  position: sticky;
  top: 30px;
  z-index: 10;
}

/* Filters */
.filter-grid-admin {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 15px;
}

.admin-select {
  border-radius: 10px;
  border: 1px solid var(--border);
  background: #fff;
  padding: 0 12px;
  font-size: 13px;
}

/* Tables */
.admin-table th {
  background: transparent;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.5px;
  font-weight: 700;
  padding: 15px 12px;
  color: var(--muted);
}

.admin-table td {
  padding: 14px 12px;
  font-size: 13px;
}

.admin-table tr:hover {
  background: rgba(49,56,34,0.02);
}

/* Logs */
.logs-container-admin {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  margin-top: 40px;
}

@media (max-width: 1100px) {
  .logs-container-admin { grid-template-columns: 1fr; }
}

.log-panel {
  padding: 20px;
}

.log-title {
  font-size: 15px;
  margin-bottom: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.log-table th {
  font-size: 10px;
  padding: 10px 8px;
}

.log-table td {
  font-size: 12px;
  padding: 10px 8px;
}

/* Activity Filter Mini */
.activity-filters-mini {
  display: flex;
  gap: 6px;
}

.filter-pill {
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 11px;
  border: 1px solid var(--border);
  background: #fff;
  cursor: pointer;
  transition: 0.2s ease;
}

.filter-pill:hover { background: var(--surface-soft); }
.filter-pill.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.activity-user-select {
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 11px;
  border: 1px solid var(--border);
  background: #fff;
  cursor: pointer;
  min-width: 120px;
}

/* Form Styles */
.admin-form .form-section {
  margin-bottom: 25px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border-soft);
}

.admin-form .form-section:last-of-type {
  border-bottom: none;
}

.modal-section-title {
  font-weight: 700;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--muted);
  margin-bottom: 15px;
}

.form-actions-admin {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
}

/* Placeholder */
.placeholder-panel {
  min-height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: var(--surface-soft);
  border: 1px dashed var(--border);
}

.placeholder-content {
  max-width: 250px;
  color: var(--muted);
}

.placeholder-icon {
  font-size: 40px;
  margin-bottom: 15px;
  opacity: 0.3;
}

/* Buttons */
.btn-danger-outline {
  padding: 10px 14px;
  border-radius: var(--r-sm);
  border: 1px solid rgba(231, 76, 60, 0.3);
  background: transparent;
  color: #e74c3c;
  cursor: pointer;
  font-size: 13px;
  transition: 0.2s ease;
}

.btn-danger-outline:hover {
  background: rgba(231, 76, 60, 0.05);
  border-color: #e74c3c;
}

.status-pill {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
}

.status-active {
  background: var(--good-bg);
  color: var(--firon-dark);
  border: 1px solid var(--good-bd);
}

.status-inactive {
  background: var(--bad-bg);
  color: var(--firon-dark);
  border: 1px solid var(--bad-bd);
}

/* ============================= */
/* ADMIN PAGE RESPONSIVE TUNING  */
/* ============================= */
.admin-page .main-content {
  padding: 24px 28px;
}

.admin-page .admin-topbar {
  margin-bottom: 20px;
  padding-bottom: 14px;
}

.admin-page .page-title {
  margin-bottom: 0;
  font-size: 24px;
}

.admin-page .admin-topbar-right {
  flex: 0 1 420px;
  min-width: 280px;
}

.admin-page .admin-search-wrapper {
  width: 100%;
  max-width: 420px;
}

.admin-page .admin-detail-header {
  margin-bottom: 20px;
}

.admin-page .admin-main-grid {
  grid-template-columns: minmax(0, 1.55fr) minmax(340px, 1fr);
  gap: 20px;
}

.admin-page .admin-filter-panel {
  margin-bottom: 16px;
  padding: 14px 16px;
}

.admin-page .admin-filter-title {
  font-size: 13px;
  margin-bottom: 12px;
  gap: 6px;
}

.admin-page .filter-grid-admin {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.admin-page .panel {
  padding: 14px 16px;
}

.admin-page .panel-title {
  font-size: 16px;
  margin-bottom: 12px;
}

.admin-page .admin-user-count {
  font-size: 12px;
  font-weight: 400;
}

.admin-page .admin-table,
.admin-page .log-table {
  font-size: 13px;
}

.admin-page .admin-table th,
.admin-page .log-table th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: #f8f9f6;
  padding: 10px 10px;
  font-size: 10px;
}

.admin-page .admin-table td,
.admin-page .log-table td {
  padding: 10px 10px;
  font-size: 12px;
}

.admin-page .table-wrap {
  max-height: 62vh;
  overflow: auto;
}

.admin-page .sticky-panel {
  top: 18px;
}

.admin-page .admin-edit-panel {
  border-top: 4px solid var(--accent);
}

.admin-page .admin-edit-title {
  font-size: 17px;
  margin-bottom: 14px;
}

.admin-page .admin-form .form-section {
  margin-bottom: 18px;
  padding-bottom: 14px;
}

.admin-page .admin-form .field {
  margin-bottom: 14px;
}

.admin-page .admin-form .field label {
  font-size: 12px;
  margin-bottom: 6px;
}

.admin-page .admin-form input[type="text"],
.admin-page .admin-form input[type="email"],
.admin-page .admin-form input[type="password"],
.admin-page .admin-form select {
  height: 40px;
  font-size: 13px;
}

.admin-page .admin-form .grid-2 {
  gap: 12px;
}

.admin-page .form-actions-admin {
  margin-top: 16px;
}

.admin-page .logs-container-admin {
  margin-top: 24px;
  gap: 20px;
}

.admin-page .log-panel {
  padding: 14px 16px;
}

.admin-page .activity-filters-mini {
  flex-wrap: wrap;
}

/* >= 1400px: use horizontal space better on large desktops */
@media (min-width: 1400px) {
  .admin-page .main-content {
    padding: 24px 36px;
  }

  .admin-page .admin-main-grid {
    grid-template-columns: minmax(0, 1.7fr) minmax(360px, 0.95fr);
    gap: 22px;
  }
}

/* 1024-1399: normal desktop */
@media (min-width: 1024px) and (max-width: 1399px) {
  .admin-page .main-content {
    padding: 20px 24px;
  }

  .admin-page .admin-main-grid {
    grid-template-columns: minmax(0, 1.45fr) minmax(320px, 1fr);
    gap: 18px;
  }

  .admin-page .filter-grid-admin {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* 768-1023: tablet/smaller laptops */
@media (min-width: 768px) and (max-width: 1023px) {
  .admin-page .main-content {
    padding: 18px 20px;
  }

  .admin-page .admin-topbar {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .admin-page .admin-topbar-right {
    width: 100%;
    max-width: none;
    min-width: 0;
  }

  .admin-page .admin-main-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .admin-page .sticky-panel {
    position: static;
  }

  .admin-page .filter-grid-admin {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-page .logs-container-admin {
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

/* <768: mobile */
@media (max-width: 767px) {
  .admin-page .main-content {
    padding: 14px;
  }

  .admin-page .page-title {
    font-size: 21px;
  }

  .admin-page .admin-topbar-right {
    display: none;
  }

  .admin-page .admin-main-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .admin-page .filter-grid-admin,
  .admin-page .admin-form .grid-2 {
    grid-template-columns: 1fr;
  }

  .admin-page .sticky-panel {
    position: static;
  }

  .admin-page .form-actions-admin {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  .admin-page .table-wrap {
    max-height: none;
  }

  .admin-page .logs-container-admin {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

.eg-actions {
  margin-top: 28px;   /* mere afstand til felterne ovenover */
  display: flex;
  gap: 10px;          /* afstand mellem knapperne */
}

.pill.draft {
  background: #e6e6e6;
  color: #555;
}

/* =========================
   LOGIN ? MOBIL FORBEDRING
   S?t nederst i styles.css
   ========================= */
   @media (max-width: 768px) {

    /* Baggrund og centrering */
    body.login-page {
      min-height: 100vh;
      display: flex;
      justify-content: center;
      align-items: center;
      padding: 18px;
      background:#e1e0da;
    }
  
    /* Logo: mindre og mere kompakt */
    .login-page .brand-logo {
      margin: 0 0 14px 0;
      display: flex;
      justify-content: center;
      align-items: center;
    }
  
    .login-page .brand-logo img {
      width: min(210px, 70vw);
      height: auto;
      max-width: min(210px, 85vw);
      display: block;
      object-fit: contain;
    }
  
    /* Kortet: fylder p?nt p? mobil og f?r ?app-card? look */
    .login-page .login-card {
      width: 100%;
      max-width: 420px;
      border-radius: 18px;
      padding: 18px;
      background: #ffffff;
      box-shadow: 0 14px 40px rgba(16, 24, 40, 0.12);
      border: 1px solid rgba(0, 0, 0, 0.06);
    }
  
    /* Tekst */
    .login-page .login-card h2 {
      font-size: 22px;
      line-height: 1.2;
      margin: 0 0 8px 0;
    }
  
    .login-page .login-card .subtitle {
      font-size: 14px;
      line-height: 1.45;
      margin: 0 0 16px 0;
      opacity: 0.8;
    }
  
    /* Formular spacing */
    .login-page .form-group {
      margin-bottom: 14px;
    }
  
    .login-page label {
      font-size: 13px;
      margin-bottom: 6px;
      display: block;
    }
  
    .login-page input[type="email"],
    .login-page input[type="text"],
    .login-page select {
      width: 100%;
      padding: 12px 12px;
      border-radius: 12px;
      border: 1px solid rgba(0,0,0,0.12);
      outline: none;
      font-size: 16px; /* vigtig p? iOS: undg?r zoom */
      background: #fff;
    }
  
    .login-page input:focus {
      border-color: rgba(85, 102, 73, 0.55);
      box-shadow: 0 0 0 4px rgba(85, 102, 73, 0.12);
    }
  
    /* Login knap: stor, flot og tydelig */
    .login-page button,
    .login-page .btn,
    .login-page .login-btn {
      width: 100%;
      border-radius: 12px;
      padding: 12px 14px;
      font-size: 16px;
      font-weight: 600;
    }
  
    @media (max-width: 768px) {
      .topbar {
        border-bottom: none !important;
        padding-bottom: 0 !important;
        margin-bottom: 0 !important;
    }
  }
}

/* ============================= */
/* EGENTEST DETAIL MODAL (GLOBAL) */
/* ============================= */
.modal-overlay-detail {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 1000;
  backdrop-filter: blur(4px);
}

.eg-detail-modal {
  background: #fff;
  width: 90%;
  max-width: 700px;
  max-height: 90vh;
  overflow-y: auto;
  border-radius: 16px;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  border-left: 6px solid #313822;
  animation: modalFadeIn 0.3s ease-out;
  position: relative;
  display: flex;
  flex-direction: column;
}

.modal-header-detail {
  padding: 20px 24px;
  border-bottom: 1px solid #e5e7eb;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 10;
}

.modal-header-detail h3 {
  margin: 0;
  font-size: 18px;
  color: #111827;
}

.modal-body-detail {
  padding: 24px;
}

.detail-section {
  margin-bottom: 24px;
}

.detail-item {
  margin-bottom: 16px;
}

.detail-item label {
  display: block;
  font-size: 11px;
  color: #6b7280;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}

.detail-value {
  font-weight: 600;
  font-size: 16px;
  color: #111827;
}

.section-title-small {
  font-weight: 600;
  font-size: 12px;
  color: #6b7280;
  margin-bottom: 15px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid #f3f4f6;
  padding-bottom: 8px;
}

.parameter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  background: #f9fafb;
  padding: 20px;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
}

.param-row {
  display: flex;
  justify-content: space-between;
  font-size: 14px;
  border-bottom: 1px solid #e5e7eb;
  padding-bottom: 8px;
}

.param-row:last-child {
  border-bottom: none;
}

.param-row span {
  color: #6b7280;
}

.param-row strong {
  color: #111827;
}

.close-modal-btn {
  background: none;
  border: none;
  font-size: 24px;
  color: #9ca3af;
  cursor: pointer;
  padding: 4px;
  line-height: 1;
  transition: color 0.2s;
}

.close-modal-btn:hover {
  color: #111827;
}

.modal-footer-detail {
  padding: 16px 24px;
  border-top: 1px solid #e5e7eb;
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  background: #f9fafb;
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 16px;
}

.btn-copy-test {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  background-color: #313822;
  color: white;
  border: none;
  border-radius: 8px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: background-color 0.2s;
}

.btn-copy-test:hover {
  background-color: #434d2f;
}

.btn-copy-test svg {
  width: 16px;
  height: 16px;
}

@keyframes modalFadeIn {
  from { opacity: 0; transform: scale(0.95); }
  to { opacity: 1; transform: scale(1); }
}

@media (max-width: 768px) {
  .parameter-grid {
    grid-template-columns: 1fr;
  }
  .eg-detail-modal {
    width: 95%;
    margin: 10px;
  }
}
  

/* Skjul sammenligningsbar p? mobil */
@media (max-width: 768px) {
  #compareSelectionBar {
    display: none !important;
  }
}

/* Vis kun p? desktop */
@media (min-width: 769px) {
  #compareSelectionBar {
    display: flex !important;
  }
}

/* ============================= */
/* UI CUSTOMIZE PAGE             */
/* ============================= */
.ui-hidden {
  display: none !important;
}

.customize-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(280px, 1fr);
  gap: 18px;
}

.customize-list {
  display: grid;
  gap: 12px;
}

.customize-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  background: #fff;
}

.customize-item-text {
  display: grid;
  gap: 4px;
}

.customize-item-title {
  font-weight: 600;
  color: var(--text);
}

.customize-item-sub {
  font-size: 12px;
  color: var(--muted);
}

.customize-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 14px;
}

.customize-feedback {
  min-height: 20px;
  margin-top: 8px;
  font-size: 13px;
  color: var(--accent);
}

.customize-intro {
  margin-bottom: 18px;
}

.preview-intro {
  margin-bottom: 12px;
}

.preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(120px, 1fr));
  gap: 12px;
}

.preview-card {
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  background: var(--surface-soft);
  padding: 14px;
  font-size: 13px;
  color: var(--text);
}

@media (max-width: 960px) {
  .customize-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================= */
/* OPTIMIZATION OVERVIEW PAGE */
/* ============================= */
.optimization-subtitle { margin: -10px 0 20px; }
.optimization-layout { display: grid; grid-template-columns: minmax(320px, 430px) minmax(0, 1fr); gap: 20px; align-items: start; }
.optimization-controls { padding: 16px; }
.optimization-status { margin: 8px 0 14px; }
.optimization-error { border: 1px solid #f3b6b6; background: #fff4f4; color: #8f1e1e; border-radius: var(--r-sm); padding: 8px 10px; margin-bottom: 12px; font-size: 13px; }
.optimization-form-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px 12px; }
.optimization-tool-section {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #fff;
  padding: 12px;
  margin-bottom: 12px;
}
.optimization-cost-section {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--surface-soft);
  padding: 12px;
  margin-bottom: 12px;
}
.optimization-technical-section {
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  background: #fff;
  padding: 12px;
}
.optimization-section-title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--accent);
  margin: 0 0 10px;
  text-transform: uppercase;
}
.optimization-cost-section .field {
  display: flex;
  flex-direction: column;
}
.optimization-cost-section .field-label {
  min-height: 44px;
}
.optimization-tool-meta { margin-top: 14px; border: 1px dashed var(--border); border-radius: var(--r-md); background: var(--surface-soft); padding: 10px 12px; display: grid; gap: 4px; font-size: 13px; }
.optimization-validation { margin-top: 12px; font-size: 13px; color: rgba(49,56,34,0.78); }
.optimization-main { display: grid; gap: 14px; }
.optimization-chart-panel { padding: 16px; }
.optimization-chart-caption { margin: 8px 0 14px; }
.optimization-chart-wrap { width: 100%; height: 340px; border: 1px solid var(--border); border-radius: var(--r-md); background: #fff; padding: 8px; }
#optimizationChart .chart-zone {
  fill: rgba(98,108,79,0.08);
}
#optimizationChart { width: 100%; height: 100%; }
#optimizationChart .chart-axis { stroke: rgba(49,56,34,0.4); stroke-width: 1; }
#optimizationChart .chart-line-wear { fill: none; stroke: var(--accent); stroke-width: 2.5; }
#optimizationChart .chart-line-cost { fill: none; stroke: #5a7d5a; stroke-width: 2.5; }
#optimizationChart .chart-guide { stroke: rgba(98,108,79,0.45); stroke-dasharray: 5 4; }
#optimizationChart .chart-point { fill: #7a4f2a; }
#optimizationChart .chart-label { fill: rgba(49,56,34,0.86); font-size: 11px; }
.optimization-chart-wrap { position: relative; }
.optimization-chart-tooltip {
  position: absolute;
  z-index: 2;
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  box-shadow: var(--shadow-sm);
  padding: 6px 8px;
  font-size: 12px;
  color: var(--text);
  pointer-events: none;
  white-space: nowrap;
}
.optimization-chart-legend { display: flex; flex-wrap: wrap; gap: 12px 18px; margin-top: 10px; font-size: 12px; color: rgba(49,56,34,0.75); }
.legend-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; margin-right: 6px; }
.legend-dot.wear { background: var(--accent); }
.legend-dot.cost { background: #5a7d5a; }
.legend-dot.point { background: #7a4f2a; }
.optimization-results .stat-card h3 { font-size: 20px; }
.optimization-key-result {
  border: 1px solid rgba(98,108,79,0.35);
  background: var(--surface-soft);
}
.optimization-technical-section .field-label,
.optimization-results .stat-card p {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.info-tooltip-trigger {
  width: 18px;
  height: 18px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  line-height: 1;
  transition: all 0.15s ease;
}
.info-tooltip-trigger:hover,
.info-tooltip-trigger:focus-visible {
  color: var(--accent);
  border-color: var(--accent);
  outline: none;
}
.info-more-link {
  border: none;
  background: transparent;
  padding: 0;
  margin-left: 2px;
  color: var(--accent);
  font-size: 11px;
  line-height: 1;
  cursor: pointer;
  text-decoration: underline;
}
.optimization-info-tooltip {
  position: fixed;
  z-index: 1300;
  max-width: min(320px, calc(100vw - 24px));
  background: #fff;
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  box-shadow: var(--shadow-md);
  padding: 7px 10px;
  font-size: 12px;
  line-height: 1.35;
  pointer-events: none;
}
.optimization-info-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 1400;
  background: rgba(0,0,0,0.5);
  display: grid;
  place-items: center;
  padding: 18px;
}
.optimization-info-modal {
  width: min(560px, 100%);
  background: #fff;
  border-radius: var(--r-lg);
  border: 1px solid var(--border-soft);
  box-shadow: var(--shadow-md);
  overflow: hidden;
}
.optimization-info-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-soft);
}
.optimization-info-modal-header h3 {
  margin: 0;
  font-size: 17px;
}
.optimization-info-modal-close {
  border: none;
  background: transparent;
  color: var(--muted);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}
.optimization-info-modal-close:hover,
.optimization-info-modal-close:focus-visible {
  color: var(--text);
  outline: none;
}
.optimization-info-modal-body {
  padding: 16px;
  font-size: 14px;
  line-height: 1.5;
}
.optimization-summary { padding: 14px 16px; }
@media (max-width: 1200px) { .optimization-layout { grid-template-columns: 1fr; } }
@media (max-width: 768px) {
  .optimization-form-grid { grid-template-columns: 1fr; }
  .optimization-form-grid .span-2 { grid-column: span 1; }
  .optimization-info-tooltip {
    max-width: calc(100vw - 20px);
    font-size: 12px;
  }
}