#dispo-piscina{max-width:1000px; margin:0 auto; font-family:'Figtree', system-ui, -apple-system, Segoe UI, Roboto, Arial;}

.piscina-card{border:1px solid #e5e5e5;border-radius:14px;padding:24px;margin:10px 0;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.piscina-head{display:flex;gap:8px;align-items:center;margin-bottom:12px;font-weight:700;text-transform:capitalize; font-size:20px;}

.piscina-bar{
  position:relative;height:14px;border-radius:99px;overflow:hidden;
  background-color: rgba(88,224,133,.7);
  background-image: repeating-linear-gradient(
    to right,
    rgba(255,255,255,.9) 0 1px,
    transparent 1px calc(var(--step))
  );
}
.segment{position:absolute;top:0;bottom:0;border-radius:0}
.segment.gran{background:#ff3b30;}
.segment.petit{background:#7e57c2;}

.legend{display:flex;gap:14px;margin-top:8px;font-size:.85rem;opacity:.85;align-items:center}
.badge{display:inline-flex;align-items:center;gap:6px}
.dot{width:10px;height:10px;border-radius:50%}
.dot-green{background:#2ba84a}
.dot-red{background:#ff3b30}
.dot-purple{background:#7e57c2}

.tooltip{
  position:absolute;background:rgba(50,50,50,.9);color:#fff;padding:6px 10px;
  border-radius:6px;font-size:.8rem;pointer-events:none;opacity:0;transition:.15s;z-index:9999;
  font-family:'Figtree', system-ui, -apple-system, Segoe UI, Roboto, Arial;max-width:260px;white-space:normal;word-break:break-word;
}

.time-scale{position:relative;height:18px;margin-top:6px;font-size:.8rem;color:#666;}
.tick-label{position:absolute;bottom:0;transform:translateX(-50%);white-space:nowrap;font-size:10px;}

/* Skeleton */
.piscina-skeleton{border:1px solid #eee;border-radius:14px;padding:16px 14px;margin:10px 0;background:#fff;overflow:hidden}
.sk-head,.sk-bar,.sk-line{position:relative;border-radius:8px;background:#f2f2f2;overflow:hidden}
.sk-head{height:18px;width:60%;margin-bottom:10px}
.sk-bar{height:14px;border-radius:99px}
.sk-line{height:14px;width:40%;margin-top:10px}
.sk-shimmer::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);animation:shimmer 1.2s infinite;}
@keyframes shimmer{100%{transform:translateX(100%)}}

@media (min-width:800px){
  #dispo-piscina{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
  #dispo-piscina .piscina-card, #dispo-piscina .piscina-skeleton{margin:0;}
  .tick-label{font-size:12px;}
}