/* ============================================================
   EditTotem 2.0 — stili
   ============================================================ */
:root{
  --ink:#14161c; --muted:#6b7280; --line:#e5e7eb; --bg:#eef0f3;
  --panel:#fff; --accent:#c8102e;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink)}
.hidden{display:none !important}
.muted{color:var(--muted);font-size:13px;line-height:1.5}

/* ---------------- topbar ---------------- */
.topbar{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid var(--line);padding:12px 22px;position:sticky;top:0;z-index:30}
.brandmark{display:flex;align-items:center;gap:11px}
.brandmark .logo{width:36px;height:36px;border-radius:9px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:19px}
.bm-name{font-weight:800;font-size:17px;letter-spacing:-.02em}
.bm-sub{font-size:12px;color:var(--muted)}
.tabs{display:flex;gap:6px}
.tab{border:none;background:#f3f4f6;color:#374151;padding:9px 18px;border-radius:9px;font-weight:600;font-size:14px;cursor:pointer;font-family:inherit}
.tab.active{background:var(--ink);color:#fff}

/* ---------------- viste ---------------- */
.view{display:none;padding:22px;max-width:1200px;margin:0 auto}
.view.active{display:block}

/* ---------------- toolbar articoli ---------------- */
.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.toolbar select{border:1px solid var(--line);border-radius:9px;padding:9px 12px;font-size:14px;font-family:inherit;background:#fff}
.status{font-size:13px;color:var(--muted)}

/* ---------------- griglia articoli ---------------- */
.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.article-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:.15s}
.article-card:hover{box-shadow:0 10px 30px rgba(15,23,42,.10)}
.ac-thumb{height:150px;background:#dde1e7 center/cover no-repeat;position:relative}
.ac-thumb .ac-noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#9aa3af;font-size:13px}
.ac-body{padding:13px 14px;display:flex;flex-direction:column;gap:8px;flex:1}
.ac-source{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--accent)}
.ac-title{font-size:15px;font-weight:600;line-height:1.3}
.ac-date{font-size:12px;color:var(--muted)}
.ac-actions{margin-top:auto;display:flex;gap:8px}
.empty{text-align:center;color:var(--muted);padding:60px 20px;font-size:15px;line-height:1.6}

/* ---------------- impostazioni ---------------- */
.settings-wrap{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px}
.card h2{font-size:16px;margin-bottom:6px;display:flex;align-items:center;gap:10px}
.badge{font-size:11px;font-weight:700;background:#f3f4f6;color:#6b7280;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}
.badge.on{background:#dcfce7;color:#166534}
.feed-list{display:flex;flex-direction:column;gap:8px;margin:12px 0}
.feed-item{display:flex;align-items:center;gap:10px;background:#fafbfc;border:1px solid var(--line);border-radius:10px;padding:10px 12px}
.feed-item .fi-name{font-weight:600;font-size:14px}
.feed-item .fi-url{font-size:12px;color:var(--muted);word-break:break-all}
.feed-item .fi-main{flex:1;min-width:0}
.feed-item button{background:#fee2e2;color:#b91c1c;border:none;border-radius:8px;width:30px;height:30px;cursor:pointer;font-size:16px}
.feed-add{display:flex;gap:8px;flex-wrap:wrap}
.feed-add input{flex:1;min-width:160px;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-size:14px;font-family:inherit}

.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:#374151}
.field input[type=text],.field input[type=password],.field input[type=datetime-local],.field textarea,.field select{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px;font-family:inherit;background:#fff;resize:vertical}
.field input[type=color]{width:100%;height:42px;border:1px solid var(--line);border-radius:10px;background:#fff;padding:4px}
.field .hint{font-size:11px;color:var(--muted);margin-top:5px;line-height:1.4}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row .field{flex:1;min-width:180px}
.settings-actions{display:flex;align-items:center;gap:14px}

/* ---------------- pulsanti ---------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;border-radius:10px;padding:10px 15px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:.15s}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:#000}
.btn-ghost{background:#f3f4f6;color:#374151}
.btn-ghost:hover{background:#e5e7eb}
.btn-block{width:100%;margin-top:6px}
.btn-sm{padding:7px 11px;font-size:13px}

/* ---------------- editor overlay ---------------- */
.editor-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:50;display:flex;align-items:center;justify-content:center;padding:24px}
.editor-panel{background:#fff;border-radius:18px;width:min(1040px,96vw);max-height:94vh;overflow:hidden;position:relative}
.editor-close{position:absolute;top:14px;right:16px;border:none;background:#f3f4f6;width:34px;height:34px;border-radius:50%;font-size:20px;cursor:pointer;z-index:5}
.editor-cols{display:flex;max-height:94vh}
.editor-controls{width:420px;min-width:420px;padding:26px;overflow-y:auto}
.editor-controls h3{font-size:18px;margin-bottom:18px}
.editor-preview{flex:1;background:#eef0f3;display:flex;align-items:center;justify-content:center;padding:24px}

.ai-msg{font-size:12px;color:var(--muted);margin-top:8px;min-height:16px;line-height:1.4}
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.toggle-row label:first-child{margin-bottom:0}
.img-controls{display:flex;gap:8px}

.layout-pick{display:flex;gap:8px}
.layout-pick button{flex:1;border:2px solid var(--line);background:#fff;border-radius:10px;padding:10px 6px;cursor:pointer;font-size:12px;font-weight:600;font-family:inherit}
.layout-pick button.active{border-color:var(--accent);box-shadow:0 0 0 3px rgba(200,16,46,.12)}

/* switch */
.switch{position:relative;display:inline-block;width:46px;height:26px}
.switch input{display:none}
.slider{position:absolute;inset:0;background:#cbd5e1;border-radius:999px;transition:.2s;cursor:pointer}
.slider:before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked + .slider{background:var(--accent)}
.switch input:checked + .slider:before{transform:translateX(20px)}

/* anteprima */
.preview-frame{border-radius:16px;overflow:hidden;box-shadow:0 18px 50px rgba(15,23,42,.25);background:#fff}
.totem-scale{transform-origin:top left}
#exportHost{position:fixed;left:-99999px;top:0;width:1080px;height:1920px}

/* ============================================================
   IL TOTEM 1080x1920 e i layout da feed
   ============================================================ */
.totem{width:1080px;height:1920px;position:relative;overflow:hidden;background:#fff;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
.t-photo{background:#2d333d center/cover no-repeat;position:relative}
.t-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);font-size:40px;font-weight:600;letter-spacing:.04em}
.t-kicker{display:inline-block;color:#fff;font-weight:800;font-size:36px;letter-spacing:.06em;text-transform:uppercase;padding:14px 28px;border-radius:6px;align-self:flex-start}
.t-headline{font-size:92px;line-height:1.05;font-weight:800;letter-spacing:-.02em;color:#14161c}
.t-headline.light{color:#fff}
.t-source{font-size:30px;color:#6b7280;font-weight:600}
.t-source.light{color:rgba(255,255,255,.85)}

/* blocco QR */
.t-qr{display:flex;align-items:center;gap:18px}
.t-qr .qr-slot{width:170px;height:170px;background:#fff;border-radius:14px;padding:12px;display:flex;align-items:center;justify-content:center}
.t-qr .qr-slot img,.t-qr .qr-slot canvas{width:100% !important;height:100% !important;display:block}
.t-qr-label{font-size:26px;font-weight:700;line-height:1.2;text-align:left}

/* Layout Copertina */
.tCover{justify-content:flex-start}
.tCover-grad{position:absolute;left:0;right:0;bottom:0;height:1100px;background:linear-gradient(to top,rgba(8,10,14,.94) 18%,rgba(8,10,14,.55) 55%,rgba(8,10,14,0) 100%)}
.tCover-top{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;padding:54px 60px;color:#fff;font-size:32px;font-weight:700;z-index:2}
.tCover-brand{letter-spacing:.04em}
.tCover-bottom{position:absolute;left:0;right:0;bottom:0;padding:60px;display:flex;flex-direction:column;gap:34px;z-index:2}
.tCover-foot{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:10px}

/* Layout Editoriale */
.tEdit-head{display:flex;justify-content:space-between;align-items:center;padding:0 60px;height:120px;color:#fff;font-size:34px;font-weight:700;letter-spacing:.04em}
.tEdit-body{flex:1;padding:60px;display:flex;flex-direction:column;gap:34px}
.tEdit-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:24px}

/* Layout Vetrina */
.tShow-top{padding:70px 60px;display:flex;flex-direction:column;gap:28px}
.tShow-foot{margin-top:auto;padding:0 60px 60px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.tShow-meta{display:flex;flex-direction:column;gap:8px}
.tShow-brand{font-size:38px;font-weight:800}

/* opzioni titolo generate dall'AI */
.title-options{display:flex;flex-direction:column;gap:7px;margin-top:8px}
.title-option{text-align:left;border:1px solid var(--line);background:#fff;border-radius:10px;padding:10px 12px;cursor:pointer;font-size:13px;line-height:1.35;font-family:inherit;transition:.12s}
.title-option:hover{border-color:var(--accent);background:#fff7f8}
.title-option.sel{border-color:var(--accent);box-shadow:0 0 0 3px rgba(200,16,46,.12)}

/* pannello di pubblicazione OptiSigns */
.publish-panel{border:1px solid var(--line);border-radius:12px;padding:14px;margin-top:8px;background:#f8fafc}
.publish-panel .field{margin-bottom:10px}
.publish-panel .row{gap:10px}

/* gestore Pubblicazioni */
.pub-manager{display:flex;flex-direction:column;gap:10px;max-width:760px;margin:0 auto}
.pub-row{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.pub-row .pub-num{font-weight:800;color:var(--accent);min-width:34px;text-align:center;font-size:16px}
.pub-row img{width:54px;height:96px;object-fit:cover;border-radius:6px;background:#eee;border:1px solid var(--line)}
.pub-row .pub-name{flex:1;font-size:14px;word-break:break-all}
.pub-row .pub-actions{display:flex;gap:6px}
.pub-row .pub-actions button{border:1px solid var(--line);background:#f3f4f6;border-radius:8px;width:36px;height:36px;cursor:pointer;font-size:16px}
.pub-row .pub-actions button:disabled{opacity:.35;cursor:default}
.pub-row .pub-actions .del{background:#fee2e2;color:#b91c1c;border-color:#fecaca}

/* ===== Flusso Contenuti ===== */
.content-wrap{display:flex;gap:20px;align-items:flex-start}
.content-controls{width:440px;min-width:440px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;max-height:calc(100vh - 130px);overflow-y:auto}
.content-controls h3{font-size:17px;margin-bottom:14px}
.src-buttons{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.src-buttons .btn{flex:1;min-width:120px}
.content-preview{flex:0 0 560px;align-self:flex-start;position:sticky;top:80px;display:flex;justify-content:center;align-items:flex-start;background:#eef0f3;border-radius:14px;padding:24px;height:88vh;max-height:900px}

/* poster */
.cPoster{align-items:center;justify-content:center}
.cPoster-img{position:absolute;inset:0;background-position:center;background-repeat:no-repeat}
.cPoster-title{position:absolute;left:0;right:0;bottom:0;padding:46px 60px;color:#fff;font-size:56px;font-weight:800;line-height:1.15;letter-spacing:-.01em}

/* annuncio */
.cAnn{display:flex;flex-direction:column}
.cAnn-top{height:120px;display:flex;align-items:center;justify-content:space-between;padding:0 60px;color:#fff;font-size:34px;font-weight:700;letter-spacing:.04em}
.cAnn-body{flex:1;padding:70px 60px;display:flex;flex-direction:column;gap:36px}
.cAnn-title{font-size:96px;line-height:1.05;font-weight:800;letter-spacing:-.02em;color:#14161c}
.cAnn-text{font-size:44px;line-height:1
/* storico programmazioni */
.sch-history{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:6px}
.sch-h-row{display:flex;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-size:13px}
/* campi programmazione */
.sched-box{border:1px dashed var(--line);border-radius:10px;padding:10px 12px;margin-top:8px;background:#fafbfc}
.sched-box .row{gap:8px}

/* kit di marca */
.totem{font-family:var(--totem-font,) -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
.t-logo{height:64px;max-width:360px;width:auto;object-fit:contain;display:block}
.tEdit-head .t-logo,.tShow-foot .t-logo{height:56px}

/* ================= Fase 5 — Accessi, bozze, approvazione ================= */
.user-chip { display:flex; align-items:center; gap:10px; margin-left:auto; padding-left:14px; }
.user-chip .uc-name { font-size:13px; color:#cbd5e1; white-space:nowrap; }
.user-chip .uc-role { font-size:11px; color:#94a3b8; background:rgba(255,255,255,.08); padding:2px 7px; border-radius:20px; margin-left:4px; }
.user-chip .uc-logout { background:rgba(255,255,255,.1); color:#fff; border:none; padding:6px 12px; border-radius:8px; font-size:12px; font-weight:600; cursor:pointer; }
.user-chip .uc-logout:hover { background:rgba(255,255,255,.2); }

.appr-badge { display:inline-block; min-width:18px; height:18px; line-height:18px; text-align:center; background:#c8102e; color:#fff; border-radius:20px; font-size:11px; font-weight:700; margin-left:6px; padding:0 5px; }

.login-gate { position:fixed; inset:0; z-index:500; background:rgba(15,18,24,.96); display:flex; align-items:center; justify-content:center; padding:20px; }
.login-gate .lg-card { background:#fff; border-radius:18px; padding:34px 30px; width:100%; max-width:380px; box-shadow:0 30px 80px rgba(0,0,0,.5); }
.login-gate .lg-logo { width:50px; height:50px; border-radius:12px; background:#c8102e; color:#fff; font-weight:800; font-size:26px; display:flex; align-items:center; justify-content:center; margin:0 auto 14px; }
.login-gate h2 { text-align:center; margin:0 0 4px; }
.login-gate .muted { text-align:center; margin:0 0 18px; }
.login-gate .field { margin-bottom:12px; }
.login-gate .lg-msg { text-align:center; margin-top:10px; min-height:18px; font-size:13px; }

.appr-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:16px; margin-top:8px; }
.appr-card { border:1px solid var(--line); border-radius:14px; overflow:hidden; background:#fff; display:flex; flex-direction:column; }
.appr-card img { width:100%; aspect-ratio:9/16; object-fit:cover; background:#0f1218; display:block; }
.appr-body { padding:12px; display:flex; flex-direction:column; gap:6px; }
.appr-name { font-weight:700; font-size:14px; word-break:break-word; }
.appr-meta { font-size:12px; }
.appr-note { font-size:13px; font-style:italic; color:#475569; background:#f1f5f9; padding:6px 9px; border-radius:8px; }
.appr-actions { display:flex; flex-wrap:wrap; gap:8px; margin-top:4px; }
.btn-sm { padding:6px 11px; font-size:12px; }

/* ================= Fase 6 — Immagini AI/Stock ================= */
.aim-overlay { position:fixed; inset:0; z-index:520; background:rgba(15,18,24,.7); display:flex; align-items:center; justify-content:center; padding:20px; }
.aim-panel { background:#fff; border-radius:16px; width:100%; max-width:720px; max-height:88vh; overflow:auto; position:relative; box-shadow:0 30px 80px rgba(0,0,0,.45); }
.aim-close { position:absolute; right:12px; top:8px; background:none; border:none; font-size:28px; line-height:1; cursor:pointer; color:#64748b; }
.aim-tabs { display:flex; gap:6px; padding:18px 20px 0; }
.aim-tab { background:#f1f5f9; border:none; padding:9px 16px; border-radius:10px 10px 0 0; font-weight:600; cursor:pointer; color:#475569; }
.aim-tab.active { background:#fff; color:#0f1218; box-shadow:0 -2px 0 var(--accent) inset; }
.aim-body { padding:18px 20px 22px; border-top:1px solid var(--line); }
.aim-search { display:flex; gap:8px; margin-bottom:12px; }
.aim-search input { flex:1; }
.aim-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:10px; }
.aim-thumb { position:relative; border:none; padding:0; cursor:pointer; border-radius:10px; overflow:hidden; aspect-ratio:3/4; background:#0f1218; }
.aim-thumb img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .2s; }
.aim-thumb:hover img { transform:scale(1.05); }
.aim-cred { position:absolute; left:0; right:0; bottom:0; font-size:10px; color:#fff; background:linear-gradient(transparent,rgba(0,0,0,.7)); padding:10px 6px 4px; text-align:left; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.aim-msg { margin-top:10px; font-size:13px; min-height:16px; }
.aim-genprev { margin-top:14px; }
.aim-genprev img { width:100%; max-width:300px; border-radius:12px; display:block; margin:0 auto 10px; }

/* Azioni video (scarica / pubblica) */
.vid-actions { margin:8px 0 4px; padding:12px; border:1px solid var(--line); border-radius:12px; background:#f8fafc; }
.vid-actions .field { margin-bottom:10px; }

/* ================= Multi-totem: pubblica su molti + gestione ================= */
.mp-overlay { position:fixed; inset:0; z-index:530; background:rgba(15,18,24,.7); display:flex; align-items:center; justify-content:center; padding:20px; }
.mp-panel { background:#fff; border-radius:16px; width:100%; max-width:640px; max-height:88vh; overflow:auto; position:relative; padding:24px; box-shadow:0 30px 80px rgba(0,0,0,.45); }
.mp-groups { display:flex; flex-wrap:wrap; gap:6px; align-items:center; }
.mp-glabel { font-size:13px; font-weight:600; color:#374151; margin-right:4px; }
.mp-chip { border:1px solid var(--line); background:#f8fafc; border-radius:20px; padding:5px 12px; font-size:13px; cursor:pointer; font-weight:600; color:#334155; }
.mp-chip span { opacity:.6; font-weight:400; }
.mp-chip.on { background:var(--accent,#c8102e); color:#fff; border-color:transparent; }
.mp-toolbar { display:flex; justify-content:space-between; align-items:center; font-size:13px; margin:6px 0; }
.mp-list { border:1px solid var(--line); border-radius:10px; max-height:34vh; overflow:auto; }
.mp-item { display:flex; align-items:center; gap:8px; padding:8px 10px; border-bottom:1px solid #f1f5f9; cursor:pointer; font-size:14px; }
.mp-item:last-child { border-bottom:none; }
.mp-name { font-weight:600; }
.mp-tags { margin-left:auto; display:flex; gap:4px; flex-wrap:wrap; }
.mp-tags i { font-style:normal; font-size:11px; background:#eef2ff; color:#3730a3; padding:1px 7px; border-radius:20px; }
.mp-actions { display:flex; align-items:center; gap:12px; margin-top:14px; }
.mp-progress { margin-top:14px; }
.mp-bar { height:10px; background:#e5e7eb; border-radius:20px; overflow:hidden; margin-bottom:6px; }
.mp-bar > div { height:100%; width:0; background:#0a7d3b; transition:width .3s; }
.tm-list { display:flex; flex-direction:column; gap:6px; }
.tm-row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; padding:8px; border:1px solid var(--line); border-radius:10px; }
.tm-info { min-width:130px; }
.tm-tags { flex:1; min-width:160px; }
.tm-discover { border:1px solid var(--line); border-radius:10px; padding:10px; margin-bottom:10px; }
