@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap');
:root{
    /* Allineato al portale XRCopilot (tema Radzen "material") */
    --ink:#1f2933; --muted:#5d6b7b;
    --navy:#322e9e;        /* heading/brand: indigo profondo (≈ --rz-primary-dark) */
    --azure:#4340d2;       /* primario interattivo (--rz-primary) */
    --azure-soft:#ecebfb;  /* tint indigo (≈ --rz-primary-lighter) */
    --purple:#6e3fa0; --purple-soft:#eae8fa;   /* lavanda card portale */
    --green:#0ea299; --green-soft:#e8f7f4;     /* teal/aqua + menta portale */
    --amber:#9a6a1b; --amber-soft:#faf5e8;     /* sabbia portale */
    --red:#b3261e;
    --link:#0ea299; --link-hover:#9e6ffa;      /* link = custom-link del portale */
    --brand-from:#b0228c; --brand-to:#6a3f9e;  /* gradiente del logo (magenta→viola) */
    --grad:linear-gradient(135deg,var(--brand-from),var(--brand-to));
    --line:#e5e7eb; --bg:#f4f6fa;              /* sfondo portale (#F4F6FA) */
    --surface-hover:#e9edf5;
    --card:#ffffff; --radius:16px;
    --shadow:0 1px 3px rgba(67,64,210,.06),0 8px 24px rgba(67,64,210,.07);
  }
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Roboto',-apple-system,"Segoe UI",Helvetica,Arial,sans-serif;color:var(--ink);
    background:var(--bg);line-height:1.55;font-size:15.5px;-webkit-font-smoothing:antialiased}
a{color:var(--link);text-decoration:none}
a:hover{color:var(--link-hover);text-decoration:underline}
header{position:sticky;top:0;z-index:40;background:#fff;border-bottom:1px solid var(--line);
    display:flex;align-items:center;gap:16px;padding:10px 22px}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;color:var(--navy);font-size:15px;letter-spacing:.2px}
