/* ==== WebAudioMarkers — Dark (Lighter) ==== */
:root{
  --bg-start: #151823;
  --bg-end:   #1b1f2a;

  --panel:    #1b1f2a;
  --panel-2:  #202536;
  --border:   #2a3142;

  --text:  #e9edf6;
  --muted: #aab2bf;

  --accent:   #59a8ff;
  --accent-2: #9cc9ff;
  --danger:   #ff6b6b;

  --mono: 'SFMono-Regular', ui-monospace, Menlo, Consolas, monospace;
}

/* === Bas === */
*{ box-sizing:border-box; }
html, body{ height:100%; }
body{
  margin:0;
  background: linear-gradient(180deg, var(--bg-start) 0%, var(--bg-end) 100%);
  color:var(--text);
  font: 15px/1.45 system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}
a{ color:var(--accent-2); text-decoration:none; }
a:hover{ text-decoration:underline; }

/* === Top-nav === */
.nav{
  position:sticky; top:0; z-index:5;
  display:flex; gap:1rem; align-items:center;
  padding:.8rem 1rem;
  background: rgba(22,25,36,.8);
  backdrop-filter: blur(8px);
  border-bottom:1px solid var(--border);
}
.nav__brand{
  margin-right:auto;
  display:flex;
  align-items:center;
  gap:.6rem;
  font-weight:700;
  letter-spacing:.3px;
}
.nav__logo{
  height:28px;
  width:auto;
  display:block;
}
.nav__links a{ margin-left:.9rem; }

.nav__appname{
  font-weight:700;
  letter-spacing:.3px;
  color: var(--accent 2);
}
.nav__appname:hover{
  text-decoration: underline;
}
}


/* === Layout & kort === */
.container{ max-width:1000px; margin:1.2rem auto; padding:0 1rem; }
.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:14px;
  padding:1rem;
  box-shadow:0 10px 26px rgba(0,0,0,.22);
}
.card--center{ max-width:520px; margin:0 auto; }
.header-row{ display:flex; align-items:center; gap:1rem; justify-content:space-between; margin-bottom:1rem; }

/* Små hjälpare */
.space{ height:.8rem; }
.hr{ height:1px; background:var(--border); border:0; margin:1rem 0; }

/* === Formulär === */
label{ display:block; margin:.5rem 0 .35rem; color:var(--muted); }
input[type="text"], input[type="email"], input[type="password"], input[type="number"],
select, textarea{
  width:100%;
  background:var(--panel-2);
  color:var(--text);
  border:1px solid var(--border);
  border-radius:10px;
  padding:.55rem .7rem;
  outline:none;
}
textarea{ min-height:120px; resize:vertical; }
input:focus, select:focus, textarea:focus{
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(89,168,255,.22);
}
.inline-form{ display:flex; gap:.6rem; align-items:center; flex-wrap:wrap; }

