:root {
  --bg: #f5f3f0; --bg2: #ede9e4; --card: #ffffff; --border: #e2ddd8; --border2: #cfc9c2;
  --blue: #4f46e5; --blue-light: rgba(79, 70, 229, 0.1); --blue-mid: #6366f1;
  --text: #0f172a; --text-muted: #475569; --text-dim: #94a3b8;
  --green: #10b981; --green-bg: #ecfdf5; --red: #ef4444; --red-bg: #fef2f2;
  --yellow: #f59e0b; --yellow-bg: #fffbeb;
  --sans: 'Outfit', -apple-system, sans-serif; --mono: 'JetBrains Mono', monospace;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
  --shadow: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
  --glass-bg: rgba(255, 255, 255, 0.9); --glass-border: rgba(255, 255, 255, 0.4);
  --spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  /* AF Personal Brand */
  --af-gradient: linear-gradient(135deg, #4f46e5 0%, #06b6d4 100%);
  --af-highlight: #00e5ff;
}

    /* DARK MODE RE-IMAGINED */
    body.dark {
  --bg:  #0A0A0F;
  --bg2: #13121a;
  --card: rgba(255, 255, 255, 0.04);
  --border: rgba(255, 255, 255, 0.08);
  --border2: rgba(255, 255, 255, 0.12);
  --text: #e8e4df; --text-muted: #9991a4; --text-dim: #5c5670;
  --blue-light: rgba(99, 102, 241, 0.15);
  --green-bg: rgba(16, 185, 129, 0.12);
  --red-bg: rgba(239, 68, 68, 0.12);
  --yellow-bg: rgba(245, 158, 11, 0.12);
  --shadow-sm: 0 4px 16px rgba(0,0,0,0.5);
  --shadow: 0 16px 40px rgba(0,0,0,0.7);
  --glass-bg: rgba(255, 255, 255, 0.03);
  --glass-border: rgba(255, 255, 255, 0.07);
  --blue: #6366f1; --blue-mid: #4f46e5;
}
    .btn-dark-toggle{background:transparent;border:1px solid var(--border);border-radius:8px;padding:5px 9px;font-size:0.9rem;cursor:pointer;transition:all 0.2s;color:var(--text-muted);line-height:1;}
    .btn-dark-toggle:hover{background:var(--bg2);border-color:var(--blue);}
    .hist-search{width:100%;border:1px solid var(--border);border-radius:7px;padding:6px 10px;font-family:var(--sans);font-size:0.77rem;background:var(--card);color:var(--text);outline:none;margin-bottom:4px;flex-shrink:0;}
    .hist-search:focus{border-color:var(--blue);}
    *{box-sizing:border-box;margin:0;padding:0;}
    body{font-family:var(--sans);background:var(--bg);color:var(--text);height:100vh;display:flex;flex-direction:column;overflow:hidden;letter-spacing:-0.02em;}

    /* BACKGROUND GLOW (AF STYLE) */
    body.dark { position: relative; }
    body.dark::before {
      content: '';
      position: fixed; inset: 0; z-index: 0; pointer-events: none;
      background:
        radial-gradient(circle at 50% -20%, rgba(99,102,241,0.2), transparent 70%),
        radial-gradient(circle at 0% 100%, rgba(6,182,212,0.1), transparent 50%),
        #0A0A0F;
    }
    body.dark > * { position: relative; z-index: 1; }

    /* HEADER */
    header{
      background: rgba(255, 255, 255, 0.05);
      backdrop-filter: blur(28px) saturate(200%);
      -webkit-backdrop-filter: blur(28px) saturate(200%);
      border-bottom: 1px solid var(--glass-border);
      padding: 0 20px; height: 58px;
      display: flex; align-items: center; gap: 14px;
      flex-shrink: 0;
      box-shadow: 0 2px 20px rgba(0,0,0,0.1), 0 1px 0 rgba(255,255,255,0.06) inset;
      position: relative; z-index: 100;
    }
    body.dark header {
      background: rgba(6, 9, 15, 0.65);
      border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }
    .header-logo { display:flex; align-items:center; gap:10px; }
    .logo-box-mini {
      width: 34px; height: 34px;
      background: linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%);
      border-radius: 9px;
      display: flex; align-items: center; justify-content: center;
      font-family: var(--mono); font-size: 11px; font-weight: 600;
      color: white; flex-shrink: 0;
      box-shadow: 0 4px 12px rgba(79, 70, 229, 0.3), 0 0 0 1px rgba(255,255,255,0.1) inset;
      position: relative; overflow: hidden;
    }
    .logo-box-mini::before {
      content:''; position:absolute; inset:0;
      background: linear-gradient(135deg, rgba(255,255,255,0.2) 0%, transparent 60%);
    }
    .header-title{font-size:1rem;font-weight:600;}
    .header-sub{font-size:0.72rem;color:var(--text-muted);font-family:var(--mono);}
    .header-spacer{flex:1;}
    .status-pills{display:flex;align-items:center;gap:6px;}
    .pill{display:flex;align-items:center;gap:6px;background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:0.72rem;font-family:var(--mono);color:var(--text-muted);white-space:nowrap;}
    .pill-dot{width:7px;height:7px;border-radius:50%;background:var(--text-dim);flex-shrink:0;transition:background 0.3s;}
    .pill-dot.green{background:var(--green);box-shadow:0 0 5px rgba(38,162,105,0.4);}
    .pill-dot.red{background:var(--red);}
    .pill-dot.yellow{background:var(--yellow);animation:blink 1s infinite;}
    /* ── AURORA BACKGROUND ────────────────────────────────────── */
    .aurora-wrap {
      position: fixed; inset: 0; z-index: 0; pointer-events: none;
      display: none; /* Show only in dark mode or via JS */
    }
    body.dark .aurora-wrap { display: block; }

    .aurora {
      position: absolute; inset: 0;
      background: radial-gradient(ellipse 120% 80% at 50% -10%, #1e1b4b 0%, #0A0A0F 60%);
      overflow: hidden;
    }
    .orb {
      position: absolute; border-radius: 50%; filter: blur(140px);
      animation: drift 25s ease-in-out infinite alternate;
      will-change: transform; opacity: 0.18;
    }
    .orb-1 { width: 800px; height: 800px; background: radial-gradient(circle, var(--blue) 0%, transparent 70%); top: -300px; left: -200px; }
    .orb-2 { width: 700px; height: 700px; background: radial-gradient(circle, var(--blue-mid) 0%, transparent 70%); bottom: -250px; right: -200px; animation-delay: -7s; }
    .orb-3 { width: 600px; height: 600px; background: radial-gradient(circle, var(--blue) 0%, transparent 70%); top: 30%; left: 50%; animation-delay: -12s; }
    .orb-4 { width: 350px; height: 350px; background: radial-gradient(circle, rgba(6,182,212,0.2) 0%, transparent 70%); top: 20%; left: 20%; animation-delay: -15s; }

    @keyframes drift { from { transform: translate(0,0) scale(1); } to { transform: translate(60px, 80px) scale(1.1); } }

    .noise {
      position: absolute; inset: 0; z-index: 1;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
      opacity: 0.04; pointer-events: none;
      filter: contrast(150%) brightness(100%);
    }
    body.dark .noise { opacity: 0.05; }


    .pill.ok{background:var(--green-bg);border-color:rgba(38,162,105,0.25);color:#1a7a4a;}
    .pill.err{background:var(--red-bg);border-color:rgba(192,28,40,0.25);color:var(--red);}
    .pill-divider{width:1px;height:18px;background:var(--border2);margin:0 2px;}
    .pill-label{font-weight:500;}
    .btn-settings{background:var(--blue);border:none;border-radius:8px;padding:7px 14px;color:white;font-family:var(--sans);font-size:0.8rem;font-weight:500;cursor:pointer;transition:background 0.2s;display:flex;align-items:center;gap:6px;margin-left:4px;box-shadow:0 2px 6px rgba(79,70,229,0.25);}
    .btn-settings:hover{background:var(--blue-mid);}

    /* COMPANY SELECTOR */
    .company-selector{display:none;align-items:center;gap:6px;margin-right:4px;}
    .company-selector.visible{display:flex;}
    .company-select{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:5px 28px 5px 10px;font-family:var(--mono);font-size:0.75rem;color:var(--text);cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%235a6a85'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:border-color 0.2s;}
    .company-select:hover{border-color:var(--blue);}

    /* DEEP LINK SAP */
    td.sap-link{color:var(--blue);cursor:pointer;font-weight:500;white-space:nowrap;transition:background 0.15s;}
    td.sap-link:hover{text-decoration:underline;background:var(--blue-light);}
    .sap-arrow{display:inline-block;width:14px;height:14px;background:#f0ab00;clip-path:polygon(0 25%,60% 25%,60% 0%,100% 50%,60% 100%,60% 75%,0 75%);margin-right:5px;vertical-align:middle;flex-shrink:0;}
    /* LAYOUT */
    .main{display:flex;flex:1;overflow:hidden;position:relative;}

    /* SIDEBAR */
    aside{
      background: var(--glass-bg);
      backdrop-filter: blur(24px) saturate(180%);
      -webkit-backdrop-filter: blur(24px) saturate(180%);
      border-right: 1px solid var(--glass-border);
      display: flex; flex-direction: column;
      transition: width 0.3s cubic-bezier(.4,0,.2,1), box-shadow 0.3s;
      width: 260px; overflow: hidden; flex-shrink: 0;
      box-shadow: 4px 0 24px rgba(0,0,0,0.08);
    }
    body.dark aside {
      background: rgba(8, 13, 26, 0.65);
      border-right: 1px solid rgba(255, 255, 255, 0.08);
    }
    aside.collapsed{width:0;box-shadow:none;border-right:none;}
    aside.sidebar-float{position:absolute;top:0;left:0;height:100%;width:260px;z-index:200;box-shadow:6px 0 28px rgba(0,0,0,0.14);border-right:1px solid var(--border);overflow:hidden;}
    .sidebar-peek-trigger{position:absolute;left:0;top:0;width:10px;height:100%;z-index:250;display:none;cursor:e-resize;}
    .sidebar-peek-trigger::after{content:'›';position:absolute;top:50%;left:0;transform:translateY(-50%);color:var(--blue);font-size:18px;opacity:0;transition:opacity 0.2s;line-height:1;}
    .sidebar-peek-trigger:hover::after{opacity:0.5;}
    .sidebar-fab{position:fixed;left:14px;z-index:300;width:36px;height:36px;border-radius:50%;background:var(--card);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px rgba(0,0,0,0.12);color:var(--text-muted);font-size:16px;transition:opacity 0.2s,transform 0.2s,background 0.2s,color 0.2s;padding:0;}
    .sidebar-fab:hover{background:var(--blue-light);color:var(--blue);border-color:rgba(79,70,229,0.3);}
    .sidebar-fab.hidden{opacity:0;pointer-events:none;transform:scale(0.7);}
    .sidebar-header{height:40px;display:flex;align-items:center;padding:0 10px;border-bottom:1px solid var(--border);flex-shrink:0;gap:8px;}
    .sidebar-label{font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dim);white-space:nowrap;flex:1;overflow:hidden;}
    .btn-collapse{background:transparent;border:none;cursor:pointer;color:var(--text-dim);padding:4px;border-radius:4px;display:flex;align-items:center;transition:color 0.2s,background 0.2s;flex-shrink:0;font-size:13px;}
    .btn-collapse:hover{color:var(--blue);background:var(--blue-light);}

    /* Sidebar: nuova sessione + search */
    .sidebar-new-wrap{padding:10px 10px 6px;flex-shrink:0;}
    .sidebar-search-wrap{padding:0 10px 6px;flex-shrink:0;}
    .sidebar-history-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 8px;}
    .sidebar-empty-msg{color:var(--text-dim);font-size:0.77rem;padding:10px 6px;}

    /* Sidebar: preferiti footer */
    .sidebar-fav-section{border-top:1px solid var(--border);flex-shrink:0;max-height:220px;display:flex;flex-direction:column;}
    .sidebar-fav-hd{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:0.75rem;font-weight:600;color:var(--text-muted);background:none;border:none;cursor:pointer;width:100%;transition:background 0.15s;}
    .sidebar-fav-hd:hover{background:var(--bg2);}
    .sidebar-fav-list{overflow-y:auto;padding:4px 8px 8px;display:flex;flex-direction:column;gap:2px;}
    .sidebar-fav-list.hidden{display:none;}
    .sidebar-fav-item{display:flex;align-items:center;gap:4px;width:100%;}
    .sidebar-fav-btn{flex:1;background:transparent;border:1px solid transparent;border-radius:7px;padding:6px 8px;cursor:pointer;text-align:left;color:var(--text-muted);font-family:var(--sans);font-size:0.76rem;line-height:1.3;transition:all 0.15s;display:flex;align-items:center;gap:7px;overflow:hidden;}
    .sidebar-fav-btn:hover{background:var(--blue-light);border-color:rgba(79,70,229,0.15);color:var(--blue);}
    .sidebar-fav-icon{font-size:12px;flex-shrink:0;}
    .sidebar-fav-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
    .sidebar-fav-del{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:3px 5px;border-radius:4px;font-size:12px;flex-shrink:0;opacity:0;transition:opacity 0.15s;}
    .sidebar-fav-item:hover .sidebar-fav-del{opacity:1;}
    .sidebar-fav-del:hover{color:var(--red);background:var(--red-bg);}

    /* Quick btn (usati ancora nei dropdown slash) */
    .quick-btn{background:transparent;border:1px solid transparent;border-radius:7px;padding:7px 8px;cursor:pointer;text-align:left;color:var(--text-muted);font-family:var(--sans);font-size:0.79rem;line-height:1.4;transition:all 0.15s;display:flex;align-items:center;gap:8px;white-space:nowrap;overflow:hidden;width:100%;}
    .quick-btn:hover{background:var(--blue-light);border-color:rgba(79,70,229,0.15);color:var(--blue);}
    .quick-btn .icon{flex-shrink:0;font-size:13px;}
    .quick-btn .label{overflow:hidden;text-overflow:ellipsis;}

    /* Empty state chat */
    .empty-state-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:40px 24px;text-align:center;animation:fadeUp 0.3s ease;}
    .empty-state-greeting{font-size:1.3rem;font-weight:600;color:var(--text);margin-bottom:8px;}
    .empty-state-sub{font-size:0.85rem;color:var(--text-muted);margin-bottom:28px;}
    .empty-state-grid{display:flex;flex-wrap:nowrap;gap:20px;padding: 12px;max-width:min(960px,calc(100% - 48px));width:fit-content;text-align:left;overflow-x:auto;padding-bottom:12px;scrollbar-width:auto;}
    .empty-state-grid::-webkit-scrollbar{height:8px;}
    .empty-state-grid::-webkit-scrollbar-track{background:var(--border);border-radius:4px;}
    .empty-state-grid::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px;}
    .es-card{
      background: var(--glass-bg);
      backdrop-filter: blur(24px) saturate(180%);
      -webkit-backdrop-filter: blur(24px) saturate(180%);
      border: 1px solid var(--glass-border);
      border-radius: 20px; padding: 20px;
      display: flex; flex-direction: column; gap: 8px;
      box-shadow: 0 8px 32px rgba(0,0,0,0.1), 0 0 0 1px rgba(255,255,255,0.05) inset;
      transition: all 0.3s var(--spring);
      min-width: 220px; max-width: 240px; flex-shrink: 0;
      cursor: pointer; position: relative; overflow: visible;
      box-shadow: none !important;
    }
    .es-card::after {
      content: ''; position: absolute; inset: 0;
      background: linear-gradient(135deg, rgba(255,255,255,0.05) 0%, transparent 100%);
      pointer-events: none;
      box-shadow: none !important;
    }
    .es-card:hover{
      transform: translateY(-2px) scale(1.02);
      box-shadow: 0 20px 40px rgba(0,0,0,0.2), 0 0 0 1px rgba(79,70,229,0.3) inset;
      border-color: rgba(79,70,229,0.4);
      box-shadow: none !important;
    }
    .es-card-hd{
      font-size:0.9rem; font-weight:700; color:var(--text);
      margin-bottom:6px; padding-bottom:10px;
      border-bottom:1px solid var(--glass-border);
      display: flex; align-items: center; gap: 8px;
    }
    .es-cmds-list{display:flex;flex-direction:column;gap:2px;height:148px;overflow-y:auto;scrollbar-width:thin;}
    .es-cmds-list::-webkit-scrollbar{width:3px;}
    .es-cmds-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}
    .es-cmd{background:none;border:none;text-align:left;padding:6px 8px;border-radius:7px;cursor:pointer;font-size:0.79rem;color:var(--text-muted);font-family:var(--sans);transition:all 0.15s;width:100%;}
    .es-cmd:hover{background:var(--blue-light);color:var(--blue);}

    /* Slash command dropdown */
    .slash-dropdown{position:fixed;background:var(--card);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);max-height:260px;overflow-y:auto;z-index:500;animation:fadeUp 0.12s ease;}
    .slash-dd-inner{padding:6px;display:flex;flex-direction:column;gap:1px;}
    .slash-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:7px;cursor:pointer;font-size:0.82rem;color:var(--text-muted);transition:all 0.12s;border:none;background:none;text-align:left;width:100%;font-family:var(--sans);}
    .slash-item:hover,.slash-item.slash-active{background:var(--blue-light);color:var(--blue);}
    .slash-item .si-icon{font-size:14px;flex-shrink:0;}
    .slash-item .si-label{font-weight:500;flex:1;}
    .slash-item .si-sub{font-size:0.7rem;color:var(--text-dim);font-family:var(--mono);}

    /* Quick filter chips */
    .quick-filters-bar{padding:6px 16px 0;overflow:hidden;flex-shrink:0;}
    .quick-filters-scroll{display:flex;gap:5px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;}
    .quick-filters-scroll::-webkit-scrollbar{display:none;}
    .qf-chip{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;background:var(--bg);border:1px solid var(--border2);border-radius:20px;padding:3px 10px;font-size:0.72rem;color:var(--text-muted);cursor:pointer;white-space:nowrap;font-family:var(--sans);transition:all 0.15s;}
    .qf-chip:hover{background:var(--blue-light);border-color:rgba(79,70,229,0.3);color:var(--blue);}
    /* Bookmark chips bar */
    .fav-chips-bar{padding:8px 16px 0;overflow:hidden;flex-shrink:0;}
    .fav-chips-scroll{display:flex;gap:6px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none;}
    .fav-chips-scroll::-webkit-scrollbar{display:none;}
    .fav-chip{display:inline-flex;align-items:center;gap:5px;flex-shrink:0;background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:0.74rem;color:var(--text-muted);cursor:pointer;white-space:nowrap;font-family:var(--sans);transition:all 0.15s;max-width:200px;overflow:hidden;}
    .fav-chip:hover{background:var(--blue-light);border-color:var(--blue);color:var(--blue);}
    .fav-chip-star{font-size:10px;flex-shrink:0;}
    .fav-chip-label{overflow:hidden;text-overflow:ellipsis;}

    /* Toolbar dropdown */
    .tb-dropdown{position:relative;display:inline-flex;}
    .tb-dd-menu{position:absolute;bottom:calc(100% + 6px);left:0;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:4px;min-width:150px;box-shadow:var(--shadow);z-index:100;display:none;flex-direction:column;gap:2px;animation:fadeUp 0.12s ease;}
    .tb-dd-menu.open{display:flex;}
    .tb-dd-menu button{background:none;border:none;text-align:left;padding:6px 10px;border-radius:5px;cursor:pointer;font-size:0.78rem;color:var(--text-muted);font-family:var(--sans);transition:all 0.12s;display:flex;align-items:center;gap:7px;white-space:nowrap;}
    .tb-dd-menu button:hover{background:var(--blue-light);color:var(--blue);}

    /* History autocomplete dropdown */
    .hist-autocomplete{position:fixed;background:var(--card);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);max-height:200px;overflow-y:auto;z-index:490;animation:fadeUp 0.12s ease;min-width:280px;}
    .hist-ac-inner{padding:6px;display:flex;flex-direction:column;gap:1px;}
    .hist-ac-item{display:block;width:100%;text-align:left;padding:8px 10px;background:none;border:none;cursor:pointer;font-size:0.81rem;color:var(--text-muted);font-family:var(--sans);border-radius:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
    .hist-ac-item:hover,.hist-ac-item.hist-ac-active{background:var(--blue-light);color:var(--blue);}
    .hist-ac-label{padding:4px 10px 2px;font-size:0.7rem;color:var(--text-dim);letter-spacing:.04em;text-transform:uppercase;}

    /* Global search Ctrl+K */
    .global-search-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:3000;display:none;align-items:flex-start;justify-content:center;padding-top:80px;}
    .global-search-overlay.open{display:flex;}
    .gs-box{background:var(--card);border-radius:14px;width:640px;max-width:calc(100vw - 32px);box-shadow:0 24px 60px rgba(0,0,0,0.22);overflow:hidden;}
    .gs-input-row{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);}
    .gs-icon{font-size:1.1rem;color:var(--text-dim);}
    .gs-inp{flex:1;border:none;background:none;font-size:1rem;color:var(--text);outline:none;font-family:var(--sans);}
    .gs-close{background:none;border:1px solid var(--border);border-radius:6px;padding:3px 8px;cursor:pointer;font-size:0.75rem;color:var(--text-dim);}
    .gs-results{max-height:420px;overflow-y:auto;}
    .gs-result-item{padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.12s;}
    .gs-result-item:hover{background:var(--bg2);}
    .gs-result-title{font-weight:600;font-size:0.85rem;color:var(--blue);margin-bottom:3px;}
    .gs-result-snippet{font-size:0.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
    .gs-empty{padding:28px;text-align:center;color:var(--text-dim);font-size:0.85rem;}

    /* Template parametri modal */
    .tp-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:3000;display:none;align-items:center;justify-content:center;}
    .tp-overlay.open{display:flex;}
    .tp-box{background:var(--card);border-radius:14px;width:420px;max-width:calc(100vw - 32px);padding:24px;box-shadow:0 24px 60px rgba(0,0,0,0.22);}

    /* Confronta aziende */
    .btn-compare{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:0.8rem;color:var(--text-muted);cursor:pointer;font-family:var(--sans);transition:all 0.15s;flex-shrink:0;display:none;}
    .btn-compare.visible{display:inline-flex;align-items:center;gap:5px;}
    .btn-compare:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);}
    .compare-tabs{display:flex;gap:4px;margin-bottom:10px;flex-wrap:wrap;}
    .compare-tab{padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg2);cursor:pointer;font-size:0.78rem;color:var(--text-muted);font-family:var(--sans);transition:all 0.12s;}
    .compare-tab.active{background:var(--blue-light);border-color:var(--blue);color:var(--blue);font-weight:600;}
    .compare-error{background:var(--yellow-bg);border:1px solid rgba(229,165,10,0.3);border-radius:6px;padding:7px 12px;font-size:0.78rem;color:#92400e;margin:4px 0;}

    .share-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:3000;display:none;align-items:center;justify-content:center;}
    .share-overlay.open{display:flex;}
    .share-box{background:var(--card);border-radius:14px;width:480px;max-width:calc(100vw - 32px);padding:24px;box-shadow:0 24px 60px rgba(0,0,0,0.22);}
    .share-link-row{display:flex;gap:8px;align-items:center;margin-top:12px;}
    .share-link-inp{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:0.8rem;font-family:var(--mono);background:var(--bg2);color:var(--text);outline:none;}

    /* Input area premium */
    .input-area{
      padding: 0;
      background: var(--glass-bg);
      backdrop-filter: blur(20px) saturate(160%);
      -webkit-backdrop-filter: blur(20px) saturate(160%);
      border-top: 1px solid var(--glass-border);
      display: flex; flex-direction: column; gap: 0;
      box-shadow: 0 -1px 0 rgba(255,255,255,0.05) inset, 0 -4px 20px rgba(0,0,0,0.08);
    }
    body.dark .input-area {
      background: rgba(6,9,15,0.70);
      border-top: 1px solid rgba(255,255,255,0.07);
      box-shadow: 0 -1px 0 rgba(255,255,255,0.04) inset, 0 -8px 32px rgba(0,0,0,0.4);
    }
    .input-row{display:flex;gap:10px;align-items:flex-end;padding:10px 24px 14px;}

    /* Textarea premium */
    #questionInput {
      flex: 1; min-height: 44px; max-height: 200px;
      background: rgba(255,255,255,0.05);
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 11px 16px;
      color: var(--text);
      font-family: var(--sans);
      font-size: 0.92rem;
      resize: none; outline: none;
      transition: all 0.25s var(--spring);
      line-height: 1.5;
    }
    body.dark #questionInput {
      background: rgba(255,255,255,0.03);
      border-color: rgba(255,255,255,0.08);
    }
    #questionInput:focus {
      border-color: var(--blue);
      background: rgba(79, 70, 229, 0.05);
      box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.15);
    }

    #sendBtn {
      background: linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%);
      color: white; border: none;
      border-radius: 22px;
      padding: 0 20px; height: 44px;
      font-family: var(--sans); font-size: 0.88rem; font-weight: 600;
      cursor: pointer;
      display: flex; align-items: center; justify-content: center; gap: 8px;
      transition: all 0.2s var(--spring);
      box-shadow: 0 8px 16px rgba(79, 70, 229, 0.25), 0 0 0 1px rgba(255,255,255,0.1) inset;
    }
    #sendBtn:hover { transform: translateY(-2px); box-shadow: 0 12px 24px rgba(79, 70, 229, 0.35); }
    #sendBtn:active { transform: translateY(0) scale(0.96); }

    .btn-history-inline {
      width: 44px; height: 44px; border-radius: 12px;
      background: var(--bg2); border: 1px solid var(--border);
      color: var(--text-muted); cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      transition: all 0.2s;
    }
    .btn-history-inline:hover { background: var(--blue-light); color: var(--blue); border-color: var(--blue); }

    /* Card sessione storico */
    .hist-item{background:transparent;border:1px solid transparent;border-radius:8px;
      padding:8px 10px;cursor:pointer;transition:all 0.15s;display:flex;
      align-items:flex-start;gap:8px;width:100%;text-align:left;position:relative;}
    .hist-item:hover{background:var(--blue-light);border-color:rgba(79,70,229,0.15);}
    .hist-item.active-session{background:var(--blue-light);border-color:rgba(79,70,229,0.3);}
    .hist-icon{font-size:14px;flex-shrink:0;margin-top:1px;}
    .hist-info{flex:1;min-width:0;}
    .hist-title{font-size:0.78rem;font-weight:500;color:var(--text);
      white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;}
    .hist-meta{font-size:0.66rem;color:var(--text-dim);margin-top:2px;font-family:var(--mono);}
    .hist-del{position:absolute;right:6px;top:50%;transform:translateY(-50%);
      background:transparent;border:none;color:var(--text-dim);font-size:13px;
      cursor:pointer;padding:3px 5px;border-radius:4px;opacity:0;transition:opacity 0.15s;}
    .hist-item:hover .hist-del{opacity:1;}
    .hist-del:hover{color:var(--red);background:var(--red-bg);}

    /* Sessione corrente badge */
    .hist-current-badge{font-size:0.62rem;background:var(--blue);color:white;
      border-radius:8px;padding:1px 6px;margin-left:4px;vertical-align:middle;}

    /* Nuova sessione btn */
    .btn-new-session{display:flex;align-items:center;gap:6px;width:100%;
      background:var(--blue);color:white;border:none;border-radius:8px;
      padding:8px 12px;font-size:0.8rem;font-weight:500;font-family:var(--sans);
      cursor:pointer;transition:background 0.2s;margin-bottom:6px;flex-shrink:0;}
    .btn-new-session:hover{background:var(--blue-mid);}

    /* Separatore data nello storico */
    .hist-date-sep{font-size:0.62rem;font-weight:600;text-transform:uppercase;
      letter-spacing:0.8px;color:var(--text-dim);padding:8px 6px 3px;
      border-top:1px solid var(--border);margin-top:4px;}
    .hist-date-sep:first-child{border-top:none;margin-top:0;}

    /* Banner "sessione caricata" nella chat */
    .session-banner{background:var(--blue-light);border:1px solid rgba(79,70,229,0.2);
      border-radius:10px;padding:10px 14px;font-size:0.82rem;color:var(--blue);
      display:flex;align-items:center;gap:8px;align-self:center;max-width:400px;}
    .session-banner .sb-icon{font-size:16px;}

    /* CHAT */
    .chat-container{
      flex:1; display:flex; flex-direction:column; overflow:hidden;
      background: transparent;
    }
    #messages{
      flex:1; overflow-y:auto; padding:24px 28px;
      display:flex; flex-direction:column; gap:20px;
      scroll-behavior:smooth;
    }
    #messages::-webkit-scrollbar{width:4px;}
    #messages::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px;}
    .msg{display:flex;flex-direction:column;max-width:88%;animation:spring-up 0.5s var(--spring);}
    @keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
    .msg.user{align-self:flex-end;align-items:flex-end;}
    .msg.bot{align-self:flex-start;align-items:flex-start;}
    .bubble{
      padding: 12px 16px;
      border-radius: 16px;
      line-height: 1.7;
      font-size: 0.875rem;
      word-break: break-word;
      overflow-wrap: break-word;
    }
    .msg.user .bubble{
      background: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%);
      color: white;
      border-bottom-right-radius: 4px;
      box-shadow: 0 4px 16px rgba(79,70,229,0.35), 0 0 0 1px rgba(255,255,255,0.08) inset;
    }
    .msg.bot .bubble{
      background: var(--glass-bg);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
      border: 1px solid var(--glass-border);
      color: var(--text);
      border-bottom-left-radius: 4px;
      box-shadow: var(--shadow-sm), 0 0 0 1px rgba(255,255,255,0.03) inset;
    }
    body.dark .msg.bot .bubble {
      background: rgba(14, 24, 44, 0.75);
      border-color: rgba(255,255,255,0.09);
    }
    .bubble.text-answer{background:rgba(79,70,229,0.07);border:1px solid rgba(79,70,229,0.25);color:var(--text);border-bottom-left-radius:3px;display:flex;gap:10px;align-items:flex-start;}
    .bubble.text-answer .ta-icon{font-size:1.15rem;flex-shrink:0;margin-top:1px;}
    .bubble.text-answer .ta-body{flex:1;}
    .bubble.text-answer .ta-badge{display:inline-block;background:var(--blue-light);color:var(--blue);border:1px solid transparent;border-radius:4px;padding:1px 6px;font-size:0.68rem;font-weight:600;letter-spacing:0.5px;margin-bottom:5px;font-family:var(--mono);}
    .bubble.text-answer .ta-badge.ta-badge-empty{background:transparent;color:var(--blue);border-color:var(--blue);opacity:0.85;}
    .bubble.text-answer .ta-body p,.bubble.text-answer .ta-body{display:flex;flex-direction:column;gap:2px;}
    .msg-time{font-size:0.67rem;color:var(--text-dim);margin-top:4px;padding:0 4px;font-family:var(--mono);}
    .doc-sources-bar{margin-top:6px;padding:5px 10px;background:rgba(79,70,229,0.06);border:1px solid rgba(79,70,229,0.2);border-radius:8px;font-size:0.72rem;color:var(--text-dim);display:flex;flex-wrap:wrap;gap:6px;align-items:center;}
    .doc-sources-bar .ds-label{font-weight:600;color:var(--blue);white-space:nowrap;}
    .doc-sources-bar .ds-chip{background:rgba(79,70,229,0.1);color:rgb(99,102,241);border-radius:4px;padding:1px 7px;font-family:var(--mono);font-size:0.7rem;}
    /* REPLAY BUTTON */
    .msg.user .bubble-row{display:flex;align-items:center;gap:6px;}
    .msg-replay{opacity:0;transition:opacity 0.15s;background:var(--card);border:1px solid var(--border);border-radius:6px;padding:3px 7px;font-size:0.78rem;cursor:pointer;color:var(--text-muted);flex-shrink:0;line-height:1;}
    .msg.user:hover .msg-replay{opacity:1;}
    .msg-replay:hover{background:var(--blue-light);border-color:rgba(79,70,229,0.3);color:var(--blue);}

    /* VOICE MESSAGES — stile WhatsApp */
    .voice-bubble{padding:10px 14px 8px;min-width:200px;max-width:100%;}
    .voice-player-row{display:flex;align-items:center;gap:10px;}
    .voice-play-btn{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,0.22);border:none;color:#fff;font-size:0.75rem;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background 0.15s;line-height:1;}
    .voice-play-btn:hover,.voice-play-btn.playing{background:rgba(255,255,255,0.38);}
    .voice-waveform{flex:1;height:26px;display:flex;align-items:center;gap:2px;overflow:hidden;}
    .vw-bar{flex:1;background:rgba(255,255,255,0.45);border-radius:2px;min-height:3px;transition:background 0.1s;}
    .voice-dur{font-size:0.7rem;font-family:var(--mono);color:rgba(255,255,255,0.75);flex-shrink:0;min-width:26px;text-align:right;}
    .voice-transcript{margin-top:5px;font-size:0.77rem;color:rgba(255,255,255,0.72);font-style:italic;line-height:1.4;word-break:break-word;}
    .vt-loading{opacity:0.55;}

    /* MIC BUTTON */
    .btn-mic{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:0;width:42px;height:42px;display:flex;align-items:center;justify-content:center;font-size:1.05rem;cursor:pointer;flex-shrink:0;transition:all 0.15s;color:var(--text-muted);}
    .btn-mic:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);}
    .btn-mic.recording{background:var(--red-bg);border-color:var(--red);color:var(--red);animation:mic-ring 1s ease-in-out infinite;}
    @keyframes mic-ring{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,0.4)}50%{box-shadow:0 0 0 6px rgba(239,68,68,0)}}

    /* RECORDING INDICATOR BAR */
    .voice-rec-indicator{display:none;align-items:center;gap:8px;padding:5px 24px;background:var(--red-bg);border-top:1px solid rgba(239,68,68,0.25);font-size:0.78rem;color:var(--red);font-weight:600;}
    .voice-rec-indicator.active{display:flex;}
    .voice-rec-dot{width:8px;height:8px;border-radius:50%;background:var(--red);flex-shrink:0;animation:rec-blink 1s ease-in-out infinite;}
    @keyframes rec-blink{0%,100%{opacity:1}50%{opacity:0.25}}
    .voice-rec-timer{font-family:var(--mono);font-size:0.8rem;}
    .voice-rec-hint{font-size:0.72rem;opacity:0.65;font-weight:400;}

    /* STREAMING BUBBLE */
    .stream-bubble{
      background:var(--card);border:1px solid var(--border);
      border-radius:12px;border-bottom-left-radius:3px;
      padding:11px 15px;font-size:0.875rem;line-height:1.65;
      box-shadow:var(--shadow-sm);min-width:180px;
    }
    .stream-label{
      font-size:0.68rem;font-family:var(--mono);color:var(--text-dim);
      margin-bottom:6px;display:flex;align-items:center;gap:6px;
    }
    .stream-label .pulse{
      width:6px;height:6px;border-radius:50%;background:var(--blue);
      animation:pulseDot 1s infinite;flex-shrink:0;
    }
    @keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(0.7)}}
    .stream-sql{
      font-family:var(--mono);font-size:0.78rem;color:#1c5e9e;
      background:var(--blue-light);border-radius:6px;padding:8px 10px;
      white-space:pre-wrap;word-break:break-all;min-height:24px;
      border-left:3px solid var(--blue);
    }
    .stream-status{
      font-size:0.72rem;color:var(--text-dim);font-family:var(--mono);
      margin-top:6px;display:flex;align-items:center;gap:5px;
    }
    .spinner{
      width:12px;height:12px;border:2px solid var(--border2);
      border-top-color:var(--blue);border-radius:50%;
      animation:spin 0.7s linear infinite;flex-shrink:0;
    }
    @keyframes spin{to{transform:rotate(360deg)}}

    /* THINKING DOTS — onda per utenti non-admin durante streaming */
    .thinking-dots{
      display:flex;gap:10px;align-items:center;justify-content:center;
      padding:14px 8px 8px;
    }
    .thinking-dots span{
      width:12px;height:12px;border-radius:50%;
      background:var(--text);flex-shrink:0;
      animation:dotWave 1.1s ease-in-out infinite;
      opacity:0.35;
    }
    .thinking-dots span:nth-child(1){animation-delay:0s}
    .thinking-dots span:nth-child(2){animation-delay:0.18s}
    .thinking-dots span:nth-child(3){animation-delay:0.36s}
    .thinking-dots span:nth-child(4){animation-delay:0.54s}
    .thinking-dots span:nth-child(5){animation-delay:0.72s}
    @keyframes dotWave{
      0%,60%,100%{transform:translateY(0) scale(1);opacity:0.35}
      30%{transform:translateY(-9px) scale(1.2);opacity:1}
    }

    /* RESULT BLOCK */
    .result-block{display:flex;flex-direction:column;gap:0;}
    .result-note{font-size:0.78rem;color:var(--text-dim);padding:5px 10px;background:var(--bg);border-left:3px solid var(--accent);border-radius:4px;margin-bottom:6px;}
    /* BP CARD */
    .bp-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;}
    .bp-card-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
    .bp-avatar{width:44px;height:44px;border-radius:50%;background:var(--blue);color:white;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;flex-shrink:0;}
    .bp-card-title{flex:1;min-width:0;}
    .bp-name{font-size:1rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
    .bp-meta{font-size:0.72rem;color:var(--text-muted);margin-top:2px;}
    .bp-sap-btn{background:none;border:1px solid var(--border);border-radius:7px;padding:5px 10px;cursor:pointer;font-size:0.75rem;color:var(--text-muted);display:flex;align-items:center;gap:4px;white-space:nowrap;transition:all 0.15s;flex-shrink:0;}
    .bp-sap-btn:hover{background:var(--blue-light);color:var(--blue);border-color:rgba(79,70,229,0.3);}
    .bp-kpi-row{display:flex;gap:16px;margin-bottom:12px;}
    .bp-kpi{background:var(--bg2);border-radius:8px;padding:8px 14px;min-width:120px;}
    .bp-kpi-val{font-size:1rem;font-weight:700;color:var(--text);font-family:var(--mono);}
    .bp-kpi-val.red{color:var(--red);}
    .bp-kpi-lbl{font-size:0.68rem;color:var(--text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:.6px;}
    .bp-details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px 16px;}
    .bp-detail{display:flex;align-items:baseline;gap:6px;font-size:0.78rem;color:var(--text);overflow:hidden;}
    .bp-dl{color:var(--text-dim);flex-shrink:0;width:16px;text-align:center;}
    .bp-extras-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:4px 16px;margin-top:8px;}
    .bp-extra-row{display:grid;grid-template-columns:140px 1fr;gap:6px;font-size:0.76rem;align-items:baseline;padding:2px 0;}
    .bp-extra-lbl{color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
    .bp-extra-val{color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
    .bp-extras-toggle{font-size:0.74rem;color:var(--blue);cursor:pointer;border:none;background:none;padding:4px 0;margin-top:6px;font-family:var(--sans);}
    .bp-extras-toggle:hover{text-decoration:underline;}
    .bp-extras-wrap{display:none;border-top:1px solid var(--border);padding-top:8px;margin-top:4px;}
    .view-switcher{display:flex;gap:4px;margin-bottom:8px;}
    .view-btn{background:white;border:1px solid var(--border2);border-radius:7px;padding:4px 12px;font-size:0.75rem;font-family:var(--sans);color:var(--text-muted);cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:5px;}
    .view-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);}
    .view-btn.active{background:var(--blue);color:white;border-color:var(--blue);}

    /* TABLE */
    .result-wrap{overflow-x:auto;border-radius:8px 8px 0 0;border:1px solid var(--border);border-bottom:none;max-height:300px;overflow-y:auto;box-shadow:var(--shadow-sm);}
    table{border-collapse:collapse;width:100%;font-size:0.8rem;min-width:280px;}
    th{background:var(--bg2);color:var(--blue);padding:0;border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0;z-index:2;overflow:hidden;}
    .th-inner{display:flex;flex-direction:column;}
    .th-resize{position:absolute;right:0;top:0;width:5px;height:100%;cursor:col-resize;z-index:3;user-select:none;border-right:2px solid transparent;transition:border-color 0.15s;}
    .th-resize:hover,.th-resize.th-resize-active{border-right-color:var(--blue-mid);}
    .th-label{padding:8px 12px 4px;font-family:var(--mono);font-size:0.7rem;font-weight:500;display:flex;align-items:center;gap:4px;cursor:pointer;user-select:none;}
    .th-label:hover{color:var(--blue-mid);}
    .sort-icon{font-size:10px;opacity:0.5;}
    .th-filter{padding:0 6px 5px;}
    .th-filter input{width:100%;border:1px solid var(--border2);border-radius:4px;padding:3px 6px;font-size:0.68rem;font-family:var(--mono);background:white;color:var(--text);outline:none;transition:border-color 0.15s;}
    .th-filter input:focus{border-color:var(--blue);}
    .th-filter input::placeholder{color:var(--text-dim);}
    td{padding:7px 12px;border-bottom:1px solid var(--border);color:var(--text);white-space:nowrap;}
    td.numeric{text-align:right;font-family:var(--mono);font-size:0.79rem;}
    td.currency{text-align:right;font-family:var(--mono);font-size:0.79rem;color:#1a5fb4;font-weight:500;}
    tr:last-child td{border-bottom:none;}
    tr:nth-child(even) td{background:rgba(244,246,249,0.5);}
    tr:hover td{background:var(--blue-light);}
    tr.filtered-out{display:none;}

    /* CHART */
    .chart-wrap{background:white;border:1px solid var(--border);border-radius:8px 8px 0 0;padding:20px;display:none;min-height:320px;position:relative;}
    .chart-wrap.active{display:flex;align-items:center;justify-content:center;}
    .chart-wrap canvas{max-height:300px;}

    /* Utility: Branding Alex Faccini */
    .gradient-text {
      background: var(--gradient-text);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }
    .highlight {
      color: var(--highlight);
      font-weight: 600;
    }
    .background-glow {
      position: fixed; inset: 0; z-index: -1;
      background: radial-gradient(circle at 50% -20%, rgba(79,70,229,0.15), transparent 70%),
                  radial-gradient(circle at 0% 100%, rgba(6,182,212,0.1), transparent 50%);
      pointer-events: none;
    }

    /* TOOLBAR */
    .result-toolbar{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:0 0 8px 8px;flex-wrap:wrap;}
    .row-badge{display:inline-flex;align-items:center;gap:4px;background:var(--green-bg);border:1px solid rgba(38,162,105,0.25);color:var(--green);font-family:var(--mono);font-size:0.69rem;padding:3px 9px;border-radius:10px;}
    .toolbar-sep{width:1px;height:16px;background:var(--border2);margin:0 2px;}
    .sql-toggle{font-family:var(--mono);font-size:0.7rem;color:var(--blue);cursor:pointer;padding:3px 9px;border-radius:6px;display:inline-flex;align-items:center;gap:5px;background:var(--blue-light);border:1px solid rgba(79,70,229,0.2);transition:background 0.2s;user-select:none;}
    .sql-toggle:hover{background:rgba(79,70,229,0.15);}
    .export-btn{font-family:var(--sans);font-size:0.71rem;font-weight:500;cursor:pointer;padding:3px 9px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;border:1px solid var(--border2);background:white;color:var(--text-muted);transition:all 0.15s;}
    .export-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);}
    .copy-btn:hover{border-color:var(--green)!important;color:var(--green)!important;background:var(--green-bg)!important;}
    .sql-box{display:none;background:#1c2333;border:1px solid var(--border);border-left:3px solid var(--blue);color:#7dd3fc;font-family:var(--mono);font-size:0.77rem;padding:12px 16px;border-radius:8px;margin-top:8px;white-space:pre-wrap;line-height:1.6;}

    /* INPUT */
    #questionInput{flex:1;resize:none;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:10px 15px;font-size:0.875rem;font-family:var(--sans);color:var(--text);outline:none;max-height:120px;line-height:1.5;transition:border-color 0.2s;}
    #questionInput::placeholder{color:var(--text-dim);}
    #questionInput:focus{border-color:var(--blue); background:var(--card); box-shadow:0 0 0 3px var(--blue-light);}
    #sendBtn{background:var(--blue);color:white;border:none;border-radius:10px;padding:10px 18px;font-size:0.875rem;font-weight:500;font-family:var(--sans);cursor:pointer;transition:background 0.2s;white-space:nowrap;box-shadow:0 2px 6px rgba(79,70,229,0.25);}
    #sendBtn:hover:not(:disabled){background:var(--blue-mid);}
    #sendBtn:disabled{background:var(--border2);color:var(--text-dim);cursor:not-allowed;box-shadow:none;}

    /* TYPING (fallback) */
    .dots{display:flex;gap:5px;align-items:center;padding:4px 0;}
    .dot{width:7px;height:7px;border-radius:50%;background:var(--blue);opacity:0.35;animation:dotB 1.4s infinite;}
    .dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}
    @keyframes dotB{0%,80%,100%{transform:translateY(0);opacity:0.35}40%{transform:translateY(-6px);opacity:1}}

    /* MODALS & OVERLAYS PREMIUM GLASS */
    .wiz-overlay, .sh-overlay, .modal-overlay, .tp-overlay, .share-overlay, .annot-overlay, .wh-overlay, #insightsOverlay, #pqcOverlay, .global-search-overlay {
      position: fixed; inset: 0;
      background: rgba(4, 6, 12, 0.45);
      backdrop-filter: blur(12px) contrast(95%);
      -webkit-backdrop-filter: blur(12px) contrast(95%);
      z-index: 2000; display: none;
      align-items: center; justify-content: center;
      padding: 20px;
    }
    .wiz-overlay.open, .sh-overlay.open, .modal-overlay.open, .tp-overlay.open, .share-overlay.open, .annot-overlay.open, .wh-overlay.open, .global-search-overlay.open {
      display: flex; animation: fade-in 0.3s var(--spring);
    }
    /* Specific styles for overlays used as 'flex' via JS style.display */
    div[id*="Overlay"][style*="flex"] {
      display: flex !important; animation: fade-in 0.3s var(--spring);
    }

    .wiz-box, .sh-box, .annot-box, .wh-box, .tp-box, .share-box, .gs-box, .modal-box {
      background: var(--glass-bg);
      backdrop-filter: blur(40px) saturate(200%);
      -webkit-backdrop-filter: blur(40px) saturate(200%);
      border: 1px solid var(--glass-border);
      border-radius: 28px;
      box-shadow: 
        0 1px 0 rgba(255,255,255,0.06) inset,
        0 32px 64px -16px rgba(0,0,0,0.6),
        0 0 80px -20px var(--glow);
      animation: scale-in 0.45s var(--spring) both;
      position: relative; overflow: hidden;
    }
    body.dark .wiz-box, body.dark .annot-box, body.dark .wh-box, body.dark .tp-box, body.dark .share-box, body.dark .gs-box {
      background: rgba(14, 13, 18, 0.88);
      border-color: rgba(255, 255, 255, 0.08);
    }
    body.dark .sh-box {
      background: rgba(12, 11, 16, 0.92);
      border-color: rgba(255, 255, 255, 0.07);
    }

    @keyframes scale-in {
      from { transform: scale(0.9) translateY(20px); opacity: 0; filter: blur(10px); }
      to   { transform: scale(1)   translateY(0);    opacity: 1; filter: blur(0);    }
    }

    .wiz-header, .sh-top, .annot-header, .wh-header, .tp-header {
      padding: 20px 28px 16px;
      display: flex; align-items: center; justify-content: space-between;
      border-bottom: 1px solid var(--glass-border);
    }
    .sh-top {
      background: rgba(255,255,255,0.02);
    }
    .wiz-title-row, .sh-top h2 {
      display: flex; align-items: center; gap: 10px;
      font-size: 1.1rem; font-weight: 700; color: var(--text);
      letter-spacing: -0.02em;
    }
    .wiz-close, .sh-top .wiz-close {
      background: rgba(255,255,255,0.05); border: 1px solid var(--glass-border);
      color: var(--text-muted); width: 34px; height: 34px; border-radius: 50%;
      cursor: pointer; display: flex; align-items: center; justify-content: center;
      transition: all 0.2s;
    }
    .wiz-close:hover { background: rgba(239, 68, 68, 0.1); color: var(--red); border-color: rgba(239, 68, 68, 0.3); }

    .wiz-body, .annot-body, .wh-body { padding: 24px 28px; display: flex; flex-direction: column; gap: 16px; }

    /* Wizard Inputs Premium */
    .wiz-input, .wiz-select, .sh-input {
      width: 100%;
      background: rgba(255,255,255,0.04);
      border: 1px solid var(--glass-border);
      border-radius: 12px;
      padding: 11px 15px;
      color: var(--text);
      font-family: var(--sans);
      font-size: 0.9rem;
      outline: none;
      transition: all 0.2s;
    }
    .wiz-input:focus, .wiz-select:focus {
      border-color: var(--blue);
      background: rgba(79, 70, 229, 0.05);
      box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.15);
    }

    .wiz-footer, .sh-footer {
      padding: 18px 28px 24px;
      display: flex; align-items: center; justify-content: flex-end; gap: 12px;
      border-top: 1px solid var(--glass-border);
    }
    .wiz-btn-back {
      background: transparent; border: 1px solid var(--glass-border);
      color: var(--text-muted); padding: 11px 20px; border-radius: 12px;
      font-weight: 600; cursor: pointer; transition: all 0.2s;
    }
    .wiz-btn-back:hover { background: rgba(255,255,255,0.05); color: var(--text); border-color: var(--text-dim); }

    .wiz-btn-next {
      background: linear-gradient(135deg, var(--blue) 0%, var(--blue-mid) 100%);
      color: white; border: none; padding: 12px 24px; border-radius: 12px;
      font-weight: 700; cursor: pointer; transition: all 0.2s var(--spring);
      box-shadow: 0 8px 16px rgba(79, 70, 229, 0.2), 0 0 0 1px rgba(255,255,255,0.08) inset;
    }
    .wiz-btn-next:hover { transform: translateY(-2px); box-shadow: 0 12px 24px rgba(79, 70, 229, 0.3); }

    /* ── SETTINGS HUB ─────────────────────────────────────────────────────── */
    .sh-box {
      width: 1200px; height: min(860px, calc(100vh - 40px));
      max-width: calc(100vw - 24px);
      display: flex; flex-direction: column; overflow: hidden;
    }
    /* Light mode: sfondo bianco solido, nessun vetro */
    body:not(.dark) .sh-box {
      background: #ffffff;
      backdrop-filter: none;
      -webkit-backdrop-filter: none;
      border-color: rgba(0,0,0,0.1);
      box-shadow: 0 8px 40px rgba(0,0,0,0.12);
    }
    body:not(.dark) .sh-nav {
      background: #f8f8fb;
      border-right-color: rgba(0,0,0,0.07);
    }
    body:not(.dark) .sh-panels { background: #ffffff; }
    body:not(.dark) .sh-top { border-bottom-color: rgba(0,0,0,0.07); }
    /* Grid 2 colonne: nav fissa 220px + panels flessibile.
       La griglia garantisce che .sh-panels abbia un'altezza DEFINITA per overflow-y:auto */
    .sh-body {
      flex: 1; min-height: 0; padding: 0;
      display: grid; grid-template-columns: 220px 1fr; overflow: hidden;
    }
    .sh-nav {
      background: rgba(255,255,255,0.02);
      border-right: 1px solid var(--glass-border);
      display: flex; flex-direction: column;
      padding: 12px 8px 12px 0; /* left=0: tab border flush con il bordo nav */
      overflow-y: auto; gap: 2px;
    }
    .sh-nav-sep {
      font-size: 0.62rem; font-weight: 700; text-transform: uppercase;
      letter-spacing: 0.9px; color: var(--text-dim);
      padding: 14px 12px 4px; margin-top: 4px;
      border-top: 1px solid var(--glass-border);
    }
    .sh-nav-sep:first-of-type { border-top: none; margin-top: 0; }
    .sh-tab {
      background: transparent;
      border: none;
      border-left: 2px solid transparent;
      text-align: left;
      padding: 8px 12px 8px 10px;
      border-radius: 0 8px 8px 0;
      color: var(--text-muted);
      font-size: 0.84rem; font-weight: 500; cursor: pointer;
      font-family: var(--sans);
      transition: all 0.15s;
      white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
      display: flex; align-items: center; gap: 7px; line-height: 1.3;
    }
    .sh-tab:hover { background: rgba(255,255,255,0.04); color: var(--text); border-left-color: var(--border2); }
    .sh-tab-sub { padding-left: 24px; font-size: 0.81rem; }
    .sh-tab.active {
      background: var(--blue-light);
      color: var(--blue);
      border-left: 2px solid var(--blue);
      font-weight: 600;
    }
    /* ── Utility buttons per pannelli impostazioni ── */
    .btn {
      display: inline-flex; align-items: center; gap: 6px;
      padding: 7px 14px; border-radius: 8px;
      font-size: 0.83rem; font-weight: 500; font-family: var(--sans);
      border: 1px solid var(--border); background: transparent;
      color: var(--text-muted); cursor: pointer;
      transition: all 0.15s; white-space: nowrap; line-height: 1.2;
    }
    .btn:hover { background: var(--bg2); color: var(--text); border-color: var(--border2); }
    .btn-primary { background: var(--blue); border-color: var(--blue); color: #fff; }
    .btn-primary:hover { background: var(--blue-mid); border-color: var(--blue-mid); color: #fff; }
    .btn-sm { padding: 5px 10px; font-size: 0.78rem; border-radius: 6px; }
    .btn-danger { border-color: transparent; color: var(--red, #ef4444); background: transparent; }
    .btn-danger:hover { background: rgba(239,68,68,0.08); border-color: rgba(239,68,68,0.3); color: #ef4444; }
    /* ── RBAC toggle switch ── */
    .rbac-toggle { position: relative; display: inline-block; flex-shrink: 0; cursor: pointer; }
    .rbac-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
    .rbac-toggle-track {
      display: block; width: 44px; height: 24px;
      background: var(--border2); border-radius: 12px;
      transition: background 0.2s;
    }
    .rbac-toggle input:checked + .rbac-toggle-track { background: var(--blue); }
    .rbac-toggle-thumb {
      position: absolute; top: 3px; left: 3px;
      width: 18px; height: 18px; border-radius: 50%;
      background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,0.3);
      transition: transform 0.2s;
    }
    .rbac-toggle input:checked ~ .rbac-toggle-track .rbac-toggle-thumb { transform: translateX(20px); }
    /* Banner stato RBAC */
    #rbacStatusBanner.rbac-on {
      background: rgba(79,70,229,0.08);
      border-color: rgba(79,70,229,0.3);
    }
    #rbacStatusBanner.rbac-on #rbacStatusLabel { color: var(--blue); }
    .rbac-role-row {
      display: grid; grid-template-columns: 140px 1fr auto auto;
      gap: 12px; align-items: center;
      padding: 11px 14px; background: var(--bg2);
      border-radius: 10px; border: 1px solid var(--border);
      transition: border-color 0.15s;
    }
    .rbac-role-row:hover { border-color: var(--border2); }
    .sh-panels { flex: 1; padding: 32px 40px; overflow-y: auto; background: transparent; }
    .sh-panel { display: none; }
    .sh-panel.active { display: block; animation: fade-in 0.2s ease; }
    /* Il pannello log usa flex-column per header fisso + scroll centrale + footer fisso */
    #shp-log { display: none; flex-direction: column; height: 100%; overflow: hidden; padding: 0; }
    #shp-log.active { display: flex; }
    @keyframes fade-in { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }
    .sh-panel-hd {
      padding-bottom: 14px;
      margin-bottom: 22px;
      display: flex; align-items: center; justify-content: space-between;
      border-bottom: 2px solid transparent;
      border-image: linear-gradient(90deg, var(--blue), transparent) 1;
    }
    .sh-panel-hd h3 {
      font-size: 1.05rem; font-weight: 700; color: var(--text);
      letter-spacing: -0.02em;
    }
    /* scroll gestito da .sh-panels */
    .sh-panel-sc { padding-right: 4px; }
    /* Utility: section card riutilizzabile nei pannelli */
    .sh-settings-card {
      background: var(--card);
      border: 1px solid var(--glass-border);
      border-radius: 14px; padding: 18px 20px; margin-bottom: 16px;
    }
    body.dark .sh-settings-card {
      background: rgba(255,255,255,0.03);
    }

    .modal{background:var(--glass-bg); backdrop-filter:blur(20px); border:1px solid var(--glass-border);border:1px solid var(--border);border-radius:16px;width:520px;max-width:95vw;box-shadow:0 20px 50px rgba(0,0,0,0.15);animation:slideUp 0.22s ease;}
    @keyframes slideUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
    .modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
    .modal-header h2{font-size:1rem;font-weight:600;}
    .modal-close{background:transparent;border:none;color:var(--text-dim);font-size:1.2rem;cursor:pointer;padding:4px;border-radius:4px;transition:color 0.2s;line-height:1;}
    .modal-close:hover{color:var(--text);}
    .modal-body{padding:24px;display:flex;flex-direction:column;gap:16px;}
    .field-group{display:flex;flex-direction:column;gap:5px;}
    .field-label{font-size:0.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.7px;font-family:var(--mono);}
    .field-input{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:9px 13px;font-size:0.875rem;font-family:var(--mono);color:var(--text);outline:none;transition:border-color 0.2s;width:100%;}
    .field-input:focus{border-color:var(--blue);background:var(--card);}
    .field-hint{font-size:0.7rem;color:var(--text-dim);}
    .modal-footer{padding:14px 24px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;align-items:center;}
    .btn-test{background:transparent;border:1.5px solid var(--border);border-radius:8px;padding:8px 14px;color:var(--text-muted);font-family:var(--sans);font-size:0.82rem;cursor:pointer;transition:all 0.2s;}
    .btn-test:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);}
    .btn-save{background:var(--blue);border:none;border-radius:8px;padding:8px 18px;color:white;font-family:var(--sans);font-size:0.82rem;font-weight:500;cursor:pointer;}
    .btn-save:hover{background:var(--blue-mid);}
    .test-result{font-size:0.75rem;font-family:var(--mono);color:var(--text-muted);flex:1;}
    .test-result.ok{color:var(--green);}.test-result.err{color:var(--red);}

    .welcome-card{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--blue);border-radius:12px;padding:20px;max-width:540px;box-shadow:var(--shadow-sm);}
    .welcome-card h3{font-size:0.95rem;font-weight:600;margin-bottom:8px;}
    .welcome-card p{font-size:0.84rem;color:var(--text-muted);line-height:1.65;}
    .welcome-card em{color:var(--blue);font-style:normal;font-weight:500;}



    /* REFRESH BUTTON */
    .btn-refresh {
      background: white; border: 1px solid var(--border2);
      border-radius: 6px; padding: 3px 9px;
      font-size: 0.71rem; font-family: var(--sans);
      color: var(--text-muted); cursor: pointer;
      display: inline-flex; align-items: center; gap: 4px;
      transition: all 0.15s;
    }
    .btn-refresh:hover {
      border-color: var(--blue); color: var(--blue);
      background: var(--blue-light);
    }
    .btn-refresh.spinning svg {
      animation: spin 0.7s linear infinite;
    }
    /* CACHE BADGE */
    .cache-badge {
      display:inline-flex;align-items:center;gap:5px;
      background:var(--yellow-bg);border:1px solid rgba(229,165,10,0.35);
      color:#8a6000;font-family:var(--mono);font-size:0.68rem;
      padding:3px 9px;border-radius:10px;margin-left:4px;
    }
    .cache-badge .flash { font-size:11px; }

    /* CACHE STATS PANEL */
    .cache-panel {
      background:var(--card);border:1px solid var(--border);
      border-radius:10px;padding:14px;margin-top:8px;
      display:none;box-shadow:var(--shadow-sm);
    }
    .cache-panel.open { display:block;animation:fadeUp 0.2s ease; }
    .cache-panel h4 { font-size:0.8rem;font-weight:600;margin-bottom:10px;color:var(--text); display:flex;justify-content:space-between;align-items:center;}
    .cache-stat-row { display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px; }
    .cache-stat {
      background:var(--bg2);border:1px solid var(--border);
      border-radius:8px;padding:8px 12px;flex:1;min-width:80px;
      text-align:center;
    }
    .cache-stat .cs-val { font-size:1.2rem;font-weight:600;font-family:var(--mono);color:var(--blue); }
    .cache-stat .cs-lbl { font-size:0.65rem;color:var(--text-dim);margin-top:2px; }
    .cache-entries { max-height:140px;overflow-y:auto;display:flex;flex-direction:column;gap:4px; }
    .cache-entry {
      display:flex;justify-content:space-between;align-items:center;
      font-size:0.7rem;font-family:var(--mono);
      background:var(--bg);border:1px solid var(--border);
      border-radius:6px;padding:4px 8px;color:var(--text-muted);
    }
    .cache-entry .ce-hits { background:var(--blue-light);color:var(--blue);padding:1px 6px;border-radius:8px; }
    .cache-entry .ce-age  { color:var(--text-dim); }
    .cache-entry .ce-del  { background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:0.75rem;padding:0 2px;line-height:1;opacity:0.6; }
    .cache-entry .ce-del:hover { color:var(--red);opacity:1; }
    .cache-entry .ce-question { flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px; }
    .cache-entry.ce-expired { opacity:0.5; }
    .btn-cache-clear {
      background:var(--red-bg);border:1px solid rgba(192,28,40,0.2);
      color:var(--red);border-radius:6px;padding:4px 10px;
      font-size:0.72rem;cursor:pointer;font-family:var(--sans);
      transition:all 0.15s;
    }
    .btn-cache-clear:hover { background:var(--red);color:white; }

    /* SUGGESTIONS */
    .suggestions-wrap {
      display:flex;flex-wrap:wrap;gap:6px;
      margin-top:10px;padding-top:10px;
      border-top:1px dashed var(--border2);
    }
    .suggestion-label {
      width:100%;font-size:0.67rem;color:var(--text-dim);
      font-family:var(--mono);margin-bottom:2px;
    }
    .suggestion-pill {
      background:var(--bg);border:1px solid var(--border2);
      border-radius:20px;padding:5px 13px;
      font-size:0.78rem;color:var(--text-muted);
      cursor:pointer;transition:all 0.15s;
      font-family:var(--sans);
      display:flex;align-items:center;gap:6px;
    }
    .suggestion-pill:hover {
      background:var(--blue-light);border-color:var(--blue);
      color:var(--blue);transform:translateY(-1px);
      box-shadow:0 2px 8px rgba(79,70,229,0.12);
    }
    .suggestion-pill:active { transform:translateY(0); }
    .suggestion-pill .s-arrow { opacity:0.5;font-size:11px; }

    /* Animazione ingresso suggerimenti */
    @keyframes suggIn {
      from{opacity:0;transform:translateY(6px)}
      to{opacity:1;transform:translateY(0)}
    }
    .suggestion-pill { animation:suggIn 0.2s ease both; }
    .suggestion-pill:nth-child(2){animation-delay:.05s}
    .suggestion-pill:nth-child(3){animation-delay:.10s}
    .suggestion-pill:nth-child(4){animation-delay:.15s}
    .toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);background:#1c2333;color:white;padding:8px 18px;border-radius:20px;font-size:0.8rem;font-family:var(--mono);opacity:0;transition:all 0.3s;pointer-events:none;z-index:99999;}
    .toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

    /* ── WIZARD ──────────────────────────────────────────────────────────── */
    .wiz-overlay{position:fixed;inset:0;background:rgba(28,35,51,0.5);backdrop-filter:blur(5px);z-index:5000;display:none;align-items:center;justify-content:center;}
    .wiz-overlay.open{display:flex;animation:fadeIn 0.2s;}
    .wiz-box{background:var(--glass-bg); backdrop-filter:blur(20px); border:1px solid var(--glass-border);border:1px solid var(--border);border-radius:18px;width:580px;max-width:96vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,0.18);animation:slideUp 0.22s ease;overflow:hidden;}
    .wiz-header{padding:22px 26px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
    .wiz-title-row{display:flex;align-items:center;gap:10px;}
    .wiz-title-row h2{font-size:1rem;font-weight:600;}
    .wiz-close{background:transparent;border:none;color:var(--text-dim);font-size:1.2rem;cursor:pointer;padding:4px;border-radius:4px;transition:color 0.2s;line-height:1;}
    .wiz-close:hover{color:var(--text);}
    /* Step indicator */
    .wiz-steps{display:flex;align-items:center;padding:18px 26px 0;gap:0;flex-shrink:0;}
    .wiz-step{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;position:relative;}
    .wiz-step:not(:last-child)::after{content:'';position:absolute;top:14px;left:calc(50% + 14px);right:calc(-50% + 14px);height:2px;background:var(--border);}
    .wiz-step.done:not(:last-child)::after{background:var(--blue);}
    .wiz-step-dot{width:28px;height:28px;border-radius:50%;background:var(--bg2);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:0.72rem;font-weight:600;color:var(--text-muted);transition:all 0.2s;z-index:1;}
    .wiz-step.active .wiz-step-dot{background:var(--blue);border-color:var(--blue);color:white;}
    .wiz-step.done .wiz-step-dot{background:var(--green);border-color:var(--green);color:white;}
    .wiz-step-label{font-size:0.65rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:0.5px;font-family:var(--mono);}
    .wiz-step.active .wiz-step-label{color:var(--blue);}
    .wiz-step.done .wiz-step-label{color:var(--green);}
    /* Body */
    .wiz-body{padding:24px 26px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:16px;}
    .wiz-section-title{font-size:0.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:4px;}
    /* Details opener dentro sh-settings-card */
    .sh-settings-card > summary { padding:16px 20px;cursor:pointer;font-weight:600;font-size:0.9rem;color:var(--text);list-style:none;display:flex;align-items:center;gap:8px; }
    .sh-settings-card > summary::marker, .sh-settings-card > summary::-webkit-details-marker { display:none; }
    .sh-settings-card > summary .sh-details-arrow { font-size:0.7rem;color:var(--text-dim);transition:transform 0.2s; }
    .sh-settings-card[open] > summary .sh-details-arrow { transform:rotate(90deg); }
    .sh-settings-card[open] > summary { border-bottom:1px solid var(--glass-border); }
    .sh-settings-card > summary + div { padding:16px 20px 20px; }
    .wiz-section-sub{font-size:0.78rem;color:var(--text-muted);margin-bottom:4px;}
    .wiz-field{display:flex;flex-direction:column;gap:5px;}
    .wiz-label{font-size:0.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.7px;font-family:var(--mono);}
    .wiz-input{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:9px 13px;font-size:0.875rem;font-family:var(--mono);color:var(--text);outline:none;transition:border-color 0.2s;width:100%;}
    .wiz-input:focus{border-color:var(--blue);background:var(--card);}
    .wiz-hint{font-size:0.7rem;color:var(--text-dim);}
    .wiz-row{display:grid;grid-template-columns:1fr 120px;gap:12px;}
    .wiz-status{font-size:0.78rem;font-family:var(--mono);padding:8px 12px;border-radius:8px;background:var(--bg2);}
    .wiz-status.ok{background:var(--green-bg);color:var(--green);}
    .wiz-status.err{background:var(--red-bg);color:var(--red);}
    .wiz-status.info{background:var(--blue-light);color:var(--blue);}
    /* Model list */
    .wiz-model-list{display:flex;flex-direction:column;gap:6px;max-height:180px;overflow-y:auto;}
    .wiz-model-item{padding:9px 13px;border:1.5px solid var(--border);border-radius:8px;cursor:pointer;font-size:0.83rem;font-family:var(--mono);display:flex;align-items:center;gap:8px;transition:all 0.15s;}
    .wiz-model-item:hover{border-color:var(--blue);background:var(--blue-light);}
    .wiz-model-item.selected{border-color:var(--blue);background:var(--blue-light);color:var(--blue);font-weight:500;}
    .wiz-model-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);flex-shrink:0;}
    .wiz-model-item.selected .wiz-model-dot{background:var(--blue);}
    /* DB list */
    .wiz-db-list{display:flex;flex-direction:column;gap:6px;}
    .wiz-db-item{padding:11px 15px;border:1.5px solid var(--border);border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all 0.15s;}
    .wiz-db-item:hover{border-color:var(--blue);background:var(--blue-light);}
    .wiz-db-item.selected{border-color:var(--blue);background:var(--blue-light);}
    .wiz-db-item.primary{border-color:var(--green);background:var(--green-bg);}
    .wiz-db-badge{background:var(--green);color:white;font-size:0.63rem;padding:1px 7px;border-radius:4px;font-weight:700;letter-spacing:0.5px;white-space:nowrap;}
    .wiz-db-name{font-size:0.88rem;font-weight:600;font-family:var(--mono);}
    .wiz-db-desc{font-size:0.72rem;color:var(--text-muted);}
    /* Schema progress */
    .wiz-progress{display:flex;flex-direction:column;gap:8px;}
    .wiz-progress-bar-wrap{background:var(--bg2);border-radius:100px;height:8px;overflow:hidden;}
    .wiz-progress-bar{height:100%;background:var(--blue);border-radius:100px;transition:width 0.4s ease;width:0%;}
    .wiz-progress-text{font-size:0.78rem;color:var(--text-muted);font-family:var(--mono);}
    .wiz-table-list{display:flex;flex-wrap:wrap;gap:5px;max-height:120px;overflow-y:auto;}
    .wiz-table-pill{font-size:0.68rem;font-family:var(--mono);padding:3px 8px;border-radius:100px;background:var(--green-bg);color:var(--green);}
    .wiz-table-pill.err{background:var(--red-bg);color:var(--red);}
    /* Footer */
    .wiz-footer{padding:14px 26px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;gap:10px;}
    .wiz-btn-back{background:transparent;border:1.5px solid var(--border);border-radius:8px;padding:8px 16px;color:var(--text-muted);font-family:var(--sans);font-size:0.82rem;cursor:pointer;transition:all 0.2s;}
    .wiz-btn-back:hover{border-color:var(--text-muted);color:var(--text);}
    .wiz-btn-next{background:var(--blue);border:none;border-radius:8px;padding:8px 22px;color:white;font-family:var(--sans);font-size:0.82rem;font-weight:500;cursor:pointer;transition:background 0.2s;display:flex;align-items:center;gap:6px;}
    .wiz-btn-next:hover{background:var(--blue-mid);}
    .wiz-btn-next:disabled{opacity:0.5;cursor:not-allowed;}
    .wiz-err{font-size:0.75rem;font-family:var(--mono);color:var(--red);flex:1;}

    /* ── AUDIT LOG ───────────────────────────────────────────────────────── */
    .audit-overlay{position:fixed;inset:0;background:rgba(28,35,51,0.5);backdrop-filter:blur(5px);z-index:3000;display:none;align-items:center;justify-content:center;}
    .audit-overlay.open{display:flex;animation:fadeIn 0.2s;}
    .audit-box{background:var(--card);border:1px solid var(--border);border-radius:18px;width:95vw;max-width:1200px;height:88vh;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,0.18);animation:slideUp 0.22s ease;overflow:hidden;}
    .audit-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
    .audit-header h2{font-size:1rem;font-weight:600;}
    .audit-filters{padding:14px 24px;border-bottom:1px solid var(--border);display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0;background:var(--bg);}
    .audit-filter-input{background:var(--card);border:1.5px solid var(--border);border-radius:8px;padding:7px 11px;font-size:0.78rem;font-family:var(--mono);color:var(--text);outline:none;transition:border-color 0.2s;min-width:130px;}
    .audit-filter-input:focus{border-color:var(--blue);}
    .audit-filter-select{background:var(--card);border:1.5px solid var(--border);border-radius:8px;padding:7px 11px;font-size:0.78rem;font-family:var(--mono);color:var(--text);outline:none;cursor:pointer;}
    .audit-btn-filter{background:var(--blue);border:none;border-radius:8px;padding:7px 16px;color:white;font-size:0.78rem;font-family:var(--sans);font-weight:500;cursor:pointer;}
    .audit-btn-filter:hover{background:var(--blue-mid);}
    .audit-btn-reset{background:transparent;border:1.5px solid var(--border);border-radius:8px;padding:7px 12px;color:var(--text-muted);font-size:0.78rem;font-family:var(--sans);cursor:pointer;}
    /* ── Audit filter bar ─────────────────────────────────────────── */
    .audit-filter-bar {
      display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
      padding: 10px 20px; border-bottom: 1px solid var(--border);
      background: var(--bg2); flex-shrink: 0;
      position: relative; z-index: 10;
    }
    /* ── Excel-style dropdown filter ─────────────────────────────── */
    .afd-wrap { position: relative; }
    .afd-btn {
      display: flex; align-items: center; gap: 4px;
      background: var(--card); border: 1.5px solid var(--border);
      border-radius: 8px; padding: 6px 10px;
      font-size: 0.78rem; font-family: var(--sans); color: var(--text);
      cursor: pointer; white-space: nowrap; transition: border-color 0.2s;
    }
    .afd-btn:hover, .afd-btn.active { border-color: var(--blue); color: var(--blue); }
    .afd-badge {
      background: var(--blue); color: #fff;
      border-radius: 100px; font-size: 0.65rem; font-weight: 700;
      padding: 1px 5px; line-height: 1.4;
    }
    .afd-panel {
      position: absolute; top: calc(100% + 4px); left: 0; z-index: 600;
      background: var(--bg2); border: 1px solid var(--border2);
      border-radius: 10px; box-shadow: 0 8px 32px rgba(0,0,0,0.3);
      min-width: 180px; max-width: 260px;
      display: flex; flex-direction: column;
    }
    .afd-panel-inner { padding: 8px 0; max-height: 240px; overflow-y: auto; }
    .afd-row {
      display: flex; align-items: center; gap: 8px;
      padding: 5px 14px; font-size: 0.8rem; cursor: pointer;
      color: var(--text); transition: background 0.1s;
    }
    .afd-row:hover { background: rgba(255,255,255,0.05); }
    .afd-row input[type=checkbox] { accent-color: var(--blue); width: 14px; height: 14px; cursor: pointer; }
    .afd-row-all { font-weight: 600; color: var(--text-muted); }
    .afd-sep { height: 1px; background: var(--border); margin: 4px 0; }
    .afd-list { }
    .afd-footer {
      display: flex; gap: 6px; padding: 8px 12px;
      border-top: 1px solid var(--border); justify-content: flex-end;
    }
    #shp-log .sh-panel-hd { flex-shrink: 0; margin-bottom: 0; }
    .audit-body { flex: 1; overflow: auto; padding: 0; min-height: 0; }
    .audit-table{width:100%;border-collapse:collapse;font-size:0.78rem;}
    .audit-table th{background:var(--bg2);padding:10px 14px;text-align:left;font-size:0.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;font-family:var(--mono);position:sticky;top:0;border-bottom:1px solid var(--border);white-space:nowrap;}
    .audit-table td{padding:9px 14px;border-bottom:1px solid var(--border);vertical-align:top;max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
    .audit-table tr:hover td{background:var(--bg);}
    .audit-badge-ok{background:var(--green-bg);color:var(--green);padding:2px 8px;border-radius:100px;font-size:0.68rem;font-weight:600;}
    .audit-badge-err{background:var(--red-bg);color:var(--red);padding:2px 8px;border-radius:100px;font-size:0.68rem;font-weight:600;}
    .audit-badge-cache{background:#1a3a5c;color:#60a5fa;padding:2px 6px;border-radius:100px;font-size:0.63rem;font-weight:600;margin-left:4px;}
    .audit-sql-btn{background:transparent;border:1px solid var(--border);border-radius:5px;padding:2px 8px;font-size:0.72rem;color:var(--text-muted);cursor:pointer;white-space:nowrap;}
    .audit-sql-btn:hover{border-color:var(--blue);color:var(--blue);background:rgba(79,70,229,0.08);}
    .audit-footer{padding:12px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:0.78rem;color:var(--text-muted);flex-shrink:0;}
    .audit-pagination{display:flex;gap:6px;align-items:center;}
    .audit-page-btn{background:transparent;border:1.5px solid var(--border);border-radius:6px;padding:4px 10px;font-size:0.75rem;cursor:pointer;color:var(--text-muted);}
    .audit-page-btn:hover{border-color:var(--blue);color:var(--blue);}
    .audit-page-btn:disabled{opacity:0.4;cursor:not-allowed;}
    .audit-prompt-cell{text-decoration:underline dotted var(--text-muted);cursor:pointer;transition:color 0.15s;}
    .audit-prompt-cell:hover{color:var(--blue);}
    .audit-sql-panel{display:none;background:#0d1117;border-bottom:2px solid var(--blue);padding:16px 24px;flex-shrink:0;}
    .audit-sql-panel.open{display:block;}
    .audit-sql-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
    .audit-sql-panel-meta{font-size:0.72rem;color:#5a6a85;font-family:var(--sans);}
    .audit-sql-panel-close{background:transparent;border:none;color:#5a6a85;cursor:pointer;font-size:1rem;line-height:1;}
    .audit-sql-panel-close:hover{color:#e8f0fc;}
    .audit-sql-code{font-family:var(--mono);font-size:0.82rem;color:#e2e8f0;white-space:pre-wrap;word-break:break-all;line-height:1.6;max-height:200px;overflow-y:auto;}
    .audit-sql-copy{background:#1a5fb4;border:none;border-radius:6px;padding:5px 14px;color:white;font-size:0.75rem;cursor:pointer;margin-top:10px;}
    .audit-sql-copy:hover{background:#3584e4;}
    .audit-sql-prompt{font-size:0.75rem;color:#99aabb;margin-bottom:6px;font-family:var(--sans);}

    /* ── DASHBOARD ────────────────────────────────────────────────── */
    .dash-overlay{position:fixed;inset:0;background:rgba(28,35,51,0.5);backdrop-filter:blur(5px);z-index:3000;display:none;align-items:center;justify-content:center;}
    .dash-overlay.open{display:flex;animation:fadeIn 0.2s;}
    .dash-box{background:var(--glass-bg); backdrop-filter:blur(20px); border:1px solid var(--glass-border);border:1px solid var(--border);border-radius:18px;width:95vw;max-width:1100px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,0.18);animation:slideUp 0.22s ease;overflow:hidden;}
    .dash-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
    .dash-header h2{font-size:1rem;font-weight:600;}
    .dash-body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:20px;}
    .dash-kpi-row{display:flex;gap:14px;flex-wrap:wrap;}
    .dash-kpi{flex:1;min-width:130px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;gap:4px;}
    .dash-kpi-val{font-size:1.7rem;font-weight:700;font-family:var(--mono);color:var(--blue);}
    .dash-kpi-label{font-size:0.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.7px;font-weight:600;}
    .dash-kpi-sub{font-size:0.72rem;color:var(--text-dim);}
    .dash-section{display:flex;flex-direction:column;gap:10px;}
    .dash-section-title{font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;color:var(--text-muted);}
    .dash-table{width:100%;border-collapse:collapse;font-size:0.78rem;}
    .dash-table th{background:var(--bg2);padding:7px 12px;text-align:left;font-size:0.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;border-bottom:1px solid var(--border);}
    .dash-table td{padding:7px 12px;border-bottom:1px solid var(--border);}
    .dash-table tr:last-child td{border-bottom:none;}
    .dash-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
    .dash-bar{background:var(--blue);height:6px;border-radius:3px;min-width:4px;}
    .dash-bar-row{display:flex;align-items:center;gap:8px;font-size:0.78rem;}
    .dash-bar-label{width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text);}
    .dash-bar-wrap{flex:1;background:var(--bg2);border-radius:3px;height:6px;}
    .dash-bar-val{width:30px;text-align:right;color:var(--text-muted);font-family:var(--mono);font-size:0.72rem;}
    .dash-days-sel{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:0.75rem;font-family:var(--mono);color:var(--text);cursor:pointer;outline:none;}

    /* ── ANNOTATION ────────────────────────────────────────────────── */
    .annot-overlay{position:fixed;inset:0;background:rgba(28,35,51,0.5);backdrop-filter:blur(4px);z-index:5000;display:none;align-items:center;justify-content:center;}
    .annot-overlay.open{display:flex;animation:fadeIn 0.2s;}
    .annot-box{background:var(--card);border:1px solid var(--border);border-radius:14px;width:480px;max-width:95vw;box-shadow:0 20px 50px rgba(0,0,0,0.15);animation:slideUp 0.22s ease;}
    .annot-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
    .annot-body{padding:20px;}
    .annot-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;max-height:200px;overflow-y:auto;}
    .annot-item{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:3px;}
    .annot-item-meta{font-size:0.68rem;color:var(--text-dim);font-family:var(--mono);display:flex;justify-content:space-between;}
    .annot-item-text{font-size:0.83rem;color:var(--text);line-height:1.5;}
    .annot-del{background:transparent;border:none;cursor:pointer;font-size:0.7rem;color:var(--red);padding:0;}
    .annot-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:9px 12px;font-size:0.875rem;font-family:var(--sans);color:var(--text);resize:vertical;min-height:60px;outline:none;transition:border-color 0.2s;}
    .annot-input:focus{border-color:var(--blue);}
    .annot-btn{background:var(--blue);border:none;border-radius:8px;padding:8px 18px;color:white;font-size:0.82rem;font-weight:500;cursor:pointer;font-family:var(--sans);}
    .annot-btn:hover{background:var(--blue-mid);}

    /* ── WEBHOOK MODAL ──────────────────────────────────────────────── */
    .wh-overlay{position:fixed;inset:0;background:rgba(28,35,51,0.5);backdrop-filter:blur(4px);z-index:3000;display:none;align-items:center;justify-content:center;}
    .wh-box{background:var(--card);border:1px solid var(--border);border-radius:14px;width:480px;max-width:95vw;box-shadow:0 20px 50px rgba(0,0,0,0.15);animation:slideUp 0.22s ease;}
    .wh-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
    .wh-body{padding:20px;display:flex;flex-direction:column;gap:14px;}
    .wh-item{display:flex;align-items:center;gap:8px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;}
    .wh-item-name{flex:1;font-size:0.85rem;font-weight:500;}
    .wh-item-url{font-size:0.72rem;color:var(--text-muted);font-family:var(--mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px;}
    .wh-send-btn{background:var(--blue);border:none;border-radius:7px;padding:6px 14px;color:white;font-size:0.8rem;font-weight:500;cursor:pointer;white-space:nowrap;}
    .wh-send-btn:hover{background:var(--blue-mid);}
    .wh-send-btn:disabled{opacity:0.5;cursor:default;}
    .wh-add-row{display:flex;gap:8px;}
    .wh-input{flex:1;background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:8px 10px;font-size:0.82rem;font-family:var(--sans);color:var(--text);outline:none;transition:border-color 0.2s;}
    .wh-input:focus{border-color:var(--blue);}
    .wh-add-btn{background:var(--blue);border:none;border-radius:8px;padding:8px 14px;color:white;font-size:0.82rem;cursor:pointer;}
    .wh-del-btn{background:none;border:none;cursor:pointer;color:var(--red,#ef4444);font-size:0.8rem;padding:2px 6px;}

    /* ── MORNING BRIEF ─────────────────────────────────────────────── */
    .morning-brief{background:var(--card);border:1px solid var(--border);border-left:3px solid #f59e0b;border-radius:10px;padding:14px 16px;max-width:600px;align-self:flex-start;animation:fadeUp 0.3s ease;}
    .morning-brief-title{font-size:0.72rem;font-weight:600;color:#f59e0b;text-transform:uppercase;letter-spacing:0.8px;margin-bottom:8px;display:flex;align-items:center;gap:6px;}
    .morning-brief-chips{display:flex;flex-direction:column;gap:6px;}
    .morning-chip{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:7px 12px;font-size:0.82rem;color:var(--text);cursor:pointer;text-align:left;font-family:var(--sans);transition:all 0.15s;}
    .morning-chip:hover{background:var(--blue-light);border-color:rgba(79,70,229,0.3);color:var(--blue);}

    /* ── SQL EXPLAIN ────────────────────────────────────────────────── */
    .sql-explain{display:none;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;margin-top:8px;font-size:0.8rem;color:var(--text-muted);line-height:1.6;}
    .sql-explain-btn{font-family:var(--mono);font-size:0.7rem;color:var(--green);cursor:pointer;padding:3px 9px;border-radius:6px;display:inline-flex;align-items:center;gap:5px;background:var(--green-bg);border:1px solid rgba(38,162,105,0.2);transition:background 0.2s;user-select:none;}
    .sql-explain-btn:hover{background:rgba(38,162,105,0.2);}

    /* ── PROVIDER CARDS ─────────────────────────────────────────────── */
    .wiz-provider-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:4px;}
    .wiz-provider-card{border:1.5px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;display:flex;align-items:center;gap:12px;transition:all 0.15s;}
    .wiz-provider-card:hover{border-color:var(--blue);background:var(--blue-light);}
    .wiz-provider-card.selected{border-color:var(--blue);background:var(--blue-light);}
    .wiz-provider-icon{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;} .wiz-provider-icon svg{width:32px;height:32px;}
    .wiz-provider-name{font-size:0.88rem;font-weight:600;}
    .wiz-provider-desc{font-size:0.7rem;color:var(--text-muted);}
    .wiz-provider-section{margin-top:14px;display:flex;flex-direction:column;gap:12px;}

    /* ── COMPARE RESULT ────────────────────────────────────────────────── */
    .compare-hd{font-size:0.8rem;font-weight:600;color:var(--blue);padding:8px 0 12px;display:flex;align-items:center;gap:8px;}
    .compare-block{border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:12px;}
    .compare-block-lbl{padding:8px 14px;background:var(--bg2);font-size:0.78rem;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);}

    /* Quick commands editor */
    .qc-card-editor{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;}
    .qc-card-hd{display:flex;align-items:center;gap:8px;margin-bottom:10px;}
    .qc-icon-input{width:48px;text-align:center;font-size:1.1rem;border:1px solid var(--border);border-radius:7px;padding:5px;background:var(--card);color:var(--text);font-family:var(--sans);}
    .qc-title-input{flex:1;border:1px solid var(--border);border-radius:7px;padding:6px 10px;background:var(--card);color:var(--text);font-family:var(--sans);font-size:0.83rem;}
    .qc-cmd-row{display:flex;align-items:center;gap:6px;margin-bottom:6px;}
    .qc-cmd-label{width:160px;flex-shrink:0;border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:0.78rem;background:var(--card);color:var(--text);font-family:var(--sans);}
    .qc-cmd-q{flex:1;border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:0.78rem;background:var(--card);color:var(--text);font-family:var(--sans);}
    .qc-del-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px 6px;border-radius:5px;font-size:13px;transition:all 0.12s;flex-shrink:0;}
    .qc-del-btn:hover{color:var(--red);background:var(--red-bg);}
    .qc-add-cmd-btn{background:none;border:1px dashed var(--border2);border-radius:6px;padding:5px 10px;font-size:0.75rem;color:var(--text-dim);cursor:pointer;width:100%;margin-top:4px;font-family:var(--sans);transition:all 0.12s;}
    .qc-add-cmd-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);}

    /* ── HISTORY INLINE BUTTON ──────────────────────────────────────────── */
    .btn-history-inline{background:transparent;border:1px solid var(--border);border-radius:10px;width:40px;height:40px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1.05rem;transition:all 0.2s;flex-shrink:0;padding:0;line-height:1;}
    .btn-history-inline:hover{background:var(--blue-light);border-color:rgba(79,70,229,0.3);color:var(--blue);}
    .btn-history-inline.active{background:var(--blue-light);border-color:rgba(79,70,229,0.3);color:var(--blue);}
    /* Nascondi il FAB flottante — sostituito dal bottone inline */
    .sidebar-fab{display:none!important;}

    /* ══════════════════════════════════════════════════════════════════════
       RESPONSIVE DESIGN SYSTEM — Mobile-First Progressive Enhancement
       Breakpoints: ≤480px (phone), ≤768px (tablet-portrait), ≤1024px (tablet-landscape)
       ══════════════════════════════════════════════════════════════════════ */

    /* ── TABLET LANDSCAPE (≤1024px) ──────────────────────────────────────── */
    @media (max-width:1024px){
      /* Settings Hub: riduci dimensioni */
      .sh-box{width:calc(100vw - 24px);height:calc(100vh - 24px);border-radius:16px;}
      .sh-body{grid-template-columns:180px 1fr;}
      .sh-panels{padding:20px 22px;}
      .sh-tab{font-size:0.8rem;padding:7px 10px 7px 8px;}
      .sh-nav-sep{font-size:0.58rem;padding:10px 10px 3px;}
      /* Dashboard */
      .dash-box{width:calc(100vw - 20px);max-height:calc(100vh - 20px);}
      .dash-kpi{min-width:110px;}
      /* Wizard */
      .wiz-box{width:calc(100vw - 20px);}
      /* Provider grid */
      .wiz-provider-grid{grid-template-columns:1fr 1fr;gap:8px;}
      /* BP Card */
      .bp-kpi-row{flex-wrap:wrap;}
      .bp-kpi{min-width:calc(50% - 8px);}
      /* RBAC grid */
      .rbac-role-row{grid-template-columns:120px 1fr auto auto;gap:8px;}
    }

    /* ── TABLET PORTRAIT (≤768px) ────────────────────────────────────────── */
    @media (max-width:768px){
      /* ─── HEADER ─── */
      header{padding:0 10px;gap:8px;height:50px;}
      .header-sub{display:none;}
      .header-title{font-size:0.88rem;}
      .status-pills{gap:4px;overflow:hidden;}
      .pill{padding:3px 7px;font-size:0.68rem;}
      .pill-label{display:none;}
      #pillCompany{display:none;}
      .pill-divider{display:none;}
      #pillServer .pill-dot + *{display:none;}
      .company-selector.visible{display:none;}
      .btn-dark-toggle{padding:4px 7px;font-size:0.85rem;}
      #userInfo{gap:5px;}
      #currentUserLabel{display:none;}
      .btn-settings{padding:5px 8px;font-size:0.82rem;}
      #btnImpostazioni{font-size:0;padding:5px 7px;}
      #btnImpostazioni::before{content:'⚙';font-size:0.95rem;}
      #btnLang{display:none;}

      /* ─── SIDEBAR: drawer overlay ─── */
      aside{width:0;position:fixed;top:0;left:0;height:100dvh;z-index:300;
        transition:width 0.3s cubic-bezier(.4,0,.2,1),transform 0.3s cubic-bezier(.4,0,.2,1);
        transform:translateX(-100%);box-shadow:none;}
      aside:not(.collapsed){width:280px;transform:translateX(0);
        box-shadow:8px 0 32px rgba(0,0,0,0.25);}
      aside.collapsed{width:0;transform:translateX(-100%);}
      .sidebar-mobile-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.4);
        z-index:299;display:none;-webkit-tap-highlight-color:transparent;}
      .sidebar-mobile-backdrop.open{display:block;}
      /* Mostra il FAB inline nell'input per aprire sidebar */
      .btn-history-inline{display:flex!important;}
      .sidebar-peek-trigger{display:none!important;}
      /* Sidebar FAB fisso */
      .sidebar-fab{display:flex!important;bottom:auto;top:calc(50px + 12px);left:10px;
        width:40px;height:40px;z-index:250;opacity:1;pointer-events:auto;transform:none;}
      .sidebar-fab.hidden{opacity:0;pointer-events:none;transform:scale(0.7);}

      /* ─── CHAT AREA ─── */
      #messages{padding:14px 10px;}
      .msg{max-width:100%;}
      .bubble{border-radius:12px;padding:10px 14px;}
      .msg.user .bubble{border-bottom-right-radius:3px;}
      .msg.bot .bubble{border-bottom-left-radius:3px;}
      .msg-time{font-size:0.63rem;}
      /* Empty state */
      .empty-state-wrap{padding:20px 12px;}
      .empty-state-greeting{font-size:1.1rem;}
      .empty-state-sub{font-size:0.8rem;margin-bottom:16px;}
      .empty-state-grid{flex-wrap:wrap;justify-content:center;gap:10px;overflow-x:visible;}
      .es-card{min-width:calc(50% - 6px);max-width:calc(50% - 6px);padding:14px;border-radius:14px;}
      .es-card-hd{font-size:0.82rem;padding-bottom:8px;}
      .es-cmds-list{height:120px;}
      .es-cmd{padding:5px 6px;font-size:0.76rem;}

      /* ─── INPUT AREA ─── */
      .input-area{padding-bottom:env(safe-area-inset-bottom,0);}
      .input-row{padding:8px 10px 10px;gap:8px;}
      #questionInput{min-height:40px;padding:9px 12px;font-size:0.85rem;border-radius:12px;}
      #sendBtn{padding:0 14px;height:40px;font-size:0.82rem;border-radius:18px;}
      .btn-mic{width:40px;height:40px;border-radius:10px;font-size:1rem;}
      .quick-filters-bar{padding:4px 10px 0;}
      .fav-chips-bar{padding:6px 10px 0;}

      /* ─── TABELLE RISULTATI ─── */
      .result-wrap{max-height:240px;-webkit-overflow-scrolling:touch;}
      table{font-size:0.74rem;}
      th .th-label{padding:6px 8px 3px;font-size:0.65rem;}
      th .th-filter{padding:0 4px 4px;}
      th .th-filter input{font-size:0.65rem;padding:2px 4px;}
      td{padding:5px 8px;font-size:0.74rem;}
      /* Result toolbar */
      .result-toolbar{gap:4px;padding:6px 8px;flex-wrap:wrap;}
      .export-btn{padding:3px 7px;font-size:0.68rem;}
      .sql-toggle{padding:3px 7px;font-size:0.68rem;}
      .row-badge{padding:2px 7px;font-size:0.66rem;}
      .toolbar-sep{height:12px;}

      /* ─── GRAFICI ─── */
      .chart-wrap{padding:12px;min-height:240px;}
      .chart-wrap canvas{max-height:220px;}
      .view-switcher{gap:3px;}
      .view-btn{padding:3px 8px;font-size:0.72rem;}

      /* ─── BP CARD ─── */
      .bp-card{padding:12px;}
      .bp-card-header{flex-wrap:wrap;gap:8px;}
      .bp-kpi-row{gap:8px;flex-wrap:wrap;}
      .bp-kpi{min-width:calc(50% - 4px);padding:6px 10px;}
      .bp-kpi-val{font-size:0.88rem;}
      .bp-details-grid{grid-template-columns:1fr;}
      .bp-extras-grid{grid-template-columns:1fr;}

      /* ─── MODALI ─── */
      .wiz-overlay,.sh-overlay,.modal-overlay,.tp-overlay,.share-overlay,.annot-overlay,.wh-overlay,#insightsOverlay,#pqcOverlay,.global-search-overlay{
        padding:0;align-items:flex-end;}
      .wiz-box,.annot-box,.wh-box,.tp-box,.share-box,.gs-box,.modal{
        width:100%;max-width:100%;border-radius:20px 20px 0 0;
        max-height:calc(100dvh - 20px);animation:slide-up-mobile 0.35s var(--spring) both;}
      @keyframes slide-up-mobile{
        from{transform:translateY(100%);opacity:0.5;}
        to{transform:translateY(0);opacity:1;}
      }
      .wiz-header,.annot-header,.wh-header{padding:16px 18px 12px;}
      .wiz-body,.annot-body,.wh-body{padding:16px 18px;}
      .wiz-footer{padding:12px 18px;flex-wrap:wrap;}
      .wiz-steps{padding:12px 18px 0;}
      .wiz-step-label{font-size:0.58rem;}
      .wiz-step-dot{width:24px;height:24px;font-size:0.68rem;}
      .modal{border-radius:20px 20px 0 0;max-height:calc(100dvh - 20px);}
      .modal-body{padding:16px 18px;}
      .modal-header{padding:14px 18px 12px;}

      /* ─── SETTINGS HUB ─── */
      .sh-box{width:100%;height:100dvh;max-width:100%;max-height:100dvh;
        border-radius:0;display:flex;flex-direction:column;}
      .sh-body{grid-template-columns:1fr;grid-template-rows:auto 1fr;overflow:hidden;}
      .sh-nav{flex-direction:row;overflow-x:auto;overflow-y:hidden;
        padding:8px;gap:4px;border-right:none;border-bottom:1px solid var(--glass-border);
        scrollbar-width:none;-webkit-overflow-scrolling:touch;white-space:nowrap;}
      .sh-nav::-webkit-scrollbar{display:none;}
      .sh-nav-sep{display:none;}
      .sh-tab{border-left:none;border-bottom:2px solid transparent;
        border-radius:8px;padding:7px 12px;font-size:0.75rem;flex-shrink:0;white-space:nowrap;}
      .sh-tab.active{border-left:none;border-bottom:2px solid var(--blue);}
      .sh-tab-sub{padding-left:12px;}
      .sh-panels{padding:16px 14px;overflow-y:auto;-webkit-overflow-scrolling:touch;}
      .sh-panel-hd{flex-direction:column;gap:8px;align-items:flex-start;}
      .sh-panel-hd h3{font-size:0.95rem;}
      .sh-settings-card{padding:14px 16px;border-radius:12px;}
      .sh-top{padding:14px 18px 12px;}
      .sh-top h2{font-size:0.95rem;}

      /* ─── AUDIT LOG ─── */
      .audit-filter-bar{gap:6px;padding:8px 12px;}
      .afd-btn{font-size:0.72rem;padding:5px 8px;}
      .audit-body{overflow-x:auto;-webkit-overflow-scrolling:touch;}
      .audit-table{min-width:700px;}
      .audit-table td{font-size:0.72rem;padding:6px 8px;max-width:160px;}
      .audit-table th{font-size:0.64rem;padding:6px 8px;}
      .audit-footer{padding:8px 14px;flex-wrap:wrap;gap:8px;}

      /* ─── DASHBOARD ─── */
      .dash-box{width:100%;height:100dvh;max-height:100dvh;border-radius:0;}
      .dash-body{padding:16px;}
      .dash-kpi-row{gap:8px;}
      .dash-kpi{min-width:calc(50% - 4px);padding:12px 14px;}
      .dash-kpi-val{font-size:1.3rem;}
      .dash-row{grid-template-columns:1fr;}

      /* ─── COMPARE ─── */
      .compare-tabs{gap:3px;}
      .compare-tab{padding:4px 8px;font-size:0.72rem;}

      /* ─── WIZARD ─── */
      .wiz-provider-grid{grid-template-columns:1fr;gap:8px;}
      .wiz-row{grid-template-columns:1fr;gap:8px;}
      .wiz-input,.wiz-select{font-size:0.85rem;padding:10px 12px;}

      /* ─── GLOBAL SEARCH ─── */
      .gs-box{width:100%;max-width:100%;border-radius:0 0 14px 14px;margin-top:0;}
      .global-search-overlay{align-items:flex-start;padding-top:0;}

      /* ─── SUGGESTIONS ─── */
      .suggestions-wrap{gap:5px;}
      .suggestion-pill{padding:4px 10px;font-size:0.74rem;}

      /* ─── CACHE PANEL ─── */
      .cache-entry .ce-question{max-width:120px;}

      /* ─── RBAC ─── */
      .rbac-role-row{grid-template-columns:1fr;gap:8px;padding:10px 12px;}

      /* ─── TOAST ─── */
      .toast{bottom:calc(env(safe-area-inset-bottom,0px) + 70px);max-width:calc(100vw - 32px);}

      /* ─── SQL BOX ─── */
      .sql-box{font-size:0.72rem;padding:8px 10px;}

      /* ─── STREAMING ─── */
      .stream-bubble{min-width:140px;}
      .stream-sql{font-size:0.72rem;}

      /* ─── MORNING BRIEF ─── */
      .morning-brief{max-width:100%;}

      /* ─── SERVICE LAYER PREVIEW ─── */
      .share-box{width:100%;border-radius:20px 20px 0 0;}
    }

    /* ── SMARTPHONE (≤480px) ──────────────────────────────────────────── */
    @media (max-width:480px){
      /* Header: compressione massima */
      header{gap:4px;height:46px;padding:0 8px;}
      .header-logo .logo-box-mini{width:28px;height:28px;border-radius:7px;}
      .header-logo .logo-box-mini span{font-size:9px;}
      .header-title{font-size:0.8rem;}
      .status-pills{display:none;}
      #userInfo{gap:3px;}
      .btn-settings{padding:4px 6px;font-size:0.78rem;border-radius:6px;}
      /* Nascondi pulsanti secondari */
      [data-onclick="openChangePassword()"]{display:none;}
      [data-onclick="openPqc()"]{display:none;}
      [data-onclick="doLogout()"]{padding:4px 8px;font-size:0.75rem;}

      /* Sidebar */
      aside:not(.collapsed){width:calc(100vw - 48px);max-width:300px;}
      .sidebar-fab{width:36px;height:36px;top:calc(46px + 8px);}

      /* Chat */
      #messages{padding:10px 8px;gap:14px;}
      .bubble{font-size:0.82rem;padding:9px 12px;border-radius:10px;}
      .msg.user .bubble{border-bottom-right-radius:2px;}
      .msg.bot .bubble{border-bottom-left-radius:2px;}

      /* Empty state */
      .empty-state-greeting{font-size:1rem;}
      .empty-state-sub{font-size:0.78rem;}
      .empty-state-grid{gap:8px;}
      .es-card{min-width:100%;max-width:100%;padding:12px;border-radius:12px;}
      .es-card-hd{font-size:0.78rem;}
      .es-cmds-list{height:100px;}

      /* Input */
      .input-row{padding:6px 8px 8px;gap:6px;}
      #questionInput{min-height:38px;padding:8px 10px;font-size:0.82rem;border-radius:10px;}
      #sendBtn{padding:0 12px;height:38px;font-size:0.78rem;border-radius:16px;min-width:64px;}
      .btn-compare{display:none!important;}
      .btn-history-inline{width:38px;height:38px;border-radius:10px;}
      .btn-mic{width:38px;height:38px;border-radius:10px;font-size:0.95rem;}
      .fav-chips-bar,.quick-filters-bar{padding:3px 8px 0;}

      /* Tabelle */
      .result-wrap{max-height:180px;}
      table{font-size:0.7rem;}
      td{padding:4px 6px;}
      th .th-label{padding:4px 6px 2px;font-size:0.62rem;}
      th .th-filter{display:none;}
      .result-toolbar{padding:5px 6px;}
      .export-btn{font-size:0.65rem;padding:2px 5px;}
      .sql-toggle{font-size:0.65rem;padding:2px 5px;}
      .toolbar-sep{display:none;}

      /* Grafici */
      .chart-wrap{padding:8px;min-height:200px;}
      .chart-wrap canvas{max-height:180px;}

      /* Modali */
      .wiz-header,.annot-header,.wh-header{padding:12px 14px 10px;}
      .wiz-body,.annot-body,.wh-body{padding:12px 14px;}
      .wiz-footer{padding:10px 14px;}
      .wiz-btn-next,.wiz-btn-back{padding:8px 14px;font-size:0.78rem;}
      .modal-body{padding:14px 16px;}
      .modal-header{padding:12px 16px 10px;}
      .modal-footer{padding:10px 16px;}

      /* Settings Hub */
      .sh-nav{padding:6px;gap:3px;}
      .sh-tab{padding:6px 10px;font-size:0.72rem;}
      .sh-panels{padding:12px 10px;}
      .sh-top{padding:10px 14px;}
      .sh-top h2{font-size:0.88rem;}

      /* Dashboard */
      .dash-kpi{min-width:100%;padding:10px 12px;}
      .dash-kpi-val{font-size:1.1rem;}
      .dash-body{padding:12px;}

      /* Audit */
      .audit-table{min-width:600px;}

      /* BP Card */
      .bp-card{padding:10px;}
      .bp-avatar{width:36px;height:36px;font-size:0.88rem;}
      .bp-kpi{min-width:100%;padding:6px 8px;}

      /* Slash dropdown */
      .slash-dropdown{left:8px!important;right:8px!important;width:auto!important;max-width:calc(100vw - 16px);}

      /* Template param modal */
      .tp-box{width:100%;border-radius:20px 20px 0 0;}

      /* Global search */
      .gs-inp{font-size:0.9rem;}

      /* Compare */
      .btn-compare{display:none!important;}
    }

    /* ── TOUCH & INTERACTION ENHANCEMENTS ─────────────────────────────── */
    @media (hover:none) and (pointer:coarse){
      /* Touch targets minimi 44px (WCAG 2.1) */
      .btn-settings,.btn-collapse,.hist-del,.sidebar-fav-del,
      .annot-del,.wh-del-btn,.qc-del-btn,.cache-entry .ce-del,
      .audit-sql-btn,.audit-page-btn,.btn-refresh{min-width:44px;min-height:44px;
        display:inline-flex;align-items:center;justify-content:center;}
      /* Rimuovi hover effects su touch */
      .es-card:hover{transform:none!important;box-shadow:none!important;}
      .suggestion-pill:hover{transform:none!important;}
      /* Active state per touch feedback */
      .es-card:active{transform:scale(0.97)!important;transition:transform 0.1s!important;}
      .suggestion-pill:active{transform:scale(0.95)!important;transition:transform 0.1s!important;}
      .hist-item:active{background:var(--blue-light);}
      /* Scroll momentum */
      .sidebar-history-list,.sh-panels,.audit-body,.cache-entries,
      .result-wrap,.empty-state-grid,.quick-filters-scroll,
      .fav-chips-scroll,.sh-nav{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;}
      /* Scrollbar sottili su mobile */
      ::-webkit-scrollbar{width:3px;height:3px;}
      ::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
    }

    /* ── SAFE AREA (iPhone notch, etc.) ───────────────────────────────── */
    @supports(padding:env(safe-area-inset-bottom)){
      @media (max-width:768px){
        .input-area{padding-bottom:env(safe-area-inset-bottom);}
        .toast{bottom:calc(env(safe-area-inset-bottom) + 70px);}
        header{padding-left:max(10px,env(safe-area-inset-left));
          padding-right:max(10px,env(safe-area-inset-right));}
      }
    }

    /* ── LANDSCAPE PHONE ──────────────────────────────────────────────── */
    @media (max-height:480px) and (orientation:landscape){
      header{height:40px;}
      .header-logo .logo-box-mini{width:26px;height:26px;}
      .header-title{font-size:0.78rem;}
      #messages{padding:8px;}
      .input-row{padding:4px 8px 6px;}
      #questionInput{min-height:34px;max-height:80px;}
      #sendBtn{height:34px;padding:0 12px;}
      .empty-state-wrap{padding:10px;}
      .empty-state-greeting{font-size:0.9rem;}
      .es-card{min-width:160px;max-width:180px;padding:8px;}
      .es-cmds-list{height:60px;}
    }
    /* n8n workflow list — Fix A (R11) */
    .n8n-wf-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;}
    .n8n-wf-info{flex:1;}
    .n8n-wf-name{font-weight:600;font-size:0.85rem;}
    .n8n-wf-meta{font-size:0.75rem;color:var(--text-muted);}
    .n8n-wf-empty{color:var(--text-muted);font-size:0.8rem;}
  
/* === Classi utility auto-generate da b_transform.py (Fix B) === */
._u0 { background:#ef4444;padding:4px 10px; }
._u1 { background:#f0fdf4;border:1px solid #16a34a;border-radius:12px;padding:14px;max-width:480px; }
._u10 { background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:12px 14px; }
._u100 { display:block;margin-top:6px; }
._u101 { display:flex;align-items:center;gap:10px;flex-wrap:wrap; }
._u102 { display:flex;align-items:center;gap:10px;font-size:0.8rem;color:var(--text-muted); }
._u103 { display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border); }
._u104 { display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;margin-bottom:8px; }
._u105 { display:flex;align-items:center;gap:12px; }
._u106 { display:flex;align-items:center;gap:12px;margin-bottom:24px; }
._u107 { display:flex;align-items:center;gap:4px;padding:4px 2px;border-bottom:1px solid var(--border); }
._u108 { display:flex;align-items:center;gap:6px;cursor:pointer;font-size:0.82rem;color:var(--text-dim); }
._u109 { display:flex;align-items:center;gap:6px;cursor:pointer;font-size:0.85rem; }
._u11 { background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:16px; }
._u110 { display:flex;align-items:center;gap:6px;cursor:pointer;font-size:14px; }
._u111 { display:flex;align-items:center;gap:6px;font-size:0.75rem; }
._u112 { display:flex;align-items:center;gap:6px;font-size:0.83rem;cursor:pointer; }
._u113 { display:flex;align-items:center;gap:8px;background:var(--bg2);border-radius:8px;padding:8px 10px; }
._u114 { display:flex;align-items:center;gap:8px;cursor:pointer; }
._u115 { display:flex;align-items:center;gap:8px;cursor:pointer;font-size:0.82rem;color:var(--text-dim); }
._u116 { display:flex;align-items:center;gap:8px;font-size:0.8rem;color:var(--text-muted);cursor:pointer; }
._u117 { display:flex;align-items:center;gap:8px;margin-bottom:10px; }
._u118 { display:flex;align-items:center;gap:8px;margin-bottom:12px; }
._u119 { display:flex;align-items:center;gap:8px;margin-bottom:4px; }
._u12 { background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px; }
._u120 { display:flex;align-items:center;gap:8px;margin-bottom:6px; }
._u121 { display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;background:var(--bg2);border:1px solid var(--border); }
._u122 { display:flex;align-items:center;justify-content:space-between;margin-bottom:10px; }
._u123 { display:flex;align-items:center;justify-content:space-between;margin-bottom:12px; }
._u124 { display:flex;align-items:center;justify-content:space-between;margin-bottom:8px; }
._u125 { display:flex;align-items:flex-end;gap:3px;height:70px; }
._u126 { display:flex;align-items:flex-end;padding-bottom:2px; }
._u127 { display:flex;align-items:flex-start;gap:10px; }
._u128 { display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap; }
._u129 { display:flex;flex-direction:column;gap:10px; }
._u13 { background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:16px; }
._u130 { display:flex;flex-direction:column;gap:12px; }
._u131 { display:flex;flex-direction:column;gap:12px;margin-bottom:20px; }
._u132 { display:flex;flex-direction:column;gap:16px; }
._u133 { display:flex;flex-direction:column;gap:18px; }
._u134 { display:flex;flex-direction:column;gap:4px;flex-shrink:0; }
._u135 { display:flex;flex-direction:column;gap:6px;flex-shrink:0; }
._u136 { display:flex;flex-direction:column;gap:8px; }
._u137 { display:flex;flex-direction:column;gap:8px;max-height:280px;overflow-y:auto; }
._u138 { display:flex;flex-wrap:wrap;gap:7px; }
._u139 { display:flex;gap:10px; }
._u14 { background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:18px; }
._u140 { display:flex;gap:10px;align-items:center;flex-wrap:wrap; }
._u141 { display:flex;gap:10px;justify-content:flex-end; }
._u142 { display:flex;gap:12px;margin-top:6px; }
._u143 { display:flex;gap:14px;flex-wrap:wrap; }
._u144 { display:flex;gap:16px;margin-bottom:12px; }
._u145 { display:flex;gap:6px;margin-top:8px; }
._u146 { display:flex;gap:8px; }
._u147 { display:flex;gap:8px;flex-wrap:wrap;font-size:0.72rem; }
._u148 { display:flex;gap:8px;font-size:0.75rem; }
._u149 { display:flex;justify-content:flex-end;margin-top:10px; }
._u15 { background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:20px; }
._u150 { display:flex;justify-content:flex-end;margin-top:4px; }
._u151 { display:flex;justify-content:space-between;align-items:center;margin-bottom:12px; }
._u152 { display:flex;justify-content:space-between;align-items:center;margin-bottom:16px; }
._u153 { display:flex;justify-content:space-between;font-size:0.65rem;color:var(--text-muted);margin-top:4px; }
._u154 { display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:10px; }
._u155 { display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:10px; }
._u156 { display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px; }
._u157 { display:grid;grid-template-columns:1fr 1fr;gap:10px; }
._u158 { display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px; }
._u159 { display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px; }
._u16 { background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:22px; }
._u160 { display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px; }
._u161 { display:grid;grid-template-columns:1fr 1fr;gap:16px; }
._u162 { display:grid;grid-template-columns:1fr 1fr;gap:8px; }
._u163 { display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px; }
._u164 { display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px; }
._u165 { display:grid;grid-template-columns:1fr 2fr;gap:8px;margin-bottom:8px; }
._u166 { display:grid;grid-template-columns:1fr 80px 100px;gap:10px;margin-bottom:10px; }
._u167 { display:grid;grid-template-columns:1fr 80px;gap:10px;margin-bottom:10px; }
._u168 { display:grid;grid-template-columns:auto 1fr;gap:10px;margin-bottom:10px;align-items:end; }
._u169 { display:none!important; }
._u17 { background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-family:var(--mono); }
._u170 { display:none; }
._u171 { display:none;background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;padding:10px 14px;margin-bottom:16px;font-size:0.82rem;color:#dc2626; }
._u172 { display:none;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px; }
._u173 { display:none;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:16px; }
._u174 { display:none;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px;margin-top:12px; }
._u175 { display:none;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:8px; }
._u176 { display:none;border-color:#ef4444;color:#ef4444; }
._u177 { display:none;flex-direction:column;gap:8px; }
._u178 { display:none;margin-bottom:10px; }
._u179 { display:none;margin-bottom:12px; }
._u18 { background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:1px 6px; }
._u180 { display:none;margin-bottom:8px; }
._u181 { display:none;margin-bottom:8px;font-size:0.85rem;padding:8px 12px;border-radius:6px;border:1px solid var(--border); }
._u182 { display:none;margin-left:8px;background:#ef4444;color:#fff;border-color:#ef4444; }
._u183 { display:none;margin-top:10px;font-size:0.8rem; }
._u184 { display:none;margin-top:8px; }
._u185 { display:none;margin-top:8px;font-size:0.8rem; }
._u186 { display:none;margin-top:8px;font-size:0.8rem;color:var(--green); }
._u187 { display:none;margin-top:8px;padding:8px 10px;background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;font-size:0.78rem;color:#92400e; }
._u188 { display:none;margin:0 8px 8px; }
._u189 { display:none;max-height:64px;max-width:180px;object-fit:contain; }
._u19 { background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-family:var(--mono); }
._u190 { display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:5000;align-items:center;justify-content:center; }
._u191 { display:none;position:fixed;inset:0;background:var(--bg);z-index:9000;overflow-y:auto;padding:40px 24px; }
._u192 { display:none;position:fixed;inset:0;background:var(--bg);z-index:9999;align-items:center;justify-content:center; }
._u193 { display:none;position:fixed;inset:0;background:var(--bg);z-index:9999;align-items:center;justify-content:center; }
._u194 { display:none;width:32px;height:32px;border-radius:6px;object-fit:contain; }
._u195 { flex-shrink:0; }
._u196 { flex:1; }
._u197 { flex:1; }
._u198 { flex:1;margin:0;padding:0;border:none; }
._u199 { flex:1;min-width:0; }
._u2 { background:#f59e0b;color:white;font-size:0.7rem;font-weight:600;padding:2px 8px;border-radius:10px;margin-left:6px; }
._u20 { background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-size:0.7rem;cursor:pointer;color:var(--text-muted); }
._u200 { flex:1;min-width:0; }
._u201 { flex:1;min-width:180px; }
._u202 { flex:1;overflow-y:auto; }
._u203 { flex:1;padding:6px 8px;font-size:0.78rem;text-align:left;white-space:normal; }
._u204 { flex:1;padding:7px;background:#16a34a;color:#fff;border:none;border-radius:7px;cursor:pointer;font-size:0.83rem;font-weight:600; }
._u205 { flex:2; }
._u206 { font-family:var(--mono);background:var(--bg3);padding:1px 5px;border-radius:4px; }
._u207 { font-family:var(--mono);color:var(--text-dim);text-align:right; }
._u208 { font-family:var(--mono);font-size:0.73rem;color:var(--text-muted); }
._u209 { font-family:var(--mono);font-size:0.73rem;color:var(--text-muted);background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:6px 10px;overflow:auto;max-height:80px;white-space:pre-wrap;word-break:break-all; }
._u21 { background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-size:0.7rem;cursor:pointer;color:var(--text-muted); }
._u210 { font-family:var(--mono);font-size:0.75rem;overflow:auto;max-height:400px;white-space:pre-wrap;word-break:break-all; }
._u211 { font-family:var(--mono);font-size:0.78rem; }
._u212 { font-family:var(--mono);font-size:0.78rem;color:var(--text-muted); }
._u213 { font-family:var(--mono);font-size:0.82rem;color:var(--blue);background:var(--bg2);padding:10px 12px;border-radius:8px;margin-top:8px;letter-spacing:2px;word-break:break-all; }
._u214 { font-family:var(--mono);font-size:0.8rem; }
._u215 { font-family:var(--mono);font-size:0.8rem;color:var(--text-muted); }
._u216 { font-family:var(--mono);letter-spacing:6px;font-size:1.1rem;text-align:center; }
._u217 { font-family:var(--mono);white-space:nowrap; }
._u218 { font-size:0.68rem;opacity:.55; }
._u219 { font-size:0.72rem;color:var(--text-dim); }
._u22 { background:var(--blue);color:#fff;border-color:var(--blue); }
._u220 { font-size:0.72rem;color:var(--text-muted); }
._u221 { font-size:0.72rem;color:var(--text-muted);border-top:1px solid var(--border);padding-top:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.6px;margin-bottom:10px; }
._u222 { font-size:0.72rem;color:var(--text-muted);margin-top:2px; }
._u223 { font-size:0.72rem;padding:3px 8px;border:1px solid var(--border);border-radius:5px;background:none;cursor:pointer;color:var(--blue); }
._u224 { font-size:0.72rem;padding:3px 8px;border:1px solid var(--border);border-radius:5px;background:none;cursor:pointer;color:var(--text-muted); }
._u225 { font-size:0.72rem;padding:3px 8px;border:1px solid var(--red-bg);border-radius:5px;background:none;cursor:pointer;color:var(--red); }
._u226 { font-size:0.74rem;color:var(--text-dim);margin-top:20px; }
._u227 { font-size:0.75rem;color:var(--green);margin-top:8px;display:none; }
._u228 { font-size:0.75rem;color:var(--text-dim); }
._u229 { font-size:0.75rem;color:var(--text-dim); }
._u23 { background:var(--blue);color:#fff;border:none;border-radius:6px;padding:4px 10px;font-size:0.78rem;cursor:pointer; }
._u230 { font-size:0.75rem;color:var(--text-muted); }
._u231 { font-size:0.75rem;color:var(--text-muted);margin-bottom:4px; }
._u232 { font-size:0.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
._u233 { font-size:0.75rem;padding:4px 6px;border:1px solid var(--border);border-radius:6px;background:var(--card);color:var(--text);cursor:pointer;font-family:var(--sans); }
._u234 { font-size:0.77rem;color:var(--text-muted);margin-bottom:4px; }
._u235 { font-size:0.78rem;color:#166534;margin-top:4px; }
._u236 { font-size:0.78rem;color:#7f1d1d;margin-top:4px; }
._u237 { font-size:0.78rem;color:var(--text-dim);padding:6px 10px;background:var(--bg);border-radius:6px;border:1px solid var(--border); }
._u238 { font-size:0.78rem;color:var(--text-muted); }
._u239 { font-size:0.78rem;color:var(--text-muted);cursor:pointer; }
._u24 { background:var(--blue-light);border:1px solid rgba(79,70,229,0.2);border-radius:10px;padding:14px 16px;margin-bottom:18px; }
._u240 { font-size:0.78rem;color:var(--text-muted);margin-bottom:10px; }
._u241 { font-size:0.78rem;color:var(--text-muted);margin-bottom:8px; }
._u242 { font-size:0.78rem;color:var(--text-muted);margin-top:4px; }
._u243 { font-size:0.78rem;color:var(--text-muted);margin:0;padding-left:18px;line-height:1.8; }
._u244 { font-size:0.78rem;color:var(--text-muted);padding-bottom:3px; }
._u245 { font-size:0.78rem;color:var(--text-muted);text-align:center;padding:4px 0; }
._u246 { font-size:0.78rem;display:none; }
._u247 { font-size:0.78rem;font-weight:600;color:var(--blue);margin-bottom:8px; }
._u248 { font-size:0.7rem; }
._u249 { font-size:0.7rem;background:var(--blue-light);color:var(--blue);border-radius:8px;padding:1px 7px; }
._u25 { background:var(--blue-light);border:1px solid rgba(79,70,229,0.2);border-radius:6px;padding:3px 8px;font-size:0.7rem;cursor:pointer;color:var(--blue); }
._u250 { font-size:0.7rem;background:var(--red-bg);color:var(--red);border-radius:8px;padding:1px 7px; }
._u251 { font-size:0.7rem;color:var(--text-dim);margin-top:4px; }
._u252 { font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#7c3aed;display:block;margin-bottom:4px; }
._u253 { font-size:0.7rem;transition:transform 0.2s; }
._u254 { font-size:0.82rem;color:var(--text-dim);text-align:center;padding:16px 0; }
._u255 { font-size:0.82rem;color:var(--text-muted);margin-bottom:12px; }
._u256 { font-size:0.82rem;color:var(--text-muted);margin-bottom:16px; }
._u257 { font-size:0.82rem;color:var(--text-muted);margin-bottom:18px; }
._u258 { font-size:0.82rem;color:var(--text-muted);margin:0; }
._u259 { font-size:0.82rem;color:var(--text-muted);padding:8px 0; }
._u26 { background:var(--blue-light);border:1px solid rgba(79,70,229,0.2);border-radius:6px;padding:4px 10px;font-size:0.78rem;color:var(--blue);cursor:pointer;text-align:left;margin-top:4px; }
._u260 { font-size:0.82rem;font-weight:600;color:var(--text); }
._u261 { font-size:0.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
._u262 { font-size:0.82rem;font-weight:600;color:var(--text-dim); }
._u263 { font-size:0.82rem;margin-top:4px; }
._u264 { font-size:0.82rem;padding:2px 0; }
._u265 { font-size:0.83rem;color:var(--text-muted);margin-bottom:16px; }
._u266 { font-size:0.83rem;color:var(--text-muted);margin-bottom:4px; }
._u267 { font-size:0.83rem;font-weight:500; }
._u268 { font-size:0.83rem;font-weight:500;margin-bottom:4px; }
._u269 { font-size:0.83rem;font-weight:600; }
._u27 { background:var(--blue-light);border:1px solid rgba(79,70,229,0.2);color:var(--blue);border-radius:6px;padding:4px 10px;font-size:0.75rem;cursor:pointer; }
._u270 { font-size:0.85rem; }
._u271 { font-size:0.85rem;flex:1; }
._u272 { font-size:0.85rem;padding:4px 7px;margin-right:2px;background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;color:var(--text-muted); }
._u273 { font-size:0.8rem;color:var(--text-muted); }
._u274 { font-size:0.8rem;color:var(--text-muted);margin-bottom:20px; }
._u275 { font-size:0.8rem;color:var(--text-muted);margin-top:6px; }
._u276 { font-size:0.8rem;color:var(--text-muted);margin:0 0 16px; }
._u277 { font-size:0.8rem;color:var(--text-muted);margin:0; }
._u278 { font-size:0.95rem;font-weight:600; }
._u279 { font-size:1.1rem; }
._u28 { background:var(--card);border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin-bottom:6px;display:flex;align-items:center;gap:10px; }
._u280 { font-size:1.2rem; }
._u281 { font-size:1.2rem;font-weight:700; }
._u282 { font-size:1.2rem;margin-top:1px; }
._u283 { font-size:1.3rem;font-weight:700;color:var(--text); }
._u284 { font-size:1.6rem; }
._u285 { font-size:11px;color:#aaa;margin-top:3px; }
._u286 { font-size:1rem; }
._u287 { font-size:20px;margin-bottom:6px; }
._u288 { font-size:2rem; }
._u289 { font-size:2rem;color:var(--text-dim); }
._u29 { background:var(--card);border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:8px;display:flex;align-items:flex-start;gap:12px; }
._u290 { font-size:2rem;margin-bottom:8px; }
._u291 { font-weight:400;color:#aaa; }
._u292 { font-weight:600;font-size:0.83rem; }
._u293 { font-weight:600;font-size:0.85rem; }
._u294 { font-weight:600;font-size:0.85rem;margin-bottom:2px; }
._u295 { font-weight:600;font-size:0.85rem;margin-bottom:4px; }
._u296 { font-weight:600;font-size:0.88rem; }
._u297 { font-weight:700;font-size:1.1rem; }
._u298 { font-weight:700;font-size:1rem; }
._u299 { gap:12px; }
._u3 { background:#fef2f2;border:1px solid #ef4444;border-radius:12px;padding:14px;max-width:480px; }
._u30 { background:var(--card);border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:10px;font-size:0.78rem;color:var(--text-dim);line-height:1.6; }
._u300 { gap:14px; }
._u301 { gap:16px; }
._u302 { justify-content:flex-end;gap:10px; }
._u303 { list-style:none;margin:6px 0 0;padding:0; }
._u304 { margin-bottom:0; }
._u305 { margin-bottom:10px; }
._u306 { margin-bottom:12px; }
._u307 { margin-bottom:16px; }
._u308 { margin-bottom:16px; }
._u309 { margin-bottom:18px; }
._u31 { background:var(--card);padding:1px 6px;border-radius:4px;font-size:0.72rem; }
._u310 { margin-bottom:18px;border-top:1px solid var(--border);padding-top:14px; }
._u311 { margin-bottom:20px; }
._u312 { margin-bottom:6px; }
._u313 { margin-bottom:8px; }
._u314 { margin-left:12px; }
._u315 { margin-left:4px;font-size:0.72rem;color:#ef4444; }
._u316 { margin-left:4px;font-size:0.72rem;padding:2px 6px;border-radius:8px;background:#d1fae5;color:#065f46; }
._u317 { margin-left:4px;font-size:0.72rem;padding:2px 6px;border-radius:8px;background:#fef3c7;color:#92400e; }
._u318 { margin-left:auto;font-family:var(--mono);font-size:0.65rem;opacity:0.5; }
._u319 { margin-left:auto;font-size:0.72rem;color:var(--text-dim);font-weight:400; }
._u32 { background:var(--green-bg);border-color:rgba(38,162,105,0.2);color:#1a7a4a; }
._u320 { margin-top:0; }
._u321 { margin-top:10px; }
._u322 { margin-top:10px;font-size:0.78rem;color:var(--text-muted); }
._u323 { margin-top:12px; }
._u324 { margin-top:14px;padding-top:10px;border-top:1px solid var(--border);display:flex;gap:8px; }
._u325 { margin-top:16px;width:auto; }
._u326 { margin-top:20px;display:flex;align-items:center;gap:10px;border-top:1px solid var(--border);padding-top:16px;flex-wrap:wrap; }
._u327 { margin-top:2px; }
._u328 { margin-top:4px; }
._u329 { margin-top:6px; }
._u33 { background:var(--red-bg);border:1px solid rgba(192,28,40,0.2);border-radius:6px;padding:3px 8px;font-size:0.7rem;cursor:pointer;color:var(--red); }
._u330 { margin-top:6px;font-size:0.75rem;color:var(--red);font-weight:500; }
._u331 { margin-top:8px; }
._u332 { margin-top:8px; }
._u333 { margin-top:8px;font-size:0.78rem;background:var(--bg2);padding:8px;border-radius:6px;white-space:pre-wrap; }
._u334 { margin-top:8px;padding:0 14px;height:34px;font-size:0.8rem; }
._u335 { margin:0; }
._u336 { margin:8px 0 4px;font-size:0.78rem;color:var(--text-muted); }
._u337 { max-width:110px; }
._u338 { max-width:120px;font-family:var(--mono); }
._u339 { max-width:200px;height:auto;display:block; }
._u34 { background:var(--red-bg);border:1px solid rgba(192,28,40,0.2);border-radius:6px;padding:3px 8px;font-size:0.7rem;cursor:pointer;color:var(--red); }
._u340 { max-width:420px;width:100%; }
._u341 { max-width:460px;width:100%; }
._u342 { max-width:480px;width:100%; }
._u343 { max-width:560px;width:100%; }
._u344 { max-width:900px;margin:0 auto; }
._u345 { min-height:320px; }
._u346 { min-height:60px;margin-bottom:20px; }
._u347 { min-height:80px; }
._u348 { min-height:80px;font-size:0.85rem;line-height:1.6;white-space:pre-wrap;color:var(--text);background:var(--bg2);border-radius:8px;padding:14px;display:none;max-height:340px;overflow-y:auto; }
._u349 { min-width:180px; }
._u35 { background:var(--red-bg);border:1px solid rgba(192,28,40,0.2);color:var(--red);border-radius:6px;padding:4px 10px;font-size:0.75rem;cursor:pointer; }
._u350 { opacity:.4; }
._u351 { opacity:0.7; }
._u352 { padding:0 14px;height:38px; }
._u353 { padding:0 16px 16px; }
._u354 { padding:0 16px 16px;font-size:0.78rem;color:var(--text-muted);line-height:1.7; }
._u355 { padding:0; }
._u356 { padding:10px 14px;border:1.5px solid var(--blue);border-radius:8px;background:var(--bg);color:var(--text);font-size:1.1rem;font-family:var(--mono);letter-spacing:6px;text-align:center; }
._u357 { padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:0.9rem;font-family:var(--sans); }
._u358 { padding:10px 40px 10px 14px;border:1.5px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:0.9rem;font-family:var(--sans);width:100%;box-sizing:border-box; }
._u359 { padding:10px;background:var(--blue);color:white;border:none;border-radius:8px;font-size:0.9rem;font-weight:600;cursor:pointer; }
._u36 { background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;width:360px;box-shadow:0 8px 32px rgba(0,0,0,0.15); }
._u360 { padding:12px 16px;cursor:pointer;font-size:0.82rem;font-weight:600;color:var(--text-muted);list-style:none;display:flex;align-items:center;gap:8px; }
._u361 { padding:12px 22px; }
._u362 { padding:14px 16px;cursor:pointer;font-weight:600;font-size:0.85rem;color:var(--text);list-style:none;display:flex;align-items:center;gap:8px; }
._u363 { padding:3px 8px;font-size:0.72rem;color:var(--red); }
._u364 { padding:4px 10px;font-size:0.75rem; }
._u365 { padding:4px 10px;font-size:0.75rem;color:var(--danger,#e74c3c); }
._u366 { padding:4px 10px;font-size:0.75rem;white-space:nowrap; }
._u367 { padding:4px 12px;font-size:0.75rem; }
._u368 { padding:4px 8px;border:1px solid #fca5a5;border-radius:4px;background:none;cursor:pointer;font-size:0.72rem;color:#ef4444; }
._u369 { padding:4px 8px;border:1px solid #fca5a5;border-radius:4px;background:none;cursor:pointer;font-size:0.75rem;color:#ef4444; }
._u37 { background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;width:400px;box-shadow:0 8px 32px rgba(0,0,0,0.15); }
._u370 { padding:4px 8px;border:1px solid var(--border);border-radius:4px;background:none;cursor:pointer;font-size:0.75rem;color:var(--text); }
._u371 { padding:5px 12px;font-size:0.78rem; }
._u372 { padding:5px 14px;font-size:0.78rem; }
._u373 { padding:6px 12px;white-space:nowrap; }
._u374 { padding:6px 14px; }
._u375 { padding:6px 14px;font-size:0.78rem; }
._u376 { padding:6px 14px;font-size:0.78rem;border-color:var(--red);color:var(--red); }
._u377 { padding:6px 14px;font-size:0.8rem; }
._u378 { padding:6px 8px; }
._u379 { padding:6px 8px;text-align:center; }
._u38 { background:var(--text-muted);color:var(--bg1);opacity:0.85; }
._u380 { padding:6px; }
._u381 { padding:7px 14px;background:var(--bg3);color:var(--text-muted);border:1px solid var(--border);border-radius:7px;cursor:pointer;font-size:0.83rem; }
._u382 { padding:7px 8px;color:var(--text-dim);font-family:var(--mono);font-size:0.72rem; }
._u383 { padding:7px 8px;font-weight:500; }
._u384 { padding:7px 8px;text-align:center; }
._u385 { padding:7px 8px;text-align:center;color:var(--text-dim); }
._u386 { padding:8px 20px; }
._u387 { position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;padding:0;color:var(--text-muted); }
._u388 { position:relative; }
._u389 { text-align:center; }
._u39 { background:var(--yellow-bg);border-color:rgba(229,165,10,0.3);color:var(--yellow); }
._u390 { text-align:center;font-size:0.85rem;font-weight:600; }
._u391 { text-align:center;margin-bottom:24px; }
._u392 { text-align:center;margin-bottom:28px; }
._u393 { text-align:center;padding:16px;background:white;border-radius:10px;border:1px solid var(--border);margin-bottom:12px;min-height:120px; }
._u394 { text-align:center;padding:30px;color:var(--red); }
._u395 { text-align:center;padding:30px;color:var(--text-dim); }
._u396 { text-align:center;padding:40px;color:var(--text-dim); }
._u397 { text-align:center;padding:40px;color:var(--text-muted); }
._u398 { text-transform:uppercase; }
._u399 { width:100%; }
._u4 { background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:0.85rem;padding:4px; }
._u40 { background:var(--yellow-bg);border:1px solid rgba(229,165,10,0.3);border-radius:6px;padding:7px 12px;font-size:0.78rem;color:#92400e;margin-top:4px; }
._u400 { width:100%;border-collapse:collapse;font-size:0.8rem; }
._u401 { width:100%;height:100%;object-fit:contain;border-radius:8px; }
._u402 { width:100px; }
._u403 { width:15px;height:15px; }
._u404 { width:15px;height:15px;cursor:pointer; }
._u405 { width:16px;height:16px; }
._u406 { width:16px;height:16px;cursor:pointer; }
._u407 { width:16px;height:16px;cursor:pointer;accent-color:var(--blue);flex-shrink:0; }
._u408 { width:420px; }
._u409 { width:440px; }
._u41 { border-color:#0891b2;color:#0891b2;background:rgba(8,145,178,0.08); }
._u410 { width:460px; }
._u411 { width:48px;height:38px;border:1px solid var(--border);border-radius:8px;cursor:pointer;padding:2px;background:var(--bg2); }
._u412 { width:56px;background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:3px 6px;color:var(--text);font-size:0.75rem;text-align:center; }
._u413 { width:80px;height:80px;border:1px solid var(--border);border-radius:10px;background:var(--bg2);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0; }
._u414 { width:auto; }
._u415 { z-index:5000; }
._u416 { z-index:5000;display:none!important; }
._u42 { border-color:#22c55e;color:#22c55e;background:rgba(34,197,94,0.08); }
._u43 { border-color:#4f46e5;color:#4f46e5;background:rgba(79,70,229,0.08); }
._u44 { border-color:#7c3aed;color:#7c3aed;background:rgba(124,58,237,0.08); }
._u45 { border-color:#8b5cf6;color:#8b5cf6;background:rgba(139,92,246,0.08); }
._u46 { border-color:#f59e0b;color:#f59e0b;background:rgba(245,158,11,0.1); }
._u47 { border-color:var(--blue);color:var(--blue); }
._u48 { border-color:var(--blue);color:var(--blue);background:var(--blue-light); }
._u49 { border-color:var(--green);color:var(--green);background:var(--green-bg); }
._u5 { background:transparent;border:none;color:var(--red);font-size:0.9rem;cursor:pointer; }
._u50 { border-color:var(--red);color:var(--red);background:var(--red-bg); }
._u51 { border-top:1px solid var(--border); }
._u52 { border-top:1px solid var(--border);margin-top:20px;padding-top:14px; }
._u53 { border-top:1px solid var(--border);margin:16px 0; }
._u54 { border-top:1px solid var(--border);padding-top:14px; }
._u55 { border:none;cursor:pointer; }
._u56 { color:#15803d;font-weight:600;font-size:0.88rem; }
._u57 { color:#dc2626;font-weight:600;font-size:0.88rem; }
._u58 { color:#ef4444; }
._u59 { color:#ef4444;font-size:0.8rem; }
._u6 { background:var(--bg2);border:1px solid #f59e0b;border-radius:12px;padding:16px;max-width:480px; }
._u60 { color:#ef4444;padding:20px; }
._u61 { color:var(--accent);word-break:break-all; }
._u62 { color:var(--blue); }
._u63 { color:var(--green); }
._u64 { color:var(--red); }
._u65 { color:var(--red); }
._u66 { color:var(--red);font-size:0.72rem; }
._u67 { color:var(--red);font-size:0.82rem; }
._u68 { color:var(--red);font-size:0.8rem; }
._u69 { color:var(--red);padding:20px; }
._u7 { background:var(--bg2);border:1px solid #fef3c7;border-radius:10px;padding:14px;margin-bottom:18px; }
._u70 { color:var(--text-dim); }
._u71 { color:var(--text-dim); }
._u72 { color:var(--text-dim);font-family:var(--mono); }
._u73 { color:var(--text-dim);font-size:.82rem; }
._u74 { color:var(--text-dim);font-size:.82rem;margin-bottom:6px; }
._u75 { color:var(--text-dim);font-size:.82rem;padding:20px 0;text-align:center; }
._u76 { color:var(--text-dim);font-size:.82rem;padding:8px 0; }
._u77 { color:var(--text-dim);font-size:.82rem;text-align:center;padding:20px 0; }
._u78 { color:var(--text-dim);font-size:0.72rem;padding:4px; }
._u79 { color:var(--text-dim);font-size:0.77rem;padding:10px 6px; }
._u8 { background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden; }
._u80 { color:var(--text-dim);font-size:0.77rem;padding:10px 6px;text-align:center; }
._u81 { color:var(--text-dim);font-size:0.8rem; }
._u82 { color:var(--text-dim);text-align:left; }
._u83 { color:var(--text-muted); }
._u84 { color:var(--text-muted); }
._u85 { color:var(--text-muted);font-size:0.82rem; }
._u86 { color:var(--text-muted);font-size:0.82rem;text-align:center; }
._u87 { color:var(--text-muted);font-size:0.85rem;padding:16px 0; }
._u88 { color:var(--text-muted);font-size:0.8rem; }
._u89 { color:var(--text-muted);font-size:0.8rem; }
._u9 { background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:16px; }
._u90 { color:var(--text-muted);font-size:0.8rem;padding:10px 0; }
._u91 { color:var(--text-muted);font-size:0.8rem;padding:4px 0; }
._u92 { color:var(--text-muted);font-size:0.8rem;padding:6px; }
._u93 { color:var(--text-muted);font-size:0.8rem;padding:8px; }
._u94 { cursor:default; }
._u95 { cursor:default;font-family:var(--mono);font-size:0.82rem; }
._u96 { cursor:default;font-family:var(--mono);font-size:0.82rem;color:var(--blue);letter-spacing:1px; }
._u97 { cursor:default;font-weight:600;font-family:var(--mono); }
._u98 { cursor:pointer; }
._u99 { cursor:pointer; }

/* === Classi semantiche per style= dinamici (Fix B — 14 casi) === */
.badge-role{margin-left:8px;font-size:0.72rem;padding:2px 7px;border-radius:10px;color:white;}
.badge-role-admin{background:#4f46e5;}
.badge-role-user{background:var(--blue);}
.badge-alert{font-size:0.72rem;padding:2px 8px;border-radius:10px;}
.badge-alert-ok{background:var(--green-bg);color:var(--green);}
.badge-alert-triggered{background:var(--red-bg);color:var(--red);}
.kpi-rate-good{color:#22c55e;}
.kpi-rate-warn{color:#f59e0b;}
.dash-bar-purple{background:#7c3aed;}
.dash-timeline-bar{flex:1;background:var(--blue);border-radius:3px 3px 0 0;min-width:6px;}
.badge-job{font-size:0.7rem;padding:2px 8px;border-radius:10px;text-align:center;}
.badge-job-active{background:var(--green-bg);color:#1a7a4a;}
.badge-job-suspended{background:var(--red-bg);color:var(--red);}
.feedback-row{background:var(--card);border-radius:8px;padding:12px 14px;margin-bottom:8px;border:1px solid var(--border);}
.feedback-row-alert{border-color:rgba(192,28,40,0.4);}
.pinned-row{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:8px;}
.pinned-row-inactive{opacity:0.55;}
/* Stagger animation per suggestion pills — sostituisce style="animation-delay:" */
.suggestions-wrap>.suggestion-pill:nth-child(2){animation-delay:.06s;}
.suggestions-wrap>.suggestion-pill:nth-child(3){animation-delay:.12s;}
.suggestions-wrap>.suggestion-pill:nth-child(4){animation-delay:.18s;}
.suggestions-wrap>.suggestion-pill:nth-child(5){animation-delay:.24s;}
.suggestions-wrap>.suggestion-pill:nth-child(6){animation-delay:.30s;}
.suggestions-wrap>.suggestion-pill:nth-child(7){animation-delay:.36s;}
.suggestions-wrap>.suggestion-pill:nth-child(8){animation-delay:.42s;}
.suggestions-wrap>.suggestion-pill:nth-child(9){animation-delay:.48s;}
.suggestions-wrap>.suggestion-pill:nth-child(n+10){animation-delay:.54s;}
.wiz-feat-on{color:var(--green);}
.wiz-feat-off{color:var(--text-dim);}
.company-limit-ok{margin-bottom:10px;font-size:0.8rem;padding:6px 10px;border-radius:6px;background:var(--bg2);border:1px solid var(--border);color:var(--text-muted);}
.company-limit-full{margin-bottom:10px;font-size:0.8rem;padding:6px 10px;border-radius:6px;background:var(--red-bg);border:1px solid rgba(192,28,40,0.2);color:var(--red);}

/* UX Premium Enhancements */
button, input, select, .suggestion-pill, .hist-item, .wiz-provider-card, .es-card { transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.2s ease, background-color 0.2s ease, border-color 0.2s ease !important; }
button:active:not(:disabled), .suggestion-pill:active { transform: scale(0.97) !important; }
.suggestion-pill:hover, .es-card:hover { transform: translateY(-3px) !important; box-shadow: var(--shadow) !important; border-color: var(--blue) !important; }

/* ── Agent Mode (v2026.104) ─────────────────────────────────────────────── */
.agent-progress {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; border-radius: 10px;
  background: var(--card); border: 1px solid var(--border);
  font-size: 0.88rem; color: var(--text-muted); max-width: 480px;
}
.agent-progress-icon { font-size: 1.1rem; flex-shrink: 0; }
.agent-progress-text { flex: 1; font-style: italic; }
.agent-progress-dots { display: flex; gap: 2px; }
.agent-progress-dots span {
  animation: agentDot 1.2s infinite; font-size: 1.2rem;
  line-height: 1; color: var(--blue);
}
.agent-progress-dots span:nth-child(2) { animation-delay: 0.2s; }
.agent-progress-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes agentDot {
  0%, 80%, 100% { opacity: 0.2; transform: translateY(0); }
  40%            { opacity: 1;   transform: translateY(-3px); }
}

.action-result-card {
  padding: 12px 16px; border-radius: 10px; border-left: 4px solid transparent;
  background: var(--card); font-size: 0.88rem; max-width: 520px;
  display: flex; flex-direction: column; gap: 6px;
}
.action-result-card--ok  { border-left-color: var(--green, #26a269); border: 1px solid rgba(38,162,105,0.25); border-left: 4px solid var(--green, #26a269); }
.action-result-card--err { border-left-color: var(--red, #c01c28);   border: 1px solid rgba(192,28,40,0.25);  border-left: 4px solid var(--red, #c01c28); }
.action-result-header { display: flex; align-items: center; gap: 8px; }
.action-result-icon   { font-size: 1.15rem; flex-shrink: 0; }
.action-result-title  { font-weight: 600; font-size: 0.90rem; }
.action-result-title--ok  { color: var(--green, #26a269); }
.action-result-title--err { color: var(--red, #c01c28); }
.action-result-id {
  margin-left: auto; font-size: 0.72rem; color: var(--text-muted);
  font-family: monospace; background: var(--bg2); padding: 2px 6px;
  border-radius: 4px; max-width: 180px; overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap;
}
.action-result-body { color: var(--text); line-height: 1.5; }
