/* SessantAnna - design system condiviso */
@import url('https://fonts.googleapis.com/css2?family=Schibsted+Grotesk:wght@500;700;800;900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root{
  --rosso:#F03E4E; --arancio:#FF8A2B; --giallo:#FFC60A; --verde:#16B894;
  --azzurro:#34B6E4; --blu:#4B3FD6; --viola:#9A4DF0;   /* "blu" mostrato in indaco */
  --bianco:#FFFFFF;
  --bg:#F4F5F8; --card:#FFFFFF; --ink:#15171C; --muted:#71757F; --line:#E7E9EE;
  --ok:#16B894; --warn:#F03E4E;
  --radius:16px; --shadow:0 6px 20px rgba(0,0,0,.07); --shadow-lg:0 16px 40px rgba(0,0,0,.10);
  --font-display:'Schibsted Grotesk',system-ui,sans-serif;
  --font-body:'Plus Jakarta Sans',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);color:var(--ink);line-height:1.5;min-height:100vh;
  background:
    radial-gradient(700px 420px at 92% -8%,rgba(154,77,240,.10),transparent 60%),
    radial-gradient(640px 400px at -6% 108%,rgba(52,182,228,.12),transparent 60%),
    var(--bg);
}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(21,23,28,.05) 1px,transparent 1px);background-size:22px 22px}
.wrap{position:relative;z-index:2;max-width:1080px;margin:0 auto;padding:0 24px}
.wrap.narrow{max-width:560px}

/* Header + logo */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:20px 0;flex-wrap:wrap;gap:12px}
.brand{font-family:var(--font-display);font-weight:900;font-size:1.5rem;letter-spacing:-.5px;display:inline-flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink)}
.brand-logo{height:72px;width:auto;display:block}
.hero-logo{width:min(420px,84vw);height:auto;display:block;margin:0 auto;filter:drop-shadow(0 12px 26px rgba(0,0,0,.14));animation:logoPop .7s cubic-bezier(.2,.9,.3,1.2) both}
@keyframes logoPop{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
.brand .dot{width:30px;height:30px;border-radius:50%;flex:none;
  background:conic-gradient(var(--rosso) 0 51.43deg,var(--arancio) 51.43deg 102.86deg,var(--giallo) 102.86deg 154.29deg,var(--verde) 154.29deg 205.71deg,var(--azzurro) 205.71deg 257.14deg,var(--blu) 257.14deg 308.57deg,var(--viola) 308.57deg 360deg);
  box-shadow:0 2px 10px rgba(0,0,0,.15)}
.logo-word{font-family:var(--font-display);font-weight:900;letter-spacing:-1px}
.logo-word .a{background:linear-gradient(90deg,var(--rosso),var(--arancio),var(--giallo));-webkit-background-clip:text;background-clip:text;color:transparent}
.logo-word .b{background:linear-gradient(90deg,var(--verde),var(--azzurro),var(--blu),var(--viola));-webkit-background-clip:text;background-clip:text;color:transparent}

/* Tipografia */
h1{font-family:var(--font-display);font-weight:900;letter-spacing:-1.5px;line-height:1.02}
h2{font-family:var(--font-display);font-weight:800;letter-spacing:-.5px}
h3{font-family:var(--font-display);font-weight:700}
.subtitle{color:var(--muted)}
.lead{font-size:1.15rem;color:var(--muted)}

/* Card */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}
.card + .card{margin-top:16px}

/* Bottoni */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-body);font-weight:800;font-size:1rem;
  border:none;cursor:pointer;padding:13px 24px;border-radius:30px;text-decoration:none;transition:transform .2s,box-shadow .2s,filter .2s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--rosso);color:#fff;box-shadow:0 8px 22px rgba(240,62,78,.32)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(240,62,78,.4)}
.btn-dark{background:var(--ink);color:#fff}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--muted)}
.btn-sm{padding:8px 16px;font-size:.88rem}
.btn-danger{background:#fff;border:1px solid #f3c0c5;color:var(--warn)}
.btn-block{display:flex;width:100%;justify-content:center}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;padding:0;transition:.15s;text-decoration:none}
.iconbtn:hover{border-color:var(--muted);background:#f7f8fa}
.iconbtn svg{width:18px;height:18px}
.iconbtn.danger{color:var(--warn);border-color:#f3c0c5}
.iconbtn.danger:hover{background:#fdeaec}
.actions{display:inline-flex;gap:6px;align-items:center;white-space:nowrap}
.actions form{display:inline}

/* Form */
label.field{display:block;margin-bottom:14px}
label.field > span{display:block;font-weight:700;font-size:.9rem;margin-bottom:6px}
.input{width:100%;font-family:var(--font-body);font-size:1.05rem;padding:13px 15px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink)}
.input:focus{outline:none;border-color:var(--blu);box-shadow:0 0 0 3px rgba(75,63,214,.15)}

/* Tabella */
table.tbl{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
table.tbl th,table.tbl td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);font-size:.95rem}
table.tbl th{font-weight:800;font-size:.78rem;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);background:#fbfbfc}
table.tbl tr:last-child td{border-bottom:none}

/* Avatar (iniziale su cerchio colorato) */
.avatar{width:44px;height:44px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  color:#fff;font-family:var(--font-display);font-weight:900;font-size:1.05rem;flex:none;box-shadow:inset 0 0 0 2px rgba(255,255,255,.3)}
img.avatar{object-fit:cover;padding:0;background:#eef0f4}

/* Pallino colore */
.cdot{width:18px;height:18px;border-radius:50%;display:inline-block;vertical-align:middle;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
.cdot.empty{background:#e3e6ec}

/* Badge */
.badge{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:.8rem;padding:6px 12px;border-radius:30px;border:1px solid var(--line);background:#fff}
.badge.ok{color:var(--ok)} .badge.warn{color:var(--warn)}
.badge .pip{width:8px;height:8px;border-radius:50%;background:currentColor}

/* Pillole PIN / monospace */
.pin{font-family:ui-monospace,Menlo,Consolas,monospace;font-weight:700;letter-spacing:2px;background:#fff;border:1px dashed #c9cdd6;border-radius:8px;padding:4px 10px;display:inline-block}

/* Flash message */
.flash{border-radius:12px;padding:12px 16px;font-weight:600;margin-bottom:16px}
.flash.ok{background:#e7f7f2;color:#0c6b54;border:1px solid #bfe9dd}
.flash.err{background:#fdeaec;color:#a01926;border:1px solid #f6c5cb}

.muted{color:var(--muted)} .right{text-align:right} .center{text-align:center}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.spacer{flex:1}
footer.foot{position:relative;z-index:2;color:var(--muted);font-size:.88rem;padding:30px 0 50px;border-top:1px solid var(--line);margin-top:40px}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
