/* Kvikr UI – Widgetar
   - Paginering, flikar, dragspel, modalfönster, tomt läge, sidemeny
   - Hjälpklasser
   - flytande knapp
   - Alla textstorlekar baseras på --fs (via base.css-variabler)
*/

/* Paginering */
.k-pagination{
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  font-size: var(--fs-sm);
}
.k-page{
  border:1px solid var(--border);
  background: var(--panel);
  border-radius: 12px;
  padding: 8px 10px;
  font-size: var(--fs-sm);
  color: var(--text);
  text-decoration:none;
}
.k-page:hover{ background: var(--panel2); text-decoration:none; }
.k-page[aria-current="page"]{
  border-color: var(--accent-border);
  background: var(--panel); /* ingen accentbakgrund */
}

/* Flikar
   - Standard: tydliga innehållsflikar
   - Variant: .k-tabs-segmented för mer kompakt växlare/navigation
*/

/* Flikar
   - Standard: klassiska innehållsflikar
   - Variant: .k-tabs-segmented för kompakt växlare
*/

.k-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:flex-end;
  border-bottom:1px solid var(--dialog-border);
  padding:0;
  margin:0 0 16px;
}

.k-tab{
  appearance:none;
  border:1px solid transparent;
  border-bottom:none;
  background:transparent;
  border-radius:12px 12px 0 0;
  padding:10px 16px 11px;
  cursor:pointer;
  font: var(--fw-strong) var(--fs-sm)/1.2 var(--font);
  color: var(--muted);
  text-decoration:none;
  position:relative;
  transition:
    color .15s ease,
    background .15s ease,
    border-color .15s ease;
}

.k-tab:hover{
  color: var(--text);
  background: var(--tab-hover-bg);
}

.k-tab[aria-selected="true"]{
  color: var(--accent);
  background: var(--panel);
  border-color: var(--dialog-border);
  margin-bottom:-1px;
  z-index:1;
}

.k-tab:focus{
  outline:none;
  box-shadow:var(--focus);
}

.k-tabpanels .k-tabpanel{ display:none; }
.k-tabpanels .k-tabpanel.active,
.k-tabpanels .k-tabpanel.is-active{ display:block; }

/* Segmenterade flikar
   - Mer som växlarknappar/filter
*/

.k-tabs.k-tabs-segmented{
  gap:8px;
  align-items:center;
  border-bottom:0;
  margin-bottom:14px;
}

.k-tabs.k-tabs-segmented .k-tab{
  border:1px solid var(--border);
  border-radius:999px;
  background: var(--panel);
  color: var(--text);
  padding:8px 14px;
  margin-bottom:0;
}

.k-tabs.k-tabs-segmented .k-tab:hover{
  border-color: var(--accent-border);
  color: var(--accent);
  background: var(--panel);
}

.k-tabs.k-tabs-segmented .k-tab[aria-selected="true"]{
  border-color: var(--accent-border);
  background: var(--panel);
  color: var(--accent);
}

@media (max-width: 640px){
  .k-tabs{
    gap:6px;
    margin-bottom:14px;
  }

  .k-tab{
    padding:9px 12px 10px;
  }

  .k-tabs.k-tabs-segmented .k-tab{
    padding:7px 12px;
  }
}

/* Dragspel */
.k-accordion{ display:grid; gap:10px; }
.k-acc-item{
  border:1px solid var(--border);
  border-radius: 14px;
  background: var(--panel);
  overflow:hidden;
}
.k-acc-btn{
  width:100%;
  text-align:left;
  border:0;
  background: transparent;
  padding: 12px 14px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color: var(--accent);
  font: var(--fs)/1.2 var(--font);
}
.k-acc-btn:hover{ background: var(--panel2); }
.k-acc-btn:focus{ outline:none; box-shadow:var(--focus); }
.k-acc-body{
  padding: 0 14px 12px 14px;
  color: var(--muted);
  display:none;
  font-size: var(--fs-sm);
}
.k-acc-item.open .k-acc-body{ display:block; }
.k-acc-item .chev{ color: var(--muted); font-size: var(--fs-sm); }

.k-acc-btn .chev{
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  fill: var(--accent);        /* var(--accent) */
  transform: rotate(0deg);
  transition: transform .15s ease;
}

/* Chevron i dragspel */
.k-acc-btn .chev{
  width: 22px;
  height: 22px;
  flex: 0 0 auto;

  color: var(--accent);
  fill: var(--accent);
  stroke: var(--accent);

  transform: rotate(0deg);
  transition: transform .15s ease;
}

/* Öppet läge */
.k-acc-item.open .k-acc-btn .chev,
.k-acc-item.is-open .k-acc-btn .chev{
  transform: rotate(180deg);
}

/* När posten är öppen: peka upp */
.k-acc-item.open .k-acc-btn .chev{
  transform: rotate(180deg);
}

/* Dragspel – växlingsikon */

[data-k-disclosure-toggle]{
  display:flex;
  align-items:center;
  justify-content:space-between;
  cursor:pointer;
}

/* rotera när öppet */
[data-k-disclosure].is-open [data-k-disclosure-toggle]::after{
  transform:rotate(180deg);
}

/* Modalfönster */
.k-modal{
  position:fixed; inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding: 18px;
  background: var(--overlay-bg);
  z-index: 50;
}
.k-modal.open{ display:flex; }
.k-modal.is-open{ display:flex; }
.k-modal-card{
  width:min(680px, 100%);
  background: var(--dialog-bg);
  border:1px solid var(--dialog-border);
  border-radius: 16px;
  box-shadow: var(--shadow);
  overflow:hidden;
}
.k-modal-head, .k-modal-foot{ padding: 14px 16px; }
.k-modal-head{
  border-bottom:1px solid var(--dialog-border);
  display:flex;
  justify-content:space-between;
  gap:12px;
}
.k-modal-body{
  padding: 16px;
  color: var(--muted);
  font-size: var(--fs-sm);
}
.k-modal-foot{
  border-top:1px solid var(--dialog-border);
  display:flex;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}

