@font-face{font-family:'Open Sauce One';src:url('/static/fonts/OpenSauceOne-Regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Open Sauce One';src:url('/static/fonts/OpenSauceOne-Medium.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Open Sauce One';src:url('/static/fonts/OpenSauceOne-SemiBold.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Open Sauce One';src:url('/static/fonts/OpenSauceOne-Bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Ivar Soft';src:url('/static/fonts/IvarSoft-SemiBold.woff2') format('woff2');font-weight:600;font-display:swap}

:root{
  /* Palette EmmeStudio — tinta primaria BLU */
  --blu:#160C30; --blu-d:#1F2763; --blu-3:#396BB2; --blu-4:#508CCA;
  --blu-6:#A5D3EC; --blu-7:#DBE8F6;
  --bg:#f4f6f8; --card:#fff;
  --line:#e2e6ea; --muted:#6b7785; --ok:#1c7a4a; --warn:#b5481f; --err:#b3261e;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Open Sauce One',-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);color:#1a2330;font-size:15px;line-height:1.5}
a{color:var(--blu-3);text-decoration:none}
h1,h2,h3{font-family:'Ivar Soft',Georgia,serif}
main{max-width:1280px;margin:0 auto;padding:22px 28px 60px}

.topbar{background:var(--blu);color:#fff;display:flex;align-items:center;
  justify-content:space-between;padding:10px 20px;flex-wrap:wrap;gap:8px}
.topbar a{color:#fff}
.brand a{display:flex;align-items:center;gap:12px}
.brand .logo{height:26px;width:auto;display:block}
.brand-sub{font-size:13px;opacity:.7;border-left:1px solid rgba(255,255,255,.3);padding-left:12px}
@media(max-width:560px){.brand-sub{display:none}}
.login-logo{display:block;width:200px;max-width:70%;margin:4px auto 14px}
.login-title{text-align:center;font-family:'Ivar Soft',Georgia,serif;font-size:20px;color:var(--blu);margin:0 0 2px}
.login-card{text-align:center}
.login-card label{text-align:left}
.topbar nav{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.topbar .who{opacity:.8;font-size:13px}
.topbar .logout{opacity:.9;border:1px solid rgba(255,255,255,.4);padding:3px 10px;border-radius:6px}
.banner-dry{background:#fff5e6;color:#8a4b00;border-bottom:1px solid #f0d9b0;
  text-align:center;padding:7px;font-size:14px}

.card{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:20px;margin-bottom:18px;box-shadow:0 1px 3px rgba(20,40,70,.04)}
.card.narrow{max-width:640px}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
@media(max-width:820px){.cols{grid-template-columns:1fr}}
/* layout asimmetrico: contenuto largo + form/sidebar stretta (es. Operatori) */
.cols-side{display:grid;grid-template-columns:1fr 320px;gap:18px;align-items:start}
@media(max-width:820px){.cols-side{grid-template-columns:1fr}}
h1,h2{color:var(--blu);margin:.2em 0 .5em}
h2{font-size:19px}
.muted{color:var(--muted)}
.hint{font-size:13px;color:var(--muted);background:#f7f9fb;border:1px solid var(--line);
  border-radius:8px;padding:8px 10px;margin-top:10px}
code{background:#eef2f6;padding:1px 5px;border-radius:4px;font-size:13px}

label{display:block;margin:10px 0;font-size:14px;color:#33414f}
input[type=text],input[type=email],input[type=password],input[type=number],select,textarea{
  width:100%;padding:9px 10px;border:1px solid #cdd5dd;border-radius:8px;font-size:15px;
  margin-top:4px;background:#fff;font-family:inherit}
textarea{resize:vertical}
label.check,label.check input{display:inline;width:auto;margin-right:6px}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row label{flex:1;min-width:160px}

.btn{display:inline-block;border:1px solid #cdd5dd;background:#fff;color:#26333f;
  padding:9px 16px;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600}
.btn:hover{background:#f1f4f7}
.btn-primary{background:var(--blu);border-color:var(--blu);color:#fff}
.btn-primary:hover{background:var(--blu-d)}
.btn-primary:disabled{background:#9fb0c0;border-color:#9fb0c0;cursor:not-allowed}
.btn-warn{border-color:#e0b4a4;color:var(--warn)}
.btn-sm{padding:5px 9px;font-size:13px}
.btn-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:12px}
.link{color:var(--muted);font-size:14px;margin-left:10px}

.steps{display:flex;gap:8px;margin-bottom:16px;font-size:13px}
.step{padding:5px 12px;border-radius:20px;background:#e7ecf1;color:var(--muted)}
.step.on{background:var(--blu);color:#fff}
.step.done{background:#d4e6da;color:var(--ok)}

.seg-group{margin:12px 0}
.seg-group-title{font-size:12px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--muted);margin-bottom:6px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-flex;align-items:center;gap:6px;border:1px solid #cdd5dd;
  border-radius:20px;padding:6px 13px;cursor:pointer;background:#fff;font-size:14px;margin:0}
.chip input{display:none}
.chip span{pointer-events:none}
.chip:has(input:checked){background:var(--blu);border-color:var(--blu);color:#fff}
.chip-special{border-style:dashed}
.chip-special:has(input:checked){background:var(--warn);border-color:var(--warn)}

.preview-card{position:sticky;top:14px}
.preview-box{min-height:120px}
.big-num{font-size:38px;font-weight:800;color:var(--blu);line-height:1}
.sample{max-height:260px;overflow:auto;border:1px solid var(--line);border-radius:8px;margin-top:10px}
.sample table{width:100%;border-collapse:collapse;font-size:13px}
.sample td{padding:4px 8px;border-bottom:1px solid #eef1f4}

.editor-toolbar{display:flex;flex-wrap:wrap;gap:4px;align-items:center;border:1px solid #cdd5dd;
  border-bottom:none;border-radius:8px 8px 0 0;padding:6px 8px;background:#f7f9fb}
.editor-toolbar .tb{border:1px solid #cdd5dd;background:#fff;border-radius:6px;padding:3px 9px;
  cursor:pointer;font-size:14px;min-width:30px}
.editor-toolbar .tb:hover{background:#eef4f9}
.tb-sep{width:1px;height:18px;background:#cdd5dd;margin:0 4px}
.editor{border:1px solid #cdd5dd;border-radius:0 0 8px 8px;min-height:200px;padding:12px;
  background:#fff;font-size:15px;line-height:1.5;overflow:auto}
.editor:focus{outline:none;border-color:var(--blu-4)}
.editor a{color:var(--blu-3)}

.attach{margin:14px 0;border:1px dashed #cdd5dd;border-radius:8px;padding:10px}
.attach-label{display:flex;align-items:center;gap:10px;margin:0;font-size:14px}
.attach-list{list-style:none;padding:0;margin:8px 0 0}
.attach-list li{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:14px;border-bottom:1px solid #eef1f4}
.attach-list .rx{border:1px solid #e0b4a4;background:#fff;color:var(--warn);border-radius:6px;
  padding:1px 8px;cursor:pointer;font-size:12px;margin-left:auto}

.var-bar{margin:8px 0;font-size:13px;color:var(--muted)}
.btn-var{border:1px solid #cdd5dd;background:#eef4f9;color:var(--blu);border-radius:6px;
  padding:3px 9px;cursor:pointer;font-size:13px;margin-left:4px}

.mail-preview{border:1px solid var(--line);border-radius:8px;padding:14px;background:#fff}
.mail-head{font-size:13px;color:var(--muted);margin-bottom:3px}
.mail-body{margin-top:8px}

table.kv{width:100%;border-collapse:collapse;margin:8px 0}
table.kv td{padding:7px 6px;border-bottom:1px solid var(--line);vertical-align:top}
table.kv td:first-child{color:var(--muted);width:160px}

table.msgs{width:100%;border-collapse:collapse;font-size:13.5px;margin-top:10px}
table.msgs th,table.msgs td{padding:6px 8px;border-bottom:1px solid var(--line);text-align:left}
table.msgs th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase}
tr.st-sent td{background:#f3faf5}
tr.st-failed td{background:#fdf2f1}
td.err{color:var(--err);font-size:12px;max-width:240px}
.actions{display:flex;gap:6px;flex-wrap:nowrap;align-items:center;white-space:nowrap}
.actions form{margin:0}
.inline-pw{display:flex;gap:4px}
.inline-pw input{width:104px;margin:0;padding:5px 8px}
td.actions,th:last-child{white-space:nowrap}
.ops td,.ops th{white-space:nowrap}   /* tabella Operatori: nomi/email su una riga */

.tag{font-size:11px;font-weight:700;border-radius:5px;padding:2px 7px;text-transform:uppercase}
.tag-dry{background:#fff0d9;color:#8a4b00}
.tag-real{background:#d4e6da;color:var(--ok)}

.progress{margin:14px 0}
.bar{height:12px;background:#e7ecf1;border-radius:8px;overflow:hidden}
.bar-fill{height:100%;width:0;background:var(--ok);transition:width .5s}
.counters{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px;font-size:14px}
.status-pill{background:#e7ecf1;border-radius:12px;padding:1px 10px;font-size:12px}

.flash{padding:10px 14px;border-radius:8px;margin-bottom:12px;font-size:14px}
.flash-error{background:#fdecea;color:var(--err);border:1px solid #f5c6c2}
.flash-ok{background:#eaf6ef;color:var(--ok);border:1px solid #bfe2cd}

.login-wrap{display:flex;justify-content:center;padding-top:8vh}
.login-card{max-width:360px;width:100%}
.warn-block{margin:10px 0;font-size:13px}
.warn-block summary{cursor:pointer;color:var(--warn)}

.preview-head{display:flex;justify-content:space-between;align-items:center}
.snap-info{font-size:12px;margin:2px 0 8px}
.recon{font-size:13px;margin:4px 0 8px;line-height:1.5}
.preview-head h2{margin:.2em 0}
.recip-search{margin:8px 0;padding:7px 10px}
.excl-line{font-size:13px;color:var(--warn);min-height:0}
.excl-line:empty{display:none}
.sample td .rx{border:1px solid #cdd5dd;background:#fff;border-radius:6px;padding:2px 8px;
  font-size:12px;cursor:pointer;color:var(--warn)}
.sample td .rx:hover{background:#fdf2f1}
tr.excluded td:not(:last-child){opacity:.4;text-decoration:line-through}
tr.excluded .rx{color:var(--ok);text-decoration:none}
.nl-box{margin:12px 0;padding:10px;border:1px dashed var(--blu-4);border-radius:8px;background:#f7fafd}
.nl-box textarea{background:#eef2f6}
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:end;margin-bottom:8px}
.filters label{margin:0;font-size:13px}
.filters input,.filters select{padding:6px 8px}
.filters .grow{flex:1;min-width:160px}

/* --- M-SUITE: home/launcher, subnav, matrice --- */
.home{max-width:1080px;margin:2rem auto;padding:0 1rem}
.home-title{font-family:"Ivar Soft",Georgia,serif;font-size:2.2rem;margin-bottom:1.5rem}
.launcher-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}
.launcher-card{display:flex;flex-direction:column;align-items:center;gap:.6rem;
  padding:1.5rem 1rem;border:1px solid #e3e3ea;border-radius:16px;text-decoration:none;
  color:inherit;background:#fff;transition:box-shadow .15s,transform .15s}
.launcher-card:hover{box-shadow:0 6px 22px rgba(22,12,48,.12);transform:translateY(-2px)}
.launcher-icon{width:48px;height:48px}
.launcher-label{font-weight:600}
.launcher-ext{font-size:.78rem;color:#7a7a88}
.subnav{display:flex;gap:1rem;align-items:center;padding:.5rem 1rem;background:#f4f4f8;
  border-bottom:1px solid #e3e3ea}
.subnav-title{font-weight:600;margin-right:.5rem}
.subnav a{text-decoration:none;color:#160c30}
.matrix-row{display:flex;gap:1.2rem;align-items:center;
  padding:.5rem 0;border-bottom:1px solid #eee}
.matrix-row strong{flex:0 0 280px}           /* email a larghezza fissa → colonne incolonnate */
.matrix-row label{flex:0 0 200px}            /* ogni sezione stessa larghezza su tutte le righe */
.matrix-row button{margin-left:auto}         /* Salva allineato a destra */

/* --- launcher: descrizione, riquadri "in arrivo" --- */
.home-sub{margin:-.8rem 0 1.6rem;max-width:620px}
.launcher-card{position:relative;text-align:center}
.launcher-desc{font-size:.82rem;color:#6b6b78;line-height:1.25}
.launcher-soon{opacity:.5;filter:grayscale(.7);cursor:not-allowed;
  background:#fafafb;pointer-events:none}
.launcher-badge{position:absolute;top:.6rem;right:.6rem;font-size:.66rem;
  font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  background:#e3e3ea;color:#555;padding:.12rem .45rem;border-radius:999px}

/* --- M-SUITE: sezione FE --- */
.page-head{display:flex;justify-content:space-between;align-items:center;margin:1rem 0}
.page-head .actions{display:flex;gap:.5rem;align-items:center}
.page-head h1,.page-head h2{margin:0}

.fe-search input{width:100%;padding:8px 12px;font-size:14px;border:1px solid #cdd5dd;border-radius:8px;margin-bottom:1rem}

table.tbl{width:100%;border-collapse:collapse;font-size:14px}
table.tbl th,table.tbl td{padding:8px 10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}
table.tbl th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em}
table.tbl tr:hover td{background:#fafbfc}
table.tbl .ar,table.tbl th.ar{text-align:right}
table.tbl code{font-size:12px;background:#f4f4f8;padding:1px 5px;border-radius:4px}

.badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;text-transform:uppercase;letter-spacing:.02em}
.badge.green{background:#d4e6da;color:var(--ok)}
.badge.orange{background:#fff0d9;color:#8a4b00}
.badge.blue{background:#dbe7f4;color:var(--blu)}
.badge.gray{background:#e7ecf1;color:#6b6b78}

.subnav.fe-tabs{margin-top:0;border-top:1px solid #e3e3ea}
.subnav.fe-tabs a.active{font-weight:600;border-bottom:2px solid var(--blu);padding-bottom:.4rem}

.form-grid{margin-top:1rem}
.form-grid .row{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.form-grid .col-1{flex:0 0 calc(8.333% - 11px)}
.form-grid .col-2{flex:0 0 calc(16.666% - 10px)}
.form-grid .col-3{flex:0 0 calc(25% - 10px)}
.form-grid .col-4{flex:0 0 calc(33.333% - 8px)}
.form-grid .col-5{flex:0 0 calc(41.666% - 8px)}
.form-grid .col-6{flex:0 0 calc(50% - 6px)}
.form-grid .col-7{flex:0 0 calc(58.333% - 6px)}
.form-grid .col-8{flex:0 0 calc(66.666% - 4px)}
.form-grid .col-12{flex:0 0 100%}
.form-grid label{display:block;font-size:13px;color:var(--muted);margin-bottom:4px}
.form-grid input,.form-grid select,.form-grid textarea{width:100%;padding:7px 10px;border:1px solid #cdd5dd;border-radius:6px;font-size:14px}
.form-grid .inline-check{display:flex;align-items:flex-end}
.form-grid .inline-check label{display:flex;gap:8px;align-items:center}
.form-grid .inline-check input{width:auto}
.form-grid .row-actions{display:flex;flex-direction:column;justify-content:flex-end}
/* riga fattura: griglia stabile su una sola riga, × di rimozione inline */
.form-grid .riga-row{display:grid;grid-template-columns:1fr 110px 130px 90px 44px;
  gap:12px;align-items:end;flex-wrap:nowrap}
.form-grid .riga-row > div{flex:none}
.form-grid .riga-row .remove-riga{width:100%}
.form-grid .req{color:var(--err)}
.form-grid .warn{color:#8a4b00;font-size:12px}

.dropzone{border:2px dashed #cdd5dd;border-radius:10px;padding:2.5rem 1.5rem;text-align:center;
  background:#fafbfc;cursor:pointer;transition:background .15s,border-color .15s}
.dropzone.dz-over{background:#eef4f9;border-color:var(--blu-4)}
.dropzone p{margin:.3rem 0}
.dropzone .small{font-size:12px}

.empty{text-align:center;padding:3rem 1rem}
.empty .btn{margin-top:1rem}

.card .kv{display:grid;grid-template-columns:160px 1fr;gap:6px 14px;font-size:14px;margin:0}
.card .kv dt{color:var(--muted)}
.card .kv dd{margin:0}

.card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:1rem 1.2rem;margin-bottom:1rem}