/* === Knappar === */
.btn{
  background: linear-gradient(180deg, #59a8ff 0%, #3c7fe2 100%);
  color:#fff; border:none; border-radius:10px;
  padding:.6rem 1rem; font-weight:600; cursor:pointer;
  box-shadow:0 8px 20px rgba(89,168,255,.28);
}
.btn:hover{ filter:brightness(1.05); }
.btn--ghost,
.btn-secondary{
  background:transparent; border:1px solid var(--border); color:var(--text);
  box-shadow:none;
}
.btn-danger{
  background: linear-gradient(180deg, var(--danger) 0%, #e34d4d 100%);
  color:#fff; border:none;
}

/* Kompatibilitet med mallar som använder "btn primary" */
.btn.primary{ background: linear-gradient(180deg, #59a8ff 0%, #3c7fe2 100%); color:#fff; }

/* === Typografi/nyanser === */
.mono{ font-family:var(--mono); }
.muted{ color:var(--muted); }

/* === Flash-meddelanden === */
.flash{ margin-bottom:1rem; }
.flash__item{
  background:#0e2d18;
  border:1px solid #1e5f36;
  padding:.6rem .9rem; border-radius:10px; color:#bfeecf;
}

/* === Listor & tabeller === */
.list{ display:grid; gap:.4rem; }
.list__item{
  display:flex; align-items:center; justify-content:space-between;
  padding:.8rem 1rem; border:1px solid var(--border); border-radius:10px;
  background:#1b2030;
}
.list__item:hover{ background:#1e2334; }
.list__title{ font-weight:600; }
.list__meta{ color:var(--muted); }
.empty{ color:var(--muted); padding:.8rem 0; }

.table{ width:100%; border-collapse:collapse; }
.table th, .table td{ text-align:left; padding:.6rem; border-bottom:1px solid var(--border); }

/* === Grid === */
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:.8rem; }
@media (max-width:900px){
  .grid-2{ grid-template-columns:1fr; }
  .grid-4{ grid-template-columns:1fr; }
}

/* === Taggar === */
.taglist{ list-style:none; margin:0; padding:0; display:flex; gap:.5rem; flex-wrap:wrap; }
.tag{
  background:#1b2030; border:1px solid var(--border);
  border-radius:999px; padding:.3rem .6rem;
  display:flex; align-items:center; gap:.4rem;
}
.tag__del{ background:transparent; border:none; color:#cfd5e2; cursor:pointer; }
.tag__del:hover{ color:#fff; }

/* === Radverktyg === */
.row-actions{ display:flex; gap:.6rem; align-items:center; }

/* =========================================================
   === Spelare / Vågform (FIXAD STACKING + iPhone overlap) ===
   ========================================================= */

/* Wave wrapper */
.wave{
  border:1px solid var(--border);
  border-radius:10px;
  height:140px;
  background:#1b2030;
  position:relative;
  overflow:hidden; /* VIKTIGT: canvas får aldrig spilla över och täcka toolbar */
}

/* Canvas: alltid botten-lager i wave */
.wave canvas{
  width:100%;
  height:140px;
  display:block;
  border-radius:10px;
  position:relative;
  z-index:1;
}

/* Play head */
.scrub-head{
  position:absolute; top:0; bottom:0; width:2px;
  background:#ffffff;
  box-shadow:0 0 0 2px rgba(89,168,255,.18), 0 0 10px rgba(89,168,255,.35);
  z-index:2; /* ovanpå canvas */
}

/* Prickar/markörer som JS skapar som div.dot */
#wave .dot{
  position:absolute;
  z-index:3; /* ovanpå canvas + scrub */
}

/* Om du använder .comment-dot någonstans (kan vara legacy) */
.comment-dot{
  position:absolute; top:50%; transform:translate(-50%, -50%);
  width:10px; height:10px; border-radius:999px;
  background: transparent; /* låt JS sätta färg dynamiskt */
  box-shadow:0 0 0 4px rgba(89,168,255,.20);
  z-index:3;
}
.comment-dot:hover{ filter:brightness(1.08); transform:translate(-50%, -50%) scale(1.06); }

/* Toolbar: ska ALDRIG ha z-index (ska ligga i normalt flöde under wave) */
.wave__toolbar{
  display:flex;
  gap:.6rem;
  align-items:center;
  margin-top:.6rem;
  position:relative; /* ok, men INGEN z-index */
  padding-top:.2rem; /* extra luft för iOS layout */
}

/* Kommentarlista */
.comments{ list-style:none; margin:0; padding:0; display:grid; gap:.4rem; }

/* Kommentarlista – högerverktyg (Redigera/Spara/Avbryt/Ta bort) */
.comments .row-actions{
  margin-left: auto;
  display: flex;
  gap: .5rem;
  align-items: center; /* vertikalt centrerade knappar */
}

/* Viktigt: flex-start + gap, så vi kan styra högerkant med margin-left:auto */
.comments li{
  padding:.5rem .6rem;
  border:1px solid var(--border);
  border-radius:10px;
  background:#1b2030;
  display:flex;
  align-items:center;          /* vertikalt centrerad innehåll */
  justify-content:flex-start;  /* var inte space-between */
  gap:.6rem;                   /* lite luft mellan blocken */
}

.comments .time{
  font-family:var(--mono);
  color:var(--accent-2);
  cursor:pointer;
}

/* Gör själva kommentartexten flexibel + vertikalt centrerad */
.comments .body{
  padding-left:.6rem;
  flex:1;
  display:flex;
  align-items:center;          /* texten följer vertikalt */
}

/* (valfritt) lite kompaktare ghost-knappar i listan */
.comments .row-actions .btn--ghost{
  padding:.45rem .7rem;
}

/* Kommentarlista: edit-läge små inputs */
.comment-time-input{
  width: 92px;
  background: var(--panel-2);
  color: var(--text);
  border:1px solid var(--border);
  border-radius:8px;
  padding:.4rem .5rem;
}
.comment-text-input{
  flex:1;
  background: var(--panel-2);
  color: var(--text);
  border:1px solid var(--border);
  border-radius:8px;
  padding:.4rem .5rem;
  margin: 0 .5rem;
  min-width: 160px;
}
/* liten färgdot i listan (matchar prickfärgen i vågformen) */
.color-dot{
  display:inline-block;
  width:10px; height:10px; border-radius:999px;
  box-shadow:0 0 0 2px rgba(0,0,0,.25);
}
.time-wrap{
  display:inline-flex; align-items:center; gap:.4rem;
}

/* === Modal: Projektkommentarer (mörkt tema, matchar appen) === */
#commentsModal{
  display:none; position:fixed; inset:0; z-index:1000;
  background: rgba(0,0,0,.65);
}
#commentsModal .modal-card{
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--border);
  max-width: 900px;
  margin: 5vh auto;
  padding: 1rem 1.25rem;
  border-radius: 14px;
  max-height: 90vh;
  overflow: auto;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
#commentsModal .modal-head{
  display:flex; justify-content:space-between; align-items:center; gap:1rem;
}
#commentsModal .modal-title{ margin:0; font-size:1.05rem; }
#commentsModal .btn{
  background:transparent; border:1px solid var(--border); color:var(--text);
  box-shadow:none;
}
#commentsModal .btn:hover{ filter:brightness(1.1); }
#commentsContainer{
  margin-top:1rem; font-family: var(--mono); font-size:.95rem; white-space:pre-wrap;
}
#commentsContainer .track-block{
  margin:1rem 0; padding-bottom:1rem; border-bottom:1px solid var(--border);
}
#commentsContainer .track-title{ font-weight:700; font-size:1.05rem; margin-bottom:.25rem; }
#commentsContainer .section-label{ margin:.25rem 0; font-style:italic; color:var(--muted); }
#commentsContainer .muted{ opacity:.85; color:var(--muted); }
#commentsContainer ul{ margin:.25rem 0 .5rem 1.25rem; padding:0; }