.brand-logo{height:30px;width:auto;display:block}
.brand-sep{width:1px;height:26px;background:var(--line);flex:none}
.brand-txt{display:flex;flex-direction:column;line-height:1.18}
.brand small{display:block;font-weight:500;color:var(--muted);font-size:11px;letter-spacing:.3px}
.hspace{flex:1}
.lang{display:flex;border:1px solid var(--line);border-radius:9px;overflow:hidden;font-size:12.5px;font-weight:700}
.lang button{border:0;background:#fff;color:var(--muted);padding:6px 11px;cursor:pointer}
.lang button.on{background:var(--navy);color:#fff}
.ring{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--muted);font-weight:600}
.ring svg{transform:rotate(-90deg)}
.wrap{display:grid;grid-template-columns:288px 1fr;align-items:start}
aside{position:sticky;top:53px;height:calc(100vh - 53px);overflow:auto;border-right:1px solid var(--line);
    background:#fff;padding:18px 14px}
.nav-h{font-size:11px;font-weight:800;letter-spacing:.8px;color:var(--muted);text-transform:uppercase;margin:14px 8px 6px}
.mod{margin-bottom:6px}
.mod>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:9px;
    font-weight:700;color:var(--navy);font-size:13.5px}
.mod>summary::-webkit-details-marker{display:none}
.mod>summary:hover{background:var(--azure-soft)}
.mod .badge{margin-left:auto;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;background:#eef2f7;color:var(--muted)}
.mod .num{width:22px;height:22px;border-radius:6px;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:800}
.sec{display:block;padding:7px 10px 7px 41px;border-radius:8px;font-size:13px;color:var(--muted);cursor:default}
.sec.active{background:var(--azure);color:#fff;font-weight:700;cursor:pointer}
.sec.done::before{content:"\2713 ";color:#9be8c0;font-weight:800}
.sec.locked{opacity:.6}
.sec.locked::after{content:" \00B7 in preparazione";font-size:11px;opacity:.7}
main{padding:30px 40px 70px;max-width:920px}
.crumb{font-size:12.5px;color:var(--muted);font-weight:600;margin-bottom:6px}
h1.title{font-size:30px;color:var(--navy);margin:0 0 4px;letter-spacing:-.3px}
.lede{color:var(--muted);font-size:16px;margin:0 0 22px}
.block{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;margin:0 0 18px;box-shadow:var(--shadow)}
.block h2{display:flex;align-items:center;gap:10px;margin:0 0 12px;font-size:17px;color:var(--navy)}
.block h2 .ic{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;font-size:15px;flex:none}
.ic.obj{background:var(--azure-soft)}
.ic.con{background:#eef2f7}
.ic.ex{background:var(--green-soft)}
.ic.lab{background:var(--amber-soft)}
.ic.scn{background:var(--purple-soft)}
.ic.qz{background:var(--azure-soft)}
.ic.src{background:#eef2f7}
.block p{margin:0 0 12px}
.block p:last-child{margin-bottom:0}
.callout{border-radius:11px;padding:14px 16px;font-size:14.5px}
.callout.obj{background:var(--azure-soft);color:#0b3b6f}
.callout.ex{background:var(--green-soft);color:#14512f}
.callout.cp{background:var(--purple-soft);color:#4a2a73;border:1px solid #e3d6f3}
.dims{display:grid;gap:10px;margin:6px 0 4px}
.dim{display:flex;gap:12px;align-items:flex-start;padding:13px 15px;border:1px solid var(--line);border-radius:11px;background:#fbfdff}
.dim .n{flex:none;width:26px;height:26px;border-radius:50%;background:var(--purple);color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px}
.dim b{color:var(--navy)}
.agents{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-top:6px}
.ag{border:1px solid var(--line);border-radius:12px;padding:14px 15px;background:#fbfdff}
.ag .lvl{font-size:10.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:#fff;border-radius:20px;padding:2px 9px;display:inline-block;margin-bottom:8px}
.ag.a1 .lvl{background:#6966db}
.ag.a2 .lvl{background:var(--purple)}
.ag.a3 .lvl{background:var(--navy)}
.ag h4{margin:0 0 5px;color:var(--navy);font-size:14.5px}
.ag p{font-size:13px;color:var(--muted);margin:0}
.channels{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}
.channels .pill{font-size:12px;font-weight:600;color:var(--navy);background:#eef2f7;border-radius:20px;padding:4px 11px}
.steps{margin:0;padding-left:20px}
.steps li{margin-bottom:9px}
.success{margin-top:14px;background:var(--green-soft);border-radius:11px;padding:13px 15px;font-size:14px;color:#14512f}
.success b{color:var(--green)}
.env{display:inline-block;font-size:11.5px;font-weight:700;color:var(--amber);background:var(--amber-soft);border-radius:20px;padding:3px 11px;margin-bottom:12px}
.scn-grid{display:grid;gap:14px}
.scn-card{border:1px solid var(--line);border-radius:12px;padding:16px 18px;background:#fbfdff}
.scn-card .vtag{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.3px;color:#fff;background:var(--purple);border-radius:20px;padding:3px 11px;margin-bottom:10px}
.scn-card .vtag.b{background:var(--azure)}
.scn-card .row{margin-bottom:9px}
.scn-card .row:last-child{margin-bottom:0}
.scn-card .k{font-weight:800;color:var(--navy);font-size:12.5px;text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:2px}
details.reveal{margin-top:4px}
details.reveal summary{cursor:pointer;color:var(--azure);font-weight:700;font-size:13.5px}
.q{border:1px solid var(--line);border-radius:12px;padding:15px 17px;margin-bottom:13px}
.q .qt{font-weight:700;color:var(--navy);margin-bottom:10px}
.opt{display:block;border:1px solid var(--line);border-radius:9px;padding:10px 13px;margin-bottom:7px;cursor:pointer;font-size:14.5px;transition:.12s}
.opt:hover{border-color:var(--azure);background:var(--azure-soft)}
.opt input{margin-right:9px}
.opt.correct{border-color:var(--green);background:var(--green-soft)}
.opt.wrong{border-color:var(--red);background:#fdeceb}
.expl{display:none;margin-top:8px;font-size:13.5px;color:var(--muted);border-top:1px dashed var(--line);padding-top:8px}
.qbtn{background:var(--azure);color:#fff;border:0;border-radius:10px;padding:12px 22px;font-weight:600;font-size:15px;cursor:pointer;transition:background .15s ease,box-shadow .15s ease}
.qbtn:hover{background:#3633a8;box-shadow:0 4px 12px rgba(67,64,210,.25)}
.qresult{display:none;margin-top:15px;border-radius:12px;padding:15px 17px;font-weight:600}
.qresult.pass{background:var(--green-soft);color:#14512f}
.qresult.fail{background:#fdeceb;color:#7a1c16}
.openq{background:#fbfdff;border:1px dashed var(--line);border-radius:11px;padding:14px 16px;margin-top:6px}
.openq textarea{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px;font-family:inherit;font-size:14px;min-height:64px;resize:vertical}
.src{list-style:none;padding:0;margin:0}
.src li{padding:9px 0;border-bottom:1px solid var(--line);font-size:13.5px;color:var(--muted)}
.src li:last-child{border:0}
.src a{font-weight:600}
.src .tagi{font-size:10.5px;font-weight:700;border-radius:20px;padding:2px 8px;margin-left:6px}
.tagi.pub{background:var(--green-soft);color:var(--green)}
.tagi.int{background:var(--amber-soft);color:var(--amber)}
footer{border-top:1px solid var(--line);padding:18px 40px;color:var(--muted);font-size:12px;background:#fff}
.note{font-size:12.5px;color:var(--muted)}
.pillrow{display:flex;flex-wrap:wrap;gap:7px;margin-top:4px}
.pill{font-size:12px;font-weight:600;color:var(--navy);background:#eef2f7;border-radius:20px;padding:4px 11px}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.agents{grid-template-columns:1fr}}
.preview-banner{background:linear-gradient(90deg,#fff7e6,#fdeccb);border:1px solid #f0d9a8;color:#7a531a;
    border-radius:11px;padding:11px 15px;font-size:13.5px;margin:0 0 20px}
.sec.done{color:var(--ink)}
.sec.done::before{content:"\2713 ";color:var(--green);font-weight:800}
/* hierarchy */
  .hier{display:flex;flex-direction:column;align-items:center;margin:6px 0 2px}
.hlvl{width:100%;max-width:600px;border:1px solid var(--line);border-radius:11px;padding:10px 14px;background:#fbfdff;display:flex;gap:12px;align-items:center}
.hlvl .tag{flex:none;font-weight:800;color:#fff;border-radius:8px;padding:4px 11px;font-size:12px;min-width:142px;text-align:center}
.hlvl .d{font-size:13px;color:var(--muted)}
.hlvl .d b{color:var(--ink)}
.l1 .tag{background:var(--navy)}
.l2 .tag{background:#5a57d6}
.l3 .tag{background:var(--azure)}
.l4 .tag{background:var(--green)}
.l5 .tag{background:var(--purple)}
.l6 .tag{background:var(--amber)}
.harr{color:#9fb3c8;font-size:16px;line-height:1;margin:5px 0}
.opbox{margin-top:14px;border:1px dashed #cdbfe6;background:var(--purple-soft);border-radius:11px;padding:13px 15px}
.opbox b{color:var(--purple)}
.opbox .r{font-size:13.5px;margin-top:4px;color:var(--ink)}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.hlvl{flex-direction:column;align-items:flex-start;gap:6px}}
.chs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:6px 0 4px}
.ch{border:1px solid var(--line);border-radius:11px;padding:12px 14px;background:#fbfdff}
.ch b{color:var(--navy)}
.ch .d{font-size:13px;color:var(--muted);margin-top:2px}
.auth{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:6px}
.au{border:1px solid var(--line);border-radius:11px;padding:12px 14px;background:#fff}
.au .h{font-weight:800;color:#fff;border-radius:8px;padding:3px 10px;font-size:12px;display:inline-block;margin-bottom:7px}
.au.pub .h{background:var(--amber)}
.au.st .h{background:var(--azure)}
.au.an .h{background:var(--purple)}
.au .d{font-size:13px;color:var(--muted)}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.chs,.auth{grid-template-columns:1fr}}
aside{position:sticky;top:53px;height:calc(100vh - 53px);overflow:auto;border-right:1px solid var(--line);background:#fff;padding:18px 14px}
.mod>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:9px;font-weight:700;color:var(--navy);font-size:13.5px}
/* architecture diagram */
  .arch{display:flex;flex-direction:column;gap:7px;margin:4px 0 2px}
.pl{border:1px solid var(--line);border-radius:11px;padding:11px 14px;text-align:center}
.pl .t{font-weight:800;color:var(--navy)}
.pl .d{font-size:12.5px;color:var(--muted)}
.pl.consume{background:var(--azure-soft);border-color:#cfe0f3}
.pl.control{background:var(--purple-soft);border-color:#e0d2f1}
.pl.control .t{color:var(--purple)}
.caps{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:7px}
.cap{background:#fbfdff;border:1px solid var(--line);border-radius:10px;padding:10px 11px;text-align:center}
.cap .t{font-weight:700;color:var(--navy);font-size:13px}
.cap .d{font-size:11.5px;color:var(--muted)}
.pl.gov{background:var(--amber-soft);border-color:#ecd9be}
.pl.gov .t{color:var(--amber)}
.pl.found{background:#eef2f7;border-color:#dbe3ec}
.harr{color:#9fb3c8;text-align:center;font-size:14px;line-height:1}
.guar{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:6px}
.g{display:flex;gap:10px;align-items:flex-start;border:1px solid var(--line);border-radius:11px;padding:12px 14px;background:#fbfdff}
.g .k{flex:none;width:26px;height:26px;border-radius:7px;background:var(--green-soft);display:grid;place-items:center;font-size:14px}
.g b{color:var(--navy)}
.g .d{font-size:13px;color:var(--muted)}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.caps,.guar{grid-template-columns:1fr 1fr}}
.preview-banner{background:linear-gradient(90deg,#fff7e6,#fdeccb);border:1px solid #f0d9a8;color:#7a531a;border-radius:11px;padding:11px 15px;font-size:13.5px;margin:0 0 20px}
body{font-family:'Roboto',-apple-system,"Segoe UI",Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55;font-size:15.5px;-webkit-font-smoothing:antialiased}
header{position:sticky;top:0;z-index:40;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:10px 22px}
.brand .mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--azure),var(--purple));color:#fff;display:grid;place-items:center;font-size:13px;font-weight:800}
.sec.test{font-weight:700;color:var(--navy)}
.sec.test::before{content:"\2605 ";color:var(--amber)}
.block h2 .ic{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;font-size:15px;flex:none;background:var(--azure-soft)}
.callout{border-radius:11px;padding:14px 16px;font-size:14.5px;background:var(--azure-soft);color:#0b3b6f}
.q .qt{font-weight:700;color:var(--navy);margin-bottom:10px;display:flex;gap:8px;align-items:baseline}
.q .qtag{flex:none;font-size:10.5px;font-weight:800;color:#fff;background:var(--azure);border-radius:20px;padding:2px 8px}
.barwrap{display:flex;gap:12px;align-items:center;margin:4px 0 16px}
.bar{flex:1;height:10px;background:#eef2f7;border-radius:20px;overflow:hidden}
.bar > i{display:block;height:100%;width:0;background:var(--azure);border-radius:20px;transition:.4s}
.qbtn.ghost{background:#fff;color:var(--navy);border:1px solid var(--line);margin-left:8px}
.qresult{display:none;margin-top:16px;border-radius:12px;padding:16px 18px}
.qresult .score{font-size:20px;font-weight:800;margin-bottom:6px}
.bd{margin-top:10px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 14px;color:var(--ink)}
.bd .row{display:flex;justify-content:space-between;font-size:13.5px;padding:4px 0;border-bottom:1px solid var(--line)}
.bd .row:last-child{border:0}
.bd .ok{color:var(--green);font-weight:700}
.bd .ko{color:var(--red);font-weight:700}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}}
.mod .num.ok{background:var(--green)}
.sec.test.done::before{content:"\2605 ";color:var(--green)}
.ic.up{background:var(--azure-soft)}
.ic.man{background:#eef2f7}
.ic.typ{background:var(--purple-soft)}
.opt2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:6px 0 4px}
.o2{border:1px solid var(--line);border-radius:11px;padding:12px 14px;background:#fbfdff}
.o2 b{color:var(--navy)}
.o2 .d{font-size:13px;color:var(--muted);margin-top:2px}
table.types{width:100%;border-collapse:collapse;margin:6px 0 2px;font-size:13.5px}
table.types th,table.types td{border:1px solid var(--line);padding:9px 11px;text-align:left;vertical-align:top}
table.types th{background:#f1f4f8;color:var(--navy);font-size:12.5px;text-transform:uppercase;letter-spacing:.3px}
table.types td .tg{font-weight:800;color:#fff;border-radius:6px;padding:2px 8px;font-size:12px;display:inline-block}
.tg.ref{background:var(--azure)}
.tg.tar{background:var(--purple)}
.tg.tem{background:var(--green)}
.actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:6px}
.act{border:1px solid var(--line);border-radius:11px;padding:11px 13px;background:#fff}
.act b{color:var(--navy)}
.act .d{font-size:12.5px;color:var(--muted)}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.opt2,.actions{grid-template-columns:1fr}}
.ic.idx{background:var(--azure-soft)}
.ic.tp{background:#eef2f7}
.ic.kg{background:var(--purple-soft)}
.flow{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:8px 0 2px}
.fstep{border:1px solid var(--line);border-radius:10px;padding:8px 12px;background:#fbfdff;font-weight:700;color:var(--navy);font-size:13px}
.farr{color:#9fb3c8;font-weight:800}
.stat{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 2px}
.st{font-size:12.5px;font-weight:700;border-radius:20px;padding:3px 11px}
.st.run{background:var(--azure-soft);color:#0b3b6f}
.st.err{background:#fdeceb;color:#7a1c16}
.st.ok{background:var(--green-soft);color:#14512f}
.statx{display:flex;flex-wrap:wrap;gap:16px;margin:8px 0 2px;align-items:center}
.sbadge{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--ink)}
.sdot{width:18px;height:18px;border-radius:50%;display:inline-grid;place-items:center;color:#fff;font-size:11px;font-weight:800;flex:none}
.sdot.ok{background:var(--green)}
.sdot.err{background:var(--red)}
.spin{width:16px;height:16px;border:2.5px solid #cfe0f3;border-top-color:var(--azure);border-radius:50%;animation:sp .8s linear infinite;flex:none}
@keyframes sp{to{transform:rotate(360deg)}}
.kgstat{display:flex;flex-wrap:wrap;gap:7px;margin-top:8px}
.kgstat .b{font-size:12px;font-weight:700;color:var(--navy);background:#eef2f7;border-radius:8px;padding:4px 10px}
.gx{display:grid;grid-template-columns:1.3fr 1fr;gap:14px;align-items:center;margin-top:6px}
.gx .feat{font-size:13.5px;color:var(--muted)}
.gx .feat b{color:var(--navy)}
.gx svg{width:100%;height:auto;border:1px solid var(--line);border-radius:11px;background:#fbfdff}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.gx{grid-template-columns:1fr}}
.ic.cfg{background:var(--azure-soft)}
.ic.rea{background:var(--purple-soft)}
.ic.par{background:#eef2f7}
.types2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:6px 0 4px}
.ty{border:1px solid var(--line);border-radius:12px;padding:15px 16px;background:#fbfdff}
.ty .tag{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:#fff;border-radius:20px;padding:2px 10px;display:inline-block;margin-bottom:8px}
.ty.base .tag{background:#6966db}
.ty.smart .tag{background:var(--purple)}
.ty h4{margin:0 0 5px;color:var(--navy)}
.ty p{font-size:13.5px;color:var(--muted);margin:0 0 6px}
.ty ul{margin:4px 0 0;padding-left:18px;font-size:13px;color:var(--muted)}
.ty li{margin-bottom:3px}
.rea{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.re{border:1px solid var(--line);border-radius:12px;padding:14px 15px;background:#fbfdff}
.re b{color:var(--navy)}
.re .d{font-size:13px;color:var(--muted)}
.re.fast{border-color:#cfe0f3}
.re.deep{border-color:#e0d2f1}
table.params{width:100%;border-collapse:collapse;margin:6px 0 2px;font-size:13.5px}
table.params th,table.params td{border:1px solid var(--line);padding:9px 11px;text-align:left;vertical-align:top}
table.params th{background:#f1f4f8;color:var(--navy);font-size:12.5px;text-transform:uppercase;letter-spacing:.3px}
table.params td b{color:var(--navy)}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.types2,.rea{grid-template-columns:1fr}}
.ic.stp{background:var(--purple-soft)}
.ic.ag{background:var(--azure-soft)}
.ic.map{background:#eef2f7}
.ic.tst{background:var(--green-soft)}
.fstep.cond{background:var(--amber-soft);border-color:#ecd9be}
table.steps2{width:100%;border-collapse:collapse;margin:6px 0 2px;font-size:13.5px}
table.steps2 th,table.steps2 td{border:1px solid var(--line);padding:9px 11px;text-align:left;vertical-align:top}
table.steps2 th{background:#f1f4f8;color:var(--navy);font-size:12.5px;text-transform:uppercase;letter-spacing:.3px}
table.steps2 td b{color:var(--navy)}
.lv{font-size:10.5px;font-weight:800;border-radius:20px;padding:2px 9px;white-space:nowrap}
.lv.base{background:var(--green-soft);color:var(--green)}
.lv.adv{background:var(--amber-soft);color:var(--amber)}
.mapgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.mp{border:1px solid var(--line);border-radius:11px;padding:13px 15px;background:#fbfdff}
.mp h4{margin:0 0 5px;color:var(--navy);font-size:14.5px}
.mp .d{font-size:13px;color:var(--muted)}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.mapgrid{grid-template-columns:1fr}}
.ic.tr{background:var(--purple-soft)}
.ic.cfg{background:#eef2f7}
.ic.mon{background:var(--green-soft)}
.trig{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin:6px 0 4px}
.tg{border:1px solid var(--line);border-radius:11px;padding:13px 14px;background:#fbfdff}
.tg .h{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:#fff;border-radius:20px;padding:2px 10px;display:inline-block;margin-bottom:7px}
.tg.man .h{background:#6966db}
.tg.sch .h{background:var(--purple)}
.tg.web .h{background:var(--amber)}
.tg .d{font-size:13px;color:var(--muted)}
.tabs{display:grid;gap:10px;margin-top:6px}
.tab{border:1px solid var(--line);border-radius:12px;padding:13px 15px;background:#fbfdff}
.tab h4{margin:0 0 4px;color:var(--navy);font-size:14.5px;display:flex;align-items:center;gap:8px}
.tab h4 .n{width:22px;height:22px;border-radius:6px;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:800}
.tab .d{font-size:13.5px;color:var(--muted)}
.tab .d b{color:var(--ink)}
.mon{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:6px}
.mo{border:1px solid var(--line);border-radius:11px;padding:12px 14px;background:#fbfdff}
.mo b{color:var(--navy)}
.mo .d{font-size:13px;color:var(--muted)}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.trig,.mon{grid-template-columns:1fr}}
.sec.test.active::before{content:"\2605 ";color:#fff}
.tg .d b{color:var(--ink)}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.trig{grid-template-columns:1fr}}
.ic.mcp{background:var(--azure-soft)}
.ic.a2a{background:var(--purple-soft)}
.ic.a365{background:var(--green-soft)}
.tg .dir{font-size:10.5px;font-weight:800;color:var(--muted);display:block;margin-bottom:5px;letter-spacing:.3px}
.ksub{font-weight:800;color:var(--navy);margin:4px 0 6px;font-size:13px;letter-spacing:.2px}
.fields{list-style:none;margin:0 0 4px;padding:0}
.fields li{padding:7px 0;border-bottom:1px dashed var(--line);font-size:13.5px}
.fields li:last-child{border:0}
.fields b{color:var(--navy)}
code{background:#eef2f7;border-radius:5px;padding:1px 5px;font-size:13px}
.ic.ph{background:var(--purple-soft)}
.ic.act{background:var(--amber-soft)}
.ic.sch{background:var(--azure-soft)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:6px 0 4px}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.grid2{grid-template-columns:1fr}}
.ic.api{background:var(--azure-soft)}
.ic.sdk{background:var(--purple-soft)}
.ic.hook{background:var(--amber-soft)}
.callout.warn{background:var(--amber-soft);color:#7a531a;border:1px solid #f0d9a8}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin:6px 0 4px}
.tg code{font-size:12px}
@media(max-width:880px){.wrap{grid-template-columns:1fr}aside{display:none}main{padding:22px 18px}.grid3{grid-template-columns:1fr}}
.ic.met{background:var(--purple-soft)}
.ic.gd{background:var(--azure-soft)}
.ic.chk{background:var(--green-soft)}
.stepf{display:grid;gap:10px;margin:6px 0 2px}
.stp{display:flex;gap:12px;align-items:flex-start;padding:13px 15px;border:1px solid var(--line);border-radius:11px;background:#fbfdff}
.stp .n{flex:none;width:26px;height:26px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px}
.stp b{color:var(--navy)}
.stp .d{font-size:13.5px;color:var(--muted)}
.stp .tagm{font-size:11px;color:var(--muted);font-weight:700}
table.gd{width:100%;border-collapse:collapse;margin:6px 0 2px;font-size:13.5px}
table.gd th,table.gd td{border:1px solid var(--line);padding:9px 11px;text-align:left;vertical-align:top}
table.gd th{background:#f1f4f8;color:var(--navy);font-size:12.5px;text-transform:uppercase;letter-spacing:.3px}
table.gd td b{color:var(--navy)}
.check{list-style:none;margin:4px 0 0;padding:0}
.check li{padding:8px 0;border-bottom:1px dashed var(--line);font-size:14px;display:flex;gap:10px;align-items:flex-start}
.check li:last-child{border:0}
.check input{margin-top:3px}
.openq textarea{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px;font-family:inherit;font-size:14px;min-height:80px;resize:vertical}
.sec.test.active{color:#fff}
.q .qt{font-weight:700;color:var(--navy);margin-bottom:10px;display:flex;gap:9px;align-items:flex-start}
.qtag{flex:none;font-size:10.5px;font-weight:800;color:#fff;background:var(--purple);border-radius:20px;padding:2px 9px;margin-top:2px}
.barwrap{height:8px;background:#eef2f7;border-radius:20px;overflow:hidden;margin:4px 0 16px}
.bar{height:100%;width:0;background:linear-gradient(90deg,var(--brand-from),var(--brand-to));transition:.3s}
.qresult{display:none;margin-top:15px;border-radius:12px;padding:16px 18px}
.qresult.pass{background:var(--green-soft)}
.qresult.fail{background:#fdeceb}
.qresult .score{font-size:18px;font-weight:800;margin-bottom:6px;color:var(--navy)}
.bd{margin-top:12px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:12px 14px}
.bd .row{display:flex;justify-content:space-between;gap:10px;padding:6px 0;border-bottom:1px dashed var(--line);font-size:13.5px}

/* ---- sito assemblato: header link, nav link, dashboard ---- */
a.brand{text-decoration:none}
a.sec{cursor:pointer} a.sec:hover{background:var(--azure-soft)} a.sec.active:hover{background:var(--azure)}
.dash-top{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin:6px 0 4px}
.dash-pct{font-size:34px;font-weight:800;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--brand-to)}
.dash-mod{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin:14px 0;box-shadow:var(--shadow)}
.dash-mod-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.dash-mod-h h3{margin:0;color:var(--navy);font-size:16px}
.dash-secs{display:grid;gap:6px}
.dash-sec{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:#fbfdff;color:var(--ink);text-decoration:none;font-size:14px}
.dash-sec:hover{border-color:var(--azure);background:var(--azure-soft)}
.dash-sec.done{border-color:#cfe8d8;background:var(--green-soft)}
.dash-sec .ds-ic{width:18px;text-align:center;color:var(--green);font-weight:800}
.dash-sec .ds-sc{margin-left:auto;font-size:12px;font-weight:700;color:var(--muted)}
.dash-res{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap} a.pill{text-decoration:none}

.gterm{padding:9px 0;border-bottom:1px dashed var(--line);font-size:14px}
.gterm:last-child{border:0}
.gterm b{color:var(--navy)}
.gterm a{font-weight:700;margin-left:4px;font-size:12px;background:#eef2f7;border-radius:20px;padding:1px 8px;text-decoration:none}
table.sc{width:100%;border-collapse:collapse;font-size:14px;margin-top:6px}
table.sc td{border:1px solid var(--line);padding:8px 10px}
table.sc .sc-modrow td{background:#f1f4f8;font-weight:800;color:var(--navy)}
.sc .ok{color:var(--green);font-weight:700} .sc .ko{color:var(--muted)}
.qbtn.off{opacity:.5;cursor:not-allowed}
.cert{display:none;border:3px solid var(--navy);border-radius:14px;padding:30px;margin-top:16px;text-align:center;background:#fff}
.cert h2{font-size:24px;color:var(--navy);margin:0 0 6px}
.cert .nm{font-size:26px;font-weight:800;color:var(--navy);margin:12px 0}
@media print{#appheader,#nav,aside,#appfooter,.no-print{display:none!important}.wrap{grid-template-columns:1fr}main{padding:0;max-width:none}.cert{display:block!important}}
