/* ============================================================
   BYRON'S CARD — style.css
   Brand: navy / ghiaccio / ciano / magenta, etichette mono.
   La scheda pubblica replica il layout del template di riferimento:
   copertina scura con pattern, avatar circolare, azioni a riquadri.
   ============================================================ */
:root{
  --ink:#0A1F33;
  --navy:#0D2B45;
  --cyan:#2BA8E0;
  --magenta:#9F1B7E;
  --slate:#5C7186;
  --bg:#EEF2F6;
  --line:#E2E8F0;
  --line-dark:rgba(255,255,255,.14);
  --radius:18px;
  --font-d:'Archivo',system-ui,sans-serif;
  --font-b:'Inter',system-ui,sans-serif;
  --font-m:'IBM Plex Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font-b);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit}
img{max-width:100%}
.wrap{max-width:1060px;margin:0 auto;padding:0 22px}
.mono{font-family:var(--font-m);font-size:.66rem;letter-spacing:.26em;text-transform:uppercase}

/* ── topbar ───────────────────────────────────────────── */
.topbar{background:linear-gradient(120deg,#081726,var(--navy));color:#fff;position:sticky;top:0;z-index:50;border-bottom:1px solid var(--line-dark)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:66px;gap:16px}
.topbar .logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.topbar .logo img{height:34px}
.logo-sub{font-family:var(--font-m);font-size:.6rem;letter-spacing:.4em;color:var(--cyan);border:1px solid rgba(43,168,224,.5);padding:4px 8px 3px;border-radius:6px}
.topbar nav{display:flex;align-items:center;gap:20px}
.topbar nav a{color:#B9CCDC;text-decoration:none;font-size:.86rem;font-weight:500;transition:color .2s}
.topbar nav a:hover{color:#fff}
.btn-mini{border:1px solid var(--cyan);color:var(--cyan)!important;border-radius:999px;padding:7px 16px;font-family:var(--font-m);font-size:.68rem!important;letter-spacing:.1em;text-transform:uppercase}
.btn-mini:hover{background:var(--cyan);color:#fff!important}

/* ── flash ────────────────────────────────────────────── */
.flash-stack{max-width:1060px;margin:14px auto 0;padding:0 22px;display:grid;gap:8px}
.flash{padding:12px 18px;border-radius:12px;font-size:.9rem;font-weight:500;animation:flashIn .35s ease both}
.flash.ok{background:#E3F6EA;color:#1E7E3E;border:1px solid #B7E4C7}
.flash.error{background:#FDEBEE;color:#C2273F;border:1px solid #F5C2CB}
@keyframes flashIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ── footer ───────────────────────────────────────────── */
.sitefoot{margin-top:70px;padding:26px 0;background:#081726;color:#7E97AB;font-size:.8rem}
.sitefoot .wrap{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* ── landing ──────────────────────────────────────────── */
.hero-land{background:
  radial-gradient(800px 420px at 85% -10%,rgba(43,168,224,.2),transparent 60%),
  radial-gradient(600px 380px at -5% 110%,rgba(159,27,126,.22),transparent 55%),
  linear-gradient(160deg,#081726,var(--navy));
  color:#fff;padding:90px 0 80px;overflow:hidden;position:relative}
.hero-land::before{content:"";position:absolute;inset:0;opacity:.45;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:64px 64px}
.hero-land .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;position:relative}
.hero-land h1{font-family:var(--font-d);font-weight:800;font-size:clamp(2rem,4.6vw,3.3rem);line-height:1.1;letter-spacing:-.015em}
.hero-land .hl{color:var(--cyan)}
.hero-land p{color:#A9C0D2;margin-top:18px;max-width:50ch}
.eyebrow{font-family:var(--font-m);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;gap:12px;margin-bottom:16px}
.eyebrow::after{content:"";width:44px;height:1px;background:currentColor;opacity:.5}
.hero-actions{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.btn{font-family:var(--font-d);font-weight:600;font-size:.92rem;padding:14px 30px;border-radius:999px;text-decoration:none;display:inline-block;transition:transform .2s,box-shadow .2s;border:0;cursor:pointer}
.btn-primary{background:var(--cyan);color:#06121E;box-shadow:0 8px 28px rgba(43,168,224,.35)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{border:1px solid rgba(255,255,255,.3);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.mock-card{background:#fff;color:var(--ink);border-radius:22px;box-shadow:0 30px 70px rgba(0,0,0,.45);overflow:hidden;transform:rotate(2deg);animation:floaty 7s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:rotate(2deg) translateY(0)}50%{transform:rotate(2deg) translateY(-12px)}}
.mock-card .mc-cover{height:110px;background:
  radial-gradient(220px 120px at 25% 30%,rgba(255,255,255,.18),transparent 60%),
  repeating-linear-gradient(45deg,rgba(255,255,255,.05) 0 14px,transparent 14px 28px),
  linear-gradient(120deg,#0b1320,#1a2433)}
.mock-card .mc-body{padding:0 22px 22px}
.mock-card .mc-ava{width:78px;height:78px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--font-d);font-weight:800;font-size:1.5rem;border:4px solid #fff;margin-top:-39px}
.mock-card h3{font-family:var(--font-d);font-size:1.3rem;margin-top:10px}
.mock-card small{color:var(--slate)}
.mock-card .mc-chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.mock-card .mc-chips span{font-size:.7rem;border:1px solid var(--line);border-radius:999px;padding:5px 12px;background:#F7FAFC}
.steps{padding:80px 0 10px}
.steps h2{font-family:var(--font-d);font-size:1.7rem;text-align:center}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s}
.step:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(13,43,69,.1)}
.step::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--c,var(--cyan))}
.step .n{font-family:var(--font-m);color:var(--c,var(--cyan));font-size:.7rem;letter-spacing:.2em}
.step b{display:block;font-family:var(--font-d);font-size:1.05rem;margin:8px 0 6px}
.step p{font-size:.88rem;color:var(--slate)}
.companies-band{padding:60px 0 20px;text-align:center}
.companies-band .mono{color:var(--slate)}
.logo-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.logo-row img{height:58px;border-radius:10px;border:1px solid var(--line);transition:transform .2s}
.logo-row img:hover{transform:translateY(-4px)}

/* ── auth ─────────────────────────────────────────────── */
.auth-wrap{max-width:430px;margin:60px auto;padding:0 22px}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:0 18px 50px rgba(13,43,69,.08)}
.panel h1{font-family:var(--font-d);font-size:1.5rem;margin-bottom:6px}
.panel .sub{color:var(--slate);font-size:.9rem;margin-bottom:24px}
label{display:block;font-family:var(--font-m);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);margin:16px 0 6px}
input[type=text],input[type=email],input[type=password],input[type=tel],input[type=url],select,textarea{
  width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-family:var(--font-b);
  font-size:.94rem;background:#FBFDFE;outline:none;transition:border-color .2s,box-shadow .2s}
input:focus,select:focus,textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(43,168,224,.15)}
.auth-foot{margin-top:20px;font-size:.85rem;color:var(--slate);text-align:center}
.auth-foot a{color:var(--cyan);font-weight:600;text-decoration:none}

/* ── pannello ─────────────────────────────────────────── */
.dash{max-width:1060px;margin:40px auto;padding:0 22px;display:grid;grid-template-columns:1.05fr .95fr;gap:26px;align-items:start}
.dash h1{font-family:var(--font-d);font-size:1.6rem}
.dash .sub{color:var(--slate);font-size:.9rem;margin:4px 0 20px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.company-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:6px}
.company-pick{position:relative;cursor:pointer}
.company-pick input{position:absolute;opacity:0;inset:0}
.company-pick .tile{
  border:2px solid var(--line);border-radius:12px;overflow:hidden;transition:border-color .2s,transform .2s;display:block}
.company-pick .tile img{display:block;width:100%;height:56px;object-fit:cover}
.company-pick .tile span{display:block;text-align:center;font-family:var(--font-m);font-size:.56rem;letter-spacing:.08em;text-transform:uppercase;padding:5px 4px;color:var(--slate);background:#F7FAFC}
.company-pick input:checked + .tile{border-color:var(--c);transform:translateY(-2px);box-shadow:0 8px 20px rgba(13,43,69,.12)}
.company-pick input:focus-visible + .tile{outline:2px solid var(--c);outline-offset:2px}
.photo-row{display:flex;align-items:center;gap:18px;margin-top:6px}
.photo-prev{width:84px;height:84px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 6px 18px rgba(13,43,69,.18);background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--font-d);font-weight:800;font-size:1.5rem}
.check-row{display:flex;align-items:center;gap:10px;margin-top:18px;font-size:.9rem;color:var(--slate)}
.check-row input{width:auto}
.save-bar{margin-top:26px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.url-box{background:#F1F7FB;border:1px dashed var(--cyan);border-radius:12px;padding:14px 16px;margin-top:18px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.url-box code{font-family:var(--font-m);font-size:.8rem;color:var(--navy)}
.copy-btn{font-family:var(--font-m);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--cyan);color:var(--cyan);background:none;border-radius:999px;padding:7px 14px;cursor:pointer;transition:background .2s,color .2s}
.copy-btn:hover{background:var(--cyan);color:#fff}
.side-sticky{position:sticky;top:90px}
.qr-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;text-align:center;margin-top:20px}
.qr-card img{width:170px;height:170px}
.qr-card p{font-size:.8rem;color:var(--slate);margin-top:8px}
.preview-frame{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg)}
.preview-frame iframe{width:100%;height:560px;border:0;display:block}

/* ── SCHEDA PUBBLICA (stile template di riferimento) ─── */
body.cardpage{background:#E9EDF2;
  background-image:radial-gradient(900px 500px at 80% -10%, rgba(43,168,224,.1), transparent 60%)}
.card-shell{max-width:760px;margin:34px auto 60px;padding:0 16px}
.bcard{background:#fff;border-radius:26px;overflow:hidden;box-shadow:0 30px 80px rgba(13,43,69,.18);animation:cardIn .7s cubic-bezier(.2,.7,.3,1) both}
@keyframes cardIn{from{opacity:0;transform:translateY(28px) scale(.985)}to{opacity:1;transform:none}}

/* copertina personalizzata per società: colore + pattern a rombi */
/* .cover{
  height:235px;position:relative;overflow:hidden;
  background:
    radial-gradient(420px 240px at 28% 35%, color-mix(in srgb, var(--c) 38%, transparent), transparent 65%),
    radial-gradient(300px 200px at 70% 10%, rgba(255,255,255,.1), transparent 60%),
    repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 16px, transparent 16px 32px),
    repeating-linear-gradient(-45deg, rgba(255,255,255,.04) 0 16px, transparent 16px 32px),
    linear-gradient(120deg, #0B1320 0%, #131C2B 55%, color-mix(in srgb, var(--c) 30%, #131C2B) 100%);
}
*/
/* copertina brandizzata — mesh di nodi + glow della società */
.cover{
  height:235px;position:relative;overflow:hidden;
  background:
    /* alone tinto col colore aziendale, in alto a sinistra */
    radial-gradient(540px 300px at 22% -20%,
      color-mix(in srgb, var(--c) 55%, transparent), transparent 60%),
    /* alone ciano freddo, in basso a destra */
    radial-gradient(420px 260px at 88% 120%,
      rgba(43,168,224,.28), transparent 60%),
    /* griglia tecnica (DNA del deck) */
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px),
    /* base navy */
    linear-gradient(135deg, #081726 0%, #0D2B45 55%, #0A1F33 100%);
  background-size:
    auto, auto,
    34px 34px, 34px 34px,
    auto;
}
/* rete di nodi: puntini connessi, deriva lenta */
.cover::before{
  content:"";position:absolute;inset:-40px;pointer-events:none;
  background-image:
    radial-gradient(circle at 12% 30%, var(--c) 0 2px, transparent 2.5px),
    radial-gradient(circle at 30% 70%, rgba(43,168,224,.9) 0 2px, transparent 2.5px),
    radial-gradient(circle at 48% 22%, rgba(255,255,255,.55) 0 1.6px, transparent 2px),
    radial-gradient(circle at 66% 60%, var(--c) 0 2px, transparent 2.5px),
    radial-gradient(circle at 82% 28%, rgba(43,168,224,.85) 0 2px, transparent 2.5px),
    radial-gradient(circle at 90% 75%, rgba(159,27,126,.85) 0 2px, transparent 2.5px);
  background-repeat:no-repeat;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 18%, #000 82%, transparent);
          mask-image:linear-gradient(90deg, transparent, #000 18%, #000 82%, transparent);
  animation:coverDrift 16s ease-in-out infinite alternate;
}
/* linee di connessione tra i nodi */
.cover::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:
    linear-gradient(74deg, transparent 0 11%,
      color-mix(in srgb, var(--c) 70%, transparent) 11% 11.15%, transparent 11.15% 30%,
      rgba(43,168,224,.5) 30% 30.15%, transparent 30.15% 66%,
      rgba(255,255,255,.25) 66% 66.12%, transparent 66.12% 82%,
      rgba(159,27,126,.5) 82% 82.15%, transparent 82.15%);
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 20%, #000 80%, transparent);
          mask-image:linear-gradient(90deg, transparent, #000 20%, #000 80%, transparent);
}
@keyframes coverDrift{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(-22px,-12px,0)}
}
@media (prefers-reduced-motion:reduce){
  .cover::before{animation:none}
  .cover .shine{animation:none}
}




.cover .shine{position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.1) 48%,transparent 60%);transform:translateX(-100%);animation:shine 6s ease-in-out infinite}
@keyframes shine{0%,55%{transform:translateX(-100%)}80%,100%{transform:translateX(100%)}}
.cover .label{position:absolute;left:28px;bottom:18px;color:rgba(255,255,255,.75);font-family:var(--font-m);font-size:.68rem;letter-spacing:.45em;text-transform:uppercase}
.cover .c-logo{position:absolute;top:18px;right:18px;height:54px;border-radius:10px;border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 24px rgba(0,0,0,.35)}
.cover .grp{position:absolute;top:24px;left:28px;height:30px;opacity:.95}

.bcard-body{padding:0 30px 30px;position:relative}
.avatar{
  width:152px;height:152px;border-radius:50%;border:6px solid #fff;margin-top:-76px;
  object-fit:cover;background:var(--ink);box-shadow:0 14px 36px rgba(13,43,69,.25);
  display:grid;place-items:center;color:#fff;font-family:var(--font-d);font-weight:800;font-size:3rem;letter-spacing:-.02em;
  animation:avaIn .8s cubic-bezier(.2,.7,.3,1) .15s both}
@keyframes avaIn{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:none}}
/* .badge-co{
  position:absolute;right:30px;top:18px;display:inline-flex;align-items:center;gap:8px;
  background:var(--ink);color:#fff;border-radius:999px;padding:11px 20px;
  font-family:var(--font-d);font-weight:600;font-size:.86rem;box-shadow:0 10px 26px rgba(13,43,69,.3)}
 */

  .badge-co{
    display:inline-flex;align-items:center;gap:8px;
    margin-top:25px;            /* sotto la copertina, nel flusso */
    float:right;                /* si appoggia a destra, l'avatar resta a sinistra */
    background:var(--ink);color:#fff;border-radius:999px;padding:11px 20px;
    font-family:var(--font-d);font-weight:600;font-size:.5rem;
    box-shadow:0 10px 26px rgba(13,43,69,.3);
  }



.badge-co::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--c);animation:dotPulse 2.4s infinite}
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--c) 50%,transparent)}50%{box-shadow:0 0 0 7px transparent}}
.bcard h1{font-family:var(--font-d);font-weight:800;font-size:clamp(1.9rem,5vw,2.5rem);letter-spacing:-.02em;margin-top:16px}
.role{color:var(--slate);font-size:1.02rem;margin-top:4px}
.role b{color:var(--navy);font-weight:600}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.chips span{border:1px solid var(--line);background:#F7FAFC;border-radius:999px;padding:8px 18px;font-size:.86rem;font-weight:500;transition:transform .2s,border-color .2s}
.chips span:hover{transform:translateY(-2px);border-color:var(--c)}

.cta-row{display:grid;grid-template-columns:1.15fr 1fr;gap:12px;margin-top:24px}
.cta{display:flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;padding:16px;
  font-family:var(--font-d);font-weight:600;font-size:.95rem;text-decoration:none;transition:transform .15s,box-shadow .2s;border:0;cursor:pointer}
.cta:active{transform:scale(.98)}
.cta-dark{background:var(--ink);color:#fff;box-shadow:0 10px 26px rgba(13,43,69,.3)}
.cta-dark:hover{transform:translateY(-2px)}
.cta-light{background:#F1F4F8;color:var(--ink);border:1px solid var(--line)}
.cta-light:hover{transform:translateY(-2px)}

.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
.tile{
  background:#F7F9FC;border:1px solid var(--line);border-radius:16px;padding:22px 10px 18px;
  text-align:center;text-decoration:none;color:var(--ink);transition:transform .2s,box-shadow .2s,border-color .2s}
.tile:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(13,43,69,.12);border-color:var(--c)}
.tile .ico{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--ink);display:grid;place-items:center;margin:0 auto 10px;font-size:1.1rem;transition:background .2s,color .2s,border-color .2s}
.tile:hover .ico{background:var(--c);border-color:var(--c);color:#fff}
.tile b{font-family:var(--font-d);font-weight:600;font-size:.9rem}
.tile.disabled{opacity:.35;pointer-events:none}

.tabs{display:flex;gap:34px;border-bottom:1px solid var(--line);margin-top:32px}
.tabs button{background:none;border:0;font-family:var(--font-d);font-weight:600;font-size:1rem;color:var(--slate);padding:12px 2px;cursor:pointer;position:relative}
.tabs button.active{color:var(--ink)}
.tabs button.active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;background:var(--c);border-radius:3px;animation:tabIn .3s ease}
@keyframes tabIn{from{transform:scaleX(.4)}to{transform:scaleX(1)}}
.tabpane{display:none;padding:24px 2px 4px;animation:flashIn .35s ease}
.tabpane.show{display:block}
.tabpane h3{font-family:var(--font-d);font-size:1.2rem;margin-bottom:10px}
.tabpane p{color:#3D5468;font-size:.97rem}
.kv{display:grid;gap:0;margin-top:6px}
.kv .row{display:grid;grid-template-columns:120px 1fr;gap:14px;padding:13px 0;border-bottom:1px solid #EFF3F7;align-items:baseline}
.kv .row:last-child{border-bottom:0}
.kv .k{font-family:var(--font-m);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--c)}
.kv .v a{color:var(--navy);text-decoration:none;border-bottom:1px solid var(--c)}
.qr-inline{display:flex;align-items:center;gap:18px;margin-top:20px;background:#F7F9FC;border:1px solid var(--line);border-radius:16px;padding:16px 20px}
.qr-inline img{width:96px;height:96px;border-radius:8px}
.qr-inline p{font-size:.82rem;color:var(--slate)}
.card-foot{margin-top:30px;padding-top:18px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.card-foot img{height:26px;opacity:.85}
.card-foot span{font-family:var(--font-m);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--slate)}

/* ── admin ────────────────────────────────────────────── */
.admin-wrap{max-width:1060px;margin:40px auto;padding:0 22px}
table.admin{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 14px 40px rgba(13,43,69,.08)}
table.admin th{font-family:var(--font-m);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:#fff;background:var(--ink);text-align:left;padding:14px 16px}
table.admin td{padding:13px 16px;border-bottom:1px solid #EFF3F7;font-size:.9rem;vertical-align:middle}
table.admin tr:hover td{background:#F7FAFC}
.tag-co{display:inline-block;font-family:var(--font-m);font-size:.62rem;letter-spacing:.1em;padding:4px 10px;border-radius:999px;color:#fff;background:var(--c,var(--slate))}
.state{font-family:var(--font-m);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase}
.state.on{color:#1E7E3E}.state.off{color:#C2273F}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}
.row-actions button{font-family:var(--font-m);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 12px;cursor:pointer;transition:all .15s}
.row-actions button:hover{border-color:var(--cyan);color:var(--cyan)}
.row-actions button.danger:hover{border-color:#C2273F;color:#C2273F}

/* ── responsive ───────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
@media(max-width:920px){
  .dash{grid-template-columns:1fr}
  .side-sticky{position:static}
  .hero-land .wrap{grid-template-columns:1fr}
  .mock-card{transform:none;max-width:380px;margin:0 auto}
  .steps-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .company-picker{grid-template-columns:repeat(2,1fr)}
  .grid2{grid-template-columns:1fr}
  .cover{height:190px}
  .cover .c-logo{height:42px}
  .avatar{width:120px;height:120px;margin-top:-60px;font-size:2.3rem}
  .badge-co{position:static;margin-top:14px}
  .bcard-body{padding:0 20px 24px}
  .cta-row{grid-template-columns:1fr}
  .tile-grid{grid-template-columns:repeat(3,1fr);gap:8px}
  .tile{padding:16px 6px 12px}
  .tile .ico{width:40px;height:40px}
  .tabs{gap:22px}
  .topbar nav{gap:12px}
  .topbar nav a{font-size:.78rem}
}

/* ── approvazioni admin ───────────────────────────────── */
.pending-badge{display:inline-grid;place-items:center;min-width:24px;height:24px;border-radius:999px;
  background:#C2273F;color:#fff;font-family:var(--font-m);font-size:.7rem;margin-left:8px;padding:0 7px;
  animation:dotPulse 2.4s infinite}
.pending-row td{background:#FFF9F0}
.row-actions button.approve{border-color:#1E7E3E;color:#1E7E3E;font-weight:600}
.row-actions button.approve:hover{background:#1E7E3E;color:#fff;border-color:#1E7E3E}
