/* ═══════════════════════════════════════════════════════
   CAM LOANO – Foglio stile globale
   ═══════════════════════════════════════════════════════ */

*{box-sizing:border-box}

:root{
  --bg:#f8fafc;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#475569;
  --border:rgba(15,23,42,0.14);
  --border-hover:rgba(249,115,22,0.55);
  --a1:#ef4444;
  --a2:#f97316;
  --ok:#16a34a;
  --err:#dc2626;
  --warn:#d97706;
  --shadow:0 10px 24px rgba(2,6,23,0.08);
  --shadow-md:0 4px 12px rgba(2,6,23,0.10);
}

body{
  margin:0;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
}

/* ── Header ─────────────────────────────────────────── */
header{
  padding:1rem 1.5rem;
  border-bottom:1px solid var(--border);
  background:var(--card);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  flex-wrap:wrap;
  position:sticky;
  top:0;
  z-index:100;
}

.brand{display:flex;align-items:center;gap:0.75rem;flex-wrap:wrap}
.brand img{height:44px;width:auto}
.brand-text h1{
  margin:0;font-size:1.3rem;font-weight:900;line-height:1.05;
  background:linear-gradient(to right,var(--a1),var(--a2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.brand-text .sub{font-size:0.88rem;color:var(--muted);margin-top:0.1rem;font-weight:700}

.hdr-nav{display:flex;gap:0.55rem;align-items:center;flex-wrap:wrap}

/* ── Bottoni ─────────────────────────────────────────── */
.btn,.navbtn{
  display:inline-flex;align-items:center;justify-content:center;gap:0.4rem;
  border-radius:999px;border:1px solid var(--border);
  padding:0.52rem 0.9rem;
  font-size:0.93rem;font-weight:800;
  cursor:pointer;text-decoration:none;white-space:nowrap;
  background:rgba(255,255,255,0.6);color:var(--text);
  transition:border-color .15s,box-shadow .15s,transform .05s,filter .15s;
}
.btn:hover,.navbtn:hover{border-color:var(--border-hover)}
.btn:active,.navbtn:active{transform:translateY(1px)}
.btn:disabled{opacity:0.6;cursor:not-allowed}

.btn-primary{
  background:linear-gradient(to right,var(--a1),var(--a2));
  color:#160701;border-color:transparent;
  box-shadow:0 8px 22px rgba(249,115,22,0.25);
}
.btn-primary:hover{filter:brightness(1.04);box-shadow:0 12px 28px rgba(249,115,22,0.32)}

.btn-secondary{background:#fff;border-color:var(--border);color:var(--text)}
.btn-secondary:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}

.btn-danger{background:#fff;border-color:rgba(220,38,38,0.4);color:var(--err)}
.btn-danger:hover{background:#fef2f2;border-color:var(--err)}

.btn-sm{padding:0.38rem 0.75rem;font-size:0.85rem}

/* ── Card ────────────────────────────────────────────── */
.card{
  background:var(--card);border:1px solid var(--border);
  border-radius:1rem;padding:1.25rem 1.35rem;
  box-shadow:var(--shadow);margin-bottom:1rem;
}
.section-title{font-size:1.08rem;font-weight:900;margin:0 0 0.35rem}
.subtitle{font-size:0.9rem;color:var(--muted);font-weight:650;margin:0 0 0.9rem}

/* ── Form ────────────────────────────────────────────── */
label{display:block;font-size:0.9rem;font-weight:800;margin:0 0 0.25rem;color:var(--text)}

input,select,textarea{
  width:100%;padding:0.62rem 0.72rem;
  border-radius:0.75rem;border:1px solid rgba(15,23,42,0.18);
  background:#fff;color:var(--text);font-size:0.95rem;
  transition:border-color .15s,box-shadow .15s;
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:rgba(249,115,22,0.65);
  box-shadow:0 0 0 4px rgba(249,115,22,0.14);
}
textarea{min-height:100px;resize:vertical;border-radius:0.85rem}

.field-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:0.75rem 1rem}
.field-full{grid-column:1/-1}
.help{font-size:0.84rem;color:var(--muted);margin-top:0.2rem}

/* ── Tabelle ─────────────────────────────────────────── */
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:0.95rem}
table{width:100%;border-collapse:separate;border-spacing:0;font-size:0.9rem;min-width:640px;
  border:1px solid rgba(15,23,42,0.12);border-radius:0.95rem;overflow:hidden;background:#fff}
th,td{padding:0.7rem 0.8rem;border-bottom:1px solid rgba(15,23,42,0.09);text-align:left;vertical-align:middle}
thead th{font-weight:900;background:rgba(248,250,252,0.95);white-space:nowrap}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:rgba(249,115,22,0.05)}
.actions-col{white-space:nowrap}

/* ── Pills / Badge ───────────────────────────────────── */
.pill{
  display:inline-flex;align-items:center;gap:0.3rem;
  padding:0.18rem 0.65rem;border-radius:999px;
  border:1px solid rgba(15,23,42,0.16);font-size:0.82rem;font-weight:800;background:#fff;
}
.pill.ok{border-color:rgba(22,163,74,0.35);color:#14532d;background:rgba(34,197,94,0.10)}
.pill.warn{border-color:rgba(217,119,6,0.35);color:#7c2d12;background:rgba(251,191,36,0.16)}
.pill.bad{border-color:rgba(220,38,38,0.35);color:#7f1d1d;background:rgba(248,113,113,0.16)}
.pill.neutral{border-color:var(--border);color:var(--muted);background:var(--bg)}

/* ── Status messaggi inline ──────────────────────────── */
.status{margin-top:0.7rem;font-size:0.97rem;font-weight:800;color:var(--muted);min-height:1.4rem}
.status.ok{color:var(--ok)}
.status.error{color:var(--err)}
.status.warn{color:var(--warn)}

/* ── Consent checkbox ────────────────────────────────── */
.consent-row{
  display:flex;align-items:flex-start;gap:0.7rem;
  padding:0.55rem 0.65rem;border:1px solid rgba(15,23,42,0.10);
  border-radius:0.85rem;background:rgba(249,250,251,0.9);margin-bottom:0.6rem;
}
.consent-row input[type="checkbox"]{flex:0 0 auto;margin-top:0.22rem;width:18px;height:18px;accent-color:#f97316}
.consent-row span{line-height:1.4;font-size:0.95rem}

/* ── Separatori ──────────────────────────────────────── */
.divider{height:1px;background:rgba(15,23,42,0.12);margin:1rem 0}

/* ── Row utils ───────────────────────────────────────── */
.row{display:flex;gap:0.75rem;flex-wrap:wrap;align-items:center;margin-top:0.9rem}
.muted{color:var(--muted);font-size:0.88rem;font-weight:650}

/* ── KV list (scheda allievo) ────────────────────────── */
.kv{display:grid;grid-template-columns:160px 1fr;gap:0.4rem 0.9rem;font-size:0.95rem}
.k{color:var(--muted);font-weight:800}
.v{color:var(--text);font-weight:700;word-break:break-word}
@media(max-width:500px){.kv{grid-template-columns:1fr}}

/* ── Grid layout 2 col ───────────────────────────────── */
.grid-2{display:grid;grid-template-columns:1.2fr 0.8fr;gap:1rem}
@media(max-width:860px){.grid-2{grid-template-columns:1fr}}

/* ── Belt timeline ───────────────────────────────────── */
.belt-timeline{position:relative;padding-left:2rem}
.belt-timeline::before{content:'';position:absolute;left:0.55rem;top:0.5rem;bottom:0.5rem;width:2px;background:var(--border)}
.belt-step{position:relative;display:flex;gap:0.9rem;align-items:flex-start;padding-bottom:1.1rem}
.belt-step:last-child{padding-bottom:0}
.belt-dot{
  width:1.1rem;height:1.1rem;border-radius:50%;flex-shrink:0;
  margin-left:-2rem;margin-top:0.2rem;border:2px solid #fff;
  position:relative;z-index:1;
}
.belt-info{flex:1;background:rgba(248,250,252,0.9);border:1px solid var(--border);border-radius:0.8rem;padding:0.6rem 0.85rem}
.belt-name{font-weight:900;font-size:0.97rem;margin-bottom:0.15rem;display:flex;align-items:center;gap:0.5rem}
.belt-meta{font-size:0.85rem;color:var(--muted);font-weight:650}
.belt-current{font-size:0.72rem;font-weight:900;background:var(--a1);color:#fff;padding:0.1rem 0.5rem;border-radius:999px}

/* ── Gruppo badge ────────────────────────────────────── */
.grp{display:inline-flex;align-items:center;padding:0.18rem 0.65rem;border-radius:999px;font-size:0.82rem;font-weight:800;border:1px solid}
.grp-panda{background:#fef9c3;color:#854d0e;border-color:#fde047}
.grp-tigers{background:#fee2e2;color:#991b1b;border-color:#fca5a5}
.grp-dragons{background:#ede9fe;color:#4c1d95;border-color:#c4b5fd}
.grp-futurenere{background:#fae8ff;color:#701a75;border-color:#e879f9}
.grp-nere{background:#f1f5f9;color:#1e293b;border-color:#cbd5e1}
.grp-juniors{background:#dcfce7;color:#14532d;border-color:#86efac}
.grp-adulti{background:#dbeafe;color:#1e3a8a;border-color:#93c5fd}
.grp-none{background:var(--bg);color:var(--muted);border-color:var(--border)}

/* ── PWA install banner ──────────────────────────────── */
#pwa-banner{
  display:none;position:fixed;bottom:1rem;left:50%;transform:translateX(-50%);
  background:#111;color:#fff;padding:0.8rem 1.2rem;border-radius:1rem;
  font-size:0.9rem;font-weight:700;z-index:999;
  box-shadow:0 8px 24px rgba(0,0,0,0.3);gap:1rem;align-items:center;
  max-width:calc(100vw - 2rem);
}
#pwa-banner.visible{display:flex}
#pwa-banner button{
  background:linear-gradient(to right,var(--a1),var(--a2));color:#160701;
  border:none;border-radius:999px;padding:0.4rem 0.9rem;font-weight:900;cursor:pointer;
}
#pwa-banner .close-pwa{background:none;color:rgba(255,255,255,0.6);font-size:1.1rem;padding:0;line-height:1}

/* ── Utility ─────────────────────────────────────────── */
.hidden{display:none!important}
.text-ok{color:var(--ok)}
.text-err{color:var(--err)}
.text-warn{color:var(--warn)}
main{max-width:1100px;margin:1.5rem auto;padding:0 1rem 2.5rem}
.opbar{display:flex;justify-content:space-between;align-items:flex-start;gap:0.8rem;flex-wrap:wrap;margin-bottom:0.8rem}

@media(max-width:600px){
  header{padding:0.8rem 1rem}
  .brand img{height:38px}
  main{padding:0 0.75rem 2rem}
}

/* ── Mobile landscape e rotazione ───────────────────────────────── */
@media screen and (orientation:landscape) and (max-height:500px){
  header{padding:0.5rem 1.2rem}
  .brand img{height:32px}
  .brand-text h1{font-size:1.1rem}
  main{margin-top:0.75rem;padding:0 0.75rem 1rem}
}

/* ── Tabelle su schermi stretti ──────────────────────────────────── */
@media(max-width:500px){
  table{min-width:480px}
  .tab-btn{padding:0.6rem 0.65rem;font-size:0.78rem}
}
