/* Projekttavla (2D) - fri yta dar projektnoder och egna rutor kan flyttas och
   kopplas med linjer. Morkt "skrivbord" med punktraster, ljusa kort ovanpa.
   Ateranvander designtokens fran styles.css. */

.tavla-body { overflow: hidden; background: #0a1120; }

.tavla-body .header {
  background: rgba(8, 16, 33, 0.72);
  border-bottom: 1px solid rgba(123, 152, 207, 0.18);
  backdrop-filter: blur(10px);
}
.tavla-body .logo, .tavla-body .logo__text { color: #eaf1ff; }
.tavla-body .nav a { color: #aebbd4; }
.tavla-body .nav a:hover { background: rgba(123, 152, 207, 0.12); color: #fff; }
.tavla-body .nav a.active { background: rgba(230, 179, 74, 0.16); color: var(--amber-400); }

/* ===== Yta ===== */
.tavla { position: fixed; inset: 73px 0 0 0; overflow: hidden; }

.tavla__viewport {
  position: absolute; inset: 0;
  background-color: #0a1120;
  background-image: radial-gradient(rgba(123, 152, 207, 0.16) 1.4px, transparent 1.4px);
  background-size: 26px 26px;
  cursor: grab;
  touch-action: none;
}
.tavla__viewport.drar { cursor: grabbing; }

.tavla__varld {
  position: absolute; top: 0; left: 0;
  width: 4200px; height: 2800px;
  transform-origin: 0 0;
}
.tavla__linjer { position: absolute; top: 0; left: 0; pointer-events: none; overflow: visible; }
.tavla__linjer path { pointer-events: stroke; }

/* ===== Rutor ===== */
.tavla-ruta {
  position: absolute;
  box-sizing: border-box;
  border-radius: 12px;
  display: flex; flex-direction: column;
  user-select: none;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.4);
  border: 1.5px solid rgba(123, 152, 207, 0.3);
  background: linear-gradient(180deg, #18243d, #121b30);
  color: #e8f0ff;
  transition: box-shadow 0.15s ease, border-color 0.15s ease;
}
.tavla-ruta.vald { border-color: var(--amber-400); box-shadow: 0 0 0 2px rgba(230,179,74,0.35), 0 12px 30px rgba(0,0,0,0.5); }

/* Nod-ruta: statusfargad kant + statusprick */
.tavla-ruta--nod { cursor: grab; }
.tavla-ruta--nod.drar { cursor: grabbing; }
.tavla-ruta--nod .ruta__topp { display: flex; align-items: center; gap: 7px; padding: 8px 10px 4px; }
.tavla-ruta--nod .statusprick { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; box-shadow: 0 0 8px currentColor; }
.tavla-ruta--nod .ruta__spar { font-size: 0.62em; text-transform: uppercase; letter-spacing: 0.6px; color: #8295b4; font-weight: 600; }
.tavla-ruta--nod .ruta__titel { padding: 0 10px 9px; font-weight: 600; line-height: 1.25; font-family: "Fraunces", serif; }

/* Fri ruta: dra-handtag + redigerbar text */
.tavla-ruta--fri { background: linear-gradient(180deg, #2a2415, #221d10); border-color: rgba(230, 179, 74, 0.4); }
.ruta__handtag {
  height: 18px; flex-shrink: 0; cursor: grab;
  border-radius: 11px 11px 0 0;
  background: rgba(230, 179, 74, 0.18);
  display: flex; align-items: center; justify-content: center; gap: 3px;
}
.ruta__handtag::before { content: ""; width: 22px; height: 3px; border-radius: 2px; background: rgba(230, 179, 74, 0.6); }
.tavla-ruta--fri.drar .ruta__handtag { cursor: grabbing; }
.ruta__text {
  flex: 1; padding: 7px 10px 9px; outline: none; overflow: auto;
  line-height: 1.3; word-break: break-word; white-space: pre-wrap;
}
.ruta__text:empty::before { content: "Skriv här..."; color: #8a7d5a; }

/* Handtag: koppling + storlek + ta bort */
.ruta__koppla {
  position: absolute; right: -9px; top: 50%; transform: translateY(-50%);
  width: 16px; height: 16px; border-radius: 50%;
  background: #5b9bd5; border: 2px solid #0a1120; cursor: crosshair;
  opacity: 0; transition: opacity 0.12s ease;
}
.ruta__resize {
  position: absolute; right: 2px; bottom: 2px;
  width: 14px; height: 14px; cursor: nwse-resize;
  opacity: 0; transition: opacity 0.12s ease;
  background: linear-gradient(135deg, transparent 50%, rgba(174, 187, 212, 0.7) 50%);
  border-radius: 0 0 10px 0;
}
.ruta__tabort {
  position: absolute; right: -8px; top: -8px;
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--red); color: #fff; border: none; cursor: pointer;
  font-size: 13px; line-height: 1; opacity: 0; transition: opacity 0.12s ease;
}
.tavla-ruta:hover .ruta__koppla,
.tavla-ruta:hover .ruta__resize,
.tavla-ruta:hover .ruta__tabort,
.tavla-ruta.vald .ruta__koppla,
.tavla-ruta.vald .ruta__resize,
.tavla-ruta.vald .ruta__tabort { opacity: 1; }

/* Pagaende koppling */
.kopplar .ruta__koppla { opacity: 1; }
.kopplar .tavla-ruta { cursor: crosshair; }

/* ===== Linjer ===== */
.linje { stroke: rgba(123, 152, 207, 0.6); stroke-width: 2.5; fill: none; transition: stroke 0.15s ease; }
.linje:hover { stroke: var(--amber-400); cursor: pointer; }
.linje.vald { stroke: var(--amber-400); stroke-width: 3.5; }
.linje-temp { stroke: var(--amber-400); stroke-width: 2.5; stroke-dasharray: 6 5; fill: none; }
.linje-prick { fill: rgba(123, 152, 207, 0.85); }

/* ===== Overlay topp ===== */
.tavla__topp {
  position: absolute; top: 22px; left: 28px; right: 28px;
  display: flex; align-items: flex-start; justify-content: space-between; gap: 20px;
  z-index: 5; pointer-events: none;
}
.tavla__titel { font-family: "Fraunces", serif; font-size: 28px; font-weight: 600; letter-spacing: -0.6px; color: #f3f7ff; margin: 0; text-shadow: 0 2px 20px rgba(0,0,0,0.6); }
.tavla__sub { margin: 5px 0 0; color: #9fb0cd; font-size: 14px; max-width: 460px; }

.tavla__vyval { display: flex; gap: 0; pointer-events: auto; background: rgba(10,18,33,0.6); border: 1px solid rgba(123,152,207,0.25); border-radius: 9px; padding: 3px; }
.vyval-knapp { font-size: 13.5px; font-weight: 600; padding: 6px 14px; border-radius: 6px; color: #aebbd4; text-decoration: none; }
.vyval-knapp:hover { color: #fff; }
.vyval-knapp--aktiv { background: rgba(230,179,74,0.18); color: var(--amber-400); }

/* ===== Verktyg ===== */
.tavla__verktyg { position: absolute; left: 28px; bottom: 26px; z-index: 5; display: flex; gap: 10px; }
.tavla-knapp {
  font: inherit; font-size: 13.5px; font-weight: 600; cursor: pointer;
  color: #0c1f3d; background: var(--amber-400); border: none; border-radius: 8px;
  padding: 9px 15px; box-shadow: 0 6px 20px rgba(0,0,0,0.35); transition: transform 0.12s ease, background 0.15s ease;
}
.tavla-knapp:hover { transform: translateY(-1px); background: #f0c668; }
.tavla-knapp--ghost { background: rgba(123,152,207,0.14); color: #dce6f7; border: 1px solid rgba(123,152,207,0.32); }
.tavla-knapp--ghost:hover { background: rgba(123,152,207,0.24); }

/* ===== Zoom ===== */
.tavla__zoom {
  position: absolute; right: 28px; bottom: 26px; z-index: 5;
  display: flex; align-items: center; gap: 6px;
  background: rgba(10,18,33,0.72); border: 1px solid rgba(123,152,207,0.25);
  border-radius: 10px; padding: 6px; backdrop-filter: blur(8px);
}
.zoom-knapp {
  width: 34px; height: 34px; border-radius: 7px; border: none; cursor: pointer;
  background: rgba(123,152,207,0.14); color: #dce6f7; font-size: 18px; line-height: 1;
  transition: background 0.14s ease;
}
.zoom-knapp:hover { background: rgba(123,152,207,0.28); color: #fff; }
.zoom-knapp--passa { font-size: 15px; }
.zoom-niva { font-size: 12.5px; color: #9fb0cd; min-width: 42px; text-align: center; font-variant-numeric: tabular-nums; }

/* ===== Sparstatus ===== */
.tavla__spar { position: absolute; top: 80px; right: 28px; z-index: 6; font-size: 13px; color: #9fb0cd; opacity: 0; transition: opacity 0.3s ease; pointer-events: none; }
.tavla__spar.syns { opacity: 1; }
.tavla__spar.sparat { color: #3ec98a; }

/* ===== Laddar ===== */
.tavla__laddar { position: absolute; inset: 0; z-index: 8; display: grid; place-items: center; color: #9fb0cd; font-size: 15px; background: #0a1120; }
.tavla__laddar.klar { opacity: 0; pointer-events: none; transition: opacity 0.5s ease; }

@media (max-width: 640px) {
  .tavla__sub { display: none; }
  .tavla__titel { font-size: 22px; }
  .tavla__topp { left: 16px; right: 16px; }
  .tavla__verktyg { left: 16px; bottom: 18px; }
  .tavla__zoom { right: 16px; bottom: 18px; }
}