/* === Modal: Projektredigering (mörkt tema) === */
#projectEditModal{
  display:none; position:fixed; inset:0; z-index:1000;
  background: rgba(0,0,0,.65);
}
#projectEditModal .modal-card{
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--border);
  max-width: 640px;
  margin: 10vh auto;
  padding: 1rem 1.25rem;
  border-radius: 14px;
  max-height: 80vh;
  overflow: auto;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
#projectEditModal .modal-head{
  display:flex; justify-content:space-between; align-items:center; gap:1rem;
}
#projectEditModal .modal-title{ margin:0; font-size:1.05rem; }

/* === Mobilanpassning === */
@media (max-width: 700px){
  .header-row{
    flex-direction: column;
    align-items: flex-start;
    gap: .6rem;
  }
  .row-actions{
    flex-wrap: wrap;
    gap: .5rem;
  }
  .inline-form{
    flex-wrap: wrap;
  }
  .btn{
    padding: .5rem .75rem;
  }
  .container{
    padding: 0 .6rem;
  }

  /* Wave: lägre på mobil */
  .wave{
    height: 110px;
  }
  .wave canvas{
    height: 110px;
  }

  .wave__toolbar{
    flex-wrap: wrap;
    gap: .4rem;
    margin-top: 1rem;  /* mer luft under wave på mobil */
    padding-top: .5rem;
  }

  .table th, .table td{
    padding: .5rem;
  }
}

@media (max-width: 520px){
  /* extra säkerhet */
  #waveCanvas{ height:110px !important; }
}
