/* =========================================================================
   styles.css — gemensam stil. Palett "Klart vatten" (från utils.py).
   ========================================================================= */
:root{
  --primary:#1A6FB5; --bg-app:#F4F7FA; --surface:#ffffff;
  --text:#1B2A3A; --text-muted:#5B6B7A; --border:#E3E9F0;
  --start:#1D9E75; --stop:#C0392B; --neutral:#6B7887;
  --scoreboard-bg:#101820; --scoreboard-amber:#FFC93C; --scoreboard-text:#C7D6E8;
  --undo-bg:#FFF3E0; --undo-accent:#E65100;
  --fly:#E84D3D; --back:#3399DB; --breast:#2ECC70; --free:#F29C12;
  --best:#1D9E75;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{
  font-family:-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  background:var(--bg-app); color:var(--text);
  display:flex; flex-direction:column; height:100vh; overflow:hidden;
}
.mono{font-family:'SF Mono',ui-monospace,'Roboto Mono',Menlo,Consolas,monospace;font-variant-numeric:tabular-nums;}

/* Skärmhanterare */
.screen{display:none; flex-direction:column; height:100%; overflow:hidden;}
.screen.active{display:flex;}

/* Header */
header{background:var(--primary); color:#fff; display:flex; align-items:center; padding:10px 16px; gap:14px; flex:0 0 auto;}
header .back{background:rgba(255,255,255,.18);border:none;color:#fff;border-radius:8px;padding:8px 14px;font-size:15px;cursor:pointer;}
header .back:hover{background:rgba(255,255,255,.28);}
header h1{font-size:19px;font-weight:600;}
header .sub{margin-left:auto;font-size:12px;opacity:.85;}

main{flex:1 1 auto;overflow:auto;padding:12px;display:flex;flex-direction:column;gap:10px;}

.panel{background:var(--surface);border-radius:12px;box-shadow:0 1px 4px rgba(0,0,0,.06);border:1px solid var(--border);}

/* Knappar */
button.btn{border:none;border-radius:10px;color:#fff;font-weight:700;font-size:15px;padding:11px 16px;cursor:pointer;transition:filter .12s,transform .05s;min-height:44px;}
button.btn:active{transform:translateY(1px);}
button.btn:hover{filter:brightness(1.06);}
button.btn:disabled{opacity:.4;cursor:not-allowed;filter:none;}
.btn.primary{background:var(--primary);} .btn.start{background:var(--start);}
.btn.stop{background:var(--stop);} .btn.neutral{background:var(--neutral);}
.btn.small{font-size:13px;padding:8px 12px;min-height:38px;}

/* ===================== MENY ===================== */
.menu-screen{justify-content:flex-start;}
.menu-hero{text-align:center;padding:26px 0 6px;}
.menu-hero h1{font-size:38px;font-weight:800;color:var(--text);letter-spacing:.5px;}
.menu-hero .tagline{color:var(--text-muted);font-size:14px;margin-top:4px;}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:760px;margin:14px auto 0;width:100%;padding:0 12px;}
.menu-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 2px 8px rgba(0,0,0,.07);
  padding:20px 18px;cursor:pointer;display:flex;align-items:center;gap:14px;transition:transform .08s,box-shadow .12s,border-color .12s;
  appearance:none;-webkit-appearance:none;font:inherit;text-align:left;width:100%;color:inherit;}
.menu-card:focus-visible{outline:3px solid var(--primary);outline-offset:2px;}
.menu-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(26,111,181,.18);border-color:var(--primary);}
.menu-card .ic{width:46px;height:46px;border-radius:12px;background:#eaf2fb;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.menu-card .ic svg{width:26px;height:26px;stroke:var(--primary);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.menu-card .lbl{font-size:16px;font-weight:700;color:var(--text);}
.menu-card .desc{font-size:12px;color:var(--text-muted);margin-top:2px;}
.menu-footer{text-align:center;color:var(--text-muted);font-size:12px;padding:14px 0 6px;}
.menu-version{margin-top:3px;font-weight:700;color:var(--primary);font-variant-numeric:tabular-nums;}
.menu-water{height:30px;background:linear-gradient(180deg,rgba(74,135,224,.0),rgba(74,135,224,.22));margin-top:auto;}

/* ===================== FORMULÄR ===================== */
.form-wrap{max-width:760px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:14px;}
.section-title{font-size:14px;font-weight:700;color:var(--primary);border-bottom:1px solid var(--border);padding-bottom:6px;margin-top:4px;}
.form-row{display:flex;gap:14px;flex-wrap:wrap;}
.field{display:flex;flex-direction:column;gap:4px;flex:1;min-width:140px;}
.field label{font-size:12px;font-weight:700;color:var(--text-muted);}
.field input,.field select{padding:10px 12px;border:2px solid var(--border);border-radius:9px;font-size:15px;background:#fafbfc;color:var(--text);}
.field input:focus,.field select:focus{outline:none;border-color:var(--primary);}
.field .hint{font-size:11px;color:var(--text-muted);}
.form-error{background:#fdecea;color:var(--stop);border:1px solid #f5c6c2;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;}
.form-ok{background:#eafaf2;color:var(--start);border:1px solid #b7e4cd;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;}

/* Avatar + färgväljare */
.avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:22px;flex:0 0 auto;box-shadow:0 2px 6px rgba(0,0,0,.15);}
.color-grid{display:flex;flex-wrap:wrap;gap:12px;}
.color-pick{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;width:58px;}
.color-pick .swatch{width:38px;height:38px;border-radius:50%;border:3px solid transparent;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:border-color .12s;}
.color-pick.sel .swatch{border-color:var(--text);}
.color-pick .cname{font-size:10px;color:var(--text-muted);}
.color-pick.sel .cname{color:var(--text);font-weight:700;}

/* ===================== LISTOR ===================== */
.list{display:flex;flex-direction:column;gap:10px;max-width:820px;margin:0 auto;width:100%;}
.list-row{background:var(--surface);border:1px solid var(--border);border-radius:11px;box-shadow:0 1px 3px rgba(0,0,0,.06);
  display:flex;align-items:center;gap:12px;padding:12px 14px;}
.list-row .grow{flex:1;min-width:0;}
.list-row .title{font-size:16px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.list-row .sub{font-size:12px;color:var(--text-muted);margin-top:2px;}
.list-row .acts{display:flex;gap:8px;flex:0 0 auto;}
.empty-note{font-size:14px;color:var(--text-muted);text-align:center;padding:30px 10px;}
.add-bar{max-width:820px;margin:0 auto;width:100%;}

/* ===================== JÄMFÖR ===================== */
.compare-selectors{display:flex;gap:16px;flex-wrap:wrap;}
.cmp-table-wrap{overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;}
table.cmp{border-collapse:collapse;}
table.cmp th,table.cmp td{padding:7px 12px;text-align:center;font-size:13px;white-space:nowrap;border-bottom:1px solid var(--border);}
table.cmp th{color:var(--text-muted);font-weight:700;font-size:12px;}
table.cmp td.rowlabel,table.cmp th.rowlabel{text-align:left;color:var(--text-muted);font-weight:700;}
table.cmp td.val{font-variant-numeric:tabular-nums;font-family:'SF Mono',ui-monospace,monospace;}
table.cmp td.best{color:var(--best);font-weight:700;}
table.cmp tr.total td{border-top:2px solid var(--border);font-weight:700;}
table.cmp tr.avg td{background:#f7fafd;}
table.cmp tr.deltarow td{font-size:12px;color:var(--text-muted);}
table.cmp td.worse{color:var(--stop);font-weight:700;}
.cmp-status{font-size:13px;color:var(--text-muted);text-align:center;}
.trend-box{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 12px;margin-bottom:10px;overflow-x:auto;}
svg.trend{display:block;}
/* Segmentkontroll (jämför-läge) */
.seg{display:inline-flex;border:2px solid var(--border);border-radius:9px;overflow:hidden;align-self:flex-start;}
.seg button{border:none;background:var(--surface);color:var(--text-muted);font-weight:700;font-size:13px;padding:9px 14px;cursor:pointer;min-height:38px;}
.seg button+button{border-left:2px solid var(--border);}
.seg button.on{background:var(--primary);color:#fff;}

/* ===================== TIDTAGNING ===================== */
.config{display:flex;align-items:center;gap:14px;padding:8px 14px;flex-wrap:wrap;}
.config > .lbl{font-size:14px;font-weight:700;color:var(--primary);}
.tfield{display:flex;flex-direction:column;gap:2px;}
.tfield label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;}
.tfield select{padding:7px 10px;border:2px solid var(--border);border-radius:8px;font-size:15px;background:#fafbfc;color:var(--text);cursor:pointer;min-width:84px;}
.tfield select:focus{outline:none;border-color:var(--primary);}
.info{font-size:12px;color:var(--text-muted);flex:1;min-width:160px;}
.info.active{color:var(--primary);font-weight:600;}
.medley{display:flex;align-items:center;gap:4px;flex-wrap:wrap;}
.leg{padding:4px 9px;border-radius:14px;font-size:10px;font-weight:700;color:#fff;text-align:center;line-height:1.2;}
.leg.fly{background:var(--fly);} .leg.back{background:var(--back);} .leg.breast{background:var(--breast);} .leg.free{background:var(--free);}
.leg .small{font-weight:500;opacity:.9;font-size:9px;}
.arrow{color:#9aa6b2;font-size:14px;}

.controls{display:flex;gap:10px;padding:10px 14px;align-items:center;}
.controls .group{display:flex;gap:8px;} .controls .spacer{flex:1;}

.savebar{display:flex;align-items:center;gap:12px;padding:8px 14px;background:var(--undo-bg);border:1px solid #ffe0b2;border-radius:10px;}
.savebar .msg{font-size:13px;color:var(--undo-accent);font-weight:600;flex:1;}
.hidden{display:none !important;}

.scoreboard{background:var(--scoreboard-bg);border-radius:12px;padding:14px 18px;display:flex;align-items:baseline;justify-content:center;gap:18px;flex-wrap:wrap;transition:background .2s;}
.scoreboard .clock{font-size:54px;font-weight:700;color:var(--scoreboard-amber);letter-spacing:1px;}
.scoreboard .summary{font-size:14px;color:var(--scoreboard-text);}
.scoreboard .series-progress{font-size:16px;color:var(--scoreboard-amber);font-weight:600;width:100%;text-align:center;}

.swim-buttons{display:flex;gap:8px;flex-wrap:wrap;padding:2px;}
.swim-btn{position:relative;flex:1 1 170px;min-width:150px;border-radius:12px;background:var(--surface);border:1px solid var(--border);
  box-shadow:0 1px 3px rgba(0,0,0,.08);padding:10px 12px 10px 16px;cursor:pointer;overflow:hidden;text-align:left;user-select:none;
  appearance:none;-webkit-appearance:none;font-family:inherit;color:inherit;}
.swim-btn:focus-visible{outline:3px solid var(--primary);outline-offset:2px;}
.swim-btn .stripe{position:absolute;left:0;top:0;bottom:0;width:7px;}
.swim-btn .name{font-size:15px;font-weight:700;display:flex;justify-content:space-between;align-items:center;gap:6px;}
.swim-btn .lane{font-size:11px;color:var(--text-muted);font-weight:600;}
.swim-btn .rep-pill{font-size:11px;font-weight:700;color:#fff;background:var(--primary);border-radius:10px;padding:1px 7px;}
.swim-btn .rep-pill.done{background:var(--start);}
.swim-btn .countdown{font-size:30px;font-weight:700;margin-top:2px;}
.swim-btn .splitinfo{font-size:11px;color:var(--text-muted);margin-top:1px;min-height:14px;}
.swim-btn.flash{animation:flash .45s ease-out;}
@keyframes flash{0%{background:#d8f5e6;box-shadow:0 0 0 3px var(--start),0 1px 3px rgba(0,0,0,.08);}100%{background:var(--surface);box-shadow:0 1px 3px rgba(0,0,0,.08);}}
.swim-btn.pulse .countdown{color:var(--start);}
.swim-btn.waiting .countdown{color:var(--stop);}
.swim-btn.done{opacity:.62;}

.results{padding:8px 12px;}
.results h2{font-size:14px;color:var(--primary);margin-bottom:6px;}
.result-grid{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-start;}
.result-box{flex:1 1 210px;min-width:190px;max-width:320px;border:1px solid var(--border);border-radius:10px;overflow:hidden;}
.result-box .rb-head{display:flex;align-items:center;gap:8px;padding:6px 10px;color:#fff;font-weight:700;font-size:14px;}
.rb-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:baseline;padding:3px 10px;font-size:13px;}
.rb-row .rb-dist{color:var(--text-muted);font-size:12px;}
.rb-row .rb-time{font-weight:700;}
.rb-row .rb-delta{font-size:11px;color:var(--text-muted);}
.rb-row.final{background:#eafaf2;} .rb-row.final .rb-time{color:var(--start);}
.rb-row.total{background:#eef4fb;border-top:1px dashed var(--border);}
.rb-row.split-only{color:var(--text-muted);font-style:italic;}
.rb-stroke{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle;}

.bottom{display:flex;gap:8px;flex:0 0 auto;min-height:200px;}
.lanes-wrap{flex:1;padding:8px;display:flex;flex-direction:column;}
.lanes-wrap .sec-title,.pool .sec-title{font-size:13px;font-weight:700;margin-bottom:6px;}
.lanes{display:flex;gap:8px;overflow-x:auto;flex:1;}
.lane{flex:1 1 0;min-width:120px;display:flex;flex-direction:column;gap:4px;}
.lane .lane-name{font-size:12px;font-weight:700;text-align:center;color:var(--text);}
.slot{border:2px dashed var(--border);border-radius:8px;min-height:38px;display:flex;align-items:center;justify-content:center;background:#fafbfc;transition:background .12s,border-color .12s;}
.slot.over{border-color:var(--primary);background:#eaf2fb;}
.pool{width:210px;padding:8px;display:flex;flex-direction:column;}
.pool .pool-list{display:flex;flex-direction:column;gap:6px;overflow-y:auto;flex:1;}
.chip{display:flex;align-items:center;gap:7px;padding:7px 9px;border-radius:9px;background:var(--surface);border:1px solid var(--border);
  box-shadow:0 1px 2px rgba(0,0,0,.07);cursor:grab;font-size:13px;font-weight:600;touch-action:none;user-select:none;}
.chip .dot{width:13px;height:13px;border-radius:50%;flex:0 0 auto;}
.chip.dragging{opacity:.4;}
.chip-ghost{position:fixed;z-index:9999;pointer-events:none;box-shadow:0 6px 18px rgba(0,0,0,.25);}

/* Historik */
.hist-detail{max-width:820px;margin:-4px auto 6px;width:100%;}
.hist-detail.hidden{display:none;}
.hist-detail-inner{display:flex;flex-wrap:wrap;gap:10px;padding:4px 0 8px;}
.hd-card{flex:1 1 280px;min-width:240px;border:1px solid var(--border);border-radius:10px;padding:8px 10px;background:var(--surface);}
.hd-head{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap;}
.hd-name{font-weight:700;font-size:14px;}
.hd-total{font-size:12px;color:var(--text-muted);margin-left:auto;font-variant-numeric:tabular-nums;}
.pb-badge{background:#fff7e0;color:#9a6b00;border:1px solid #ffe08a;border-radius:10px;font-size:11px;font-weight:700;padding:1px 7px;}
.hd-incomplete{font-size:11px;color:var(--stop);font-weight:600;}

/* Utskrift / spara som PDF */
#printArea{display:none;}
@media print{
  body *{visibility:hidden;}
  #printArea, #printArea *{visibility:visible;}
  #printArea{display:block;position:absolute;left:0;top:0;width:100%;padding:24px;}
  #printArea h2{font-size:20px;margin-bottom:4px;}
  #printArea .print-meta{font-size:12px;color:#555;margin-bottom:14px;}
  #printArea .hd-card{break-inside:avoid;border:1px solid #ccc;}
  .modal-bg{display:none !important;}
}

/* Dialog */
.modal-bg{position:fixed;inset:0;background:rgba(20,30,45,.45);display:flex;align-items:center;justify-content:center;z-index:1000;}
.modal{background:var(--surface);border-radius:14px;padding:20px;width:min(440px,92vw);box-shadow:0 12px 40px rgba(0,0,0,.3);}
.modal h3{font-size:18px;margin-bottom:12px;color:var(--text);}
.modal .modal-acts{display:flex;gap:10px;justify-content:flex-end;margin-top:16px;}
.modal .check-row{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:14px;}
.modal .check-row input{width:18px;height:18px;}

/* ===================== RESPONSIVT (telefon / porträtt) ===================== */
@media (max-width:768px){
  main{padding:8px;gap:8px;}
  .config{gap:10px;padding:8px 10px;}
  .controls{flex-wrap:wrap;gap:8px;}
  .controls .spacer{display:none;}
  .controls .group{flex:1 1 auto;}
  .scoreboard{padding:10px 12px;gap:10px;}
  .scoreboard .clock{font-size:42px;}
  .swim-btn{flex:1 1 140px;min-width:130px;}
  .swim-btn .countdown{font-size:26px;}
  .bottom{flex-direction:column;min-height:0;}
  .pool{width:100%;}
  .lanes{flex-wrap:wrap;}
  .menu-grid{grid-template-columns:1fr;}
  .menu-hero h1{font-size:30px;}
  header h1{font-size:17px;}
  .compare-selectors{gap:10px;}
}