/* Tomt läge */
.k-empty{
  border:1px dashed var(--border);
  background: var(--panel2);
  border-radius: 14px;
  padding: 16px;
  color: var(--muted);
  font-size: var(--fs-sm);
}
.k-empty strong{
  color: var(--text);
  font-size: var(--fs-md);
}

/* Sidebar menu */
.k-sidemenu{
  list-style:none; padding:0; margin:0;
  display:grid; gap:6px;
}
.k-sidemenu a{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding: 9px 10px;
  border-radius: 12px;
  border:1px solid transparent;
  color: var(--link);
  text-decoration:none;
  background: transparent;
  font-size: var(--fs-sm);
}
.k-sidemenu a:hover{
  background: var(--panel2);
  border-color: var(--border);
  text-decoration:none;
}
.k-sidemenu .hint{
  font-size: var(--fs-xs);
  color: var(--muted);
}

/* TOC / innehållsförteckning: länkar ska vara länkar */
.k-toc a,
.k-sidemenu a,
.k-sidebar a{
  color: var(--link);
}

.k-toc a:hover,
.k-sidemenu a:hover,
.k-sidebar a:hover{
  text-decoration: underline;
}

/* Hjälpklasser */
.k-row{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.k-split{ display:flex; gap:10px; justify-content:space-between; align-items:center; flex-wrap:wrap; }
.k-hr{ height:1px; background: var(--border); margin: 12px 0; }

/* =========================================================
   Floating Action Button (flytande knapp) – rund flytande knapp
   ========================================================= */
.k-fab{
  position: fixed;
  right: var(--fab-gap);
  bottom: var(--fab-gap);
  z-index: 60;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;
}

.k-fab-main{
  width: var(--fab-size);
  height: var(--fab-size);
  border-radius: 999px;
  border: 1px solid var(--accent-border-strong);
  background: var(--panel);
  box-shadow: var(--shadow-fab-strong);
  display:grid;
  place-items:center;
  cursor:pointer;
  color: var(--accent);
  user-select:none;
}
.k-fab-main:hover{ background: var(--panel2); }
.k-fab-main:focus{
  outline:none;
  box-shadow: var(--focus), var(--shadow-fab-strong);
}
.k-fab-main svg{ width: 22px; height: 22px; }

.k-fab-menu{
  display:none;
  flex-direction:column;
  gap:10px;
  align-items:flex-end;
}
.k-fab.open .k-fab-menu{ display:flex; }

.k-fab-item{
  display:flex;
  align-items:center;
  gap:10px;
}

.k-fab-label{
  background: var(--dialog-bg);
  border:1px solid var(--dialog-border);
  color: var(--text);
  padding: 7px 10px;
  border-radius: 999px;
  box-shadow: var(--shadow-fab);
  font-size: var(--fs-sm);
  white-space: nowrap;
}

.k-fab-btn{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border:1px solid var(--border);
  background: var(--panel);
  box-shadow: var(--shadow-fab);
  cursor:pointer;
  display:grid;
  place-items:center;
  color: var(--accent);
}
.k-fab-btn:hover{ background: var(--panel2); }
.k-fab-btn:focus{ outline:none; box-shadow:var(--focus); }
.k-fab-btn svg{ width:18px; height:18px; }

@media (max-width: 520px){
  :root{ --fab-gap: 12px; --fab-size: 52px; }
}

/* =========================================================
   Secondary Floating Button (Toggle Background)
   ========================================================= */

.k-fab-secondary{
  position: fixed;
  right: var(--fab-gap);
  bottom: calc(var(--fab-gap) + var(--fab-size) + 12px);
  z-index: 60;
}

.k-fab-secondary-btn{
  width: var(--fab-size);
  height: var(--fab-size);
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--panel);
  box-shadow: var(--shadow-fab-strong);
  cursor:pointer;
  overflow:hidden;
  padding:0;
  display:block;
}

.k-fab-secondary-btn img{
  width:100%;
  height:100%;
  object-fit:cover;   /* fyll hela knappen */
  display:block;
}

.k-fab-secondary-btn:focus{
  outline:none;
  box-shadow: var(--focus), var(--shadow-fab-strong);
}

.k-fab-secondary-btn:hover{
  background: var(--panel2);
}


/* =========================================================
   Kvikr UI JS – komponenter (kvikr-ui.js)
   - Tooltip och toast (utöver befintliga widgetar)
   - Obs: Position (left/top) sätts av JS, resten här.
========================================================= */

/* Tooltip (hjälpruta) */
.k-tooltip-pop{
  position: fixed;
  z-index: 9999;
  max-width: 420px;
  width: 360px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--panel);
  box-shadow: var(--shadow2);
  font-size: var(--fs-sm);
  line-height: 1.35;
}

/* Toast */
#kToasts{
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 9999;
  display: grid;
  gap: 10px;
}

.k-toast{
  min-width: 260px;
  max-width: 360px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--panel);
  box-shadow: var(--shadow2);
}

.k-toast-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}

.k-toast-title{
  font-weight: var(--fw-label);
  font-size: var(--fs-sm);
}

.k-toast-body{
  margin-top: 6px;
  font-size: var(--fs-sm);
  line-height: 1.35;
}

